2013-05-08 21:45:39 +00:00
/******************************************************************************
*
* Copyright ( c ) 2007 - 2011 Realtek Corporation . All rights reserved .
2013-05-19 04:28:07 +00:00
*
2013-05-08 21:45:39 +00:00
* This program is free software ; you can redistribute it and / or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation .
*
* 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 , USA
*
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-07-10 18:25:07 +00:00
/* */
/* include files */
/* */
2013-05-08 21:45:39 +00:00
# include "odm_precomp.h"
2013-06-03 19:52:18 +00:00
static const u2Byte dB_Invert_Table [ 8 ] [ 12 ] = {
{ 1 , 1 , 1 , 2 , 2 , 2 , 2 , 3 , 3 , 3 , 4 , 4 } ,
{ 4 , 5 , 6 , 6 , 7 , 8 , 9 , 10 , 11 , 13 , 14 , 16 } ,
{ 18 , 20 , 22 , 25 , 28 , 32 , 35 , 40 , 45 , 50 , 56 , 63 } ,
{ 71 , 79 , 89 , 100 , 112 , 126 , 141 , 158 , 178 , 200 , 224 , 251 } ,
{ 282 , 316 , 355 , 398 , 447 , 501 , 562 , 631 , 708 , 794 , 891 , 1000 } ,
{ 1122 , 1259 , 1413 , 1585 , 1778 , 1995 , 2239 , 2512 , 2818 , 3162 , 3548 , 3981 } ,
{ 4467 , 5012 , 5623 , 6310 , 7079 , 7943 , 8913 , 10000 , 11220 , 12589 , 14125 , 15849 } ,
{ 17783 , 19953 , 22387 , 25119 , 28184 , 31623 , 35481 , 39811 , 44668 , 50119 , 56234 , 65535 }
} ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* avoid to warn in FreeBSD ==> To DO modify */
2013-06-03 19:52:18 +00:00
static u4Byte EDCAParam [ HT_IOT_PEER_MAX ] [ 3 ] =
2013-07-10 18:25:07 +00:00
{ /* UL DL */
{ 0x5ea42b , 0x5ea42b , 0x5ea42b } , /* 0:unknown AP */
{ 0xa44f , 0x5ea44f , 0x5e431c } , /* 1:realtek AP */
{ 0x5ea42b , 0x5ea42b , 0x5ea42b } , /* 2:unknown AP => realtek_92SE */
{ 0x5ea32b , 0x5ea42b , 0x5e4322 } , /* 3:broadcom AP */
{ 0x5ea422 , 0x00a44f , 0x00a44f } , /* 4:ralink AP */
{ 0x5ea322 , 0x00a630 , 0x00a44f } , /* 5:atheros AP */
{ 0x5e4322 , 0x5e4322 , 0x5e4322 } , /* 6:cisco AP */
{ 0x5ea44f , 0x00a44f , 0x5ea42b } , /* 8:marvell AP */
{ 0x5ea42b , 0x5ea42b , 0x5ea42b } , /* 10:unknown AP=> 92U AP */
{ 0x5ea42b , 0xa630 , 0x5e431c } , /* 11:airgocap AP */
2013-05-08 21:45:39 +00:00
} ;
2013-06-03 19:52:18 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* Global var */
/* */
2013-05-08 21:45:39 +00:00
u4Byte OFDMSwingTable [ OFDM_TABLE_SIZE_92D ] = {
2013-07-10 18:25:07 +00:00
0x7f8001fe , /* 0, +6.0dB */
0x788001e2 , /* 1, +5.5dB */
0x71c001c7 , /* 2, +5.0dB */
0x6b8001ae , /* 3, +4.5dB */
0x65400195 , /* 4, +4.0dB */
0x5fc0017f , /* 5, +3.5dB */
0x5a400169 , /* 6, +3.0dB */
0x55400155 , /* 7, +2.5dB */
0x50800142 , /* 8, +2.0dB */
0x4c000130 , /* 9, +1.5dB */
0x47c0011f , /* 10, +1.0dB */
0x43c0010f , /* 11, +0.5dB */
0x40000100 , /* 12, +0dB */
0x3c8000f2 , /* 13, -0.5dB */
0x390000e4 , /* 14, -1.0dB */
0x35c000d7 , /* 15, -1.5dB */
0x32c000cb , /* 16, -2.0dB */
0x300000c0 , /* 17, -2.5dB */
0x2d4000b5 , /* 18, -3.0dB */
0x2ac000ab , /* 19, -3.5dB */
0x288000a2 , /* 20, -4.0dB */
0x26000098 , /* 21, -4.5dB */
0x24000090 , /* 22, -5.0dB */
0x22000088 , /* 23, -5.5dB */
0x20000080 , /* 24, -6.0dB */
0x1e400079 , /* 25, -6.5dB */
0x1c800072 , /* 26, -7.0dB */
0x1b00006c , /* 27. -7.5dB */
0x19800066 , /* 28, -8.0dB */
0x18000060 , /* 29, -8.5dB */
0x16c0005b , /* 30, -9.0dB */
0x15800056 , /* 31, -9.5dB */
0x14400051 , /* 32, -10.0dB */
0x1300004c , /* 33, -10.5dB */
0x12000048 , /* 34, -11.0dB */
0x11000044 , /* 35, -11.5dB */
0x10000040 , /* 36, -12.0dB */
0x0f00003c , /* 37, -12.5dB */
0x0e400039 , /* 38, -13.0dB */
0x0d800036 , /* 39, -13.5dB */
0x0cc00033 , /* 40, -14.0dB */
0x0c000030 , /* 41, -14.5dB */
0x0b40002d , /* 42, -15.0dB */
2013-05-08 21:45:39 +00:00
} ;
u1Byte CCKSwingTable_Ch1_Ch13 [ CCK_TABLE_SIZE ] [ 8 ] = {
2013-07-10 18:25:07 +00:00
{ 0x36 , 0x35 , 0x2e , 0x25 , 0x1c , 0x12 , 0x09 , 0x04 } , /* 0, +0dB */
{ 0x33 , 0x32 , 0x2b , 0x23 , 0x1a , 0x11 , 0x08 , 0x04 } , /* 1, -0.5dB */
{ 0x30 , 0x2f , 0x29 , 0x21 , 0x19 , 0x10 , 0x08 , 0x03 } , /* 2, -1.0dB */
{ 0x2d , 0x2d , 0x27 , 0x1f , 0x18 , 0x0f , 0x08 , 0x03 } , /* 3, -1.5dB */
{ 0x2b , 0x2a , 0x25 , 0x1e , 0x16 , 0x0e , 0x07 , 0x03 } , /* 4, -2.0dB */
{ 0x28 , 0x28 , 0x22 , 0x1c , 0x15 , 0x0d , 0x07 , 0x03 } , /* 5, -2.5dB */
{ 0x26 , 0x25 , 0x21 , 0x1b , 0x14 , 0x0d , 0x06 , 0x03 } , /* 6, -3.0dB */
{ 0x24 , 0x23 , 0x1f , 0x19 , 0x13 , 0x0c , 0x06 , 0x03 } , /* 7, -3.5dB */
{ 0x22 , 0x21 , 0x1d , 0x18 , 0x11 , 0x0b , 0x06 , 0x02 } , /* 8, -4.0dB */
{ 0x20 , 0x20 , 0x1b , 0x16 , 0x11 , 0x08 , 0x05 , 0x02 } , /* 9, -4.5dB */
{ 0x1f , 0x1e , 0x1a , 0x15 , 0x10 , 0x0a , 0x05 , 0x02 } , /* 10, -5.0dB */
{ 0x1d , 0x1c , 0x18 , 0x14 , 0x0f , 0x0a , 0x05 , 0x02 } , /* 11, -5.5dB */
{ 0x1b , 0x1a , 0x17 , 0x13 , 0x0e , 0x09 , 0x04 , 0x02 } , /* 12, -6.0dB */
{ 0x1a , 0x19 , 0x16 , 0x12 , 0x0d , 0x09 , 0x04 , 0x02 } , /* 13, -6.5dB */
{ 0x18 , 0x17 , 0x15 , 0x11 , 0x0c , 0x08 , 0x04 , 0x02 } , /* 14, -7.0dB */
{ 0x17 , 0x16 , 0x13 , 0x10 , 0x0c , 0x08 , 0x04 , 0x02 } , /* 15, -7.5dB */
{ 0x16 , 0x15 , 0x12 , 0x0f , 0x0b , 0x07 , 0x04 , 0x01 } , /* 16, -8.0dB */
{ 0x14 , 0x14 , 0x11 , 0x0e , 0x0b , 0x07 , 0x03 , 0x02 } , /* 17, -8.5dB */
{ 0x13 , 0x13 , 0x10 , 0x0d , 0x0a , 0x06 , 0x03 , 0x01 } , /* 18, -9.0dB */
{ 0x12 , 0x12 , 0x0f , 0x0c , 0x09 , 0x06 , 0x03 , 0x01 } , /* 19, -9.5dB */
{ 0x11 , 0x11 , 0x0f , 0x0c , 0x09 , 0x06 , 0x03 , 0x01 } , /* 20, -10.0dB */
{ 0x10 , 0x10 , 0x0e , 0x0b , 0x08 , 0x05 , 0x03 , 0x01 } , /* 21, -10.5dB */
{ 0x0f , 0x0f , 0x0d , 0x0b , 0x08 , 0x05 , 0x03 , 0x01 } , /* 22, -11.0dB */
{ 0x0e , 0x0e , 0x0c , 0x0a , 0x08 , 0x05 , 0x02 , 0x01 } , /* 23, -11.5dB */
{ 0x0d , 0x0d , 0x0c , 0x0a , 0x07 , 0x05 , 0x02 , 0x01 } , /* 24, -12.0dB */
{ 0x0d , 0x0c , 0x0b , 0x09 , 0x07 , 0x04 , 0x02 , 0x01 } , /* 25, -12.5dB */
{ 0x0c , 0x0c , 0x0a , 0x09 , 0x06 , 0x04 , 0x02 , 0x01 } , /* 26, -13.0dB */
{ 0x0b , 0x0b , 0x0a , 0x08 , 0x06 , 0x04 , 0x02 , 0x01 } , /* 27, -13.5dB */
{ 0x0b , 0x0a , 0x09 , 0x08 , 0x06 , 0x04 , 0x02 , 0x01 } , /* 28, -14.0dB */
{ 0x0a , 0x0a , 0x09 , 0x07 , 0x05 , 0x03 , 0x02 , 0x01 } , /* 29, -14.5dB */
{ 0x0a , 0x09 , 0x08 , 0x07 , 0x05 , 0x03 , 0x02 , 0x01 } , /* 30, -15.0dB */
{ 0x09 , 0x09 , 0x08 , 0x06 , 0x05 , 0x03 , 0x01 , 0x01 } , /* 31, -15.5dB */
{ 0x09 , 0x08 , 0x07 , 0x06 , 0x04 , 0x03 , 0x01 , 0x01 } /* 32, -16.0dB */
2013-05-08 21:45:39 +00:00
} ;
u1Byte CCKSwingTable_Ch14 [ CCK_TABLE_SIZE ] [ 8 ] = {
2013-07-10 18:25:07 +00:00
{ 0x36 , 0x35 , 0x2e , 0x1b , 0x00 , 0x00 , 0x00 , 0x00 } , /* 0, +0dB */
{ 0x33 , 0x32 , 0x2b , 0x19 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 1, -0.5dB */
{ 0x30 , 0x2f , 0x29 , 0x18 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 2, -1.0dB */
{ 0x2d , 0x2d , 0x17 , 0x17 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 3, -1.5dB */
{ 0x2b , 0x2a , 0x25 , 0x15 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 4, -2.0dB */
{ 0x28 , 0x28 , 0x24 , 0x14 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 5, -2.5dB */
{ 0x26 , 0x25 , 0x21 , 0x13 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 6, -3.0dB */
{ 0x24 , 0x23 , 0x1f , 0x12 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 7, -3.5dB */
{ 0x22 , 0x21 , 0x1d , 0x11 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 8, -4.0dB */
{ 0x20 , 0x20 , 0x1b , 0x10 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 9, -4.5dB */
{ 0x1f , 0x1e , 0x1a , 0x0f , 0x00 , 0x00 , 0x00 , 0x00 } , /* 10, -5.0dB */
{ 0x1d , 0x1c , 0x18 , 0x0e , 0x00 , 0x00 , 0x00 , 0x00 } , /* 11, -5.5dB */
{ 0x1b , 0x1a , 0x17 , 0x0e , 0x00 , 0x00 , 0x00 , 0x00 } , /* 12, -6.0dB */
{ 0x1a , 0x19 , 0x16 , 0x0d , 0x00 , 0x00 , 0x00 , 0x00 } , /* 13, -6.5dB */
{ 0x18 , 0x17 , 0x15 , 0x0c , 0x00 , 0x00 , 0x00 , 0x00 } , /* 14, -7.0dB */
{ 0x17 , 0x16 , 0x13 , 0x0b , 0x00 , 0x00 , 0x00 , 0x00 } , /* 15, -7.5dB */
{ 0x16 , 0x15 , 0x12 , 0x0b , 0x00 , 0x00 , 0x00 , 0x00 } , /* 16, -8.0dB */
{ 0x14 , 0x14 , 0x11 , 0x0a , 0x00 , 0x00 , 0x00 , 0x00 } , /* 17, -8.5dB */
{ 0x13 , 0x13 , 0x10 , 0x0a , 0x00 , 0x00 , 0x00 , 0x00 } , /* 18, -9.0dB */
{ 0x12 , 0x12 , 0x0f , 0x09 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 19, -9.5dB */
{ 0x11 , 0x11 , 0x0f , 0x09 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 20, -10.0dB */
{ 0x10 , 0x10 , 0x0e , 0x08 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 21, -10.5dB */
{ 0x0f , 0x0f , 0x0d , 0x08 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 22, -11.0dB */
{ 0x0e , 0x0e , 0x0c , 0x07 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 23, -11.5dB */
{ 0x0d , 0x0d , 0x0c , 0x07 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 24, -12.0dB */
{ 0x0d , 0x0c , 0x0b , 0x06 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 25, -12.5dB */
{ 0x0c , 0x0c , 0x0a , 0x06 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 26, -13.0dB */
{ 0x0b , 0x0b , 0x0a , 0x06 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 27, -13.5dB */
{ 0x0b , 0x0a , 0x09 , 0x05 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 28, -14.0dB */
{ 0x0a , 0x0a , 0x09 , 0x05 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 29, -14.5dB */
{ 0x0a , 0x09 , 0x08 , 0x05 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 30, -15.0dB */
{ 0x09 , 0x09 , 0x08 , 0x05 , 0x00 , 0x00 , 0x00 , 0x00 } , /* 31, -15.5dB */
{ 0x09 , 0x08 , 0x07 , 0x04 , 0x00 , 0x00 , 0x00 , 0x00 } /* 32, -16.0dB */
2013-05-19 04:28:07 +00:00
} ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* Local Function predefine. */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* START------------COMMON INFO RELATED--------------- */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CommonInfoSelfInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CommonInfoSelfUpdate (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoInit_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoHook_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoUpdate_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-07-10 18:25:07 +00:00
/* END------------COMMON INFO RELATED--------------- */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* START---------------DIG--------------------------- */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_FalseAlarmCounterStatistics (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DIGInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DIG (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CCKPacketDetectionThresh (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-07-10 18:25:07 +00:00
/* END---------------DIG--------------------------- */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* START-------BB POWER SAVE----------------------- */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicBBPowerSavingInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicBBPowerSaving (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_1R_CCA (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-07-10 18:25:07 +00:00
/* END---------BB POWER SAVE----------------------- */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskAPADSL (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerRestorePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerNIC (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerSavePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerWritePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Value ) ;
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPower_92C (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPower (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SwAntDivInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SwAntDivInit_NIC (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SwAntDivChkAntSwitch (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Step
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SwAntDivChkAntSwitchNIC (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Step
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void odm_SwAntDivChkAntSwitchCallback ( void * FunctionContext ) ;
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_GlobalAdapterCheck (
2013-05-25 20:45:50 +00:00
void
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMask (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_TXPowerTrackingCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RateAdaptiveMaskInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingThermalMeterInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_EdcaTurboCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_EdcaTurboInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_EdcaTurboCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:28:07 +00:00
# define RxDefaultAnt1 0x65a9
2013-05-08 21:45:39 +00:00
# define RxDefaultAnt2 0x569a
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_InitHybridAntDiv (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:48:10 +00:00
bool
2013-05-08 21:45:39 +00:00
odm_StaDefAntSel (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-27 03:51:56 +00:00
u4Byte OFDM_Ant1_Cnt ,
u4Byte OFDM_Ant2_Cnt ,
u4Byte CCK_Ant1_Cnt ,
u4Byte CCK_Ant2_Cnt ,
u1Byte * pDefAnt
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SetRxIdleAnt (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Ant ,
2013-05-27 03:51:56 +00:00
bool bDualPath
2013-05-08 21:45:39 +00:00
) ;
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_HwAntDiv (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
) ;
2013-07-10 18:25:07 +00:00
/* 3 Export Interface */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* 2011/09/21 MH Add to describe different team necessary resource allocate?? */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_DMInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
# if (FPGA_TWO_MAC_VERIFICATION == 1)
odm_RateAdaptiveMaskInit ( pDM_Odm ) ;
return ;
# endif
2013-07-10 18:25:07 +00:00
/* 2012.05.03 Luke: For all IC series */
2013-05-08 21:45:39 +00:00
odm_CommonInfoSelfInit ( pDM_Odm ) ;
odm_CmnInfoInit_Debug ( pDM_Odm ) ;
odm_DIGInit ( pDM_Odm ) ;
odm_RateAdaptiveMaskInit ( pDM_Odm ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ODM_IC_11AC_SERIES )
2013-05-08 21:45:39 +00:00
{
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportICType & ODM_IC_11N_SERIES )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
odm_PrimaryCCA_Init ( pDM_Odm ) ; /* Gary */
2013-05-08 21:45:39 +00:00
odm_DynamicBBPowerSavingInit ( pDM_Odm ) ;
odm_DynamicTxPowerInit ( pDM_Odm ) ;
odm_TXPowerTrackingInit ( pDM_Odm ) ;
ODM_EdcaTurboInit ( pDM_Odm ) ;
ODM_RAInfo_Init_all ( pDM_Odm ) ;
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > AntDivType = = CG_TRX_HW_ANTDIV ) | |
2013-05-19 04:28:07 +00:00
( pDM_Odm - > AntDivType = = CGCS_RX_HW_ANTDIV ) | |
2013-05-08 21:45:39 +00:00
( pDM_Odm - > AntDivType = = CG_TRX_SMART_ANTDIV ) )
{
odm_InitHybridAntDiv ( pDM_Odm ) ;
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > AntDivType = = CGCS_RX_SW_ANTDIV )
2013-05-08 21:45:39 +00:00
{
odm_SwAntDivInit ( pDM_Odm ) ;
}
}
}
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/20 MH This is the entry pointer for all team to execute HW out source DM. */
/* You can not add any dummy function here, be care, you can only use DM structure */
/* to perform any new ODM_DM. */
/* */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_DMWatchdog (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* 2012.05.03 Luke: For all IC series */
2013-05-08 21:45:39 +00:00
odm_GlobalAdapterCheck ( ) ;
odm_CmnInfoHook_Debug ( pDM_Odm ) ;
odm_CmnInfoUpdate_Debug ( pDM_Odm ) ;
2013-05-19 04:28:07 +00:00
odm_CommonInfoSelfUpdate ( pDM_Odm ) ;
odm_FalseAlarmCounterStatistics ( pDM_Odm ) ;
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheck ( pDM_Odm ) ;
2013-07-10 18:25:07 +00:00
/* For CE Platform(SPRD or Tablet) */
/* 8723A or 8189ES platform */
/* NeilChen--2012--08--24-- */
/* Fix Leave LPS issue */
if ( ( pDM_Odm - > Adapter - > pwrctrlpriv . pwr_mode ! = PS_MODE_ACTIVE ) & & /* in LPS mode */
2013-05-19 04:28:07 +00:00
(
2013-05-08 21:45:39 +00:00
( pDM_Odm - > SupportICType & ( ODM_RTL8723A ) ) | |
2013-05-19 04:28:07 +00:00
( pDM_Odm - > SupportICType & ( ODM_RTL8188E ) & & ( ( pDM_Odm - > SupportInterface = = ODM_ITRF_SDIO ) ) )
2013-07-10 18:25:07 +00:00
/* pDM_Odm->SupportInterface == ODM_ITRF_SDIO)) */
2013-05-19 04:28:07 +00:00
)
2013-05-08 21:45:39 +00:00
)
{
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " ----Step1: odm_DIG is in LPS mode \n " ) ) ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " ---Step2: 8723AS is in LPS mode \n " ) ) ;
odm_DIGbyRSSI_LPS ( pDM_Odm ) ;
2013-05-19 04:28:07 +00:00
}
else
2013-05-08 21:45:39 +00:00
{
odm_DIG ( pDM_Odm ) ;
}
odm_CCKPacketDetectionThresh ( pDM_Odm ) ;
2013-05-27 22:32:24 +00:00
if ( * ( pDM_Odm - > pbPowerSaving ) = = true )
2013-05-08 21:45:39 +00:00
return ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMask ( pDM_Odm ) ;
2013-05-19 04:28:07 +00:00
odm_DynamicBBPowerSaving ( pDM_Odm ) ;
odm_DynamicPrimaryCCA ( pDM_Odm ) ;
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > AntDivType = = CG_TRX_HW_ANTDIV ) | |
2013-05-19 04:28:07 +00:00
( pDM_Odm - > AntDivType = = CGCS_RX_HW_ANTDIV ) | |
2013-05-08 21:45:39 +00:00
( pDM_Odm - > AntDivType = = CG_TRX_SMART_ANTDIV ) )
{
odm_HwAntDiv ( pDM_Odm ) ;
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > AntDivType = = CGCS_RX_SW_ANTDIV )
2013-05-08 21:45:39 +00:00
{
odm_SwAntDivChkAntSwitch ( pDM_Odm , SWAW_STEP_PEAK ) ;
}
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ODM_IC_11AC_SERIES )
2013-05-08 21:45:39 +00:00
{
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportICType & ODM_IC_11N_SERIES )
2013-05-08 21:45:39 +00:00
{
ODM_TXPowerTrackingCheck ( pDM_Odm ) ;
odm_EdcaTurboCheck ( pDM_Odm ) ;
odm_DynamicTxPower ( pDM_Odm ) ;
}
odm_dtc ( pDM_Odm ) ;
}
2013-07-10 18:25:07 +00:00
/* */
/* Init /.. Fixed HW value. Only init time. */
/* */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_CmnInfoInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
enum odm_common_info_def CmnInfo ,
2013-05-25 20:45:50 +00:00
u4Byte Value
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* This section is used for init value */
2013-05-08 21:45:39 +00:00
switch ( CmnInfo )
{
2013-07-10 18:25:07 +00:00
/* */
/* Fixed ODM value. */
/* */
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_ABILITY :
pDM_Odm - > SupportAbility = ( u4Byte ) Value ;
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_PLATFORM :
pDM_Odm - > SupportPlatform = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_INTERFACE :
pDM_Odm - > SupportInterface = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_MP_TEST_CHIP :
pDM_Odm - > bIsMPChip = ( u1Byte ) Value ;
break ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_IC_TYPE :
pDM_Odm - > SupportICType = Value ;
break ;
case ODM_CMNINFO_CUT_VER :
pDM_Odm - > CutVersion = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_FAB_VER :
pDM_Odm - > FabVersion = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_RF_TYPE :
pDM_Odm - > RFType = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_RF_ANTENNA_TYPE :
pDM_Odm - > AntDivType = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_BOARD_TYPE :
pDM_Odm - > BoardType = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_EXT_LNA :
pDM_Odm - > ExtLNA = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_EXT_PA :
pDM_Odm - > ExtPA = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_EXT_TRSW :
pDM_Odm - > ExtTRSW = ( u1Byte ) Value ;
break ;
2013-05-19 04:28:07 +00:00
case ODM_CMNINFO_PATCH_ID :
2013-05-08 21:45:39 +00:00
pDM_Odm - > PatchID = ( u1Byte ) Value ;
break ;
2013-05-19 04:28:07 +00:00
case ODM_CMNINFO_BINHCT_TEST :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bInHctTest = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
2013-05-19 04:28:07 +00:00
case ODM_CMNINFO_BWIFI_TEST :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bWIFITest = ( bool ) Value ;
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_SMART_CONCURRENT :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bDualMacSmartConcurrent = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* To remove the compiler warning, must add an empty default statement to handle the other values. */
2013-05-08 21:45:39 +00:00
default :
2013-07-10 18:25:07 +00:00
/* do nothing */
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* */
/* Tx power tracking BB swing table. */
/* The base index = 12. +((12-n)/2)dB 13~?? = decrease tx pwr by -((n-12)/2)dB */
/* */
pDM_Odm - > BbSwingIdxOfdm = 12 ; /* Set defalut value as index 12. */
2013-05-19 04:28:07 +00:00
pDM_Odm - > BbSwingIdxOfdmCurrent = 12 ;
2013-05-27 22:32:24 +00:00
pDM_Odm - > BbSwingFlagOfdm = false ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_CmnInfoHook (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
enum odm_common_info_def CmnInfo ,
void * pValue
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
/* Hook call by reference pointer. */
/* */
2013-05-08 21:45:39 +00:00
switch ( CmnInfo )
{
2013-07-10 18:25:07 +00:00
/* */
/* Dynamic call by reference pointer. */
/* */
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_MAC_PHY_MODE :
pDM_Odm - > pMacPhyMode = ( u1Byte * ) pValue ;
break ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_TX_UNI :
pDM_Odm - > pNumTxBytesUnicast = ( u8Byte * ) pValue ;
break ;
case ODM_CMNINFO_RX_UNI :
pDM_Odm - > pNumRxBytesUnicast = ( u8Byte * ) pValue ;
break ;
case ODM_CMNINFO_WM_MODE :
pDM_Odm - > pWirelessMode = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_BAND :
pDM_Odm - > pBandType = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_SEC_CHNL_OFFSET :
pDM_Odm - > pSecChOffset = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_SEC_MODE :
pDM_Odm - > pSecurity = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_BW :
pDM_Odm - > pBandWidth = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_CHNL :
pDM_Odm - > pChannel = ( u1Byte * ) pValue ;
break ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_DMSP_GET_VALUE :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbGetValueFromOtherMac = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_BUDDY_ADAPTOR :
2013-07-27 01:08:39 +00:00
pDM_Odm - > pBuddyAdapter = ( struct adapter * * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_DMSP_IS_MASTER :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbMasterOfDMSP = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_SCAN :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbScanInProcess = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_POWER_SAVING :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbPowerSaving = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_ONE_PATH_CCA :
pDM_Odm - > pOnePathCCA = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_DRV_STOP :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbDriverStopped = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_PNP_IN :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbDriverIsGoingToPnpSetPowerSleep = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_INIT_ON :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pinit_adpt_in_progress = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_ANT_TEST :
pDM_Odm - > pAntennaTest = ( u1Byte * ) pValue ;
break ;
case ODM_CMNINFO_NET_CLOSED :
2013-05-19 04:48:10 +00:00
pDM_Odm - > pbNet_closed = ( bool * ) pValue ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_MP_MODE :
pDM_Odm - > mp_mode = ( u1Byte * ) pValue ;
break ;
2013-07-10 18:25:07 +00:00
/* case ODM_CMNINFO_BT_COEXIST: */
/* pDM_Odm->BTCoexist = (bool *)pValue; */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* case ODM_CMNINFO_STA_STATUS: */
2013-07-26 20:25:06 +00:00
/* pDM_Odm->pODM_StaInfo[] = (struct sta_info *)pValue; */
2013-07-10 18:25:07 +00:00
/* break; */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* case ODM_CMNINFO_PHY_STATUS: */
/* pDM_Odm->pPhyInfo = (ODM_PHY_INFO *)pValue; */
/* break; */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* case ODM_CMNINFO_MAC_STATUS: */
/* pDM_Odm->pMacInfo = (ODM_MAC_INFO *)pValue; */
/* break; */
/* To remove the compiler warning, must add an empty default statement to handle the other values. */
2013-05-08 21:45:39 +00:00
default :
2013-07-10 18:25:07 +00:00
/* do nothing */
2013-05-08 21:45:39 +00:00
break ;
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_CmnInfoPtrArrayHook (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
enum odm_common_info_def CmnInfo ,
2013-05-25 20:45:50 +00:00
u2Byte Index ,
2013-07-26 16:20:42 +00:00
void * pValue
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
/* Hook call by reference pointer. */
/* */
2013-05-08 21:45:39 +00:00
switch ( CmnInfo )
{
2013-07-10 18:25:07 +00:00
/* */
/* Dynamic call by reference pointer. */
/* */
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_STA_STATUS :
2013-07-26 20:25:06 +00:00
pDM_Odm - > pODM_StaInfo [ Index ] = ( struct sta_info * ) pValue ;
2013-05-19 04:28:07 +00:00
break ;
2013-07-10 18:25:07 +00:00
/* To remove the compiler warning, must add an empty default statement to handle the other values. */
2013-05-08 21:45:39 +00:00
default :
2013-07-10 18:25:07 +00:00
/* do nothing */
2013-05-08 21:45:39 +00:00
break ;
}
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* */
/* Update Band/CHannel/.. The values are dynamic but non-per-packet. */
/* */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_CmnInfoUpdate (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u4Byte CmnInfo ,
u8Byte Value
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
/* This init variable may be changed in run time. */
/* */
2013-05-08 21:45:39 +00:00
switch ( CmnInfo )
{
case ODM_CMNINFO_ABILITY :
pDM_Odm - > SupportAbility = ( u4Byte ) Value ;
break ;
case ODM_CMNINFO_RF_TYPE :
pDM_Odm - > RFType = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_WIFI_DIRECT :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bWIFI_Direct = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_WIFI_DISPLAY :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bWIFI_Display = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_LINK :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bLinked = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_RSSI_MIN :
pDM_Odm - > RSSI_Min = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_DBG_COMP :
pDM_Odm - > DebugComponents = Value ;
break ;
case ODM_CMNINFO_DBG_LEVEL :
pDM_Odm - > DebugLevel = ( u4Byte ) Value ;
break ;
case ODM_CMNINFO_RA_THRESHOLD_HIGH :
pDM_Odm - > RateAdaptive . HighRSSIThresh = ( u1Byte ) Value ;
break ;
case ODM_CMNINFO_RA_THRESHOLD_LOW :
pDM_Odm - > RateAdaptive . LowRSSIThresh = ( u1Byte ) Value ;
break ;
2013-05-09 04:04:25 +00:00
# if (BT_30_SUPPORT == 1)
2013-07-10 18:25:07 +00:00
/* The following is for BT HS mode and BT coexist mechanism. */
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_BT_DISABLED :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bBtDisabled = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_BT_OPERATION :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bBtHsOperation = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
case ODM_CMNINFO_BT_DIG :
pDM_Odm - > btHsDigVal = ( u1Byte ) Value ;
break ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_BT_BUSY :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bBtBusy = ( bool ) Value ;
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
case ODM_CMNINFO_BT_DISABLE_EDCA :
2013-05-19 04:48:10 +00:00
pDM_Odm - > bBtDisableEdcaTurbo = ( bool ) Value ;
2013-05-08 21:45:39 +00:00
break ;
# endif
}
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CommonInfoSelfInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-05-19 04:48:10 +00:00
pDM_Odm - > bCckHighPower = ( bool ) ODM_GetBBReg ( pDM_Odm , 0x824 , BIT9 ) ;
2013-05-08 21:45:39 +00:00
pDM_Odm - > RFPathRxEnable = ( u1Byte ) ODM_GetBBReg ( pDM_Odm , 0xc04 , 0x0F ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ( ODM_RTL8192C | ODM_RTL8192D ) )
2013-05-08 21:45:39 +00:00
pDM_Odm - > AntDivType = CG_TRX_HW_ANTDIV ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ( ODM_RTL8723A ) )
2013-05-08 21:45:39 +00:00
pDM_Odm - > AntDivType = CGCS_RX_SW_ANTDIV ;
2013-05-19 04:28:07 +00:00
ODM_InitDebugSetting ( pDM_Odm ) ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CommonInfoSelfUpdate (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
u1Byte EntryCnt = 0 ;
u1Byte i ;
2013-07-26 20:25:06 +00:00
struct sta_info * pEntry ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pBandWidth ) = = ODM_BW40M )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pSecChOffset ) = = 1 )
2013-05-08 21:45:39 +00:00
pDM_Odm - > ControlChannel = * ( pDM_Odm - > pChannel ) - 2 ;
2013-05-09 04:04:25 +00:00
else if ( * ( pDM_Odm - > pSecChOffset ) = = 2 )
2013-05-08 21:45:39 +00:00
pDM_Odm - > ControlChannel = * ( pDM_Odm - > pChannel ) + 2 ;
}
else
pDM_Odm - > ControlChannel = * ( pDM_Odm - > pChannel ) ;
for ( i = 0 ; i < ODM_ASSOCIATE_ENTRY_NUM ; i + + )
{
pEntry = pDM_Odm - > pODM_StaInfo [ i ] ;
2013-05-09 04:04:25 +00:00
if ( IS_STA_VALID ( pEntry ) )
2013-05-08 21:45:39 +00:00
EntryCnt + + ;
}
2013-05-09 04:04:25 +00:00
if ( EntryCnt = = 1 )
2013-05-27 22:32:24 +00:00
pDM_Odm - > bOneEntryOnly = true ;
2013-05-08 21:45:39 +00:00
else
2013-05-27 22:32:24 +00:00
pDM_Odm - > bOneEntryOnly = false ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoInit_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " odm_CmnInfoInit_Debug==> \n " ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " SupportPlatform=%d \n " , pDM_Odm - > SupportPlatform ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " SupportAbility=0x%x \n " , pDM_Odm - > SupportAbility ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " SupportInterface=%d \n " , pDM_Odm - > SupportInterface ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " SupportICType=0x%x \n " , pDM_Odm - > SupportICType ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " CutVersion=%d \n " , pDM_Odm - > CutVersion ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " FabVersion=%d \n " , pDM_Odm - > FabVersion ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " RFType=%d \n " , pDM_Odm - > RFType ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " BoardType=%d \n " , pDM_Odm - > BoardType ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " ExtLNA=%d \n " , pDM_Odm - > ExtLNA ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " ExtPA=%d \n " , pDM_Odm - > ExtPA ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " ExtTRSW=%d \n " , pDM_Odm - > ExtTRSW ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " PatchID=%d \n " , pDM_Odm - > PatchID ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bInHctTest=%d \n " , pDM_Odm - > bInHctTest ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bWIFITest=%d \n " , pDM_Odm - > bWIFITest ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bDualMacSmartConcurrent=%d \n " , pDM_Odm - > bDualMacSmartConcurrent ) ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoHook_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " odm_CmnInfoHook_Debug==> \n " ) ) ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pNumTxBytesUnicast=%llu \n " , * ( pDM_Odm - > pNumTxBytesUnicast ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pNumRxBytesUnicast=%llu \n " , * ( pDM_Odm - > pNumRxBytesUnicast ) ) ) ;
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pWirelessMode=0x%x \n " , * ( pDM_Odm - > pWirelessMode ) ) ) ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pSecChOffset=%d \n " , * ( pDM_Odm - > pSecChOffset ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pSecurity=%d \n " , * ( pDM_Odm - > pSecurity ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pBandWidth=%d \n " , * ( pDM_Odm - > pBandWidth ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pChannel=%d \n " , * ( pDM_Odm - > pChannel ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pbScanInProcess=%d \n " , * ( pDM_Odm - > pbScanInProcess ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pbPowerSaving=%d \n " , * ( pDM_Odm - > pbPowerSaving ) ) ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportPlatform & ( ODM_AP | ODM_ADSL ) )
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " pOnePathCCA=%d \n " , * ( pDM_Odm - > pOnePathCCA ) ) ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CmnInfoUpdate_Debug (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " odm_CmnInfoUpdate_Debug==> \n " ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bWIFI_Direct=%d \n " , pDM_Odm - > bWIFI_Direct ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bWIFI_Display=%d \n " , pDM_Odm - > bWIFI_Display ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " bLinked=%d \n " , pDM_Odm - > bLinked ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_COMMON , ODM_DBG_LOUD , ( " RSSI_Min=%d \n " , pDM_Odm - > RSSI_Min ) ) ;
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 DIG */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
/*-----------------------------------------------------------------------------
* Function : odm_DIGInit ( )
*
* Overview : Set DIG scheme init value .
*
* Input : NONE
*
* Output : NONE
*
* Return : NONE
*
* Revised History :
* When Who Remark
*
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2013-06-03 19:52:18 +00:00
static void ODM_ChangeDynamicInitGainThresh (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u4Byte DM_Type ,
u4Byte DM_Value
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
2013-05-08 21:45:39 +00:00
2013-07-26 16:20:42 +00:00
if ( DM_Type = = DM_DIG_THRESH_HIGH )
2013-05-08 21:45:39 +00:00
{
2013-05-19 04:28:07 +00:00
pDM_DigTable - > RssiHighThresh = DM_Value ;
2013-05-08 21:45:39 +00:00
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = DM_DIG_THRESH_LOW )
2013-05-08 21:45:39 +00:00
{
pDM_DigTable - > RssiLowThresh = DM_Value ;
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = RT_TYPE_ENABLE )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_DigTable - > Dig_Enable_Flag = true ;
2013-05-19 04:28:07 +00:00
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = RT_TYPE_DISABLE )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_DigTable - > Dig_Enable_Flag = false ;
2013-05-19 04:28:07 +00:00
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = RT_TYPE_BACKOFF )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( DM_Value > 30 )
2013-05-08 21:45:39 +00:00
DM_Value = 30 ;
pDM_DigTable - > BackoffVal = ( u1Byte ) DM_Value ;
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = RT_TYPE_RX_GAIN_MIN )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( DM_Value = = 0 )
2013-05-08 21:45:39 +00:00
DM_Value = 0x1 ;
pDM_DigTable - > rx_gain_range_min = ( u1Byte ) DM_Value ;
}
2013-07-26 16:20:42 +00:00
else if ( DM_Type = = RT_TYPE_RX_GAIN_MAX )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( DM_Value > 0x50 )
2013-05-08 21:45:39 +00:00
DM_Value = 0x50 ;
pDM_DigTable - > rx_gain_range_max = ( u1Byte ) DM_Value ;
}
} /* DM_ChangeDynamicInitGainThresh */
2013-06-03 19:52:18 +00:00
static int getIGIForDiff ( int value_IGI )
2013-05-08 21:45:39 +00:00
{
# define ONERCCA_LOW_TH 0x30
# define ONERCCA_LOW_DIFF 8
if ( value_IGI < ONERCCA_LOW_TH ) {
if ( ( ONERCCA_LOW_TH - value_IGI ) < ONERCCA_LOW_DIFF )
return ONERCCA_LOW_TH ;
else
return value_IGI + ONERCCA_LOW_DIFF ;
} else {
return value_IGI ;
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_Write_DIG (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte CurrentIGI
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " ODM_REG(IGI_A,pDM_Odm)=0x%x, ODM_BIT(IGI,pDM_Odm)=0x%x \n " ,
2013-05-08 21:45:39 +00:00
ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) ) ) ;
2013-07-10 18:25:07 +00:00
if ( pDM_DigTable - > CurIGValue ! = CurrentIGI ) /* if (pDM_DigTable->PreIGValue != CurrentIGI) */
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportPlatform & ( ODM_CE | ODM_MP ) )
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType ! = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_B , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportPlatform & ( ODM_AP | ODM_ADSL ) )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
switch ( * ( pDM_Odm - > pOnePathCCA ) )
2013-05-08 21:45:39 +00:00
{
case ODM_CCA_2R :
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType ! = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_B , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
break ;
case ODM_CCA_1R_A :
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType ! = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_B , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , getIGIForDiff ( CurrentIGI ) ) ;
break ;
case ODM_CCA_1R_B :
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , getIGIForDiff ( CurrentIGI ) ) ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType ! = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG ( IGI_B , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) , CurrentIGI ) ;
break ;
}
}
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " CurrentIGI(0x%02x). \n " , CurrentIGI ) ) ;
2013-07-10 18:25:07 +00:00
/* pDM_DigTable->PreIGValue = pDM_DigTable->CurIGValue; */
2013-05-08 21:45:39 +00:00
pDM_DigTable - > CurIGValue = CurrentIGI ;
}
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " ODM_Write_DIG():CurrentIGI=0x%x \n " , CurrentIGI ) ) ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* Add by Neil Chen to enable edcca to MP Platform */
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* Need LPS mode for CE platform --2012--08--24--- */
/* 8723AS/8189ES */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DIGbyRSSI_LPS (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter = pDM_Odm - > Adapter ;
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
struct false_alarm_stats * pFalseAlmCnt = & pDM_Odm - > FalseAlmCnt ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
u1Byte RSSI_Lower = DM_DIG_MIN_NIC ; /* 0x1E or 0x1C */
2013-05-27 22:32:24 +00:00
u1Byte bFwCurrentInPSMode = false ;
2013-05-08 21:45:39 +00:00
u1Byte CurrentIGI = pDM_Odm - > RSSI_Min ;
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportICType & ( ODM_RTL8723A | ODM_RTL8188E ) ) )
2013-05-08 21:45:39 +00:00
return ;
CurrentIGI = CurrentIGI + RSSI_OFFSET_DIG ;
2013-05-19 04:28:07 +00:00
bFwCurrentInPSMode = pAdapter - > pwrctrlpriv . bFwCurrentInPSMode ;
2013-07-10 18:25:07 +00:00
/* Using FW PS mode to make IGI */
2013-05-09 04:04:25 +00:00
if ( bFwCurrentInPSMode )
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " ---Neil---odm_DIG is in LPS mode \n " ) ) ;
2013-07-10 18:25:07 +00:00
/* Adjust by FA in LPS MODE */
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH2_LPS )
2013-05-08 21:45:39 +00:00
CurrentIGI = CurrentIGI + 2 ;
else if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH1_LPS )
CurrentIGI = CurrentIGI + 1 ;
2013-05-09 04:04:25 +00:00
else if ( pFalseAlmCnt - > Cnt_all < DM_DIG_FA_TH0_LPS )
2013-05-19 04:28:07 +00:00
CurrentIGI = CurrentIGI - 1 ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:28:07 +00:00
else
2013-05-08 21:45:39 +00:00
{
CurrentIGI = RSSI_Lower ;
}
2013-07-10 18:25:07 +00:00
/* Lower bound checking */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* RSSI Lower bound check */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > RSSI_Min - 10 ) > DM_DIG_MIN_NIC )
2013-05-08 21:45:39 +00:00
RSSI_Lower = ( pDM_Odm - > RSSI_Min - 10 ) ;
else
RSSI_Lower = DM_DIG_MIN_NIC ;
2013-07-10 18:25:07 +00:00
/* Upper and Lower Bound checking */
2013-05-09 04:04:25 +00:00
if ( CurrentIGI > DM_DIG_MAX_NIC )
2013-05-19 04:28:07 +00:00
CurrentIGI = DM_DIG_MAX_NIC ;
2013-05-09 04:04:25 +00:00
else if ( CurrentIGI < RSSI_Lower )
2013-05-08 21:45:39 +00:00
CurrentIGI = RSSI_Lower ;
2013-07-10 18:25:07 +00:00
ODM_Write_DIG ( pDM_Odm , CurrentIGI ) ; /* ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue); */
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DIGInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
2013-05-08 21:45:39 +00:00
pDM_DigTable - > CurIGValue = ( u1Byte ) ODM_GetBBReg ( pDM_Odm , ODM_REG ( IGI_A , pDM_Odm ) , ODM_BIT ( IGI , pDM_Odm ) ) ;
2013-05-19 04:28:07 +00:00
pDM_DigTable - > RssiLowThresh = DM_DIG_THRESH_LOW ;
pDM_DigTable - > RssiHighThresh = DM_DIG_THRESH_HIGH ;
2013-05-27 22:32:24 +00:00
pDM_DigTable - > FALowThresh = DM_false_ALARM_THRESH_LOW ;
pDM_DigTable - > FAHighThresh = DM_false_ALARM_THRESH_HIGH ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > BoardType = = ODM_BOARD_HIGHPWR )
2013-05-08 21:45:39 +00:00
{
pDM_DigTable - > rx_gain_range_max = DM_DIG_MAX_NIC ;
pDM_DigTable - > rx_gain_range_min = DM_DIG_MIN_NIC ;
}
else
{
pDM_DigTable - > rx_gain_range_max = DM_DIG_MAX_NIC ;
pDM_DigTable - > rx_gain_range_min = DM_DIG_MIN_NIC ;
}
pDM_DigTable - > BackoffVal = DM_DIG_BACKOFF_DEFAULT ;
pDM_DigTable - > BackoffVal_range_max = DM_DIG_BACKOFF_MAX ;
pDM_DigTable - > BackoffVal_range_min = DM_DIG_BACKOFF_MIN ;
pDM_DigTable - > PreCCK_CCAThres = 0xFF ;
pDM_DigTable - > CurCCK_CCAThres = 0x83 ;
pDM_DigTable - > ForbiddenIGI = DM_DIG_MIN_NIC ;
pDM_DigTable - > LargeFAHit = 0 ;
pDM_DigTable - > Recover_cnt = 0 ;
pDM_DigTable - > DIG_Dynamic_MIN_0 = DM_DIG_MIN_NIC ;
pDM_DigTable - > DIG_Dynamic_MIN_1 = DM_DIG_MIN_NIC ;
2013-05-27 22:32:24 +00:00
pDM_DigTable - > bMediaConnect_0 = false ;
pDM_DigTable - > bMediaConnect_1 = false ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* To Initialize pDM_Odm->bDMInitialGainEnable == false to avoid DIG error */
2013-05-27 22:32:24 +00:00
pDM_Odm - > bDMInitialGainEnable = true ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DIG (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
struct false_alarm_stats * pFalseAlmCnt = & pDM_Odm - > FalseAlmCnt ;
struct rx_hpc * pRX_HP_Table = & pDM_Odm - > DM_RXHP_Table ;
2013-05-08 21:45:39 +00:00
u1Byte DIG_Dynamic_MIN ;
u1Byte DIG_MaxOfMin ;
2013-05-19 04:48:10 +00:00
bool FirstConnect , FirstDisConnect ;
2013-05-08 21:45:39 +00:00
u1Byte dm_dig_max , dm_dig_min ;
u1Byte CurrentIGI = pDM_DigTable - > CurIGValue ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG()==> \n " ) ) ;
2013-05-09 04:04:25 +00:00
if ( ( ! ( pDM_Odm - > SupportAbility & ODM_BB_DIG ) ) | | ( ! ( pDM_Odm - > SupportAbility & ODM_BB_FA_CNT ) ) )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() Return: SupportAbility ODM_BB_DIG or ODM_BB_FA_CNT is disabled \n " ) ) ;
return ;
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pbScanInProcess ) )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() Return: In Scan Progress \n " ) ) ;
2013-05-19 04:28:07 +00:00
return ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* add by Neil Chen to avoid PSD is processing */
2013-05-27 22:32:24 +00:00
if ( pDM_Odm - > bDMInitialGainEnable = = false )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() Return: PSD is Processing \n " ) ) ;
2013-05-08 21:45:39 +00:00
return ;
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8192D )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pMacPhyMode ) = = ODM_DMSP )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pbMasterOfDMSP ) )
2013-05-08 21:45:39 +00:00
{
DIG_Dynamic_MIN = pDM_DigTable - > DIG_Dynamic_MIN_0 ;
2013-05-27 22:32:24 +00:00
FirstConnect = ( pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = false ) ;
FirstDisConnect = ( ! pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = true ) ;
2013-05-08 21:45:39 +00:00
}
else
{
DIG_Dynamic_MIN = pDM_DigTable - > DIG_Dynamic_MIN_1 ;
2013-05-27 22:32:24 +00:00
FirstConnect = ( pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_1 = = false ) ;
FirstDisConnect = ( ! pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_1 = = true ) ;
2013-05-08 21:45:39 +00:00
}
}
else
{
2013-05-09 04:04:25 +00:00
if ( * ( pDM_Odm - > pBandType ) = = ODM_BAND_5G )
2013-05-08 21:45:39 +00:00
{
DIG_Dynamic_MIN = pDM_DigTable - > DIG_Dynamic_MIN_0 ;
2013-05-27 22:32:24 +00:00
FirstConnect = ( pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = false ) ;
FirstDisConnect = ( ! pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = true ) ;
2013-05-08 21:45:39 +00:00
}
else
{
DIG_Dynamic_MIN = pDM_DigTable - > DIG_Dynamic_MIN_1 ;
2013-05-27 22:32:24 +00:00
FirstConnect = ( pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_1 = = false ) ;
FirstDisConnect = ( ! pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_1 = = true ) ;
2013-05-08 21:45:39 +00:00
}
}
}
else
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
DIG_Dynamic_MIN = pDM_DigTable - > DIG_Dynamic_MIN_0 ;
2013-05-27 22:32:24 +00:00
FirstConnect = ( pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = false ) ;
FirstDisConnect = ( ! pDM_Odm - > bLinked ) & & ( pDM_DigTable - > bMediaConnect_0 = = true ) ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* 1 Boundary Decision */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > SupportICType & ( ODM_RTL8192C | ODM_RTL8723A ) ) & &
2013-05-08 21:45:39 +00:00
( ( pDM_Odm - > BoardType = = ODM_BOARD_HIGHPWR ) | | pDM_Odm - > ExtLNA ) )
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportPlatform & ( ODM_AP | ODM_ADSL ) )
2013-05-08 21:45:39 +00:00
{
dm_dig_max = DM_DIG_MAX_AP_HP ;
dm_dig_min = DM_DIG_MIN_AP_HP ;
}
else
{
dm_dig_max = DM_DIG_MAX_NIC_HP ;
dm_dig_min = DM_DIG_MIN_NIC_HP ;
}
DIG_MaxOfMin = DM_DIG_MAX_AP_HP ;
}
else
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportPlatform & ( ODM_AP | ODM_ADSL ) )
2013-05-08 21:45:39 +00:00
{
dm_dig_max = DM_DIG_MAX_AP ;
dm_dig_min = DM_DIG_MIN_AP ;
DIG_MaxOfMin = dm_dig_max ;
}
else
{
dm_dig_max = DM_DIG_MAX_NIC ;
dm_dig_min = DM_DIG_MIN_NIC ;
DIG_MaxOfMin = DM_DIG_MAX_AP ;
}
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > bLinked )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* 2 8723A Series, offset need to be 10 */
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ( ODM_RTL8723A ) )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* 2 Upper Bound */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > RSSI_Min + 10 ) > DM_DIG_MAX_NIC )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_max = DM_DIG_MAX_NIC ;
2013-05-09 04:04:25 +00:00
else if ( ( pDM_Odm - > RSSI_Min + 10 ) < DM_DIG_MIN_NIC )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_max = DM_DIG_MIN_NIC ;
else
pDM_DigTable - > rx_gain_range_max = pDM_Odm - > RSSI_Min + 10 ;
2013-07-10 18:25:07 +00:00
/* 2 If BT is Concurrent, need to set Lower Bound */
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
# if (BT_30_SUPPORT == 1)
if ( pDM_Odm - > bBtBusy )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min > 10 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > RSSI_Min - 10 ) > DM_DIG_MAX_NIC )
2013-05-08 21:45:39 +00:00
DIG_Dynamic_MIN = DM_DIG_MAX_NIC ;
2013-05-09 04:04:25 +00:00
else if ( ( pDM_Odm - > RSSI_Min - 10 ) < DM_DIG_MIN_NIC )
2013-05-08 21:45:39 +00:00
DIG_Dynamic_MIN = DM_DIG_MIN_NIC ;
else
DIG_Dynamic_MIN = pDM_Odm - > RSSI_Min - 10 ;
}
else
DIG_Dynamic_MIN = DM_DIG_MIN_NIC ;
}
else
# endif
{
DIG_Dynamic_MIN = DM_DIG_MIN_NIC ;
}
}
else
{
2013-07-10 18:25:07 +00:00
/* 2 Modify DIG upper bound */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > RSSI_Min + 20 ) > dm_dig_max )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_max = dm_dig_max ;
2013-05-09 04:04:25 +00:00
else if ( ( pDM_Odm - > RSSI_Min + 20 ) < dm_dig_min )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_max = dm_dig_min ;
else
pDM_DigTable - > rx_gain_range_max = pDM_Odm - > RSSI_Min + 20 ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* 2 Modify DIG lower bound */
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > bOneEntryOnly )
2013-05-19 04:28:07 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min < dm_dig_min )
2013-05-08 21:45:39 +00:00
DIG_Dynamic_MIN = dm_dig_min ;
else if ( pDM_Odm - > RSSI_Min > DIG_MaxOfMin )
DIG_Dynamic_MIN = DIG_MaxOfMin ;
else
DIG_Dynamic_MIN = pDM_Odm - > RSSI_Min ;
2013-05-27 22:32:24 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() : bOneEntryOnly=true, DIG_Dynamic_MIN=0x%x \n " , DIG_Dynamic_MIN ) ) ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() : pDM_Odm->RSSI_Min=%d \n " , pDM_Odm - > RSSI_Min ) ) ;
}
2013-07-10 18:25:07 +00:00
/* 1 Lower Bound for 88E AntDiv */
2013-05-09 04:04:25 +00:00
else if ( ( pDM_Odm - > SupportICType = = ODM_RTL8188E ) & & ( pDM_Odm - > SupportAbility & ODM_BB_ANT_DIV ) )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > AntDivType = = CG_TRX_HW_ANTDIV )
2013-05-08 21:45:39 +00:00
{
DIG_Dynamic_MIN = ( u1Byte ) pDM_DigTable - > AntDiv_RSSI_max ;
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_DIG(): pDM_DigTable->AntDiv_RSSI_max=%d \n " , pDM_DigTable - > AntDiv_RSSI_max ) ) ;
2013-05-08 21:45:39 +00:00
}
}
else
{
DIG_Dynamic_MIN = dm_dig_min ;
}
}
}
else
{
pDM_DigTable - > rx_gain_range_max = dm_dig_max ;
DIG_Dynamic_MIN = dm_dig_min ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG() : No Link \n " ) ) ;
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* 1 Modify DIG lower bound, deal with abnormally large false alarm */
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > 10000 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " dm_DIG(): Abnornally false alarm case. \n " ) ) ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_DigTable - > LargeFAHit ! = 3 )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > LargeFAHit + + ;
2013-07-10 18:25:07 +00:00
if ( pDM_DigTable - > ForbiddenIGI < CurrentIGI ) /* if (pDM_DigTable->ForbiddenIGI < pDM_DigTable->CurIGValue) */
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
pDM_DigTable - > ForbiddenIGI = CurrentIGI ; /* pDM_DigTable->ForbiddenIGI = pDM_DigTable->CurIGValue; */
2013-05-08 21:45:39 +00:00
pDM_DigTable - > LargeFAHit = 1 ;
}
2013-05-09 04:04:25 +00:00
if ( pDM_DigTable - > LargeFAHit > = 3 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( ( pDM_DigTable - > ForbiddenIGI + 1 ) > pDM_DigTable - > rx_gain_range_max )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_min = pDM_DigTable - > rx_gain_range_max ;
else
pDM_DigTable - > rx_gain_range_min = ( pDM_DigTable - > ForbiddenIGI + 1 ) ;
2013-07-10 18:25:07 +00:00
pDM_DigTable - > Recover_cnt = 3600 ; /* 3600=2hr */
2013-05-08 21:45:39 +00:00
}
}
else
{
2013-07-10 18:25:07 +00:00
/* Recovery mechanism for IGI lower bound */
2013-05-09 04:04:25 +00:00
if ( pDM_DigTable - > Recover_cnt ! = 0 )
2013-05-08 21:45:39 +00:00
pDM_DigTable - > Recover_cnt - - ;
else
{
2013-05-09 04:04:25 +00:00
if ( pDM_DigTable - > LargeFAHit < 3 )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
if ( ( pDM_DigTable - > ForbiddenIGI - 1 ) < DIG_Dynamic_MIN ) /* DM_DIG_MIN) */
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
pDM_DigTable - > ForbiddenIGI = DIG_Dynamic_MIN ; /* DM_DIG_MIN; */
pDM_DigTable - > rx_gain_range_min = DIG_Dynamic_MIN ; /* DM_DIG_MIN; */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): Normal Case: At Lower Bound \n " ) ) ;
}
else
{
pDM_DigTable - > ForbiddenIGI - - ;
pDM_DigTable - > rx_gain_range_min = ( pDM_DigTable - > ForbiddenIGI + 1 ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): Normal Case: Approach Lower Bound \n " ) ) ;
}
}
else
{
pDM_DigTable - > LargeFAHit = 0 ;
}
}
}
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): pDM_DigTable->LargeFAHit=%d \n " , pDM_DigTable - > LargeFAHit ) ) ;
2013-07-10 18:25:07 +00:00
/* 1 Adjust initial gain by false alarm */
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > bLinked )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): DIG AfterLink \n " ) ) ;
2013-05-09 04:04:25 +00:00
if ( FirstConnect )
2013-05-08 21:45:39 +00:00
{
CurrentIGI = pDM_Odm - > RSSI_Min ;
2013-06-03 19:52:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " DIG: First Connect \n " ) ) ;
2013-05-08 21:45:39 +00:00
}
else
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8192D )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH2_92D )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 2 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+2; */
2013-05-08 21:45:39 +00:00
else if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH1_92D )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 1 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+1; */
2013-05-09 04:04:25 +00:00
else if ( pFalseAlmCnt - > Cnt_all < DM_DIG_FA_TH0_92D )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI - 1 ; /* pDM_DigTable->CurIGValue =pDM_DigTable->PreIGValue-1; */
2013-05-08 21:45:39 +00:00
}
else
{
2013-05-09 04:04:25 +00:00
# if (BT_30_SUPPORT == 1)
if ( pDM_Odm - > bBtBusy )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > 0x300 )
2013-05-08 21:45:39 +00:00
CurrentIGI = CurrentIGI + 2 ;
else if ( pFalseAlmCnt - > Cnt_all > 0x250 )
CurrentIGI = CurrentIGI + 1 ;
2013-05-09 04:04:25 +00:00
else if ( pFalseAlmCnt - > Cnt_all < DM_DIG_FA_TH0 )
2013-05-08 21:45:39 +00:00
CurrentIGI = CurrentIGI - 1 ;
}
else
# endif
{
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH2 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 4 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+2; */
2013-05-08 21:45:39 +00:00
else if ( pFalseAlmCnt - > Cnt_all > DM_DIG_FA_TH1 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 2 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+1; */
2013-05-09 04:04:25 +00:00
else if ( pFalseAlmCnt - > Cnt_all < DM_DIG_FA_TH0 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI - 2 ; /* pDM_DigTable->CurIGValue =pDM_DigTable->PreIGValue-1; */
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
}
2013-05-19 04:28:07 +00:00
}
}
2013-05-08 21:45:39 +00:00
else
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): DIG BeforeLink \n " ) ) ;
2013-05-09 04:04:25 +00:00
if ( FirstDisConnect )
2013-05-08 21:45:39 +00:00
{
CurrentIGI = pDM_DigTable - > rx_gain_range_min ;
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): First DisConnect \n " ) ) ;
2013-05-08 21:45:39 +00:00
}
else
{
2013-07-10 18:25:07 +00:00
/* 2012.03.30 LukeLee: enable DIG before link but with very high thresholds */
2013-05-09 04:04:25 +00:00
if ( pFalseAlmCnt - > Cnt_all > 10000 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 2 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+2; */
2013-05-08 21:45:39 +00:00
else if ( pFalseAlmCnt - > Cnt_all > 8000 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI + 1 ; /* pDM_DigTable->CurIGValue = pDM_DigTable->PreIGValue+1; */
2013-05-09 04:04:25 +00:00
else if ( pFalseAlmCnt - > Cnt_all < 500 )
2013-07-10 18:25:07 +00:00
CurrentIGI = CurrentIGI - 1 ; /* pDM_DigTable->CurIGValue =pDM_DigTable->PreIGValue-1; */
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): England DIG \n " ) ) ;
2013-05-08 21:45:39 +00:00
}
}
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): DIG End Adjust IGI \n " ) ) ;
2013-07-10 18:25:07 +00:00
/* 1 Check initial gain by upper/lower bound */
2013-05-09 04:04:25 +00:00
if ( CurrentIGI > pDM_DigTable - > rx_gain_range_max )
2013-05-08 21:45:39 +00:00
CurrentIGI = pDM_DigTable - > rx_gain_range_max ;
2013-05-09 04:04:25 +00:00
if ( CurrentIGI < pDM_DigTable - > rx_gain_range_min )
2013-05-08 21:45:39 +00:00
CurrentIGI = pDM_DigTable - > rx_gain_range_min ;
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): rx_gain_range_max=0x%x, rx_gain_range_min=0x%x \n " ,
2013-05-08 21:45:39 +00:00
pDM_DigTable - > rx_gain_range_max , pDM_DigTable - > rx_gain_range_min ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): TotalFA=%d \n " , pFalseAlmCnt - > Cnt_all ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_DIG , ODM_DBG_LOUD , ( " odm_DIG(): CurIGValue=0x%x \n " , CurrentIGI ) ) ;
2013-07-10 18:25:07 +00:00
/* 2 High power RSSI threshold */
2013-05-19 04:28:07 +00:00
2013-07-21 23:06:56 +00:00
ODM_Write_DIG ( pDM_Odm , CurrentIGI ) ; /* ODM_Write_DIG(pDM_Odm, pDM_DigTable->CurIGValue); */
pDM_DigTable - > bMediaConnect_0 = pDM_Odm - > bLinked ;
pDM_DigTable - > DIG_Dynamic_MIN_0 = DIG_Dynamic_MIN ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 FASLE ALARM CHECK */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_FalseAlarmCounterStatistics (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
u4Byte ret_value ;
2013-07-26 16:20:42 +00:00
struct false_alarm_stats * FalseAlmCnt = & ( pDM_Odm - > FalseAlmCnt ) ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_FA_CNT ) )
2013-05-08 21:45:39 +00:00
return ;
2013-07-10 18:25:07 +00:00
if ( pDM_Odm - > SupportICType & ODM_IC_11N_SERIES ) {
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* hold ofdm counter */
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_HOLDC_11N , BIT31 , 1 ) ; /* hold page C counter */
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTD_11N , BIT31 , 1 ) ; /* hold page D counter */
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_TYPE1_11N , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_Fast_Fsync = ( ret_value & 0xffff ) ;
FalseAlmCnt - > Cnt_SB_Search_fail = ( ( ret_value & 0xffff0000 ) > > 16 ) ;
2013-05-08 21:45:39 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_TYPE2_11N , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_OFDM_CCA = ( ret_value & 0xffff ) ;
FalseAlmCnt - > Cnt_Parity_Fail = ( ( ret_value & 0xffff0000 ) > > 16 ) ;
2013-05-08 21:45:39 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_TYPE3_11N , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_Rate_Illegal = ( ret_value & 0xffff ) ;
FalseAlmCnt - > Cnt_Crc8_fail = ( ( ret_value & 0xffff0000 ) > > 16 ) ;
2013-05-08 21:45:39 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_TYPE4_11N , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_Mcs_fail = ( ret_value & 0xffff ) ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_Ofdm_fail = FalseAlmCnt - > Cnt_Parity_Fail + FalseAlmCnt - > Cnt_Rate_Illegal +
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_Crc8_fail + FalseAlmCnt - > Cnt_Mcs_fail +
FalseAlmCnt - > Cnt_Fast_Fsync + FalseAlmCnt - > Cnt_SB_Search_fail ;
2013-07-10 18:25:07 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8188E ) {
2013-05-08 21:45:39 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_SC_CNT_11N , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_BW_LSC = ( ret_value & 0xffff ) ;
FalseAlmCnt - > Cnt_BW_USC = ( ( ret_value & 0xffff0000 ) > > 16 ) ;
}
2013-05-08 21:45:39 +00:00
2013-07-21 23:06:56 +00:00
/* hold cck counter */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT12 , 1 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT14 , 1 ) ;
2013-05-19 04:28:07 +00:00
2013-07-21 23:06:56 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_CCK_FA_LSB_11N , bMaskByte0 ) ;
FalseAlmCnt - > Cnt_Cck_fail = ret_value ;
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_CCK_FA_MSB_11N , bMaskByte3 ) ;
FalseAlmCnt - > Cnt_Cck_fail + = ( ret_value & 0xff ) < < 8 ;
2013-05-08 21:45:39 +00:00
2013-07-21 23:06:56 +00:00
ret_value = ODM_GetBBReg ( pDM_Odm , ODM_REG_CCK_CCA_CNT_11N , bMaskDWord ) ;
FalseAlmCnt - > Cnt_CCK_CCA = ( ( ret_value & 0xFF ) < < 8 ) | ( ( ret_value & 0xFF00 ) > > 8 ) ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_all = ( FalseAlmCnt - > Cnt_Fast_Fsync +
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_SB_Search_fail +
FalseAlmCnt - > Cnt_Parity_Fail +
FalseAlmCnt - > Cnt_Rate_Illegal +
FalseAlmCnt - > Cnt_Crc8_fail +
FalseAlmCnt - > Cnt_Mcs_fail +
2013-05-19 04:28:07 +00:00
FalseAlmCnt - > Cnt_Cck_fail ) ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
FalseAlmCnt - > Cnt_CCA_all = FalseAlmCnt - > Cnt_OFDM_CCA + FalseAlmCnt - > Cnt_CCK_CCA ;
2013-05-08 21:45:39 +00:00
2013-07-21 23:06:56 +00:00
if ( pDM_Odm - > SupportICType > = ODM_RTL8723A ) {
2013-07-10 18:25:07 +00:00
/* reset false alarm counter registers */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTC_11N , BIT31 , 1 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTC_11N , BIT31 , 0 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTD_11N , BIT27 , 1 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTD_11N , BIT27 , 0 ) ;
2013-07-10 18:25:07 +00:00
/* update ofdm counter */
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_HOLDC_11N , BIT31 , 0 ) ; /* update page C counter */
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RSTD_11N , BIT31 , 0 ) ; /* update page D counter */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* reset CCK CCA counter */
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT13 | BIT12 , 0 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT13 | BIT12 , 2 ) ;
2013-07-10 18:25:07 +00:00
/* reset CCK FA counter */
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT15 | BIT14 , 0 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11N , BIT15 | BIT14 , 2 ) ;
2013-07-10 18:25:07 +00:00
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Enter odm_FalseAlarmCounterStatistics \n " ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Cnt_Fast_Fsync=%d, Cnt_SB_Search_fail=%d \n " ,
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_Fast_Fsync , FalseAlmCnt - > Cnt_SB_Search_fail ) ) ;
2013-07-10 18:25:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Cnt_Parity_Fail=%d, Cnt_Rate_Illegal=%d \n " ,
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_Parity_Fail , FalseAlmCnt - > Cnt_Rate_Illegal ) ) ;
2013-07-10 18:25:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Cnt_Crc8_fail=%d, Cnt_Mcs_fail=%d \n " ,
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_Crc8_fail , FalseAlmCnt - > Cnt_Mcs_fail ) ) ;
}
2013-07-10 18:25:07 +00:00
else /* FOR ODM_IC_11AC_SERIES */
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* read OFDM FA counter */
2013-05-08 21:45:39 +00:00
FalseAlmCnt - > Cnt_Ofdm_fail = ODM_GetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_11AC , bMaskLWord ) ;
FalseAlmCnt - > Cnt_Cck_fail = ODM_GetBBReg ( pDM_Odm , ODM_REG_CCK_FA_11AC , bMaskLWord ) ;
FalseAlmCnt - > Cnt_all = FalseAlmCnt - > Cnt_Ofdm_fail + FalseAlmCnt - > Cnt_Cck_fail ;
2013-07-10 18:25:07 +00:00
/* reset OFDM FA coutner */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RST_11AC , BIT17 , 1 ) ;
ODM_SetBBReg ( pDM_Odm , ODM_REG_OFDM_FA_RST_11AC , BIT17 , 0 ) ;
2013-07-10 18:25:07 +00:00
/* reset CCK FA counter */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11AC , BIT15 , 0 ) ;
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_FA_RST_11AC , BIT15 , 1 ) ;
2013-05-08 21:45:39 +00:00
}
2013-06-03 19:52:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Cnt_Cck_fail=%d \n " , FalseAlmCnt - > Cnt_Cck_fail ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Cnt_Ofdm_fail=%d \n " , FalseAlmCnt - > Cnt_Ofdm_fail ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_FA_CNT , ODM_DBG_LOUD , ( " Total False Alarm=%d \n " , FalseAlmCnt - > Cnt_all ) ) ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 CCK Packet Detect Threshold */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_CCKPacketDetectionThresh (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
2013-05-08 21:45:39 +00:00
u1Byte CurCCK_CCAThres ;
2013-07-26 16:20:42 +00:00
struct false_alarm_stats * FalseAlmCnt = & ( pDM_Odm - > FalseAlmCnt ) ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ( ODM_BB_CCK_PD | ODM_BB_FA_CNT ) ) )
2013-05-08 21:45:39 +00:00
return ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > ExtLNA )
2013-05-08 21:45:39 +00:00
return ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > bLinked )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min > 25 )
2013-05-08 21:45:39 +00:00
CurCCK_CCAThres = 0xcd ;
2013-05-09 04:04:25 +00:00
else if ( ( pDM_Odm - > RSSI_Min < = 25 ) & & ( pDM_Odm - > RSSI_Min > 10 ) )
2013-05-08 21:45:39 +00:00
CurCCK_CCAThres = 0x83 ;
else
{
2013-05-09 04:04:25 +00:00
if ( FalseAlmCnt - > Cnt_Cck_fail > 1000 )
2013-05-08 21:45:39 +00:00
CurCCK_CCAThres = 0x83 ;
else
CurCCK_CCAThres = 0x40 ;
}
}
else
{
2013-05-09 04:04:25 +00:00
if ( FalseAlmCnt - > Cnt_Cck_fail > 1000 )
2013-05-08 21:45:39 +00:00
CurCCK_CCAThres = 0x83 ;
else
CurCCK_CCAThres = 0x40 ;
}
2013-05-19 04:28:07 +00:00
2013-07-21 23:06:56 +00:00
ODM_Write_CCK_CCA_Thres ( pDM_Odm , CurCCK_CCAThres ) ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_Write_CCK_CCA_Thres (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte CurCCK_CCAThres
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtw_dig * pDM_DigTable = & pDM_Odm - > DM_DigTable ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
if ( pDM_DigTable - > CurCCK_CCAThres ! = CurCCK_CCAThres ) /* modify by Guo.Mingzhi 2012-01-03 */
2013-05-08 21:45:39 +00:00
{
ODM_Write1Byte ( pDM_Odm , ODM_REG ( CCK_CCA , pDM_Odm ) , CurCCK_CCAThres ) ;
}
pDM_DigTable - > PreCCK_CCAThres = pDM_DigTable - > CurCCK_CCAThres ;
pDM_DigTable - > CurCCK_CCAThres = CurCCK_CCAThres ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 BB Power Save */
/* 3============================================================ */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicBBPowerSavingInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtl_ps * pDM_PSTable = & pDM_Odm - > DM_PSTable ;
2013-05-08 21:45:39 +00:00
pDM_PSTable - > PreCCAState = CCA_MAX ;
pDM_PSTable - > CurCCAState = CCA_MAX ;
pDM_PSTable - > PreRFState = RF_MAX ;
pDM_PSTable - > CurRFState = RF_MAX ;
pDM_PSTable - > Rssi_val_min = 0 ;
pDM_PSTable - > initialize = 0 ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicBBPowerSaving (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
if ( ( pDM_Odm - > SupportICType ! = ODM_RTL8192C ) & & ( pDM_Odm - > SupportICType ! = ODM_RTL8723A ) )
return ;
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_PWR_SAVE ) )
2013-05-08 21:45:39 +00:00
return ;
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportPlatform & ( ODM_MP | ODM_CE ) ) )
2013-05-08 21:45:39 +00:00
return ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* 1 2.Power Saving for 92C */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > SupportICType = = ODM_RTL8192C ) & & ( pDM_Odm - > RFType = = ODM_2T2R ) )
2013-05-08 21:45:39 +00:00
{
odm_1R_CCA ( pDM_Odm ) ;
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* 20100628 Joseph: Turn off BB power save for 88CE because it makesthroughput unstable. */
/* 20100831 Joseph: Turn ON BB power save again after modifying AGC delay from 900ns ot 600ns. */
/* 1 3.Power Saving for 88C */
2013-05-08 21:45:39 +00:00
else
{
2013-05-27 22:32:24 +00:00
ODM_RF_Saving ( pDM_Odm , false ) ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_1R_CCA (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtl_ps * pDM_PSTable = & pDM_Odm - > DM_PSTable ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min ! = 0xFF )
2013-05-08 21:45:39 +00:00
{
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_PSTable - > PreCCAState = = CCA_2R )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min > = 35 )
2013-05-08 21:45:39 +00:00
pDM_PSTable - > CurCCAState = CCA_1R ;
else
pDM_PSTable - > CurCCAState = CCA_2R ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
else {
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min < = 30 )
2013-05-08 21:45:39 +00:00
pDM_PSTable - > CurCCAState = CCA_2R ;
else
pDM_PSTable - > CurCCAState = CCA_1R ;
}
}
else {
pDM_PSTable - > CurCCAState = CCA_MAX ;
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
if ( pDM_PSTable - > PreCCAState ! = pDM_PSTable - > CurCCAState ) {
if ( pDM_PSTable - > CurCCAState = = CCA_1R ) {
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RFType = = ODM_2T2R )
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0xc04 , bMaskByte0 , 0x13 ) ;
else
ODM_SetBBReg ( pDM_Odm , 0xc04 , bMaskByte0 , 0x23 ) ;
2013-07-10 18:25:07 +00:00
} else {
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0xc04 , bMaskByte0 , 0x33 ) ;
}
pDM_PSTable - > PreCCAState = pDM_PSTable - > CurCCAState ;
}
}
void
ODM_RF_Saving (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte bForceInNormal
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct rtl_ps * pDM_PSTable = & pDM_Odm - > DM_PSTable ;
2013-05-08 21:45:39 +00:00
u1Byte Rssi_Up_bound = 30 ;
u1Byte Rssi_Low_bound = 25 ;
2013-07-15 04:50:52 +00:00
2013-07-10 18:25:07 +00:00
if ( pDM_Odm - > PatchID = = 40 ) /* RT_CID_819x_FUNAI_TV */
2013-05-08 21:45:39 +00:00
{
Rssi_Up_bound = 50 ;
Rssi_Low_bound = 45 ;
}
2013-05-09 04:04:25 +00:00
if ( pDM_PSTable - > initialize = = 0 ) {
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
pDM_PSTable - > Reg874 = ( ODM_GetBBReg ( pDM_Odm , 0x874 , bMaskDWord ) & 0x1CC000 ) > > 14 ;
pDM_PSTable - > RegC70 = ( ODM_GetBBReg ( pDM_Odm , 0xc70 , bMaskDWord ) & BIT3 ) > > 3 ;
pDM_PSTable - > Reg85C = ( ODM_GetBBReg ( pDM_Odm , 0x85c , bMaskDWord ) & 0xFF000000 ) > > 24 ;
pDM_PSTable - > RegA74 = ( ODM_GetBBReg ( pDM_Odm , 0xa74 , bMaskDWord ) & 0xF000 ) > > 12 ;
pDM_PSTable - > initialize = 1 ;
}
2013-05-09 04:04:25 +00:00
if ( ! bForceInNormal )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min ! = 0xFF )
2013-05-19 04:28:07 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_PSTable - > PreRFState = = RF_Normal )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min > = Rssi_Up_bound )
2013-05-08 21:45:39 +00:00
pDM_PSTable - > CurRFState = RF_Save ;
else
pDM_PSTable - > CurRFState = RF_Normal ;
}
else {
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > RSSI_Min < = Rssi_Low_bound )
2013-05-08 21:45:39 +00:00
pDM_PSTable - > CurRFState = RF_Normal ;
else
pDM_PSTable - > CurRFState = RF_Save ;
}
}
else
pDM_PSTable - > CurRFState = RF_MAX ;
}
else
{
pDM_PSTable - > CurRFState = RF_Normal ;
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_PSTable - > PreRFState ! = pDM_PSTable - > CurRFState )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( pDM_PSTable - > CurRFState = = RF_Save )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* <tynli_note> 8723 RSSI report will be wrong. Set 0x874[5]=1 when enter BB power saving mode. */
/* Suggested by SD3 Yu-Nan. 2011.01.20. */
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8723A )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , 0x874 , BIT5 , 0x1 ) ; /* Reg874[5]=1b'1 */
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , 0x874 , 0x1C0000 , 0x2 ) ; /* Reg874[20:18]=3'b010 */
ODM_SetBBReg ( pDM_Odm , 0xc70 , BIT3 , 0 ) ; /* RegC70[3]=1'b0 */
ODM_SetBBReg ( pDM_Odm , 0x85c , 0xFF000000 , 0x63 ) ; /* Reg85C[31:24]=0x63 */
ODM_SetBBReg ( pDM_Odm , 0x874 , 0xC000 , 0x2 ) ; /* Reg874[15:14]=2'b10 */
ODM_SetBBReg ( pDM_Odm , 0xa74 , 0xF000 , 0x3 ) ; /* RegA75[7:4]=0x3 */
ODM_SetBBReg ( pDM_Odm , 0x818 , BIT28 , 0x0 ) ; /* Reg818[28]=1'b0 */
ODM_SetBBReg ( pDM_Odm , 0x818 , BIT28 , 0x1 ) ; /* Reg818[28]=1'b1 */
2013-05-08 21:45:39 +00:00
}
else
{
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , 0x874 , 0x1CC000 , pDM_PSTable - > Reg874 ) ;
ODM_SetBBReg ( pDM_Odm , 0xc70 , BIT3 , pDM_PSTable - > RegC70 ) ;
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0x85c , 0xFF000000 , pDM_PSTable - > Reg85C ) ;
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , 0xa74 , 0xF000 , pDM_PSTable - > RegA74 ) ;
ODM_SetBBReg ( pDM_Odm , 0x818 , BIT28 , 0x0 ) ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8723A )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , 0x874 , BIT5 , 0x0 ) ; /* Reg874[5]=1b'0 */
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* ODM_RT_TRACE(pDM_Odm, COMP_BB_POWERSAVING, DBG_LOUD, (" RF_Normal")); */
2013-05-08 21:45:39 +00:00
}
pDM_PSTable - > PreRFState = pDM_PSTable - > CurRFState ;
}
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 RATR MASK */
/* 3============================================================ */
/* 3============================================================ */
/* 3 Rate Adaptive */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RateAdaptiveMaskInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct odm_rate_adapt * pOdmRA = & pDM_Odm - > RateAdaptive ;
2013-05-08 21:45:39 +00:00
pOdmRA - > Type = DM_Type_ByDriver ;
if ( pOdmRA - > Type = = DM_Type_ByDriver )
2013-05-26 03:02:10 +00:00
pDM_Odm - > bUseRAMask = true ;
2013-05-08 21:45:39 +00:00
else
2013-05-26 03:02:10 +00:00
pDM_Odm - > bUseRAMask = false ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
pOdmRA - > RATRState = DM_RATR_STA_INIT ;
pOdmRA - > HighRSSIThresh = 50 ;
pOdmRA - > LowRSSIThresh = 20 ;
}
u4Byte ODM_Get_Rate_Bitmap (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u4Byte macid ,
u4Byte ra_mask ,
u1Byte rssi_level )
2013-05-19 04:28:07 +00:00
{
2013-07-26 20:25:06 +00:00
struct sta_info * pEntry ;
2013-05-19 04:28:07 +00:00
u4Byte rate_bitmap = 0x0fffffff ;
u1Byte WirelessMode ;
2013-05-08 21:45:39 +00:00
pEntry = pDM_Odm - > pODM_StaInfo [ macid ] ;
2013-05-09 04:04:25 +00:00
if ( ! IS_STA_VALID ( pEntry ) )
2013-05-08 21:45:39 +00:00
return ra_mask ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
WirelessMode = pEntry - > wireless_mode ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
switch ( WirelessMode ) {
case ODM_WM_B :
if ( ra_mask & 0x0000000c ) /* 11M or 5.5M enable */
rate_bitmap = 0x0000000d ;
else
rate_bitmap = 0x0000000f ;
break ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
case ( ODM_WM_A | ODM_WM_G ) :
if ( rssi_level = = DM_RATR_STA_HIGH )
rate_bitmap = 0x00000f00 ;
else
rate_bitmap = 0x00000ff0 ;
break ;
case ( ODM_WM_B | ODM_WM_G ) :
if ( rssi_level = = DM_RATR_STA_HIGH )
rate_bitmap = 0x00000f00 ;
else if ( rssi_level = = DM_RATR_STA_MIDDLE )
rate_bitmap = 0x00000ff0 ;
else
rate_bitmap = 0x00000ff5 ;
break ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
case ( ODM_WM_B | ODM_WM_G | ODM_WM_N24G ) :
case ( ODM_WM_A | ODM_WM_B | ODM_WM_G | ODM_WM_N24G ) :
{
if ( pDM_Odm - > RFType = = ODM_1T2R | | pDM_Odm - > RFType = = ODM_1T1R )
2013-05-19 04:28:07 +00:00
{
2013-07-10 18:25:07 +00:00
if ( rssi_level = = DM_RATR_STA_HIGH )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
rate_bitmap = 0x000f0000 ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
else if ( rssi_level = = DM_RATR_STA_MIDDLE )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
rate_bitmap = 0x000ff000 ;
}
else {
if ( * ( pDM_Odm - > pBandWidth ) = = ODM_BW40M )
rate_bitmap = 0x000ff015 ;
2013-05-08 21:45:39 +00:00
else
2013-07-10 18:25:07 +00:00
rate_bitmap = 0x000ff005 ;
}
} else {
if ( rssi_level = = DM_RATR_STA_HIGH ) {
rate_bitmap = 0x0f8f0000 ;
} else if ( rssi_level = = DM_RATR_STA_MIDDLE ) {
rate_bitmap = 0x0f8ff000 ;
} else {
if ( * ( pDM_Odm - > pBandWidth ) = = ODM_BW40M )
rate_bitmap = 0x0f8ff015 ;
else
rate_bitmap = 0x0f8ff005 ;
2013-05-08 21:45:39 +00:00
}
}
2013-07-10 18:25:07 +00:00
}
break ;
default :
/* case WIRELESS_11_24N: */
/* case WIRELESS_11_5N: */
if ( pDM_Odm - > RFType = = RF_1T2R )
rate_bitmap = 0x000fffff ;
else
rate_bitmap = 0x0fffffff ;
break ;
2013-05-08 21:45:39 +00:00
}
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_RA_MASK , ODM_DBG_LOUD , ( " ==> rssi_level:0x%02x, WirelessMode:0x%02x, rate_bitmap:0x%08x \n " , rssi_level , WirelessMode , rate_bitmap ) ) ;
2013-05-08 21:45:39 +00:00
return rate_bitmap ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
/*-----------------------------------------------------------------------------
* Function : odm_RefreshRateAdaptiveMask ( )
*
* Overview : Update rate table mask according to rssi
*
* Input : NONE
*
* Output : NONE
*
* Return : NONE
*
* Revised History :
* When Who Remark
2013-05-19 04:28:07 +00:00
* 05 / 27 / 2009 hpfan Create Version 0.
2013-05-08 21:45:39 +00:00
*
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMask (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_RA_MASK ) )
2013-05-19 04:28:07 +00:00
return ;
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
2013-05-08 21:45:39 +00:00
switch ( pDM_Odm - > SupportPlatform )
{
case ODM_MP :
odm_RefreshRateAdaptiveMaskMP ( pDM_Odm ) ;
break ;
case ODM_CE :
odm_RefreshRateAdaptiveMaskCE ( pDM_Odm ) ;
break ;
case ODM_AP :
case ODM_ADSL :
odm_RefreshRateAdaptiveMaskAPADSL ( pDM_Odm ) ;
break ;
}
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
u1Byte i ;
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter = pDM_Odm - > Adapter ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
if ( pAdapter - > bDriverStopped ) {
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_RA_MASK , ODM_DBG_TRACE , ( " <---- odm_RefreshRateAdaptiveMask(): driver is going to unload \n " ) ) ;
return ;
}
2013-07-15 04:50:52 +00:00
if ( ! pDM_Odm - > bUseRAMask ) {
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_RA_MASK , ODM_DBG_LOUD , ( " <---- odm_RefreshRateAdaptiveMask(): driver does not control rate adaptive mask \n " ) ) ;
return ;
}
2013-05-09 04:04:25 +00:00
for ( i = 0 ; i < ODM_ASSOCIATE_ENTRY_NUM ; i + + ) {
2013-07-26 20:25:06 +00:00
struct sta_info * pstat = pDM_Odm - > pODM_StaInfo [ i ] ;
2013-05-09 04:04:25 +00:00
if ( IS_STA_VALID ( pstat ) ) {
2013-07-15 04:50:52 +00:00
if ( true = = ODM_RAStateCheck ( pDM_Odm , pstat - > rssi_stat . UndecoratedSmoothedPWDB , false , & pstat - > rssi_level ) ) {
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_RA_MASK , ODM_DBG_LOUD , ( " RSSI:%d, RSSI_LEVEL:%d \n " , pstat - > rssi_stat . UndecoratedSmoothedPWDB , pstat - > rssi_level ) ) ;
rtw_hal_update_ra_mask ( pAdapter , i , pstat - > rssi_level ) ;
}
}
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RefreshRateAdaptiveMaskAPADSL (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-07-10 18:25:07 +00:00
/* Return Value: bool */
/* - true: RATRState is changed. */
2013-05-19 04:48:10 +00:00
bool
2013-05-08 21:45:39 +00:00
ODM_RAStateCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
s4Byte RSSI ,
bool bForceUpdate ,
pu1Byte pRATRState
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct odm_rate_adapt * pRA = & pDM_Odm - > RateAdaptive ;
2013-05-08 21:45:39 +00:00
const u1Byte GoUpGap = 5 ;
u1Byte HighRSSIThreshForRA = pRA - > HighRSSIThresh ;
u1Byte LowRSSIThreshForRA = pRA - > LowRSSIThresh ;
u1Byte RATRState ;
2013-07-10 18:25:07 +00:00
/* Threshold Adjustment: */
/* when RSSI state trends to go up one or two levels, make sure RSSI is high enough. */
/* Here GoUpGap is added to solve the boundary's level alternation issue. */
2013-05-08 21:45:39 +00:00
switch ( * pRATRState )
{
case DM_RATR_STA_INIT :
case DM_RATR_STA_HIGH :
break ;
case DM_RATR_STA_MIDDLE :
HighRSSIThreshForRA + = GoUpGap ;
break ;
case DM_RATR_STA_LOW :
HighRSSIThreshForRA + = GoUpGap ;
LowRSSIThreshForRA + = GoUpGap ;
break ;
2013-05-19 04:28:07 +00:00
default :
2013-05-27 22:32:24 +00:00
ODM_RT_ASSERT ( pDM_Odm , false , ( " wrong rssi level setting %d ! " , * pRATRState ) ) ;
2013-05-08 21:45:39 +00:00
break ;
}
2013-07-10 18:25:07 +00:00
/* Decide RATRState by RSSI. */
2013-05-09 04:04:25 +00:00
if ( RSSI > HighRSSIThreshForRA )
2013-05-08 21:45:39 +00:00
RATRState = DM_RATR_STA_HIGH ;
2013-05-09 04:04:25 +00:00
else if ( RSSI > LowRSSIThreshForRA )
2013-05-08 21:45:39 +00:00
RATRState = DM_RATR_STA_MIDDLE ;
else
RATRState = DM_RATR_STA_LOW ;
2013-05-09 04:04:25 +00:00
if ( * pRATRState ! = RATRState | | bForceUpdate )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_RA_MASK , ODM_DBG_LOUD , ( " RSSI Level %d -> %d \n " , * pRATRState , RATRState ) ) ;
* pRATRState = RATRState ;
2013-05-27 22:32:24 +00:00
return true ;
2013-05-08 21:45:39 +00:00
}
2013-05-27 22:32:24 +00:00
return false ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 Dynamic Tx Power */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( Adapter ) ;
2013-05-08 21:45:39 +00:00
struct dm_priv * pdmpriv = & pHalData - > dmpriv ;
2013-05-26 03:02:10 +00:00
pdmpriv - > bDynamicTxPowerEnable = false ;
2013-05-08 21:45:39 +00:00
pdmpriv - > LastDTPLvl = TxHighPwrLevel_Normal ;
2013-05-19 04:28:07 +00:00
pdmpriv - > DynamicTxHighPowerLvl = TxHighPwrLevel_Normal ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerSavePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
u1Byte index ;
u4Byte Power_Index_REG [ 6 ] = { 0xc90 , 0xc91 , 0xc92 , 0xc98 , 0xc99 , 0xc9a } ;
2013-05-19 04:28:07 +00:00
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( Adapter ) ;
2013-05-08 21:45:39 +00:00
struct dm_priv * pdmpriv = & pHalData - > dmpriv ;
2013-05-09 04:04:25 +00:00
for ( index = 0 ; index < 6 ; index + + )
2013-05-08 21:45:39 +00:00
pdmpriv - > PowerIndex_backup [ index ] = rtw_read8 ( Adapter , Power_Index_REG [ index ] ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerRestorePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
u1Byte index ;
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-05-08 21:45:39 +00:00
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( Adapter ) ;
2013-05-08 21:45:39 +00:00
u4Byte Power_Index_REG [ 6 ] = { 0xc90 , 0xc91 , 0xc92 , 0xc98 , 0xc99 , 0xc9a } ;
struct dm_priv * pdmpriv = & pHalData - > dmpriv ;
2013-05-09 04:04:25 +00:00
for ( index = 0 ; index < 6 ; index + + )
2013-05-08 21:45:39 +00:00
rtw_write8 ( Adapter , Power_Index_REG [ index ] , pdmpriv - > PowerIndex_backup [ index ] ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerWritePowerIndex (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Value )
2013-05-08 21:45:39 +00:00
{
u1Byte index ;
u4Byte Power_Index_REG [ 6 ] = { 0xc90 , 0xc91 , 0xc92 , 0xc98 , 0xc99 , 0xc9a } ;
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
for ( index = 0 ; index < 6 ; index + + )
2013-05-08 21:45:39 +00:00
ODM_Write1Byte ( pDM_Odm , Power_Index_REG [ index ] , Value ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPower (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
2013-07-26 16:20:42 +00:00
/* For AP/ADSL use struct rtl8192cd_priv * */
2013-07-27 01:08:39 +00:00
/* For CE/NIC use struct adapter * */
2013-07-10 18:25:07 +00:00
/* */
2013-05-08 21:45:39 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_DYNAMIC_TXPWR ) )
return ;
2013-07-10 18:25:07 +00:00
/* 2012/01/12 MH According to Luke's suggestion, only high power will support the feature. */
2013-05-27 22:32:24 +00:00
if ( pDM_Odm - > ExtPA = = false )
2013-05-08 21:45:39 +00:00
return ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
switch ( pDM_Odm - > SupportPlatform ) {
case ODM_MP :
case ODM_CE :
odm_DynamicTxPowerNIC ( pDM_Odm ) ;
break ;
case ODM_AP :
odm_DynamicTxPowerAP ( pDM_Odm ) ;
break ;
case ODM_ADSL :
break ;
2013-05-08 21:45:39 +00:00
}
}
2013-07-26 16:20:42 +00:00
void odm_DynamicTxPowerNIC ( struct odm_dm_struct * pDM_Odm )
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_DYNAMIC_TXPWR ) )
return ;
2013-05-19 04:28:07 +00:00
2013-07-21 23:06:56 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* ??? */
/* This part need to be redefined. */
2013-05-08 21:45:39 +00:00
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_DynamicTxPowerAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
}
2013-07-26 16:20:42 +00:00
void odm_DynamicTxPower_92C ( struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 RSSI Monitor */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
2013-07-26 16:20:42 +00:00
/* For AP/ADSL use struct rtl8192cd_priv * */
2013-07-27 01:08:39 +00:00
/* For CE/NIC use struct adapter * */
2013-07-10 18:25:07 +00:00
/* */
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter = pDM_Odm - > Adapter ;
2013-07-26 16:20:42 +00:00
struct rtl8192cd_priv * priv = pDM_Odm - > priv ;
2013-05-08 21:45:39 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_RSSI_MONITOR ) )
return ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
2013-05-08 21:45:39 +00:00
switch ( pDM_Odm - > SupportPlatform )
{
case ODM_MP :
odm_RSSIMonitorCheckMP ( pDM_Odm ) ;
break ;
case ODM_CE :
odm_RSSIMonitorCheckCE ( pDM_Odm ) ;
break ;
case ODM_AP :
odm_RSSIMonitorCheckAP ( pDM_Odm ) ;
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
case ODM_ADSL :
2013-07-10 18:25:07 +00:00
/* odm_DIGAP(pDM_Odm); */
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
} /* odm_RSSIMonitorCheck */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-15 04:50:52 +00:00
}
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
/* */
/* sherry move from DUSC to here 20110517 */
/* */
static void
FindMinimumRSSI_Dmsp (
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter
2013-07-15 04:50:52 +00:00
)
{
}
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
static void
FindMinimumRSSI (
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter
2013-07-15 04:50:52 +00:00
)
{
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( pAdapter ) ;
2013-07-15 04:50:52 +00:00
struct dm_priv * pdmpriv = & pHalData - > dmpriv ;
struct mlme_priv * pmlmepriv = & pAdapter - > mlmepriv ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* 1 1.Determine the minimum RSSI */
2013-05-26 03:02:10 +00:00
if ( ( check_fwstate ( pmlmepriv , _FW_LINKED ) = = false ) & &
2013-05-08 21:45:39 +00:00
( pdmpriv - > EntryMinUndecoratedSmoothedPWDB = = 0 ) )
{
pdmpriv - > MinUndecoratedPWDBForDM = 0 ;
}
2013-07-10 18:25:07 +00:00
if ( check_fwstate ( pmlmepriv , _FW_LINKED ) = = true ) /* Default port */
2013-05-08 21:45:39 +00:00
{
pdmpriv - > MinUndecoratedPWDBForDM = pdmpriv - > EntryMinUndecoratedSmoothedPWDB ;
}
2013-07-10 18:25:07 +00:00
else /* associated entry pwdb */
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
pdmpriv - > MinUndecoratedPWDBForDM = pdmpriv - > EntryMinUndecoratedSmoothedPWDB ;
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( Adapter ) ;
2013-05-08 21:45:39 +00:00
struct dm_priv * pdmpriv = & pHalData - > dmpriv ;
int i ;
int tmpEntryMaxPWDB = 0 , tmpEntryMinPWDB = 0xff ;
2013-05-19 04:28:07 +00:00
u8 sta_cnt = 0 ;
2013-07-10 18:25:07 +00:00
u32 PWDB_rssi [ NUM_STA ] = { 0 } ; /* 0~15]:MACID, [16~31]:PWDB_rssi */
2013-05-08 21:45:39 +00:00
2013-07-12 03:50:49 +00:00
if ( ! check_fwstate ( & Adapter - > mlmepriv , _FW_LINKED ) )
2013-05-08 21:45:39 +00:00
return ;
{
struct sta_info * psta ;
struct sta_priv * pstapriv = & Adapter - > stapriv ;
u8 bcast_addr [ ETH_ALEN ] = { 0xff , 0xff , 0xff , 0xff , 0xff , 0xff } ;
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
for ( i = 0 ; i < ODM_ASSOCIATE_ENTRY_NUM ; i + + ) {
2013-05-08 21:45:39 +00:00
if ( IS_STA_VALID ( psta = pDM_Odm - > pODM_StaInfo [ i ] )
& & ( psta - > state & WIFI_ASOC_STATE )
2013-05-26 03:02:10 +00:00
& & _rtw_memcmp ( psta - > hwaddr , bcast_addr , ETH_ALEN ) = = false
& & _rtw_memcmp ( psta - > hwaddr , myid ( & Adapter - > eeprompriv ) , ETH_ALEN ) = = false
2013-05-08 21:45:39 +00:00
) {
2013-05-09 04:04:25 +00:00
if ( psta - > rssi_stat . UndecoratedSmoothedPWDB < tmpEntryMinPWDB )
2013-05-08 21:45:39 +00:00
tmpEntryMinPWDB = psta - > rssi_stat . UndecoratedSmoothedPWDB ;
2013-05-09 04:04:25 +00:00
if ( psta - > rssi_stat . UndecoratedSmoothedPWDB > tmpEntryMaxPWDB )
2013-05-08 21:45:39 +00:00
tmpEntryMaxPWDB = psta - > rssi_stat . UndecoratedSmoothedPWDB ;
2013-05-09 04:04:25 +00:00
if ( psta - > rssi_stat . UndecoratedSmoothedPWDB ! = ( - 1 ) ) {
2013-05-08 21:45:39 +00:00
PWDB_rssi [ sta_cnt + + ] = ( psta - > mac_id | ( psta - > rssi_stat . UndecoratedSmoothedPWDB < < 16 ) ) ;
}
}
}
2013-07-10 18:25:07 +00:00
for ( i = 0 ; i < sta_cnt ; i + + ) {
2013-05-09 04:04:25 +00:00
if ( PWDB_rssi [ i ] ! = ( 0 ) ) {
2013-07-10 18:25:07 +00:00
if ( pHalData - > fw_ractrl = = true ) /* Report every sta's RSSI to FW */
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
}
else {
ODM_RA_SetRSSI_8188E (
& ( pHalData - > odmpriv ) , ( PWDB_rssi [ i ] & 0xFF ) , ( u8 ) ( ( PWDB_rssi [ i ] > > 16 ) & 0xFF ) ) ;
}
}
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
if ( tmpEntryMaxPWDB ! = 0 ) /* If associated entry is found */
2013-05-08 21:45:39 +00:00
{
2013-05-19 04:28:07 +00:00
pdmpriv - > EntryMaxUndecoratedSmoothedPWDB = tmpEntryMaxPWDB ;
2013-05-08 21:45:39 +00:00
}
else
{
pdmpriv - > EntryMaxUndecoratedSmoothedPWDB = 0 ;
}
2013-07-10 18:25:07 +00:00
if ( tmpEntryMinPWDB ! = 0xff ) /* If associated entry is found */
2013-05-08 21:45:39 +00:00
{
2013-05-19 04:28:07 +00:00
pdmpriv - > EntryMinUndecoratedSmoothedPWDB = tmpEntryMinPWDB ;
2013-05-08 21:45:39 +00:00
}
else
{
pdmpriv - > EntryMinUndecoratedSmoothedPWDB = 0 ;
}
FindMinimumRSSI ( Adapter ) ;
ODM_CmnInfoUpdate ( & pHalData - > odmpriv , ODM_CMNINFO_RSSI_MIN , pdmpriv - > MinUndecoratedPWDBForDM ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_RSSIMonitorCheckAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_InitAllTimers (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
ODM_InitializeTimer ( pDM_Odm , & pDM_Odm - > DM_SWAT_Table . SwAntennaSwitchTimer ,
2013-07-26 20:25:06 +00:00
( void * ) odm_SwAntDivChkAntSwitchCallback , NULL , " SwAntennaSwitchTimer " ) ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_CancelAllTimers (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
ODM_CancelTimer ( pDM_Odm , & pDM_Odm - > DM_SWAT_Table . SwAntennaSwitchTimer ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_ReleaseAllTimers (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
ODM_ReleaseTimer ( pDM_Odm , & pDM_Odm - > DM_SWAT_Table . SwAntennaSwitchTimer ) ;
ODM_ReleaseTimer ( pDM_Odm , & pDM_Odm - > FastAntTrainingTimer ) ;
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 Tx Power Tracking */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
odm_TXPowerTrackingThermalMeterInit ( pDM_Odm ) ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingThermalMeterInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-07-11 15:59:02 +00:00
pDM_Odm - > RFCalibrateInfo . bTXPowerTracking = true ;
pDM_Odm - > RFCalibrateInfo . TXPowercount = 0 ;
pDM_Odm - > RFCalibrateInfo . bTXPowerTrackingInit = false ;
if ( * ( pDM_Odm - > mp_mode ) ! = 1 )
2013-05-26 03:02:10 +00:00
pDM_Odm - > RFCalibrateInfo . TxPowerTrackControl = true ;
2013-07-11 15:59:02 +00:00
MSG_88E ( " pDM_Odm TxPowerTrackControl = %d \n " , pDM_Odm - > RFCalibrateInfo . TxPowerTrackControl ) ;
2013-05-08 21:45:39 +00:00
2013-07-11 15:59:02 +00:00
pDM_Odm - > RFCalibrateInfo . TxPowerTrackControl = true ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_TXPowerTrackingCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
2013-07-26 16:20:42 +00:00
/* For AP/ADSL use struct rtl8192cd_priv * */
2013-07-27 01:08:39 +00:00
/* For CE/NIC use struct adapter * */
2013-07-10 18:25:07 +00:00
/* */
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter = pDM_Odm - > Adapter ;
2013-07-26 16:20:42 +00:00
struct rtl8192cd_priv * priv = pDM_Odm - > priv ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* if (!(pDM_Odm->SupportAbility & ODM_RF_TX_PWR_TRACK)) */
/* return; */
2013-05-26 17:17:22 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
2013-05-08 21:45:39 +00:00
switch ( pDM_Odm - > SupportPlatform )
{
case ODM_MP :
odm_TXPowerTrackingCheckMP ( pDM_Odm ) ;
break ;
case ODM_CE :
odm_TXPowerTrackingCheckCE ( pDM_Odm ) ;
break ;
case ODM_AP :
2013-05-19 04:28:07 +00:00
odm_TXPowerTrackingCheckAP ( pDM_Odm ) ;
break ;
2013-05-08 21:45:39 +00:00
case ODM_ADSL :
2013-07-10 18:25:07 +00:00
/* odm_DIGAP(pDM_Odm); */
2013-05-19 04:28:07 +00:00
break ;
2013-05-08 21:45:39 +00:00
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_RF_TX_PWR_TRACK ) )
2013-05-08 21:45:39 +00:00
{
return ;
}
2013-07-10 18:25:07 +00:00
if ( ! pDM_Odm - > RFCalibrateInfo . TM_Trigger ) /* at least delay 1 sec */
2013-05-08 21:45:39 +00:00
{
PHY_SetRFReg ( Adapter , RF_PATH_A , RF_T_METER_88E , BIT17 | BIT16 , 0x03 ) ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
pDM_Odm - > RFCalibrateInfo . TM_Trigger = 1 ;
return ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
}
else
{
odm_TXPowerTrackingCallback_ThermalMeter_8188E ( Adapter ) ;
pDM_Odm - > RFCalibrateInfo . TM_Trigger = 0 ;
}
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckMP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_TXPowerTrackingCheckAP (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-07-10 18:25:07 +00:00
/* antenna mapping info */
/* 1: right-side antenna */
/* 2/0: left-side antenna */
/* PDM_SWAT_Table->CCK_Ant1_Cnt /OFDM_Ant1_Cnt: for right-side antenna: Ant:1 RxDefaultAnt1 */
/* PDM_SWAT_Table->CCK_Ant2_Cnt /OFDM_Ant2_Cnt: for left-side antenna: Ant:0 RxDefaultAnt2 */
/* We select left antenna as default antenna in initial process, modify it as needed */
/* */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 SW Antenna Diversity */
/* 3============================================================ */
2013-07-26 16:20:42 +00:00
void odm_SwAntDivInit ( struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
}
2013-07-26 16:20:42 +00:00
void ODM_SwAntDivChkPerPktRssi ( struct odm_dm_struct * pDM_Odm , u1Byte StationID , struct odm_phy_status_info * pPhyInfo )
2013-05-08 21:45:39 +00:00
{
}
2013-07-26 16:20:42 +00:00
void odm_SwAntDivChkAntSwitch ( struct odm_dm_struct * pDM_Odm , u1Byte Step )
2013-05-08 21:45:39 +00:00
{
}
2013-07-26 16:20:42 +00:00
static void ODM_SwAntDivResetBeforeLink ( struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
2013-07-14 19:10:10 +00:00
2013-05-08 21:45:39 +00:00
}
2013-07-26 16:20:42 +00:00
void ODM_SwAntDivRestAfterLink ( struct odm_dm_struct * pDM_Odm )
2013-05-19 04:28:07 +00:00
{
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void odm_SwAntDivChkAntSwitchCallback ( void * FunctionContext )
2013-05-08 21:45:39 +00:00
{
}
2013-07-10 18:25:07 +00:00
/* 3============================================================ */
/* 3 SW Antenna Diversity */
/* 3============================================================ */
2013-05-08 21:45:39 +00:00
2013-06-03 19:52:18 +00:00
static void odm_InitHybridAntDiv_88C_92D (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-07-10 18:25:07 +00:00
u1Byte bTxPathSel = 0 ; /* 0:Path-A 1:Path-B */
2013-05-08 21:45:39 +00:00
u1Byte i ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_InitHybridAntDiv==============> \n " ) ) ;
2013-07-10 18:25:07 +00:00
/* whether to do antenna diversity or not */
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > SupportICType ! = ODM_RTL8192C ) & & ( pDM_Odm - > SupportICType ! = ODM_RTL8192D ) )
2013-05-08 21:45:39 +00:00
return ;
2013-05-27 22:32:24 +00:00
bTxPathSel = ( pDM_Odm - > RFType = = ODM_1T1R ) ? false : true ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_BB_PWR_SAV1_11N , BIT23 , 0 ) ; /* No update ANTSEL during GNT_BT=1 */
ODM_SetBBReg ( pDM_Odm , ODM_REG_TX_ANT_CTRL_11N , BIT21 , 1 ) ; /* TX atenna selection from tx_info */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTSEL_PIN_11N , BIT23 , 1 ) ; /* enable LED[1:0] pin as ANTSEL */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTSEL_CTRL_11N , BIT8 | BIT9 , 0x01 ) ; /* 0x01: left antenna, 0x02: right antenna */
/* check HW setting: ANTSEL pin connection */
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* only AP support different path selection temperarly */
if ( ! bTxPathSel ) { /* PATH-A */
ODM_SetBBReg ( pDM_Odm , ODM_REG_PIN_CTRL_11N , BIT8 | BIT9 , 0 ) ; /* ANTSEL as HW control */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTSEL_PATH_11N , BIT13 , 1 ) ; /* select TX ANTESEL from path A */
2013-07-15 04:50:52 +00:00
} else {
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_PIN_CTRL_11N , BIT24 | BIT25 , 0 ) ; /* ANTSEL as HW control */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTSEL_PATH_11N , BIT13 , 0 ) ; /* select ANTESEL from path B */
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* Set OFDM HW RX Antenna Diversity */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTDIV_PARA1_11N , 0x7FF , 0x0c0 ) ; /* Pwdb threshold=8dB */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTDIV_PARA1_11N , BIT11 , 0 ) ; /* Switch to another antenna by checking pwdb threshold */
ODM_SetBBReg ( pDM_Odm , ODM_REG_ANTDIV_PARA3_11N , BIT23 , 1 ) ; /* Decide final antenna by comparing 2 antennas' pwdb */
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* Set CCK HW RX Antenna Diversity */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_ANTDIV_PARA2_11N , BIT4 , 0 ) ; /* Antenna diversity decision period = 32 sample */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_ANTDIV_PARA2_11N , 0xf , 0xf ) ; /* Threshold for antenna diversity. Check another antenna power if input power < ANT_lim*4 */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_ANTDIV_PARA3_11N , BIT13 , 1 ) ; /* polarity ana_A=1 and ana_B=0 */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_ANTDIV_PARA4_11N , 0x1f , 0x8 ) ; /* default antenna power = inpwr*(0.5 + r_ant_step/16) */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* Enable HW Antenna Diversity */
if ( ! bTxPathSel ) /* PATH-A */
ODM_SetBBReg ( pDM_Odm , ODM_REG_IGI_A_11N , BIT7 , 1 ) ; /* Enable Hardware antenna switch */
2013-05-08 21:45:39 +00:00
else
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_IGI_B_11N , BIT7 , 1 ) ; /* Enable Hardware antenna switch */
ODM_SetBBReg ( pDM_Odm , ODM_REG_CCK_ANTDIV_PARA1_11N , BIT15 , 1 ) ; /* Enable antenna diversity */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
pDM_SWAT_Table - > CurAntenna = 0 ; /* choose left antenna as default antenna */
2013-05-08 21:45:39 +00:00
pDM_SWAT_Table - > PreAntenna = 0 ;
2013-05-09 04:04:25 +00:00
for ( i = 0 ; i < ASSOCIATE_ENTRY_NUM ; i + + )
2013-05-08 21:45:39 +00:00
{
pDM_SWAT_Table - > CCK_Ant1_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > CCK_Ant2_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > OFDM_Ant1_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > OFDM_Ant2_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > RSSI_Ant1_Sum [ i ] = 0 ;
pDM_SWAT_Table - > RSSI_Ant2_Sum [ i ] = 0 ;
}
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " <==============odm_InitHybridAntDiv \n " ) ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_InitHybridAntDiv (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_ANT_DIV ) )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Return: Not Support HW AntDiv \n " ) ) ;
return ;
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ( ODM_RTL8192C | ODM_RTL8192D ) )
2013-05-08 21:45:39 +00:00
{
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportICType = = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
{
ODM_AntennaDiversityInit_88E ( pDM_Odm ) ;
}
}
2013-07-27 02:37:57 +00:00
bool odm_StaDefAntSel ( struct odm_dm_struct * pDM_Odm , u4Byte OFDM_Ant1_Cnt ,
u4Byte OFDM_Ant2_Cnt , u4Byte CCK_Ant1_Cnt , u4Byte CCK_Ant2_Cnt , u1Byte * pDefAnt )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_StaDefAntSelect==============> \n " ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " OFDM_Ant1_Cnt:%d, OFDM_Ant2_Cnt:%d \n " , OFDM_Ant1_Cnt , OFDM_Ant2_Cnt ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " CCK_Ant1_Cnt:%d, CCK_Ant2_Cnt:%d \n " , CCK_Ant1_Cnt , CCK_Ant2_Cnt ) ) ;
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( ( ( OFDM_Ant1_Cnt + OFDM_Ant2_Cnt ) = = 0 ) & & ( ( CCK_Ant1_Cnt + CCK_Ant2_Cnt ) < 10 ) ) {
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_StaDefAntSelect Fail: No enough packet info! \n " ) ) ;
2013-05-27 22:32:24 +00:00
return false ;
2013-05-08 21:45:39 +00:00
}
2013-05-09 04:04:25 +00:00
if ( OFDM_Ant1_Cnt | | OFDM_Ant2_Cnt ) {
2013-07-10 18:25:07 +00:00
/* if RX OFDM packet number larger than 0 */
2013-05-09 04:04:25 +00:00
if ( OFDM_Ant1_Cnt > OFDM_Ant2_Cnt )
2013-05-08 21:45:39 +00:00
( * pDefAnt ) = 1 ;
else
( * pDefAnt ) = 0 ;
}
2013-07-10 18:25:07 +00:00
/* else if RX CCK packet number larger than 10 */
2013-05-09 04:04:25 +00:00
else if ( ( CCK_Ant1_Cnt + CCK_Ant2_Cnt ) > = 10 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( CCK_Ant1_Cnt > ( 5 * CCK_Ant2_Cnt ) )
2013-05-08 21:45:39 +00:00
( * pDefAnt ) = 1 ;
2013-05-09 04:04:25 +00:00
else if ( CCK_Ant2_Cnt > ( 5 * CCK_Ant1_Cnt ) )
2013-05-08 21:45:39 +00:00
( * pDefAnt ) = 0 ;
2013-05-09 04:04:25 +00:00
else if ( CCK_Ant1_Cnt > CCK_Ant2_Cnt )
2013-05-08 21:45:39 +00:00
( * pDefAnt ) = 0 ;
else
( * pDefAnt ) = 1 ;
}
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " TxAnt = %s \n " , ( ( * pDefAnt ) = = 1 ) ? " Ant1 " : " Ant2 " ) ) ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " <==============odm_StaDefAntSelect \n " ) ) ;
2013-05-27 22:32:24 +00:00
return true ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_SetRxIdleAnt (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte Ant ,
2013-05-27 03:51:56 +00:00
bool bDualPath
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
if ( Ant ! = pDM_SWAT_Table - > RxIdleAnt ) {
/* for path-A */
if ( Ant = = 1 )
ODM_SetBBReg ( pDM_Odm , ODM_REG_RX_DEFUALT_A_11N , 0xFFFF , 0x65a9 ) ; /* right-side antenna */
else
ODM_SetBBReg ( pDM_Odm , ODM_REG_RX_DEFUALT_A_11N , 0xFFFF , 0x569a ) ; /* left-side antenna */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* for path-B */
if ( bDualPath ) {
2013-05-19 04:28:07 +00:00
if ( Ant = = 0 )
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , ODM_REG_RX_DEFUALT_A_11N , 0xFFFF0000 , 0x65a9 ) ; /* right-side antenna */
else
ODM_SetBBReg ( pDM_Odm , ODM_REG_RX_DEFUALT_A_11N , 0xFFFF0000 , 0x569a ) ; /* left-side antenna */
2013-05-08 21:45:39 +00:00
}
}
2013-07-10 18:25:07 +00:00
pDM_SWAT_Table - > RxIdleAnt = Ant ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " RxIdleAnt: %s Reg858=0x%x \n " , ( Ant = = 1 ) ? " Ant1 " : " Ant2 " , ( Ant = = 1 ) ? 0x65a9 : 0x569a ) ) ;
2013-07-10 18:25:07 +00:00
}
2013-05-19 04:28:07 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_AntselStatistics_88C (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte MacId ,
u4Byte PWDBAll ,
bool isCCKrate
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_SWAT_Table - > antsel = = 1 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( isCCKrate )
2013-05-08 21:45:39 +00:00
pDM_SWAT_Table - > CCK_Ant1_Cnt [ MacId ] + + ;
else
{
pDM_SWAT_Table - > OFDM_Ant1_Cnt [ MacId ] + + ;
pDM_SWAT_Table - > RSSI_Ant1_Sum [ MacId ] + = PWDBAll ;
}
}
else
{
2013-05-09 04:04:25 +00:00
if ( isCCKrate )
2013-05-08 21:45:39 +00:00
pDM_SWAT_Table - > CCK_Ant2_Cnt [ MacId ] + + ;
else
{
pDM_SWAT_Table - > OFDM_Ant2_Cnt [ MacId ] + + ;
pDM_SWAT_Table - > RSSI_Ant2_Sum [ MacId ] + = PWDBAll ;
}
}
}
2013-07-15 04:50:52 +00:00
static void
ODM_SetTxAntByTxInfo_88C_92D (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
}
2013-07-26 16:20:42 +00:00
static void odm_HwAntDiv_92C_92D ( struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-05-08 21:45:39 +00:00
u4Byte RSSI_Min = 0xFF , RSSI , RSSI_Ant1 , RSSI_Ant2 ;
u1Byte RxIdleAnt , i ;
2013-05-27 22:32:24 +00:00
bool bRet = false ;
2013-07-26 20:25:06 +00:00
struct sta_info * pEntry ;
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_HwAntDiv==============> \n " ) ) ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_ANT_DIV ) ) /* if don't support antenna diveristy */
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " odm_HwAntDiv: Not supported! \n " ) ) ;
return ;
}
2013-05-09 04:04:25 +00:00
if ( ( pDM_Odm - > SupportICType ! = ODM_RTL8192C ) & & ( pDM_Odm - > SupportICType ! = ODM_RTL8192D ) )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Return: IC Type is not 92C or 92D \n " ) ) ;
return ;
}
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
if ( ! pDM_Odm - > bLinked ) {
2013-05-27 22:32:24 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Return: bLinked is false \n " ) ) ;
2013-05-08 21:45:39 +00:00
return ;
}
2013-07-15 04:50:52 +00:00
for ( i = 0 ; i < ODM_ASSOCIATE_ENTRY_NUM ; i + + ) {
2013-05-08 21:45:39 +00:00
pEntry = pDM_Odm - > pODM_StaInfo [ i ] ;
2013-07-15 04:50:52 +00:00
if ( IS_STA_VALID ( pEntry ) ) {
2013-05-08 21:45:39 +00:00
RSSI_Ant1 = ( pDM_SWAT_Table - > OFDM_Ant1_Cnt [ i ] = = 0 ) ? 0 : ( pDM_SWAT_Table - > RSSI_Ant1_Sum [ i ] / pDM_SWAT_Table - > OFDM_Ant1_Cnt [ i ] ) ;
RSSI_Ant2 = ( pDM_SWAT_Table - > OFDM_Ant2_Cnt [ i ] = = 0 ) ? 0 : ( pDM_SWAT_Table - > RSSI_Ant2_Sum [ i ] / pDM_SWAT_Table - > OFDM_Ant2_Cnt [ i ] ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " RSSI_Ant1=%d, RSSI_Ant2=%d \n " , RSSI_Ant1 , RSSI_Ant2 ) ) ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
if ( RSSI_Ant1 | | RSSI_Ant2 ) {
RSSI = ( RSSI_Ant1 < RSSI_Ant2 ) ? RSSI_Ant1 : RSSI_Ant2 ;
if ( ( ! RSSI ) | | ( RSSI < RSSI_Min ) ) {
pDM_SWAT_Table - > TargetSTA = i ;
RSSI_Min = RSSI ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
}
2013-07-10 18:25:07 +00:00
/* STA: found out default antenna */
2013-05-19 04:28:07 +00:00
bRet = odm_StaDefAntSel ( pDM_Odm ,
pDM_SWAT_Table - > OFDM_Ant1_Cnt [ i ] ,
pDM_SWAT_Table - > OFDM_Ant2_Cnt [ i ] ,
pDM_SWAT_Table - > CCK_Ant1_Cnt [ i ] ,
pDM_SWAT_Table - > CCK_Ant2_Cnt [ i ] ,
2013-05-08 21:45:39 +00:00
& pDM_SWAT_Table - > TxAnt [ i ] ) ;
2013-07-10 18:25:07 +00:00
/* if Tx antenna selection: successful */
2013-05-19 04:28:07 +00:00
if ( bRet ) {
2013-05-08 21:45:39 +00:00
pDM_SWAT_Table - > RSSI_Ant1_Sum [ i ] = 0 ;
pDM_SWAT_Table - > RSSI_Ant2_Sum [ i ] = 0 ;
pDM_SWAT_Table - > OFDM_Ant1_Cnt [ i ] = 0 ;
2013-05-19 04:28:07 +00:00
pDM_SWAT_Table - > OFDM_Ant2_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > CCK_Ant1_Cnt [ i ] = 0 ;
pDM_SWAT_Table - > CCK_Ant2_Cnt [ i ] = 0 ;
2013-05-08 21:45:39 +00:00
}
}
}
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* set RX Idle Ant */
2013-05-08 21:45:39 +00:00
RxIdleAnt = pDM_SWAT_Table - > TxAnt [ pDM_SWAT_Table - > TargetSTA ] ;
2013-05-27 22:32:24 +00:00
odm_SetRxIdleAnt ( pDM_Odm , RxIdleAnt , false ) ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " <==============odm_HwAntDiv \n " ) ) ;
}
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_HwAntDiv (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
2013-05-19 04:28:07 +00:00
{
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_ANT_DIV ) )
2013-05-08 21:45:39 +00:00
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Return: Not Support HW AntDiv \n " ) ) ;
return ;
}
2013-05-19 04:28:07 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType & ( ODM_RTL8192C | ODM_RTL8192D ) )
2013-05-08 21:45:39 +00:00
{
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportICType = = ODM_RTL8188E )
2013-05-08 21:45:39 +00:00
{
ODM_AntennaDiversity_88E ( pDM_Odm ) ;
}
}
2013-07-10 18:25:07 +00:00
/* */
/* EDCA Turbo */
/* */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_EdcaTurboInit (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-05-27 22:32:24 +00:00
pDM_Odm - > DM_EDCA_Table . bCurrentTurboEDCA = false ;
pDM_Odm - > DM_EDCA_Table . bIsCurRDLState = false ;
Adapter - > recvpriv . bIsAnyNonBEPkts = false ;
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " Orginial VO PARAM: 0x%x \n " , ODM_Read4Byte ( pDM_Odm , ODM_EDCA_VO_PARAM ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " Orginial VI PARAM: 0x%x \n " , ODM_Read4Byte ( pDM_Odm , ODM_EDCA_VI_PARAM ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " Orginial BE PARAM: 0x%x \n " , ODM_Read4Byte ( pDM_Odm , ODM_EDCA_BE_PARAM ) ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " Orginial BK PARAM: 0x%x \n " , ODM_Read4Byte ( pDM_Odm , ODM_EDCA_BK_PARAM ) ) ) ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
} /* ODM_InitEdcaTurbo */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_EdcaTurboCheck (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-10 18:25:07 +00:00
/* */
2013-07-26 16:20:42 +00:00
/* For AP/ADSL use struct rtl8192cd_priv * */
2013-07-27 01:08:39 +00:00
/* For CE/NIC use struct adapter * */
2013-07-10 18:25:07 +00:00
/* */
2013-07-27 01:08:39 +00:00
struct adapter * pAdapter = pDM_Odm - > Adapter ;
2013-07-26 16:20:42 +00:00
struct rtl8192cd_priv * priv = pDM_Odm - > priv ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* 2011/09/29 MH In HW integration first stage, we provide 4 different handle to operate */
/* at the same time. In the stage2/3, we need to prive universal interface and merge all */
/* HW dynamic mechanism. */
/* */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " odm_EdcaTurboCheck========================> \n " ) ) ;
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_MAC_EDCA_TURBO ) )
2013-05-08 21:45:39 +00:00
return ;
2013-07-15 04:50:52 +00:00
switch ( pDM_Odm - > SupportPlatform ) {
case ODM_MP :
break ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
case ODM_CE :
odm_EdcaTurboCheckCE ( pDM_Odm ) ;
break ;
case ODM_AP :
case ODM_ADSL :
break ;
2013-05-08 21:45:39 +00:00
}
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_EDCA_TURBO , ODM_DBG_LOUD , ( " <========================odm_EdcaTurboCheck \n " ) ) ;
2013-07-10 18:25:07 +00:00
} /* odm_CheckEdcaTurbo */
2013-05-08 21:45:39 +00:00
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
odm_EdcaTurboCheckCE (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-27 01:08:39 +00:00
struct adapter * Adapter = pDM_Odm - > Adapter ;
2013-05-19 04:28:07 +00:00
u32 trafficIndex ;
2013-05-08 21:45:39 +00:00
u32 edca_param ;
u64 cur_tx_bytes = 0 ;
u64 cur_rx_bytes = 0 ;
2013-05-26 03:02:10 +00:00
u8 bbtchange = false ;
2013-07-22 23:18:19 +00:00
struct hal_data_8188e * pHalData = GET_HAL_DATA ( Adapter ) ;
2013-07-15 04:50:52 +00:00
struct xmit_priv * pxmitpriv = & ( Adapter - > xmitpriv ) ;
struct recv_priv * precvpriv = & ( Adapter - > recvpriv ) ;
struct registry_priv * pregpriv = & Adapter - > registrypriv ;
struct mlme_ext_priv * pmlmeext = & ( Adapter - > mlmeextpriv ) ;
struct mlme_ext_info * pmlmeinfo = & ( pmlmeext - > mlmext_info ) ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
if ( ( pregpriv - > wifi_spec = = 1 ) ) /* (pmlmeinfo->HT_enable == 0)) */
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
goto dm_CheckEdcaTurbo_EXIT ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
if ( pmlmeinfo - > assoc_AP_vendor > = HT_IOT_PEER_MAX )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
goto dm_CheckEdcaTurbo_EXIT ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
# ifdef CONFIG_BT_COEXIST
if ( BT_DisableEDCATurbo ( Adapter ) )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
goto dm_CheckEdcaTurbo_EXIT ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
# endif
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
/* Check if the status needs to be changed. */
if ( ( bbtchange ) | | ( ! precvpriv - > bIsAnyNonBEPkts ) )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
cur_tx_bytes = pxmitpriv - > tx_bytes - pxmitpriv - > last_tx_bytes ;
cur_rx_bytes = precvpriv - > rx_bytes - precvpriv - > last_rx_bytes ;
/* traffic, TX or RX */
if ( ( pmlmeinfo - > assoc_AP_vendor = = HT_IOT_PEER_RALINK ) | | ( pmlmeinfo - > assoc_AP_vendor = = HT_IOT_PEER_ATHEROS ) )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
if ( cur_tx_bytes > ( cur_rx_bytes < < 2 ) )
{ /* Uplink TP is present. */
trafficIndex = UP_LINK ;
}
else
{ /* Balance TP is present. */
trafficIndex = DOWN_LINK ;
}
2013-05-08 21:45:39 +00:00
}
else
{
2013-07-15 04:50:52 +00:00
if ( cur_rx_bytes > ( cur_tx_bytes < < 2 ) )
{ /* Downlink TP is present. */
trafficIndex = DOWN_LINK ;
2013-05-08 21:45:39 +00:00
}
else
2013-07-15 04:50:52 +00:00
{ /* Balance TP is present. */
trafficIndex = UP_LINK ;
2013-05-08 21:45:39 +00:00
}
}
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
if ( ( pDM_Odm - > DM_EDCA_Table . prv_traffic_idx ! = trafficIndex ) | | ( ! pDM_Odm - > DM_EDCA_Table . bCurrentTurboEDCA ) )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
if ( ( pmlmeinfo - > assoc_AP_vendor = = HT_IOT_PEER_CISCO ) & & ( pmlmeext - > cur_wireless_mode & WIRELESS_11_24N ) )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
edca_param = EDCAParam [ pmlmeinfo - > assoc_AP_vendor ] [ trafficIndex ] ;
2013-05-08 21:45:39 +00:00
}
else
{
2013-07-15 04:50:52 +00:00
edca_param = EDCAParam [ HT_IOT_PEER_UNKNOWN ] [ trafficIndex ] ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
rtw_write32 ( Adapter , REG_EDCA_BE_PARAM , edca_param ) ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
pDM_Odm - > DM_EDCA_Table . prv_traffic_idx = trafficIndex ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
pDM_Odm - > DM_EDCA_Table . bCurrentTurboEDCA = true ;
}
else
{
/* */
/* Turn Off EDCA turbo here. */
/* Restore original EDCA according to the declaration of AP. */
/* */
if ( pDM_Odm - > DM_EDCA_Table . bCurrentTurboEDCA )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
rtw_write32 ( Adapter , REG_EDCA_BE_PARAM , pHalData - > AcParam_BE ) ;
pDM_Odm - > DM_EDCA_Table . bCurrentTurboEDCA = false ;
}
}
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
dm_CheckEdcaTurbo_EXIT :
/* Set variables for next time. */
precvpriv - > bIsAnyNonBEPkts = false ;
pxmitpriv - > last_tx_bytes = pxmitpriv - > tx_bytes ;
precvpriv - > last_rx_bytes = precvpriv - > rx_bytes ;
}
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
/* need to ODM CE Platform */
/* move to here for ANT detection mechanism using */
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
u4Byte
GetPSDData (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-07-15 04:50:52 +00:00
unsigned int point ,
u1Byte initial_gain_psd )
{
u4Byte psd_report ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
/* Set DCO frequency index, offset=(40MHz/SamplePts)*point */
ODM_SetBBReg ( pDM_Odm , 0x808 , 0x3FF , point ) ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
/* Start PSD calculation, Reg808[22]=0->1 */
ODM_SetBBReg ( pDM_Odm , 0x808 , BIT22 , 1 ) ;
/* Need to wait for HW PSD report */
ODM_StallExecution ( 30 ) ;
ODM_SetBBReg ( pDM_Odm , 0x808 , BIT22 , 0 ) ;
/* Read PSD report, Reg8B4[15:0] */
psd_report = ODM_GetBBReg ( pDM_Odm , 0x8B4 , bMaskDWord ) & 0x0000FFFF ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
psd_report = ( u4Byte ) ( ConvertTo_dB ( psd_report ) ) + ( u4Byte ) ( initial_gain_psd - 0x1c ) ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
return psd_report ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
}
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
u4Byte
ConvertTo_dB (
u4Byte Value )
{
u1Byte i ;
u1Byte j ;
u4Byte dB ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
Value = Value & 0xFFFF ;
2013-05-19 04:28:07 +00:00
2013-07-15 04:50:52 +00:00
for ( i = 0 ; i < 8 ; i + + )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
if ( Value < = dB_Invert_Table [ i ] [ 11 ] )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
break ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
if ( i > = 8 )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
return ( 96 ) ; /* maximum 96 dB */
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
for ( j = 0 ; j < 12 ; j + + )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
if ( Value < = dB_Invert_Table [ i ] [ j ] )
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
break ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
dB = i * 12 + j + 1 ;
2013-05-08 21:45:39 +00:00
2013-07-15 04:50:52 +00:00
return ( dB ) ;
2013-05-08 21:45:39 +00:00
}
2013-07-15 04:50:52 +00:00
/* */
/* 2011/09/22 MH Add for 92D global spin lock utilization. */
/* */
2013-05-19 04:37:45 +00:00
void
2013-07-15 04:50:52 +00:00
odm_GlobalAdapterCheck (
void
)
2013-05-08 21:45:39 +00:00
{
2013-07-15 04:50:52 +00:00
} /* odm_GlobalAdapterCheck */
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* */
/* Description: */
/* Set Single/Dual Antenna default setting for products that do not do detection in advance. */
/* */
/* Added by Joseph, 2012.03.22 */
/* */
2013-05-19 04:37:45 +00:00
void
2013-05-08 21:45:39 +00:00
ODM_SingleDualAntennaDefaultSetting (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = true ;
pDM_SWAT_Table - > ANTB_ON = true ;
2013-05-08 21:45:39 +00:00
}
2013-07-10 18:25:07 +00:00
/* 2 8723A ANT DETECT */
2013-05-08 21:45:39 +00:00
2013-07-26 16:20:42 +00:00
static void odm_PHY_SaveAFERegisters ( struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
pu4Byte AFEReg ,
pu4Byte AFEBackup ,
u4Byte RegisterNum
2013-05-08 21:45:39 +00:00
)
{
u4Byte i ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* RTPRINT(FINIT, INIT_IQK, ("Save ADDA parameters.\n")); */
2013-05-09 04:04:25 +00:00
for ( i = 0 ; i < RegisterNum ; i + + ) {
2013-05-08 21:45:39 +00:00
AFEBackup [ i ] = ODM_GetBBReg ( pDM_Odm , AFEReg [ i ] , bMaskDWord ) ;
}
}
2013-06-03 19:52:18 +00:00
static void odm_PHY_ReloadAFERegisters (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
pu4Byte AFEReg ,
pu4Byte AFEBackup ,
u4Byte RegiesterNum
2013-05-08 21:45:39 +00:00
)
{
u4Byte i ;
2013-07-10 18:25:07 +00:00
/* RTPRINT(FINIT, INIT_IQK, ("Reload ADDA power saving parameters !\n")); */
2013-05-09 04:04:25 +00:00
for ( i = 0 ; i < RegiesterNum ; i + + )
2013-05-08 21:45:39 +00:00
{
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , AFEReg [ i ] , bMaskDWord , AFEBackup [ i ] ) ;
}
}
2013-07-10 18:25:07 +00:00
/* 2 8723A ANT DETECT */
/* */
/* Description: */
/* Implement IQK single tone for RF DPK loopback and BB PSD scanning. */
/* This function is cooperated with BB team Neil. */
/* */
/* Added by Roger, 2011.12.15 */
/* */
2013-05-19 04:48:10 +00:00
bool
2013-05-08 21:45:39 +00:00
ODM_SingleDualAntennaDetection (
2013-07-26 16:20:42 +00:00
struct odm_dm_struct * pDM_Odm ,
2013-05-25 20:45:50 +00:00
u1Byte mode
2013-05-08 21:45:39 +00:00
)
{
2013-07-26 16:20:42 +00:00
struct sw_ant_switch * pDM_SWAT_Table = & pDM_Odm - > DM_SWAT_Table ;
2013-05-08 21:45:39 +00:00
u4Byte CurrentChannel , RfLoopReg ;
u1Byte n ;
u4Byte Reg88c , Regc08 , Reg874 , Regc50 ;
u1Byte initial_gain = 0x5a ;
u4Byte PSD_report_tmp ;
u4Byte AntA_report = 0x0 , AntB_report = 0x0 , AntO_report = 0x0 ;
2013-05-27 22:32:24 +00:00
bool bResult = true ;
2013-05-08 21:45:39 +00:00
u4Byte AFE_Backup [ 16 ] ;
u4Byte AFE_REG_8723A [ 16 ] = {
2013-06-03 19:52:18 +00:00
rRx_Wait_CCA , rTx_CCK_RFON ,
rTx_CCK_BBON , rTx_OFDM_RFON ,
rTx_OFDM_BBON , rTx_To_Rx ,
rTx_To_Tx , rRx_CCK ,
rRx_OFDM , rRx_Wait_RIFS ,
rRx_TO_Rx , rStandby ,
rSleep , rPMPD_ANAEN ,
2013-05-08 21:45:39 +00:00
rFPGA0_XCD_SwitchControl , rBlue_Tooth } ;
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportICType & ( ODM_RTL8723A | ODM_RTL8192C ) ) )
2013-05-08 21:45:39 +00:00
return bResult ;
2013-05-09 04:04:25 +00:00
if ( ! ( pDM_Odm - > SupportAbility & ODM_BB_ANT_DIV ) )
2013-05-08 21:45:39 +00:00
return bResult ;
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8192C )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* Which path in ADC/DAC is turnned on for PSD: both I/Q */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0x808 , BIT10 | BIT11 , 0x3 ) ;
2013-07-10 18:25:07 +00:00
/* Ageraged number: 8 */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0x808 , BIT12 | BIT13 , 0x1 ) ;
2013-07-10 18:25:07 +00:00
/* pts = 128; */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , 0x808 , BIT14 | BIT15 , 0x0 ) ;
}
2013-07-10 18:25:07 +00:00
/* 1 Backup Current RF/BB Settings */
2013-05-19 04:28:07 +00:00
2013-05-08 21:45:39 +00:00
CurrentChannel = ODM_GetRFReg ( pDM_Odm , RF_PATH_A , ODM_CHANNEL , bRFRegOffsetMask ) ;
RfLoopReg = ODM_GetRFReg ( pDM_Odm , RF_PATH_A , 0x00 , bRFRegOffsetMask ) ;
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , ODM_DPDT , Antenna_A ) ; /* change to Antenna A */
/* Step 1: USE IQK to transmitter single tone */
2013-05-08 21:45:39 +00:00
ODM_StallExecution ( 10 ) ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* Store A Path Register 88c, c08, 874, c50 */
2013-05-08 21:45:39 +00:00
Reg88c = ODM_GetBBReg ( pDM_Odm , rFPGA0_AnalogParameter4 , bMaskDWord ) ;
Regc08 = ODM_GetBBReg ( pDM_Odm , rOFDM0_TRMuxPar , bMaskDWord ) ;
Reg874 = ODM_GetBBReg ( pDM_Odm , rFPGA0_XCD_RFInterfaceSW , bMaskDWord ) ;
2013-05-19 04:28:07 +00:00
Regc50 = ODM_GetBBReg ( pDM_Odm , rOFDM0_XAAGCCore1 , bMaskDWord ) ;
2013-07-10 18:25:07 +00:00
/* Store AFE Registers */
2013-05-19 04:28:07 +00:00
odm_PHY_SaveAFERegisters ( pDM_Odm , AFE_REG_8723A , AFE_Backup , 16 ) ;
2013-07-10 18:25:07 +00:00
/* Set PSD 128 pts */
ODM_SetBBReg ( pDM_Odm , rFPGA0_PSDFunction , BIT14 | BIT15 , 0x0 ) ; /* 128 pts */
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* To SET CH1 to do */
ODM_SetRFReg ( pDM_Odm , RF_PATH_A , ODM_CHANNEL , bRFRegOffsetMask , 0x01 ) ; /* Channel 1 */
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* AFE all on step */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rRx_Wait_CCA , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_CCK_RFON , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_CCK_BBON , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_OFDM_RFON , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_OFDM_BBON , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_To_Rx , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rTx_To_Tx , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_CCK , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_OFDM , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_Wait_RIFS , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_TO_Rx , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rStandby , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rSleep , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rPMPD_ANAEN , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rFPGA0_XCD_SwitchControl , bMaskDWord , 0x6FDB25A4 ) ;
ODM_SetBBReg ( pDM_Odm , rBlue_Tooth , bMaskDWord , 0x6FDB25A4 ) ;
2013-07-10 18:25:07 +00:00
/* 3 wire Disable */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_AnalogParameter4 , bMaskDWord , 0xCCF000C0 ) ;
2013-05-19 04:28:07 +00:00
2013-07-10 18:25:07 +00:00
/* BB IQK Setting */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rOFDM0_TRMuxPar , bMaskDWord , 0x000800E4 ) ;
ODM_SetBBReg ( pDM_Odm , rFPGA0_XCD_RFInterfaceSW , bMaskDWord , 0x22208000 ) ;
2013-07-10 18:25:07 +00:00
/* IQK setting tone@ 4.34Mhz */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rTx_IQK_Tone_A , bMaskDWord , 0x10008C1C ) ;
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , rTx_IQK , bMaskDWord , 0x01007c00 ) ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* Page B init */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rConfig_AntA , bMaskDWord , 0x00080000 ) ;
ODM_SetBBReg ( pDM_Odm , rConfig_AntA , bMaskDWord , 0x0f600000 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_IQK , bMaskDWord , 0x01004800 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_IQK_Tone_A , bMaskDWord , 0x10008c1f ) ;
ODM_SetBBReg ( pDM_Odm , rTx_IQK_PI_A , bMaskDWord , 0x82150008 ) ;
ODM_SetBBReg ( pDM_Odm , rRx_IQK_PI_A , bMaskDWord , 0x28150008 ) ;
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , rIQK_AGC_Rsp , bMaskDWord , 0x001028d0 ) ;
2013-05-08 21:45:39 +00:00
2013-07-10 18:25:07 +00:00
/* RF loop Setting */
2013-05-19 04:28:07 +00:00
ODM_SetRFReg ( pDM_Odm , RF_PATH_A , 0x0 , 0xFFFFF , 0x50008 ) ;
2013-07-10 18:25:07 +00:00
/* IQK Single tone start */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_IQK , bMaskDWord , 0x80800000 ) ;
ODM_SetBBReg ( pDM_Odm , rIQK_AGC_Pts , bMaskDWord , 0xf8000000 ) ;
ODM_StallExecution ( 1000 ) ;
PSD_report_tmp = 0x0 ;
for ( n = 0 ; n < 2 ; n + + )
2013-05-19 04:28:07 +00:00
{
PSD_report_tmp = GetPSDData ( pDM_Odm , 14 , initial_gain ) ;
2013-05-09 04:04:25 +00:00
if ( PSD_report_tmp > AntA_report )
2013-05-08 21:45:39 +00:00
AntA_report = PSD_report_tmp ;
}
PSD_report_tmp = 0x0 ;
2013-07-10 18:25:07 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , 0x300 , Antenna_B ) ; /* change to Antenna B */
2013-05-19 04:28:07 +00:00
ODM_StallExecution ( 10 ) ;
2013-05-08 21:45:39 +00:00
for ( n = 0 ; n < 2 ; n + + )
2013-05-19 04:28:07 +00:00
{
PSD_report_tmp = GetPSDData ( pDM_Odm , 14 , initial_gain ) ;
2013-05-09 04:04:25 +00:00
if ( PSD_report_tmp > AntB_report )
2013-05-08 21:45:39 +00:00
AntB_report = PSD_report_tmp ;
}
2013-07-10 18:25:07 +00:00
/* change to open case */
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , 0x300 , 0 ) ; /* change to Ant A and B all open case */
2013-05-19 04:28:07 +00:00
ODM_StallExecution ( 10 ) ;
2013-05-08 21:45:39 +00:00
for ( n = 0 ; n < 2 ; n + + )
2013-05-19 04:28:07 +00:00
{
PSD_report_tmp = GetPSDData ( pDM_Odm , 14 , initial_gain ) ;
2013-05-09 04:04:25 +00:00
if ( PSD_report_tmp > AntO_report )
2013-05-08 21:45:39 +00:00
AntO_report = PSD_report_tmp ;
}
2013-07-10 18:25:07 +00:00
/* Close IQK Single Tone function */
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_IQK , bMaskDWord , 0x00000000 ) ;
PSD_report_tmp = 0x0 ;
2013-07-10 18:25:07 +00:00
/* 1 Return to antanna A */
2013-05-19 04:28:07 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , 0x300 , Antenna_A ) ;
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_AnalogParameter4 , bMaskDWord , Reg88c ) ;
ODM_SetBBReg ( pDM_Odm , rOFDM0_TRMuxPar , bMaskDWord , Regc08 ) ;
ODM_SetBBReg ( pDM_Odm , rFPGA0_XCD_RFInterfaceSW , bMaskDWord , Reg874 ) ;
ODM_SetBBReg ( pDM_Odm , rOFDM0_XAAGCCore1 , 0x7F , 0x40 ) ;
ODM_SetBBReg ( pDM_Odm , rOFDM0_XAAGCCore1 , bMaskDWord , Regc50 ) ;
ODM_SetRFReg ( pDM_Odm , RF_PATH_A , RF_CHNLBW , bRFRegOffsetMask , CurrentChannel ) ;
ODM_SetRFReg ( pDM_Odm , RF_PATH_A , 0x00 , bRFRegOffsetMask , RfLoopReg ) ;
2013-07-10 18:25:07 +00:00
/* Reload AFE Registers */
2013-05-19 04:28:07 +00:00
odm_PHY_ReloadAFERegisters ( pDM_Odm , AFE_REG_8723A , AFE_Backup , 16 ) ;
2013-05-08 21:45:39 +00:00
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " psd_report_A[%d]= %d \n " , 2416 , AntA_report ) ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " psd_report_B[%d]= %d \n " , 2416 , AntB_report ) ) ;
2013-05-09 04:09:18 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " psd_report_O[%d]= %d \n " , 2416 , AntO_report ) ) ;
2013-05-08 21:45:39 +00:00
2013-05-09 04:04:25 +00:00
if ( pDM_Odm - > SupportICType = = ODM_RTL8723A )
2013-05-08 21:45:39 +00:00
{
2013-07-10 18:25:07 +00:00
/* 2 Test Ant B based on Ant A is ON */
2013-05-09 04:04:25 +00:00
if ( mode = = ANTTESTB )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( AntA_report > = 100 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( AntB_report > ( AntA_report + 1 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTB_ON = false ;
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Single Antenna A \n " ) ) ;
}
2013-05-08 21:45:39 +00:00
else
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTB_ON = true ;
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Dual Antenna is A and B \n " ) ) ;
}
2013-05-08 21:45:39 +00:00
}
else
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Need to check again \n " ) ) ;
2013-07-10 18:25:07 +00:00
pDM_SWAT_Table - > ANTB_ON = false ; /* Set Antenna B off as default */
2013-05-27 22:32:24 +00:00
bResult = false ;
2013-05-08 21:45:39 +00:00
}
2013-05-19 04:28:07 +00:00
}
2013-07-10 18:25:07 +00:00
/* 2 Test Ant A and B based on DPDT Open */
2013-05-09 04:04:25 +00:00
else if ( mode = = ANTTESTALL )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( ( AntO_report > = 100 ) & ( AntO_report < 118 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( AntA_report > ( AntO_report + 1 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = false ;
2013-07-10 18:25:07 +00:00
/* RT_TRACE(COMP_ANTENNA, DBG_LOUD, ("ODM_AntennaDetection(): Antenna A is OFF\n")); */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Ant A is OFF " ) ) ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
else
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = true ;
2013-07-10 18:25:07 +00:00
/* RT_TRACE(COMP_ANTENNA, DBG_LOUD, ("ODM_AntennaDetection(): Antenna A is ON\n")); */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Ant A is ON " ) ) ;
}
2013-05-09 04:04:25 +00:00
if ( AntB_report > ( AntO_report + 2 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTB_ON = false ;
2013-07-10 18:25:07 +00:00
/* RT_TRACE(COMP_ANTENNA, DBG_LOUD, ("ODM_AntennaDetection(): Antenna B is OFF\n")); */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Ant B is OFF " ) ) ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
else
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTB_ON = true ;
2013-07-10 18:25:07 +00:00
/* RT_TRACE(COMP_ANTENNA, DBG_LOUD, ("ODM_AntennaDetection(): Antenna B is ON\n")); */
2013-05-08 21:45:39 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " Ant B is ON " ) ) ;
}
}
}
}
2013-05-09 04:04:25 +00:00
else if ( pDM_Odm - > SupportICType = = ODM_RTL8192C )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( AntA_report > = 100 )
2013-05-08 21:45:39 +00:00
{
2013-05-09 04:04:25 +00:00
if ( AntB_report > ( AntA_report + 2 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = false ;
pDM_SWAT_Table - > ANTB_ON = true ;
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , 0x300 , Antenna_B ) ;
2013-05-19 04:28:07 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Single Antenna B \n " ) ) ;
}
2013-05-09 04:04:25 +00:00
else if ( AntA_report > ( AntB_report + 2 ) )
2013-05-08 21:45:39 +00:00
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = true ;
pDM_SWAT_Table - > ANTB_ON = false ;
2013-05-08 21:45:39 +00:00
ODM_SetBBReg ( pDM_Odm , rFPGA0_XA_RFInterfaceOE , 0x300 , Antenna_A ) ;
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Single Antenna A \n " ) ) ;
2013-05-19 04:28:07 +00:00
}
2013-05-08 21:45:39 +00:00
else
{
2013-05-27 22:32:24 +00:00
pDM_SWAT_Table - > ANTA_ON = true ;
pDM_SWAT_Table - > ANTB_ON = true ;
2013-05-17 21:52:06 +00:00
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD ,
( " ODM_SingleDualAntennaDetection(): Dual Antenna \n " ) ) ;
2013-05-08 21:45:39 +00:00
}
}
else
{
ODM_RT_TRACE ( pDM_Odm , ODM_COMP_ANT_DIV , ODM_DBG_LOUD , ( " ODM_SingleDualAntennaDetection(): Need to check again \n " ) ) ;
2013-07-10 18:25:07 +00:00
pDM_SWAT_Table - > ANTA_ON = true ; /* Set Antenna A on as default */
pDM_SWAT_Table - > ANTB_ON = false ; /* Set Antenna B off as default */
2013-05-27 22:32:24 +00:00
bResult = false ;
2013-05-08 21:45:39 +00:00
}
}
return bResult ;
}
/* Justin: According to the current RRSI to adjust Response Frame TX power, 2012/11/05 */
2013-07-26 16:20:42 +00:00
void odm_dtc ( struct odm_dm_struct * pDM_Odm )
2013-05-08 21:45:39 +00:00
{
}