| /* |
| * Copyright (c) 1996, 2003 VIA Networking Technologies, Inc. |
| * All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License along |
| * with this program; if not, write to the Free Software Foundation, Inc., |
| * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. |
| * |
| * |
| * File: baseband.c |
| * |
| * Purpose: Implement functions to access baseband |
| * |
| * Author: Jerry Chen |
| * |
| * Date: Jun. 5, 2002 |
| * |
| * Functions: |
| * BBuGetFrameTime - Calculate data frame transmitting time |
| * BBvCalculateParameter - Calculate PhyLength, PhyService and Phy Signal parameter for baseband Tx |
| * BBbVT3184Init - VIA VT3184 baseband chip init code |
| * BBvLoopbackOn - Turn on BaseBand Loopback mode |
| * BBvLoopbackOff - Turn off BaseBand Loopback mode |
| * |
| * Revision History: |
| * |
| * |
| */ |
| |
| #include "tmacro.h" |
| #include "tether.h" |
| #include "mac.h" |
| #include "baseband.h" |
| #include "rf.h" |
| #include "srom.h" |
| #include "control.h" |
| #include "datarate.h" |
| #include "rndis.h" |
| |
| /*--------------------- Static Definitions -------------------------*/ |
| static int msglevel =MSG_LEVEL_INFO; |
| //static int msglevel =MSG_LEVEL_DEBUG; |
| |
| /*--------------------- Static Classes ----------------------------*/ |
| |
| /*--------------------- Static Variables --------------------------*/ |
| |
| /*--------------------- Static Functions --------------------------*/ |
| |
| /*--------------------- Export Variables --------------------------*/ |
| |
| /*--------------------- Static Definitions -------------------------*/ |
| |
| /*--------------------- Static Classes ----------------------------*/ |
| |
| /*--------------------- Static Variables --------------------------*/ |
| |
| |
| BYTE abyVT3184_AGC[] = { |
| 0x00, //0 |
| 0x00, //1 |
| 0x02, //2 |
| 0x02, //3 //RobertYu:20060505, 0x04, //3 |
| 0x04, //4 |
| 0x04, //5 //RobertYu:20060505, 0x06, //5 |
| 0x06, //6 |
| 0x06, //7 |
| 0x08, //8 |
| 0x08, //9 |
| 0x0A, //A |
| 0x0A, //B |
| 0x0C, //C |
| 0x0C, //D |
| 0x0E, //E |
| 0x0E, //F |
| 0x10, //10 |
| 0x10, //11 |
| 0x12, //12 |
| 0x12, //13 |
| 0x14, //14 |
| 0x14, //15 |
| 0x16, //16 |
| 0x16, //17 |
| 0x18, //18 |
| 0x18, //19 |
| 0x1A, //1A |
| 0x1A, //1B |
| 0x1C, //1C |
| 0x1C, //1D |
| 0x1E, //1E |
| 0x1E, //1F |
| 0x20, //20 |
| 0x20, //21 |
| 0x22, //22 |
| 0x22, //23 |
| 0x24, //24 |
| 0x24, //25 |
| 0x26, //26 |
| 0x26, //27 |
| 0x28, //28 |
| 0x28, //29 |
| 0x2A, //2A |
| 0x2A, //2B |
| 0x2C, //2C |
| 0x2C, //2D |
| 0x2E, //2E |
| 0x2E, //2F |
| 0x30, //30 |
| 0x30, //31 |
| 0x32, //32 |
| 0x32, //33 |
| 0x34, //34 |
| 0x34, //35 |
| 0x36, //36 |
| 0x36, //37 |
| 0x38, //38 |
| 0x38, //39 |
| 0x3A, //3A |
| 0x3A, //3B |
| 0x3C, //3C |
| 0x3C, //3D |
| 0x3E, //3E |
| 0x3E //3F |
| }; |
| |
| |
| BYTE abyVT3184_AL2230[] = { |
| 0x31,//00 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x80, |
| 0x00, |
| 0x00, |
| 0x70, |
| 0x45,//tx //0x64 for FPGA |
| 0x2A, |
| 0x76, |
| 0x00, |
| 0x00, |
| 0x80, |
| 0x00, |
| 0x00,//10 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x8e, //RobertYu:20060522, //0x8d, |
| 0x0a, //RobertYu:20060515, //0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00,//20 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x4a, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x4a, |
| 0x00, |
| 0x0c, //RobertYu:20060522, //0x10, |
| 0x26,//30 |
| 0x5b, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xaa, |
| 0xaa, |
| 0xff, |
| 0xff, |
| 0x79, |
| 0x00, |
| 0x00, |
| 0x0b, |
| 0x48, |
| 0x04, |
| 0x00,//40 |
| 0x08, |
| 0x00, |
| 0x08, |
| 0x08, |
| 0x14, |
| 0x05, |
| 0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x09, |
| 0x73, |
| 0x00, |
| 0xc5, |
| 0x00,//50 //RobertYu:20060505, //0x15,//50 |
| 0x19, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xd0, //RobertYu:20060505, //0xb0, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xe4,//60 |
| 0x80, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x98, |
| 0x0a, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, //0x80 for FPGA |
| 0x03, |
| 0x01, |
| 0x00, |
| 0x00,//70 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x8c,//80 |
| 0x01, |
| 0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x08, |
| 0x00, |
| 0x1f, //RobertYu:20060516, //0x0f, |
| 0xb7, |
| 0x88, |
| 0x47, |
| 0xaa, |
| 0x00, //RobertYu:20060505, //0x02, |
| 0x20,//90 //RobertYu:20060505, //0x22,//90 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xeb, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x01, |
| 0x00,//a0 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x00, |
| 0x18, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x15, //RobertYu:20060516, //0x00, |
| 0x00, |
| 0x18, |
| 0x38,//b0 |
| 0x30, |
| 0x00, |
| 0x00, |
| 0xff, |
| 0x0f, |
| 0xe4, |
| 0xe2, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x03, |
| 0x01, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x18,//c0 |
| 0x20, |
| 0x07, |
| 0x18, |
| 0xff, |
| 0xff, //RobertYu:20060509, //0x2c, |
| 0x0e, //RobertYu:20060530, //0x0c, |
| 0x0a, |
| 0x0e, |
| 0x00, //RobertYu:20060505, //0x01, |
| 0x82, //RobertYu:20060516, //0x8f, |
| 0xa7, |
| 0x3c, |
| 0x10, |
| 0x30, //RobertYu:20060627, //0x0b, |
| 0x05, //RobertYu:20060516, //0x25, |
| 0x40,//d0 |
| 0x12, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x28, |
| 0x80, |
| 0x2A, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00,//e0 |
| 0xf3, //RobertYu:20060516, //0xd3, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x00, |
| 0x12, //RobertYu:20060627, //0x10, |
| 0x00, |
| 0xf4, |
| 0x00, |
| 0xff, |
| 0x79, |
| 0x20, |
| 0x30, |
| 0x05, //RobertYu:20060516, //0x0c, |
| 0x00,//f0 |
| 0x3e, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00 |
| }; |
| |
| |
| |
| //{{RobertYu:20060515, new BB setting for VT3226D0 |
| BYTE abyVT3184_VT3226D0[] = { |
| 0x31,//00 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x80, |
| 0x00, |
| 0x00, |
| 0x70, |
| 0x45,//tx //0x64 for FPGA |
| 0x2A, |
| 0x76, |
| 0x00, |
| 0x00, |
| 0x80, |
| 0x00, |
| 0x00,//10 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x8e, //RobertYu:20060525, //0x8d, |
| 0x0a, //RobertYu:20060515, //0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00,//20 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x4a, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x4a, |
| 0x00, |
| 0x0c, //RobertYu:20060525, //0x10, |
| 0x26,//30 |
| 0x5b, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xaa, |
| 0xaa, |
| 0xff, |
| 0xff, |
| 0x79, |
| 0x00, |
| 0x00, |
| 0x0b, |
| 0x48, |
| 0x04, |
| 0x00,//40 |
| 0x08, |
| 0x00, |
| 0x08, |
| 0x08, |
| 0x14, |
| 0x05, |
| 0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x09, |
| 0x73, |
| 0x00, |
| 0xc5, |
| 0x00,//50 //RobertYu:20060505, //0x15,//50 |
| 0x19, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xd0, //RobertYu:20060505, //0xb0, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xe4,//60 |
| 0x80, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x98, |
| 0x0a, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, //0x80 for FPGA |
| 0x03, |
| 0x01, |
| 0x00, |
| 0x00,//70 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x8c,//80 |
| 0x01, |
| 0x09, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x08, |
| 0x00, |
| 0x1f, //RobertYu:20060515, //0x0f, |
| 0xb7, |
| 0x88, |
| 0x47, |
| 0xaa, |
| 0x00, //RobertYu:20060505, //0x02, |
| 0x20,//90 //RobertYu:20060505, //0x22,//90 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0xeb, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x01, |
| 0x00,//a0 |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x00, |
| 0x18, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x18, |
| 0x38,//b0 |
| 0x30, |
| 0x00, |
| 0x00, |
| 0xff, |
| 0x0f, |
| 0xe4, |
| 0xe2, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x03, |
| 0x01, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x18,//c0 |
| 0x20, |
| 0x07, |
| 0x18, |
| 0xff, |
| 0xff, //RobertYu:20060509, //0x2c, |
| 0x10, //RobertYu:20060525, //0x0c, |
| 0x0a, |
| 0x0e, |
| 0x00, //RobertYu:20060505, //0x01, |
| 0x84, //RobertYu:20060525, //0x8f, |
| 0xa7, |
| 0x3c, |
| 0x10, |
| 0x24, //RobertYu:20060627, //0x18, |
| 0x05, //RobertYu:20060515, //0x25, |
| 0x40,//d0 |
| 0x12, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x28, |
| 0x80, |
| 0x2A, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00,//e0 |
| 0xf3, //RobertYu:20060515, //0xd3, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x10, |
| 0x00, |
| 0x10, //RobertYu:20060627, //0x0e, |
| 0x00, |
| 0xf4, |
| 0x00, |
| 0xff, |
| 0x79, |
| 0x20, |
| 0x30, |
| 0x08, //RobertYu:20060515, //0x0c, |
| 0x00,//f0 |
| 0x3e, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| 0x00, |
| }; |
| |
| const WORD awcFrameTime[MAX_RATE] = |
| {10, 20, 55, 110, 24, 36, 48, 72, 96, 144, 192, 216}; |
| |
| /*--------------------- Static Functions --------------------------*/ |
| |
| /* |
| static |
| unsigned long |
| s_ulGetLowSQ3(PSDevice pDevice); |
| |
| static |
| unsigned long |
| s_ulGetRatio(PSDevice pDevice); |
| |
| static |
| void |
| s_vClearSQ3Value(PSDevice pDevice); |
| */ |
| |
| /*--------------------- Export Variables --------------------------*/ |
| /* |
| * Description: Calculate data frame transmitting time |
| * |
| * Parameters: |
| * In: |
| * byPreambleType - Preamble Type |
| * byPktType - PK_TYPE_11A, PK_TYPE_11B, PK_TYPE_11GB, PK_TYPE_11GA |
| * cbFrameLength - Baseband Type |
| * wRate - Tx Rate |
| * Out: |
| * |
| * Return Value: FrameTime |
| * |
| */ |
| unsigned int |
| BBuGetFrameTime( |
| BYTE byPreambleType, |
| BYTE byPktType, |
| unsigned int cbFrameLength, |
| WORD wRate |
| ) |
| { |
| unsigned int uFrameTime; |
| unsigned int uPreamble; |
| unsigned int uTmp; |
| unsigned int uRateIdx = (unsigned int)wRate; |
| unsigned int uRate = 0; |
| |
| |
| if (uRateIdx > RATE_54M) { |
| ASSERT(0); |
| return 0; |
| } |
| |
| uRate = (unsigned int)awcFrameTime[uRateIdx]; |
| |
| if (uRateIdx <= 3) { //CCK mode |
| |
| if (byPreambleType == 1) {//Short |
| uPreamble = 96; |
| } else { |
| uPreamble = 192; |
| } |
| uFrameTime = (cbFrameLength * 80) / uRate; //????? |
| uTmp = (uFrameTime * uRate) / 80; |
| if (cbFrameLength != uTmp) { |
| uFrameTime ++; |
| } |
| |
| return (uPreamble + uFrameTime); |
| } |
| else { |
| uFrameTime = (cbFrameLength * 8 + 22) / uRate; //???????? |
| uTmp = ((uFrameTime * uRate) - 22) / 8; |
| if(cbFrameLength != uTmp) { |
| uFrameTime ++; |
| } |
| uFrameTime = uFrameTime * 4; //??????? |
| if(byPktType != PK_TYPE_11A) { |
| uFrameTime += 6; |
| } |
| return (20 + uFrameTime); //?????? |
| } |
| } |
| |
| /* |
| * Description: Calculate Length, Service, and Signal fields of Phy for Tx |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * cbFrameLength - Tx Frame Length |
| * wRate - Tx Rate |
| * Out: |
| * pwPhyLen - pointer to Phy Length field |
| * pbyPhySrv - pointer to Phy Service field |
| * pbyPhySgn - pointer to Phy Signal field |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvCalculateParameter(struct vnt_private *pDevice, u32 cbFrameLength, |
| u16 wRate, u8 byPacketType, u16 *pwPhyLen, u8 *pbyPhySrv, |
| u8 *pbyPhySgn) |
| { |
| u32 cbBitCount; |
| u32 cbUsCount = 0; |
| u32 cbTmp; |
| int bExtBit; |
| u8 byPreambleType = pDevice->byPreambleType; |
| int bCCK = pDevice->bCCK; |
| |
| cbBitCount = cbFrameLength * 8; |
| bExtBit = false; |
| |
| switch (wRate) { |
| case RATE_1M : |
| cbUsCount = cbBitCount; |
| *pbyPhySgn = 0x00; |
| break; |
| |
| case RATE_2M : |
| cbUsCount = cbBitCount / 2; |
| if (byPreambleType == 1) |
| *pbyPhySgn = 0x09; |
| else // long preamble |
| *pbyPhySgn = 0x01; |
| break; |
| |
| case RATE_5M : |
| if (bCCK == false) |
| cbBitCount ++; |
| cbUsCount = (cbBitCount * 10) / 55; |
| cbTmp = (cbUsCount * 55) / 10; |
| if (cbTmp != cbBitCount) |
| cbUsCount ++; |
| if (byPreambleType == 1) |
| *pbyPhySgn = 0x0a; |
| else // long preamble |
| *pbyPhySgn = 0x02; |
| break; |
| |
| case RATE_11M : |
| |
| if (bCCK == false) |
| cbBitCount ++; |
| cbUsCount = cbBitCount / 11; |
| cbTmp = cbUsCount * 11; |
| if (cbTmp != cbBitCount) { |
| cbUsCount ++; |
| if ((cbBitCount - cbTmp) <= 3) |
| bExtBit = TRUE; |
| } |
| if (byPreambleType == 1) |
| *pbyPhySgn = 0x0b; |
| else // long preamble |
| *pbyPhySgn = 0x03; |
| break; |
| |
| case RATE_6M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9B; //1001 1011 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8B; //1000 1011 |
| } |
| break; |
| |
| case RATE_9M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9F; //1001 1111 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8F; //1000 1111 |
| } |
| break; |
| |
| case RATE_12M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9A; //1001 1010 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8A; //1000 1010 |
| } |
| break; |
| |
| case RATE_18M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9E; //1001 1110 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8E; //1000 1110 |
| } |
| break; |
| |
| case RATE_24M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x99; //1001 1001 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x89; //1000 1001 |
| } |
| break; |
| |
| case RATE_36M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9D; //1001 1101 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8D; //1000 1101 |
| } |
| break; |
| |
| case RATE_48M : |
| if(byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x98; //1001 1000 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x88; //1000 1000 |
| } |
| break; |
| |
| case RATE_54M : |
| if (byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9C; //1001 1100 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8C; //1000 1100 |
| } |
| break; |
| |
| default : |
| if (byPacketType == PK_TYPE_11A) {//11a, 5GHZ |
| *pbyPhySgn = 0x9C; //1001 1100 |
| } |
| else {//11g, 2.4GHZ |
| *pbyPhySgn = 0x8C; //1000 1100 |
| } |
| break; |
| } |
| |
| if (byPacketType == PK_TYPE_11B) { |
| *pbyPhySrv = 0x00; |
| if (bExtBit) |
| *pbyPhySrv = *pbyPhySrv | 0x80; |
| *pwPhyLen = (WORD) cbUsCount; |
| } |
| else { |
| *pbyPhySrv = 0x00; |
| *pwPhyLen = (WORD)cbFrameLength; |
| } |
| } |
| |
| |
| /* |
| * Description: Set Antenna mode |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * byAntennaMode - Antenna Mode |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvSetAntennaMode(struct vnt_private *pDevice, u8 byAntennaMode) |
| { |
| switch (byAntennaMode) { |
| case ANT_TXA: |
| case ANT_TXB: |
| break; |
| case ANT_RXA: |
| pDevice->byBBRxConf &= 0xFC; |
| break; |
| case ANT_RXB: |
| pDevice->byBBRxConf &= 0xFE; |
| pDevice->byBBRxConf |= 0x02; |
| break; |
| } |
| |
| |
| CONTROLnsRequestOut(pDevice, |
| MESSAGE_TYPE_SET_ANTMD, |
| (WORD) byAntennaMode, |
| 0, |
| 0, |
| NULL); |
| } |
| |
| /* |
| * Description: Set Antenna mode |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * byAntennaMode - Antenna Mode |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| |
| int BBbVT3184Init(struct vnt_private *pDevice) |
| { |
| int ntStatus; |
| WORD wLength; |
| PBYTE pbyAddr; |
| PBYTE pbyAgc; |
| WORD wLengthAgc; |
| BYTE abyArray[256]; |
| |
| ntStatus = CONTROLnsRequestIn(pDevice, |
| MESSAGE_TYPE_READ, |
| 0, |
| MESSAGE_REQUEST_EEPROM, |
| EEP_MAX_CONTEXT_SIZE, |
| pDevice->abyEEPROM); |
| if (ntStatus != STATUS_SUCCESS) { |
| return false; |
| } |
| |
| |
| // if ((pDevice->abyEEPROM[EEP_OFS_RADIOCTL]&0x06)==0x04) |
| // return false; |
| |
| //zonetype initial |
| pDevice->byOriginalZonetype = pDevice->abyEEPROM[EEP_OFS_ZONETYPE]; |
| if(pDevice->config_file.ZoneType >= 0) { //read zonetype file ok! |
| if ((pDevice->config_file.ZoneType == 0)&& |
| (pDevice->abyEEPROM[EEP_OFS_ZONETYPE] !=0x00)){ //for USA |
| pDevice->abyEEPROM[EEP_OFS_ZONETYPE] = 0; |
| pDevice->abyEEPROM[EEP_OFS_MAXCHANNEL] = 0x0B; |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Init Zone Type :USA\n"); |
| } |
| else if((pDevice->config_file.ZoneType == 1)&& |
| (pDevice->abyEEPROM[EEP_OFS_ZONETYPE]!=0x01)){ //for Japan |
| pDevice->abyEEPROM[EEP_OFS_ZONETYPE] = 0x01; |
| pDevice->abyEEPROM[EEP_OFS_MAXCHANNEL] = 0x0D; |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Init Zone Type :Japan\n"); |
| } |
| else if((pDevice->config_file.ZoneType == 2)&& |
| (pDevice->abyEEPROM[EEP_OFS_ZONETYPE]!=0x02)){ //for Europe |
| pDevice->abyEEPROM[EEP_OFS_ZONETYPE] = 0x02; |
| pDevice->abyEEPROM[EEP_OFS_MAXCHANNEL] = 0x0D; |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Init Zone Type :Europe\n"); |
| } |
| else { |
| if(pDevice->config_file.ZoneType !=pDevice->abyEEPROM[EEP_OFS_ZONETYPE]) |
| printk("zonetype in file[%02x] mismatch with in EEPROM[%02x]\n",pDevice->config_file.ZoneType,pDevice->abyEEPROM[EEP_OFS_ZONETYPE]); |
| else |
| printk("Read Zonetype file success,use default zonetype setting[%02x]\n",pDevice->config_file.ZoneType); |
| } |
| } |
| |
| if ( !pDevice->bZoneRegExist ) { |
| pDevice->byZoneType = pDevice->abyEEPROM[EEP_OFS_ZONETYPE]; |
| } |
| pDevice->byRFType = pDevice->abyEEPROM[EEP_OFS_RFTYPE]; |
| |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"Zone Type %x\n", pDevice->byZoneType); |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"RF Type %d\n", pDevice->byRFType); |
| |
| if ((pDevice->byRFType == RF_AL2230) || (pDevice->byRFType == RF_AL2230S)) { |
| pDevice->byBBRxConf = abyVT3184_AL2230[10]; |
| wLength = sizeof(abyVT3184_AL2230); |
| pbyAddr = abyVT3184_AL2230; |
| pbyAgc = abyVT3184_AGC; |
| wLengthAgc = sizeof(abyVT3184_AGC); |
| |
| pDevice->abyBBVGA[0] = 0x1C; |
| pDevice->abyBBVGA[1] = 0x10; |
| pDevice->abyBBVGA[2] = 0x0; |
| pDevice->abyBBVGA[3] = 0x0; |
| pDevice->ldBmThreshold[0] = -70; |
| pDevice->ldBmThreshold[1] = -48; |
| pDevice->ldBmThreshold[2] = 0; |
| pDevice->ldBmThreshold[3] = 0; |
| } |
| else if (pDevice->byRFType == RF_AIROHA7230) { |
| pDevice->byBBRxConf = abyVT3184_AL2230[10]; |
| wLength = sizeof(abyVT3184_AL2230); |
| pbyAddr = abyVT3184_AL2230; |
| pbyAgc = abyVT3184_AGC; |
| wLengthAgc = sizeof(abyVT3184_AGC); |
| |
| // Init ANT B select,TX Config CR09 = 0x61->0x45, 0x45->0x41(VC1/VC2 define, make the ANT_A, ANT_B inverted) |
| //pbyAddr[0x09] = 0x41; |
| // Init ANT B select,RX Config CR10 = 0x28->0x2A, 0x2A->0x28(VC1/VC2 define, make the ANT_A, ANT_B inverted) |
| //pbyAddr[0x0a] = 0x28; |
| // Select VC1/VC2, CR215 = 0x02->0x06 |
| pbyAddr[0xd7] = 0x06; |
| |
| pDevice->abyBBVGA[0] = 0x1C; |
| pDevice->abyBBVGA[1] = 0x10; |
| pDevice->abyBBVGA[2] = 0x0; |
| pDevice->abyBBVGA[3] = 0x0; |
| pDevice->ldBmThreshold[0] = -70; |
| pDevice->ldBmThreshold[1] = -48; |
| pDevice->ldBmThreshold[2] = 0; |
| pDevice->ldBmThreshold[3] = 0; |
| } |
| else if ( (pDevice->byRFType == RF_VT3226) || (pDevice->byRFType == RF_VT3226D0) ) { |
| pDevice->byBBRxConf = abyVT3184_VT3226D0[10]; //RobertYu:20060515 |
| wLength = sizeof(abyVT3184_VT3226D0); //RobertYu:20060515 |
| pbyAddr = abyVT3184_VT3226D0; //RobertYu:20060515 |
| pbyAgc = abyVT3184_AGC; |
| wLengthAgc = sizeof(abyVT3184_AGC); |
| |
| pDevice->abyBBVGA[0] = 0x20; //RobertYu:20060104, reguest by Jack |
| pDevice->abyBBVGA[1] = 0x10; |
| pDevice->abyBBVGA[2] = 0x0; |
| pDevice->abyBBVGA[3] = 0x0; |
| pDevice->ldBmThreshold[0] = -70; |
| pDevice->ldBmThreshold[1] = -48; |
| pDevice->ldBmThreshold[2] = 0; |
| pDevice->ldBmThreshold[3] = 0; |
| // Fix VT3226 DFC system timing issue |
| MACvRegBitsOn(pDevice, MAC_REG_SOFTPWRCTL2, SOFTPWRCTL_RFLEOPT); |
| //}} |
| //{{RobertYu:20060609 |
| } else if ( (pDevice->byRFType == RF_VT3342A0) ) { |
| pDevice->byBBRxConf = abyVT3184_VT3226D0[10]; |
| wLength = sizeof(abyVT3184_VT3226D0); |
| pbyAddr = abyVT3184_VT3226D0; |
| pbyAgc = abyVT3184_AGC; |
| wLengthAgc = sizeof(abyVT3184_AGC); |
| |
| pDevice->abyBBVGA[0] = 0x20; |
| pDevice->abyBBVGA[1] = 0x10; |
| pDevice->abyBBVGA[2] = 0x0; |
| pDevice->abyBBVGA[3] = 0x0; |
| pDevice->ldBmThreshold[0] = -70; |
| pDevice->ldBmThreshold[1] = -48; |
| pDevice->ldBmThreshold[2] = 0; |
| pDevice->ldBmThreshold[3] = 0; |
| // Fix VT3226 DFC system timing issue |
| MACvRegBitsOn(pDevice, MAC_REG_SOFTPWRCTL2, SOFTPWRCTL_RFLEOPT); |
| //}} |
| } else { |
| return TRUE; |
| } |
| |
| memcpy(abyArray, pbyAddr, wLength); |
| CONTROLnsRequestOut(pDevice, |
| MESSAGE_TYPE_WRITE, |
| 0, |
| MESSAGE_REQUEST_BBREG, |
| wLength, |
| abyArray |
| ); |
| |
| memcpy(abyArray, pbyAgc, wLengthAgc); |
| CONTROLnsRequestOut(pDevice, |
| MESSAGE_TYPE_WRITE, |
| 0, |
| MESSAGE_REQUEST_BBAGC, |
| wLengthAgc, |
| abyArray |
| ); |
| |
| |
| if ((pDevice->byRFType == RF_VT3226) || //RobertYu:20051116, 20060111 remove VT3226D0 |
| (pDevice->byRFType == RF_VT3342A0) //RobertYu:20060609 |
| ) { |
| ControlvWriteByte(pDevice,MESSAGE_REQUEST_MACREG,MAC_REG_ITRTMSET,0x23); |
| MACvRegBitsOn(pDevice,MAC_REG_PAPEDELAY,0x01); |
| } |
| else if (pDevice->byRFType == RF_VT3226D0) |
| { |
| ControlvWriteByte(pDevice,MESSAGE_REQUEST_MACREG,MAC_REG_ITRTMSET,0x11); |
| MACvRegBitsOn(pDevice,MAC_REG_PAPEDELAY,0x01); |
| } |
| |
| |
| ControlvWriteByte(pDevice,MESSAGE_REQUEST_BBREG,0x04,0x7F); |
| ControlvWriteByte(pDevice,MESSAGE_REQUEST_BBREG,0x0D,0x01); |
| |
| RFbRFTableDownload(pDevice); |
| return TRUE;//ntStatus; |
| } |
| |
| |
| /* |
| * Description: Turn on BaseBand Loopback mode |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvLoopbackOn(struct vnt_private *pDevice) |
| { |
| BYTE byData; |
| |
| //CR C9 = 0x00 |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0xC9, &pDevice->byBBCRc9);//CR201 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0); |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x4D, &pDevice->byBBCR4d);//CR77 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x4D, 0x90); |
| |
| //CR 88 = 0x02(CCK), 0x03(OFDM) |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x88, &pDevice->byBBCR88);//CR136 |
| |
| if (pDevice->wCurrentRate <= RATE_11M) { //CCK |
| // Enable internal digital loopback: CR33 |= 0000 0001 |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x21, &byData);//CR33 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x21, (BYTE)(byData | 0x01));//CR33 |
| // CR154 = 0x00 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x9A, 0); //CR154 |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x88, 0x02);//CR239 |
| } |
| else { //OFDM |
| // Enable internal digital loopback:CR154 |= 0000 0001 |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x9A, &byData);//CR154 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x9A, (BYTE)(byData | 0x01));//CR154 |
| // CR33 = 0x00 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x21, 0); //CR33 |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x88, 0x03);//CR239 |
| } |
| |
| //CR14 = 0x00 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0E, 0);//CR14 |
| |
| // Disable TX_IQUN |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x09, &pDevice->byBBCR09); |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x09, (BYTE)(pDevice->byBBCR09 & 0xDE)); |
| } |
| |
| /* |
| * Description: Turn off BaseBand Loopback mode |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvLoopbackOff(struct vnt_private *pDevice) |
| { |
| u8 byData; |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, pDevice->byBBCRc9);//CR201 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x88, pDevice->byBBCR88);//CR136 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x09, pDevice->byBBCR09);//CR136 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x4D, pDevice->byBBCR4d);//CR77 |
| |
| if (pDevice->wCurrentRate <= RATE_11M) { // CCK |
| // Set the CR33 Bit2 to disable internal Loopback. |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x21, &byData);//CR33 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x21, (BYTE)(byData & 0xFE));//CR33 |
| } else { /* OFDM */ |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x9A, &byData);//CR154 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x9A, (BYTE)(byData & 0xFE));//CR154 |
| } |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0x0E, &byData);//CR14 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0E, (BYTE)(byData | 0x80));//CR14 |
| |
| } |
| |
| |
| /* |
| * Description: Set ShortSlotTime mode |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvSetShortSlotTime(struct vnt_private *pDevice) |
| { |
| BYTE byBBVGA=0; |
| |
| if (pDevice->bShortSlotTime) |
| pDevice->byBBRxConf &= 0xDF;//1101 1111 |
| else |
| pDevice->byBBRxConf |= 0x20;//0010 0000 |
| |
| ControlvReadByte (pDevice, MESSAGE_REQUEST_BBREG, 0xE7, &byBBVGA); |
| if (byBBVGA == pDevice->abyBBVGA[0]) |
| pDevice->byBBRxConf |= 0x20;//0010 0000 |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0A, pDevice->byBBRxConf); |
| } |
| |
| |
| void BBvSetVGAGainOffset(struct vnt_private *pDevice, BYTE byData) |
| { |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xE7, byData); |
| |
| // patch for 3253B0 Baseband with Cardbus module |
| if (pDevice->bShortSlotTime) |
| pDevice->byBBRxConf &= 0xDF; /* 1101 1111 */ |
| else |
| pDevice->byBBRxConf |= 0x20; /* 0010 0000 */ |
| |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0A, pDevice->byBBRxConf);//CR10 |
| } |
| |
| |
| /* |
| * Description: Baseband SoftwareReset |
| * |
| * Parameters: |
| * In: |
| * dwIoBase - I/O base address |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvSoftwareReset(struct vnt_private *pDevice) |
| { |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x50, 0x40); |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x50, 0); |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x9C, 0x01); |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x9C, 0); |
| } |
| |
| /* |
| * Description: BBvSetDeepSleep |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| void BBvSetDeepSleep(struct vnt_private *pDevice) |
| { |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0c, 0x17);//CR12 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0D, 0xB9);//CR13 |
| } |
| |
| void BBvExitDeepSleep(struct vnt_private *pDevice) |
| { |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0C, 0x00);//CR12 |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0D, 0x01);//CR13 |
| } |
| |
| |
| static unsigned long s_ulGetLowSQ3(struct vnt_private *pDevice) |
| { |
| int ii; |
| unsigned long ulSQ3 = 0; |
| unsigned long ulMaxPacket; |
| |
| ulMaxPacket = pDevice->aulPktNum[RATE_54M]; |
| if (pDevice->aulPktNum[RATE_54M] != 0) |
| ulSQ3 = pDevice->aulSQ3Val[RATE_54M] / pDevice->aulPktNum[RATE_54M]; |
| |
| for (ii = RATE_48M; ii >= RATE_6M; ii--) |
| if (pDevice->aulPktNum[ii] > ulMaxPacket) { |
| ulMaxPacket = pDevice->aulPktNum[ii]; |
| ulSQ3 = pDevice->aulSQ3Val[ii] / pDevice->aulPktNum[ii]; |
| } |
| |
| return ulSQ3; |
| } |
| |
| static unsigned long s_ulGetRatio(struct vnt_private *pDevice) |
| { |
| int ii, jj; |
| unsigned long ulRatio = 0; |
| unsigned long ulMaxPacket; |
| unsigned long ulPacketNum; |
| |
| //This is a thousand-ratio |
| ulMaxPacket = pDevice->aulPktNum[RATE_54M]; |
| if ( pDevice->aulPktNum[RATE_54M] != 0 ) { |
| ulPacketNum = pDevice->aulPktNum[RATE_54M]; |
| ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt); |
| ulRatio += TOP_RATE_54M; |
| } |
| for (ii = RATE_48M; ii >= RATE_1M; ii--) |
| if ( pDevice->aulPktNum[ii] > ulMaxPacket ) { |
| ulPacketNum = 0; |
| for ( jj=RATE_54M;jj>=ii;jj--) |
| ulPacketNum += pDevice->aulPktNum[jj]; |
| ulRatio = (ulPacketNum * 1000 / pDevice->uDiversityCnt); |
| ulRatio += TOP_RATE_48M; |
| ulMaxPacket = pDevice->aulPktNum[ii]; |
| } |
| |
| return ulRatio; |
| } |
| |
| |
| static void s_vClearSQ3Value(struct vnt_private *pDevice) |
| { |
| int ii; |
| pDevice->uDiversityCnt = 0; |
| |
| for ( ii=RATE_1M;ii<MAX_RATE;ii++) { |
| pDevice->aulPktNum[ii] = 0; |
| pDevice->aulSQ3Val[ii] = 0; |
| } |
| } |
| |
| |
| /* |
| * Description: Antenna Diversity |
| * |
| * Parameters: |
| * In: |
| * pDevice - Device Structure |
| * byRSR - RSR from received packet |
| * bySQ3 - SQ3 value from received packet |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| */ |
| |
| void BBvAntennaDiversity(struct vnt_private *pDevice, |
| u8 byRxRate, u8 bySQ3) |
| { |
| |
| pDevice->uDiversityCnt++; |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"pDevice->uDiversityCnt = %d\n", (int)pDevice->uDiversityCnt); |
| |
| if (byRxRate == 2) { |
| pDevice->aulPktNum[RATE_1M]++; |
| } |
| else if (byRxRate==4) { |
| pDevice->aulPktNum[RATE_2M]++; |
| } |
| else if (byRxRate==11) { |
| pDevice->aulPktNum[RATE_5M]++; |
| } |
| else if (byRxRate==22) { |
| pDevice->aulPktNum[RATE_11M]++; |
| } |
| else if(byRxRate==12){ |
| pDevice->aulPktNum[RATE_6M]++; |
| pDevice->aulSQ3Val[RATE_6M] += bySQ3; |
| } |
| else if(byRxRate==18){ |
| pDevice->aulPktNum[RATE_9M]++; |
| pDevice->aulSQ3Val[RATE_9M] += bySQ3; |
| } |
| else if(byRxRate==24){ |
| pDevice->aulPktNum[RATE_12M]++; |
| pDevice->aulSQ3Val[RATE_12M] += bySQ3; |
| } |
| else if(byRxRate==36){ |
| pDevice->aulPktNum[RATE_18M]++; |
| pDevice->aulSQ3Val[RATE_18M] += bySQ3; |
| } |
| else if(byRxRate==48){ |
| pDevice->aulPktNum[RATE_24M]++; |
| pDevice->aulSQ3Val[RATE_24M] += bySQ3; |
| } |
| else if(byRxRate==72){ |
| pDevice->aulPktNum[RATE_36M]++; |
| pDevice->aulSQ3Val[RATE_36M] += bySQ3; |
| } |
| else if(byRxRate==96){ |
| pDevice->aulPktNum[RATE_48M]++; |
| pDevice->aulSQ3Val[RATE_48M] += bySQ3; |
| } |
| else if(byRxRate==108){ |
| pDevice->aulPktNum[RATE_54M]++; |
| pDevice->aulSQ3Val[RATE_54M] += bySQ3; |
| } |
| |
| if (pDevice->byAntennaState == 0) { |
| |
| if (pDevice->uDiversityCnt > pDevice->ulDiversityNValue) { |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"ulDiversityNValue=[%d],54M-[%d]\n",(int)pDevice->ulDiversityNValue, (int)pDevice->aulPktNum[RATE_54M]); |
| |
| pDevice->ulSQ3_State0 = s_ulGetLowSQ3(pDevice); |
| pDevice->ulRatio_State0 = s_ulGetRatio(pDevice); |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"SQ3_State0, SQ3= [%08x] rate = [%08x]\n",(int)pDevice->ulSQ3_State0,(int)pDevice->ulRatio_State0); |
| |
| if ( ((pDevice->aulPktNum[RATE_54M] < pDevice->ulDiversityNValue/2) && |
| (pDevice->ulSQ3_State0 > pDevice->ulSQ3TH) ) || |
| (pDevice->ulSQ3_State0 == 0 ) ) { |
| |
| if ( pDevice->byTMax == 0 ) |
| return; |
| |
| bScheduleCommand((void *) pDevice, |
| WLAN_CMD_CHANGE_ANTENNA, |
| NULL); |
| |
| pDevice->byAntennaState = 1; |
| |
| del_timer(&pDevice->TimerSQ3Tmax3); |
| del_timer(&pDevice->TimerSQ3Tmax2); |
| pDevice->TimerSQ3Tmax1.expires = RUN_AT(pDevice->byTMax * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax1); |
| |
| } else { |
| pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax3); |
| } |
| s_vClearSQ3Value(pDevice); |
| |
| } |
| } else { //byAntennaState == 1 |
| |
| if (pDevice->uDiversityCnt > pDevice->ulDiversityMValue) { |
| |
| del_timer(&pDevice->TimerSQ3Tmax1); |
| pDevice->ulSQ3_State1 = s_ulGetLowSQ3(pDevice); |
| pDevice->ulRatio_State1 = s_ulGetRatio(pDevice); |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"SQ3_State1, rate0 = %08x,rate1 = %08x\n",(int)pDevice->ulRatio_State0,(int)pDevice->ulRatio_State1); |
| |
| if ( ((pDevice->ulSQ3_State1 == 0) && (pDevice->ulSQ3_State0 != 0)) || |
| ((pDevice->ulSQ3_State1 == 0) && (pDevice->ulSQ3_State0 == 0) && (pDevice->ulRatio_State1 < pDevice->ulRatio_State0)) || |
| ((pDevice->ulSQ3_State1 != 0) && (pDevice->ulSQ3_State0 != 0) && (pDevice->ulSQ3_State0 < pDevice->ulSQ3_State1)) |
| ) { |
| |
| bScheduleCommand((void *) pDevice, |
| WLAN_CMD_CHANGE_ANTENNA, |
| NULL); |
| |
| pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ); |
| pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax3); |
| add_timer(&pDevice->TimerSQ3Tmax2); |
| |
| } |
| pDevice->byAntennaState = 0; |
| s_vClearSQ3Value(pDevice); |
| } |
| } //byAntennaState |
| } |
| |
| |
| /*+ |
| * |
| * Description: |
| * Timer for SQ3 antenna diversity |
| * |
| * Parameters: |
| * In: |
| * pvSysSpec1 |
| * hDeviceContext - Pointer to the adapter |
| * pvSysSpec2 |
| * pvSysSpec3 |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| -*/ |
| |
| void TimerSQ3CallBack(struct vnt_private *pDevice) |
| { |
| |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"TimerSQ3CallBack..."); |
| spin_lock_irq(&pDevice->lock); |
| |
| bScheduleCommand((void *) pDevice, WLAN_CMD_CHANGE_ANTENNA, NULL); |
| pDevice->byAntennaState = 0; |
| s_vClearSQ3Value(pDevice); |
| pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ); |
| pDevice->TimerSQ3Tmax2.expires = RUN_AT(pDevice->byTMax2 * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax3); |
| add_timer(&pDevice->TimerSQ3Tmax2); |
| |
| |
| spin_unlock_irq(&pDevice->lock); |
| } |
| |
| |
| /*+ |
| * |
| * Description: |
| * Timer for SQ3 antenna diversity |
| * |
| * Parameters: |
| * In: |
| * pvSysSpec1 |
| * hDeviceContext - Pointer to the adapter |
| * pvSysSpec2 |
| * pvSysSpec3 |
| * Out: |
| * none |
| * |
| * Return Value: none |
| * |
| -*/ |
| |
| void TimerSQ3Tmax3CallBack(struct vnt_private *pDevice) |
| { |
| |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"TimerSQ3Tmax3CallBack..."); |
| spin_lock_irq(&pDevice->lock); |
| |
| pDevice->ulRatio_State0 = s_ulGetRatio(pDevice); |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO"SQ3_State0 = [%08x]\n",(int)pDevice->ulRatio_State0); |
| |
| s_vClearSQ3Value(pDevice); |
| if ( pDevice->byTMax == 0 ) { |
| pDevice->TimerSQ3Tmax3.expires = RUN_AT(pDevice->byTMax3 * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax3); |
| spin_unlock_irq(&pDevice->lock); |
| return; |
| } |
| |
| bScheduleCommand((void *) pDevice, WLAN_CMD_CHANGE_ANTENNA, NULL); |
| pDevice->byAntennaState = 1; |
| del_timer(&pDevice->TimerSQ3Tmax3); |
| del_timer(&pDevice->TimerSQ3Tmax2); |
| pDevice->TimerSQ3Tmax1.expires = RUN_AT(pDevice->byTMax * HZ); |
| add_timer(&pDevice->TimerSQ3Tmax1); |
| |
| spin_unlock_irq(&pDevice->lock); |
| } |
| |
| void BBvUpdatePreEDThreshold(struct vnt_private *pDevice, int bScanning) |
| { |
| |
| |
| switch(pDevice->byRFType) |
| { |
| case RF_AL2230: |
| case RF_AL2230S: |
| case RF_AIROHA7230: |
| //RobertYu:20060627, update new table |
| |
| if( bScanning ) |
| { // need Max sensitivity //RSSI -69, -70,.... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -69, -70, -71,...\n"); |
| break; |
| } |
| |
| if(pDevice->byBBPreEDRSSI <= 45) { // RSSI 0, -1,-2,....-45 |
| if(pDevice->byBBPreEDIndex == 20) break; |
| pDevice->byBBPreEDIndex = 20; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0xFF); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI 0, -1,-2,..-45\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 46) { //RSSI -46 |
| if(pDevice->byBBPreEDIndex == 19) break; |
| pDevice->byBBPreEDIndex = 19; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x1A); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -46\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 47) { //RSSI -47 |
| if(pDevice->byBBPreEDIndex == 18) break; |
| pDevice->byBBPreEDIndex = 18; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x15); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -47\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 49) { //RSSI -48, -49 |
| if(pDevice->byBBPreEDIndex == 17) break; |
| pDevice->byBBPreEDIndex = 17; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x0E); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -48,-49\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 51) { //RSSI -50, -51 |
| if(pDevice->byBBPreEDIndex == 16) break; |
| pDevice->byBBPreEDIndex = 16; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x09); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -50,-51\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 53) { //RSSI -52, -53 |
| if(pDevice->byBBPreEDIndex == 15) break; |
| pDevice->byBBPreEDIndex = 15; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x06); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -52,-53\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 55) { //RSSI -54, -55 |
| if(pDevice->byBBPreEDIndex == 14) break; |
| pDevice->byBBPreEDIndex = 14; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x03); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -54,-55\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 56) { //RSSI -56 |
| if(pDevice->byBBPreEDIndex == 13) break; |
| pDevice->byBBPreEDIndex = 13; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xA0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -56\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 57) { //RSSI -57 |
| if(pDevice->byBBPreEDIndex == 12) break; |
| pDevice->byBBPreEDIndex = 12; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x20); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -57\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 58) { //RSSI -58 |
| if(pDevice->byBBPreEDIndex == 11) break; |
| pDevice->byBBPreEDIndex = 11; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xA0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -58\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 59) { //RSSI -59 |
| if(pDevice->byBBPreEDIndex == 10) break; |
| pDevice->byBBPreEDIndex = 10; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x54); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -59\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 60) { //RSSI -60 |
| if(pDevice->byBBPreEDIndex == 9) break; |
| pDevice->byBBPreEDIndex = 9; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x18); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -60\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 61) { //RSSI -61 |
| if(pDevice->byBBPreEDIndex == 8) break; |
| pDevice->byBBPreEDIndex = 8; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xE3); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -61\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 62) { //RSSI -62 |
| if(pDevice->byBBPreEDIndex == 7) break; |
| pDevice->byBBPreEDIndex = 7; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xB9); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -62\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 63) { //RSSI -63 |
| if(pDevice->byBBPreEDIndex == 6) break; |
| pDevice->byBBPreEDIndex = 6; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x93); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -63\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 64) { //RSSI -64 |
| if(pDevice->byBBPreEDIndex == 5) break; |
| pDevice->byBBPreEDIndex = 5; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x79); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -64\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 65) { //RSSI -65 |
| if(pDevice->byBBPreEDIndex == 4) break; |
| pDevice->byBBPreEDIndex = 4; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x62); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -65\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 66) { //RSSI -66 |
| if(pDevice->byBBPreEDIndex == 3) break; |
| pDevice->byBBPreEDIndex = 3; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x51); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -66\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 67) { //RSSI -67 |
| if(pDevice->byBBPreEDIndex == 2) break; |
| pDevice->byBBPreEDIndex = 2; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x43); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -67\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 68) { //RSSI -68 |
| if(pDevice->byBBPreEDIndex == 1) break; |
| pDevice->byBBPreEDIndex = 1; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x36); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -68\n"); |
| } else { //RSSI -69, -70,.... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -69, -70,...\n"); |
| } |
| break; |
| |
| case RF_VT3226: |
| case RF_VT3226D0: |
| //RobertYu:20060627, update new table |
| |
| if( bScanning ) |
| { // need Max sensitivity //RSSI -69, -70, ... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x24); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -69, -70,..\n"); |
| break; |
| } |
| |
| if(pDevice->byBBPreEDRSSI <= 41) { // RSSI 0, -1,-2,....-41 |
| if(pDevice->byBBPreEDIndex == 22) break; |
| pDevice->byBBPreEDIndex = 22; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0xFF); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI 0, -1,-2,..-41\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 42) { //RSSI -42 |
| if(pDevice->byBBPreEDIndex == 21) break; |
| pDevice->byBBPreEDIndex = 21; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x36); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -42\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 43) { //RSSI -43 |
| if(pDevice->byBBPreEDIndex == 20) break; |
| pDevice->byBBPreEDIndex = 20; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x26); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -43\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 45) { //RSSI -44, -45 |
| if(pDevice->byBBPreEDIndex == 19) break; |
| pDevice->byBBPreEDIndex = 19; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x18); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -44,-45\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 47) { //RSSI -46, -47 |
| if(pDevice->byBBPreEDIndex == 18) break; |
| pDevice->byBBPreEDIndex = 18; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x11); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -46,-47\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 49) { //RSSI -48, -49 |
| if(pDevice->byBBPreEDIndex == 17) break; |
| pDevice->byBBPreEDIndex = 17; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x0a); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -48,-49\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 51) { //RSSI -50, -51 |
| if(pDevice->byBBPreEDIndex == 16) break; |
| pDevice->byBBPreEDIndex = 16; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x07); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -50,-51\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 53) { //RSSI -52, -53 |
| if(pDevice->byBBPreEDIndex == 15) break; |
| pDevice->byBBPreEDIndex = 15; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x04); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -52,-53\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 55) { //RSSI -54, -55 |
| if(pDevice->byBBPreEDIndex == 14) break; |
| pDevice->byBBPreEDIndex = 14; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xC0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -54,-55\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 56) { //RSSI -56 |
| if(pDevice->byBBPreEDIndex == 13) break; |
| pDevice->byBBPreEDIndex = 13; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -56\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 57) { //RSSI -57 |
| if(pDevice->byBBPreEDIndex == 12) break; |
| pDevice->byBBPreEDIndex = 12; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xB0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -57\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 58) { //RSSI -58 |
| if(pDevice->byBBPreEDIndex == 11) break; |
| pDevice->byBBPreEDIndex = 11; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x70); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -58\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 59) { //RSSI -59 |
| if(pDevice->byBBPreEDIndex == 10) break; |
| pDevice->byBBPreEDIndex = 10; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -59\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 60) { //RSSI -60 |
| if(pDevice->byBBPreEDIndex == 9) break; |
| pDevice->byBBPreEDIndex = 9; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xEA); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -60\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 61) { //RSSI -61 |
| if(pDevice->byBBPreEDIndex == 8) break; |
| pDevice->byBBPreEDIndex = 8; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xC0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -61\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 62) { //RSSI -62 |
| if(pDevice->byBBPreEDIndex == 7) break; |
| pDevice->byBBPreEDIndex = 7; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x9C); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -62\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 63) { //RSSI -63 |
| if(pDevice->byBBPreEDIndex == 6) break; |
| pDevice->byBBPreEDIndex = 6; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x80); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -63\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 64) { //RSSI -64 |
| if(pDevice->byBBPreEDIndex == 5) break; |
| pDevice->byBBPreEDIndex = 5; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x68); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -64\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 65) { //RSSI -65 |
| if(pDevice->byBBPreEDIndex == 4) break; |
| pDevice->byBBPreEDIndex = 4; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x52); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -65\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 66) { //RSSI -66 |
| if(pDevice->byBBPreEDIndex == 3) break; |
| pDevice->byBBPreEDIndex = 3; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x43); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -66\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 67) { //RSSI -67 |
| if(pDevice->byBBPreEDIndex == 2) break; |
| pDevice->byBBPreEDIndex = 2; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x36); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -67\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 68) { //RSSI -68 |
| if(pDevice->byBBPreEDIndex == 1) break; |
| pDevice->byBBPreEDIndex = 1; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x2D); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -68\n"); |
| } else { //RSSI -69, -70, ... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x24); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -69, -70,..\n"); |
| } |
| break; |
| |
| case RF_VT3342A0: //RobertYu:20060627, testing table |
| if( bScanning ) |
| { // need Max sensitivity //RSSI -67, -68, ... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x38); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -67, -68,..\n"); |
| break; |
| } |
| |
| if(pDevice->byBBPreEDRSSI <= 41) { // RSSI 0, -1,-2,....-41 |
| if(pDevice->byBBPreEDIndex == 20) break; |
| pDevice->byBBPreEDIndex = 20; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0xFF); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI 0, -1,-2,..-41\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 42) { //RSSI -42 |
| if(pDevice->byBBPreEDIndex == 19) break; |
| pDevice->byBBPreEDIndex = 19; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x36); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -42\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 43) { //RSSI -43 |
| if(pDevice->byBBPreEDIndex == 18) break; |
| pDevice->byBBPreEDIndex = 18; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x26); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -43\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 45) { //RSSI -44, -45 |
| if(pDevice->byBBPreEDIndex == 17) break; |
| pDevice->byBBPreEDIndex = 17; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x18); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -44,-45\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 47) { //RSSI -46, -47 |
| if(pDevice->byBBPreEDIndex == 16) break; |
| pDevice->byBBPreEDIndex = 16; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x11); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -46,-47\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 49) { //RSSI -48, -49 |
| if(pDevice->byBBPreEDIndex == 15) break; |
| pDevice->byBBPreEDIndex = 15; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x0a); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -48,-49\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 51) { //RSSI -50, -51 |
| if(pDevice->byBBPreEDIndex == 14) break; |
| pDevice->byBBPreEDIndex = 14; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x07); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -50,-51\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 53) { //RSSI -52, -53 |
| if(pDevice->byBBPreEDIndex == 13) break; |
| pDevice->byBBPreEDIndex = 13; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x04); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x00); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -52,-53\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 55) { //RSSI -54, -55 |
| if(pDevice->byBBPreEDIndex == 12) break; |
| pDevice->byBBPreEDIndex = 12; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xC0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -54,-55\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 56) { //RSSI -56 |
| if(pDevice->byBBPreEDIndex == 11) break; |
| pDevice->byBBPreEDIndex = 11; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x02); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -56\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 57) { //RSSI -57 |
| if(pDevice->byBBPreEDIndex == 10) break; |
| pDevice->byBBPreEDIndex = 10; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xB0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -57\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 58) { //RSSI -58 |
| if(pDevice->byBBPreEDIndex == 9) break; |
| pDevice->byBBPreEDIndex = 9; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x70); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -58\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 59) { //RSSI -59 |
| if(pDevice->byBBPreEDIndex == 8) break; |
| pDevice->byBBPreEDIndex = 8; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x01); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x30); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -59\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 60) { //RSSI -60 |
| if(pDevice->byBBPreEDIndex == 7) break; |
| pDevice->byBBPreEDIndex = 7; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xEA); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -60\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 61) { //RSSI -61 |
| if(pDevice->byBBPreEDIndex == 6) break; |
| pDevice->byBBPreEDIndex = 6; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0xC0); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -61\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 62) { //RSSI -62 |
| if(pDevice->byBBPreEDIndex == 5) break; |
| pDevice->byBBPreEDIndex = 5; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x9C); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -62\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 63) { //RSSI -63 |
| if(pDevice->byBBPreEDIndex == 4) break; |
| pDevice->byBBPreEDIndex = 4; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x80); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -63\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 64) { //RSSI -64 |
| if(pDevice->byBBPreEDIndex == 3) break; |
| pDevice->byBBPreEDIndex = 3; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x68); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -64\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 65) { //RSSI -65 |
| if(pDevice->byBBPreEDIndex == 2) break; |
| pDevice->byBBPreEDIndex = 2; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x52); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -65\n"); |
| } else if(pDevice->byBBPreEDRSSI <= 66) { //RSSI -66 |
| if(pDevice->byBBPreEDIndex == 1) break; |
| pDevice->byBBPreEDIndex = 1; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x43); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -66\n"); |
| } else { //RSSI -67, -68, ... |
| if(pDevice->byBBPreEDIndex == 0) break; |
| pDevice->byBBPreEDIndex = 0; |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xC9, 0x00); //CR201(0xC9) |
| ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xCE, 0x38); //CR206(0xCE) |
| DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO" pDevice->byBBPreEDRSSI -67, -68,..\n"); |
| } |
| break; |
| |
| } |
| |
| } |
| |