|  | /* | 
|  | * 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 | 
|  | *      BBvCaculateParameter   - Caculate 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: Caculate 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 | 
|  | BBvCaculateParameter ( | 
|  | PSDevice pDevice, | 
|  | unsigned int cbFrameLength, | 
|  | WORD wRate, | 
|  | BYTE byPacketType, | 
|  | PWORD pwPhyLen, | 
|  | PBYTE pbyPhySrv, | 
|  | PBYTE pbyPhySgn | 
|  | ) | 
|  | { | 
|  | unsigned int cbBitCount; | 
|  | unsigned int cbUsCount = 0; | 
|  | unsigned int cbTmp; | 
|  | BOOL bExtBit; | 
|  | BYTE byPreambleType = pDevice->byPreambleType; | 
|  | BOOL 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 (PSDevice pDevice, BYTE byAntennaMode) | 
|  | { | 
|  | //{{ RobertYu: 20041124, ABG Mode, VC1/VC2 define, make the ANT_A, ANT_B inverted | 
|  | /*if ( (pDevice->byRFType == RF_MAXIM2829) || | 
|  | (pDevice->byRFType == RF_UW2452) || | 
|  | (pDevice->byRFType == RF_AIROHA7230) ) { // RobertYu: 20041210, 20050104 | 
|  |  | 
|  | switch (byAntennaMode) { | 
|  | case ANT_TXA: | 
|  | byAntennaMode = ANT_TXB; | 
|  | break; | 
|  | case ANT_TXB: | 
|  | byAntennaMode = ANT_TXA; | 
|  | break; | 
|  | case ANT_RXA: | 
|  | byAntennaMode = ANT_RXB; | 
|  | break; | 
|  | case ANT_RXB: | 
|  | byAntennaMode = ANT_RXA; | 
|  | break; | 
|  | } | 
|  | }*/ | 
|  |  | 
|  | switch (byAntennaMode) { | 
|  | case ANT_TXA: | 
|  | break; | 
|  | 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 | 
|  | * | 
|  | */ | 
|  |  | 
|  | BOOL BBbVT3184Init(PSDevice 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 (PSDevice 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 (PSDevice pDevice) | 
|  | { | 
|  | BYTE      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 (PSDevice 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(PSDevice pDevice, BYTE byData) | 
|  | { | 
|  |  | 
|  | ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0xE7, byData); | 
|  |  | 
|  | // patch for 3253B0 Baseband with Cardbus module | 
|  | if (byData == pDevice->abyBBVGA[0]) { | 
|  | pDevice->byBBRxConf |= 0x20;//0010 0000 | 
|  | } else 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 (PSDevice 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 (PSDevice pDevice) | 
|  | { | 
|  | ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0c, 0x17);//CR12 | 
|  | ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0D, 0xB9);//CR13 | 
|  | } | 
|  |  | 
|  | void | 
|  | BBvExitDeepSleep (PSDevice pDevice) | 
|  | { | 
|  | ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0C, 0x00);//CR12 | 
|  | ControlvWriteByte(pDevice, MESSAGE_REQUEST_BBREG, 0x0D, 0x01);//CR13 | 
|  | } | 
|  |  | 
|  |  | 
|  | static unsigned long s_ulGetLowSQ3(PSDevice 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(PSDevice 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 (PSDevice 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 (PSDevice pDevice, BYTE byRxRate, BYTE 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(void *hDeviceContext) | 
|  | { | 
|  | PSDevice        pDevice = (PSDevice)hDeviceContext; | 
|  |  | 
|  | 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); | 
|  | return; | 
|  | } | 
|  |  | 
|  |  | 
|  | /*+ | 
|  | * | 
|  | * Description: | 
|  | *  Timer for SQ3 antenna diversity | 
|  | * | 
|  | * Parameters: | 
|  | *  In: | 
|  | *      pvSysSpec1 | 
|  | *      hDeviceContext - Pointer to the adapter | 
|  | *      pvSysSpec2 | 
|  | *      pvSysSpec3 | 
|  | *  Out: | 
|  | *      none | 
|  | * | 
|  | * Return Value: none | 
|  | * | 
|  | -*/ | 
|  |  | 
|  | void TimerSQ3Tmax3CallBack(void *hDeviceContext) | 
|  | { | 
|  | PSDevice        pDevice = (PSDevice)hDeviceContext; | 
|  |  | 
|  | 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); | 
|  | return; | 
|  | } | 
|  |  | 
|  | void | 
|  | BBvUpdatePreEDThreshold( | 
|  | PSDevice    pDevice, | 
|  | BOOL        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; | 
|  |  | 
|  | } | 
|  |  | 
|  | } | 
|  |  |