1 /******************************************************************************
2 * Copyright(c) 2008 - 2010 Realtek Corporation. All rights reserved.
4 * This program is distributed in the hope that it will be useful, but WITHOUT
5 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
6 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
9 * You should have received a copy of the GNU General Public License along with
10 * this program; if not, write to the Free Software Foundation, Inc.,
11 * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
13 * The full GNU General Public License is included in this distribution in the
14 * file called LICENSE.
16 * Contact Information:
17 * wlanfae <wlanfae@realtek.com>
18 ******************************************************************************/
21 #include "r8192E_hw.h"
22 #include "r8192E_phy.h"
23 #include "r8192E_phyreg.h"
24 #include "r8190P_rtl8256.h"
25 #include "r8192E_cmdpkt.h"
27 /*---------------------------Define Local Constant---------------------------*/
28 static u32 edca_setting_DL[HT_IOT_PEER_MAX] = {
39 static u32 edca_setting_DL_GMode[HT_IOT_PEER_MAX] = {
50 static u32 edca_setting_UL[HT_IOT_PEER_MAX] = {
61 #define RTK_UL_EDCA 0xa44f
62 #define RTK_DL_EDCA 0x5e4322
63 /*---------------------------Define Local Constant---------------------------*/
66 /*------------------------Define global variable-----------------------------*/
67 struct dig_t dm_digtable;
68 u8 dm_shadow[16][256] = {
72 struct drx_path_sel DM_RxPathSelTable;
73 /*------------------------Define global variable-----------------------------*/
76 /*------------------------Define local variable------------------------------*/
77 /*------------------------Define local variable------------------------------*/
81 /*---------------------Define local function prototype-----------------------*/
82 static void dm_check_rate_adaptive(struct net_device *dev);
84 static void dm_init_bandwidth_autoswitch(struct net_device *dev);
85 static void dm_bandwidth_autoswitch(struct net_device *dev);
88 static void dm_check_txpower_tracking(struct net_device *dev);
94 static void dm_bb_initialgain_restore(struct net_device *dev);
97 static void dm_bb_initialgain_backup(struct net_device *dev);
99 static void dm_dig_init(struct net_device *dev);
100 static void dm_ctrl_initgain_byrssi(struct net_device *dev);
101 static void dm_ctrl_initgain_byrssi_highpwr(struct net_device *dev);
102 static void dm_ctrl_initgain_byrssi_by_driverrssi(struct net_device *dev);
103 static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(struct net_device *dev);
104 static void dm_initial_gain(struct net_device *dev);
105 static void dm_pd_th(struct net_device *dev);
106 static void dm_cs_ratio(struct net_device *dev);
108 static void dm_init_ctstoself(struct net_device *dev);
109 static void dm_Init_WA_Broadcom_IOT(struct net_device *dev);
111 static void dm_check_edca_turbo(struct net_device *dev);
113 static void dm_check_pbc_gpio(struct net_device *dev);
116 static void dm_check_rx_path_selection(struct net_device *dev);
117 static void dm_init_rxpath_selection(struct net_device *dev);
118 static void dm_rxpath_sel_byrssi(struct net_device *dev);
121 static void dm_init_fsync(struct net_device *dev);
122 static void dm_deInit_fsync(struct net_device *dev);
124 static void dm_check_txrateandretrycount(struct net_device *dev);
125 static void dm_check_ac_dc_power(struct net_device *dev);
127 /*---------------------Define local function prototype-----------------------*/
129 static void dm_init_dynamic_txpower(struct net_device *dev);
130 static void dm_dynamic_txpower(struct net_device *dev);
133 static void dm_send_rssi_tofw(struct net_device *dev);
134 static void dm_ctstoself(struct net_device *dev);
135 /*---------------------------Define function prototype------------------------*/
137 void init_hal_dm(struct net_device *dev)
139 struct r8192_priv *priv = rtllib_priv(dev);
141 priv->DM_Type = DM_Type_ByDriver;
143 priv->undecorated_smoothed_pwdb = -1;
145 dm_init_dynamic_txpower(dev);
147 init_rate_adaptive(dev);
150 dm_init_edca_turbo(dev);
151 dm_init_bandwidth_autoswitch(dev);
153 dm_init_rxpath_selection(dev);
154 dm_init_ctstoself(dev);
155 if (IS_HARDWARE_TYPE_8192SE(dev))
156 dm_Init_WA_Broadcom_IOT(dev);
158 INIT_DELAYED_WORK_RSL(&priv->gpio_change_rf_wq, (void *)dm_CheckRfCtrlGPIO, dev);
161 void deinit_hal_dm(struct net_device *dev)
164 dm_deInit_fsync(dev);
168 void hal_dm_watchdog(struct net_device *dev)
170 struct r8192_priv *priv = rtllib_priv(dev);
172 if (priv->being_init_adapter)
175 dm_check_ac_dc_power(dev);
177 dm_check_pbc_gpio(dev);
178 dm_check_txrateandretrycount(dev);
179 dm_check_edca_turbo(dev);
181 dm_check_rate_adaptive(dev);
182 dm_dynamic_txpower(dev);
183 dm_check_txpower_tracking(dev);
185 dm_ctrl_initgain_byrssi(dev);
186 dm_bandwidth_autoswitch(dev);
188 dm_check_rx_path_selection(dev);
191 dm_send_rssi_tofw(dev);
195 static void dm_check_ac_dc_power(struct net_device *dev)
197 struct r8192_priv *priv = rtllib_priv(dev);
198 static char *ac_dc_check_script_path = "/etc/acpi/wireless-rtl-ac-dc-power.sh";
199 char *argv[] = {ac_dc_check_script_path, DRV_NAME, NULL};
200 static char *envp[] = {"HOME=/",
202 "PATH=/usr/bin:/bin",
205 if (priv->ResetProgress == RESET_TYPE_SILENT) {
206 RT_TRACE((COMP_INIT | COMP_POWER | COMP_RF),
207 "GPIOChangeRFWorkItemCallBack(): Silent Reset!!!!!!!\n");
211 if (priv->rtllib->state != RTLLIB_LINKED)
213 call_usermodehelper(ac_dc_check_script_path, argv, envp, UMH_WAIT_PROC);
219 void init_rate_adaptive(struct net_device *dev)
222 struct r8192_priv *priv = rtllib_priv(dev);
223 struct rate_adaptive *pra = (struct rate_adaptive *)&priv->rate_adaptive;
225 pra->ratr_state = DM_RATR_STA_MAX;
226 pra->high2low_rssi_thresh_for_ra = RateAdaptiveTH_High;
227 pra->low2high_rssi_thresh_for_ra20M = RateAdaptiveTH_Low_20M+5;
228 pra->low2high_rssi_thresh_for_ra40M = RateAdaptiveTH_Low_40M+5;
230 pra->high_rssi_thresh_for_ra = RateAdaptiveTH_High+5;
231 pra->low_rssi_thresh_for_ra20M = RateAdaptiveTH_Low_20M;
232 pra->low_rssi_thresh_for_ra40M = RateAdaptiveTH_Low_40M;
234 if (priv->CustomerID == RT_CID_819x_Netcore)
235 pra->ping_rssi_enable = 1;
237 pra->ping_rssi_enable = 0;
238 pra->ping_rssi_thresh_for_ra = 15;
241 if (priv->rf_type == RF_2T4R) {
242 pra->upper_rssi_threshold_ratr = 0x8f0f0000;
243 pra->middle_rssi_threshold_ratr = 0x8f0ff000;
244 pra->low_rssi_threshold_ratr = 0x8f0ff001;
245 pra->low_rssi_threshold_ratr_40M = 0x8f0ff005;
246 pra->low_rssi_threshold_ratr_20M = 0x8f0ff001;
247 pra->ping_rssi_ratr = 0x0000000d;
248 } else if (priv->rf_type == RF_1T2R) {
249 pra->upper_rssi_threshold_ratr = 0x000fc000;
250 pra->middle_rssi_threshold_ratr = 0x000ff000;
251 pra->low_rssi_threshold_ratr = 0x000ff001;
252 pra->low_rssi_threshold_ratr_40M = 0x000ff005;
253 pra->low_rssi_threshold_ratr_20M = 0x000ff001;
254 pra->ping_rssi_ratr = 0x0000000d;
260 static void dm_check_rate_adaptive(struct net_device *dev)
262 struct r8192_priv *priv = rtllib_priv(dev);
263 struct rt_hi_throughput *pHTInfo = priv->rtllib->pHTInfo;
264 struct rate_adaptive *pra = (struct rate_adaptive *)&priv->rate_adaptive;
265 u32 currentRATR, targetRATR = 0;
266 u32 LowRSSIThreshForRA = 0, HighRSSIThreshForRA = 0;
267 bool bshort_gi_enabled = false;
268 static u8 ping_rssi_state;
271 RT_TRACE(COMP_RATE, "<---- dm_check_rate_adaptive(): driver is going to unload\n");
275 if (pra->rate_adaptive_disabled)
278 if (!(priv->rtllib->mode == WIRELESS_MODE_N_24G ||
279 priv->rtllib->mode == WIRELESS_MODE_N_5G))
282 if (priv->rtllib->state == RTLLIB_LINKED) {
284 bshort_gi_enabled = (pHTInfo->bCurTxBW40MHz && pHTInfo->bCurShortGI40MHz) ||
285 (!pHTInfo->bCurTxBW40MHz && pHTInfo->bCurShortGI20MHz);
288 pra->upper_rssi_threshold_ratr =
289 (pra->upper_rssi_threshold_ratr & (~BIT31)) | ((bshort_gi_enabled) ? BIT31 : 0);
291 pra->middle_rssi_threshold_ratr =
292 (pra->middle_rssi_threshold_ratr & (~BIT31)) | ((bshort_gi_enabled) ? BIT31 : 0);
294 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20) {
295 pra->low_rssi_threshold_ratr =
296 (pra->low_rssi_threshold_ratr_40M & (~BIT31)) | ((bshort_gi_enabled) ? BIT31 : 0);
298 pra->low_rssi_threshold_ratr =
299 (pra->low_rssi_threshold_ratr_20M & (~BIT31)) | ((bshort_gi_enabled) ? BIT31 : 0);
301 pra->ping_rssi_ratr =
302 (pra->ping_rssi_ratr & (~BIT31)) | ((bshort_gi_enabled) ? BIT31 : 0);
304 if (pra->ratr_state == DM_RATR_STA_HIGH) {
305 HighRSSIThreshForRA = pra->high2low_rssi_thresh_for_ra;
306 LowRSSIThreshForRA = (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20) ?
307 (pra->low_rssi_thresh_for_ra40M) : (pra->low_rssi_thresh_for_ra20M);
308 } else if (pra->ratr_state == DM_RATR_STA_LOW) {
309 HighRSSIThreshForRA = pra->high_rssi_thresh_for_ra;
310 LowRSSIThreshForRA = (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20) ?
311 (pra->low2high_rssi_thresh_for_ra40M) : (pra->low2high_rssi_thresh_for_ra20M);
313 HighRSSIThreshForRA = pra->high_rssi_thresh_for_ra;
314 LowRSSIThreshForRA = (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20) ?
315 (pra->low_rssi_thresh_for_ra40M) : (pra->low_rssi_thresh_for_ra20M);
318 if (priv->undecorated_smoothed_pwdb >= (long)HighRSSIThreshForRA) {
319 pra->ratr_state = DM_RATR_STA_HIGH;
320 targetRATR = pra->upper_rssi_threshold_ratr;
321 } else if (priv->undecorated_smoothed_pwdb >= (long)LowRSSIThreshForRA) {
322 pra->ratr_state = DM_RATR_STA_MIDDLE;
323 targetRATR = pra->middle_rssi_threshold_ratr;
325 pra->ratr_state = DM_RATR_STA_LOW;
326 targetRATR = pra->low_rssi_threshold_ratr;
329 if (pra->ping_rssi_enable) {
330 if (priv->undecorated_smoothed_pwdb < (long)(pra->ping_rssi_thresh_for_ra+5)) {
331 if ((priv->undecorated_smoothed_pwdb < (long)pra->ping_rssi_thresh_for_ra) ||
333 pra->ratr_state = DM_RATR_STA_LOW;
334 targetRATR = pra->ping_rssi_ratr;
342 if (priv->rtllib->GetHalfNmodeSupportByAPsHandler(dev))
343 targetRATR &= 0xf00fffff;
345 currentRATR = read_nic_dword(dev, RATR0);
346 if (targetRATR != currentRATR) {
349 ratr_value = targetRATR;
351 "currentRATR = %x, targetRATR = %x\n",
352 currentRATR, targetRATR);
353 if (priv->rf_type == RF_1T2R)
354 ratr_value &= ~(RATE_ALL_OFDM_2SS);
355 write_nic_dword(dev, RATR0, ratr_value);
356 write_nic_byte(dev, UFWP, 1);
358 pra->last_ratr = targetRATR;
362 pra->ratr_state = DM_RATR_STA_MAX;
366 static void dm_init_bandwidth_autoswitch(struct net_device *dev)
368 struct r8192_priv *priv = rtllib_priv(dev);
370 priv->rtllib->bandwidth_auto_switch.threshold_20Mhzto40Mhz = BW_AUTO_SWITCH_LOW_HIGH;
371 priv->rtllib->bandwidth_auto_switch.threshold_40Mhzto20Mhz = BW_AUTO_SWITCH_HIGH_LOW;
372 priv->rtllib->bandwidth_auto_switch.bforced_tx20Mhz = false;
373 priv->rtllib->bandwidth_auto_switch.bautoswitch_enable = false;
376 static void dm_bandwidth_autoswitch(struct net_device *dev)
378 struct r8192_priv *priv = rtllib_priv(dev);
380 if (priv->CurrentChannelBW == HT_CHANNEL_WIDTH_20 ||
381 !priv->rtllib->bandwidth_auto_switch.bautoswitch_enable)
383 if (priv->rtllib->bandwidth_auto_switch.bforced_tx20Mhz == false) {
384 if (priv->undecorated_smoothed_pwdb <=
385 priv->rtllib->bandwidth_auto_switch.threshold_40Mhzto20Mhz)
386 priv->rtllib->bandwidth_auto_switch.bforced_tx20Mhz = true;
388 if (priv->undecorated_smoothed_pwdb >=
389 priv->rtllib->bandwidth_auto_switch.threshold_20Mhzto40Mhz)
390 priv->rtllib->bandwidth_auto_switch.bforced_tx20Mhz = false;
394 static u32 OFDMSwingTable[OFDM_Table_Length] = {
416 static u8 CCKSwingTable_Ch1_Ch13[CCK_Table_length][8] = {
417 {0x36, 0x35, 0x2e, 0x25, 0x1c, 0x12, 0x09, 0x04},
418 {0x30, 0x2f, 0x29, 0x21, 0x19, 0x10, 0x08, 0x03},
419 {0x2b, 0x2a, 0x25, 0x1e, 0x16, 0x0e, 0x07, 0x03},
420 {0x26, 0x25, 0x21, 0x1b, 0x14, 0x0d, 0x06, 0x03},
421 {0x22, 0x21, 0x1d, 0x18, 0x11, 0x0b, 0x06, 0x02},
422 {0x1f, 0x1e, 0x1a, 0x15, 0x10, 0x0a, 0x05, 0x02},
423 {0x1b, 0x1a, 0x17, 0x13, 0x0e, 0x09, 0x04, 0x02},
424 {0x18, 0x17, 0x15, 0x11, 0x0c, 0x08, 0x04, 0x02},
425 {0x16, 0x15, 0x12, 0x0f, 0x0b, 0x07, 0x04, 0x01},
426 {0x13, 0x13, 0x10, 0x0d, 0x0a, 0x06, 0x03, 0x01},
427 {0x11, 0x11, 0x0f, 0x0c, 0x09, 0x06, 0x03, 0x01},
428 {0x0f, 0x0f, 0x0d, 0x0b, 0x08, 0x05, 0x03, 0x01}
431 static u8 CCKSwingTable_Ch14[CCK_Table_length][8] = {
432 {0x36, 0x35, 0x2e, 0x1b, 0x00, 0x00, 0x00, 0x00},
433 {0x30, 0x2f, 0x29, 0x18, 0x00, 0x00, 0x00, 0x00},
434 {0x2b, 0x2a, 0x25, 0x15, 0x00, 0x00, 0x00, 0x00},
435 {0x26, 0x25, 0x21, 0x13, 0x00, 0x00, 0x00, 0x00},
436 {0x22, 0x21, 0x1d, 0x11, 0x00, 0x00, 0x00, 0x00},
437 {0x1f, 0x1e, 0x1a, 0x0f, 0x00, 0x00, 0x00, 0x00},
438 {0x1b, 0x1a, 0x17, 0x0e, 0x00, 0x00, 0x00, 0x00},
439 {0x18, 0x17, 0x15, 0x0c, 0x00, 0x00, 0x00, 0x00},
440 {0x16, 0x15, 0x12, 0x0b, 0x00, 0x00, 0x00, 0x00},
441 {0x13, 0x13, 0x10, 0x0a, 0x00, 0x00, 0x00, 0x00},
442 {0x11, 0x11, 0x0f, 0x09, 0x00, 0x00, 0x00, 0x00},
443 {0x0f, 0x0f, 0x0d, 0x08, 0x00, 0x00, 0x00, 0x00}
446 #define Pw_Track_Flag 0x11d
447 #define Tssi_Mea_Value 0x13c
448 #define Tssi_Report_Value1 0x134
449 #define Tssi_Report_Value2 0x13e
450 #define FW_Busy_Flag 0x13f
452 static void dm_TXPowerTrackingCallback_TSSI(struct net_device *dev)
454 struct r8192_priv *priv = rtllib_priv(dev);
455 bool bHighpowerstate, viviflag = false;
456 struct dcmd_txcmd tx_cmd;
457 u8 powerlevelOFDM24G;
458 int i = 0, j = 0, k = 0;
459 u8 RF_Type, tmp_report[5] = {0, 0, 0, 0, 0};
462 u16 Avg_TSSI_Meas, TSSI_13dBm, Avg_TSSI_Meas_from_driver = 0;
465 RT_TRACE(COMP_POWER_TRACKING, "%s()\n", __func__);
466 write_nic_byte(dev, Pw_Track_Flag, 0);
467 write_nic_byte(dev, FW_Busy_Flag, 0);
468 priv->rtllib->bdynamic_txpower_enable = false;
469 bHighpowerstate = priv->bDynamicTxHighPower;
471 powerlevelOFDM24G = (u8)(priv->Pwr_Track>>24);
472 RF_Type = priv->rf_type;
473 Value = (RF_Type<<8) | powerlevelOFDM24G;
475 RT_TRACE(COMP_POWER_TRACKING, "powerlevelOFDM24G = %x\n",
479 for (j = 0; j <= 30; j++) {
481 tx_cmd.Op = TXCMD_SET_TX_PWR_TRACKING;
483 tx_cmd.Value = Value;
484 cmpk_message_handle_tx(dev, (u8 *)&tx_cmd,
485 DESC_PACKET_TYPE_INIT,
486 sizeof(struct dcmd_txcmd));
488 for (i = 0; i <= 30; i++) {
489 Pwr_Flag = read_nic_byte(dev, Pw_Track_Flag);
494 if (priv->bResetInProgress) {
495 RT_TRACE(COMP_POWER_TRACKING,
496 "we are in silent reset progress, so return\n");
497 write_nic_byte(dev, Pw_Track_Flag, 0);
498 write_nic_byte(dev, FW_Busy_Flag, 0);
501 if (priv->rtllib->eRFPowerState != eRfOn) {
502 RT_TRACE(COMP_POWER_TRACKING,
503 "we are in power save, so return\n");
504 write_nic_byte(dev, Pw_Track_Flag, 0);
505 write_nic_byte(dev, FW_Busy_Flag, 0);
512 Avg_TSSI_Meas = read_nic_word(dev, Tssi_Mea_Value);
514 if (Avg_TSSI_Meas == 0) {
515 write_nic_byte(dev, Pw_Track_Flag, 0);
516 write_nic_byte(dev, FW_Busy_Flag, 0);
520 for (k = 0; k < 5; k++) {
522 tmp_report[k] = read_nic_byte(dev,
523 Tssi_Report_Value1+k);
525 tmp_report[k] = read_nic_byte(dev,
528 RT_TRACE(COMP_POWER_TRACKING,
529 "TSSI_report_value = %d\n",
532 if (tmp_report[k] <= 20) {
539 write_nic_byte(dev, Pw_Track_Flag, 0);
541 RT_TRACE(COMP_POWER_TRACKING, "we filted this data\n");
542 for (k = 0; k < 5; k++)
547 for (k = 0; k < 5; k++)
548 Avg_TSSI_Meas_from_driver += tmp_report[k];
550 Avg_TSSI_Meas_from_driver = Avg_TSSI_Meas_from_driver*100/5;
551 RT_TRACE(COMP_POWER_TRACKING,
552 "Avg_TSSI_Meas_from_driver = %d\n",
553 Avg_TSSI_Meas_from_driver);
554 TSSI_13dBm = priv->TSSI_13dBm;
555 RT_TRACE(COMP_POWER_TRACKING, "TSSI_13dBm = %d\n", TSSI_13dBm);
557 if (Avg_TSSI_Meas_from_driver > TSSI_13dBm)
558 delta = Avg_TSSI_Meas_from_driver - TSSI_13dBm;
560 delta = TSSI_13dBm - Avg_TSSI_Meas_from_driver;
562 if (delta <= E_FOR_TX_POWER_TRACK) {
563 priv->rtllib->bdynamic_txpower_enable = true;
564 write_nic_byte(dev, Pw_Track_Flag, 0);
565 write_nic_byte(dev, FW_Busy_Flag, 0);
566 RT_TRACE(COMP_POWER_TRACKING,
567 "tx power track is done\n");
568 RT_TRACE(COMP_POWER_TRACKING,
569 "priv->rfa_txpowertrackingindex = %d\n",
570 priv->rfa_txpowertrackingindex);
571 RT_TRACE(COMP_POWER_TRACKING,
572 "priv->rfa_txpowertrackingindex_real = %d\n",
573 priv->rfa_txpowertrackingindex_real);
574 RT_TRACE(COMP_POWER_TRACKING,
575 "priv->CCKPresentAttentuation_difference = %d\n",
576 priv->CCKPresentAttentuation_difference);
577 RT_TRACE(COMP_POWER_TRACKING,
578 "priv->CCKPresentAttentuation = %d\n",
579 priv->CCKPresentAttentuation);
582 if (Avg_TSSI_Meas_from_driver < TSSI_13dBm - E_FOR_TX_POWER_TRACK) {
583 if (RF_Type == RF_2T4R) {
585 if ((priv->rfa_txpowertrackingindex > 0) &&
586 (priv->rfc_txpowertrackingindex > 0)) {
587 priv->rfa_txpowertrackingindex--;
588 if (priv->rfa_txpowertrackingindex_real > 4) {
589 priv->rfa_txpowertrackingindex_real--;
590 rtl8192_setBBreg(dev,
591 rOFDM0_XATxIQImbalance,
593 priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
596 priv->rfc_txpowertrackingindex--;
597 if (priv->rfc_txpowertrackingindex_real > 4) {
598 priv->rfc_txpowertrackingindex_real--;
599 rtl8192_setBBreg(dev,
600 rOFDM0_XCTxIQImbalance,
602 priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
605 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance,
607 priv->txbbgain_table[4].txbbgain_value);
608 rtl8192_setBBreg(dev,
609 rOFDM0_XCTxIQImbalance,
610 bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
613 if (priv->rfa_txpowertrackingindex > 0) {
614 priv->rfa_txpowertrackingindex--;
615 if (priv->rfa_txpowertrackingindex_real > 4) {
616 priv->rfa_txpowertrackingindex_real--;
617 rtl8192_setBBreg(dev,
618 rOFDM0_XATxIQImbalance,
620 priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
623 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance,
624 bMaskDWord, priv->txbbgain_table[4].txbbgain_value);
628 if (RF_Type == RF_2T4R) {
629 if ((priv->rfa_txpowertrackingindex <
630 TxBBGainTableLength - 1) &&
631 (priv->rfc_txpowertrackingindex <
632 TxBBGainTableLength - 1)) {
633 priv->rfa_txpowertrackingindex++;
634 priv->rfa_txpowertrackingindex_real++;
635 rtl8192_setBBreg(dev,
636 rOFDM0_XATxIQImbalance,
639 [priv->rfa_txpowertrackingindex_real].txbbgain_value);
640 priv->rfc_txpowertrackingindex++;
641 priv->rfc_txpowertrackingindex_real++;
642 rtl8192_setBBreg(dev,
643 rOFDM0_XCTxIQImbalance,
645 priv->txbbgain_table[priv->rfc_txpowertrackingindex_real].txbbgain_value);
647 rtl8192_setBBreg(dev,
648 rOFDM0_XATxIQImbalance,
650 priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
651 rtl8192_setBBreg(dev,
652 rOFDM0_XCTxIQImbalance,
653 bMaskDWord, priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
656 if (priv->rfa_txpowertrackingindex < (TxBBGainTableLength - 1)) {
657 priv->rfa_txpowertrackingindex++;
658 priv->rfa_txpowertrackingindex_real++;
659 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance,
661 priv->txbbgain_table[priv->rfa_txpowertrackingindex_real].txbbgain_value);
663 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance,
665 priv->txbbgain_table[TxBBGainTableLength - 1].txbbgain_value);
668 if (RF_Type == RF_2T4R) {
669 priv->CCKPresentAttentuation_difference
670 = priv->rfa_txpowertrackingindex - priv->rfa_txpowertracking_default;
672 priv->CCKPresentAttentuation_difference
673 = priv->rfa_txpowertrackingindex_real - priv->rfa_txpowertracking_default;
676 if (priv->CurrentChannelBW == HT_CHANNEL_WIDTH_20)
677 priv->CCKPresentAttentuation =
678 priv->CCKPresentAttentuation_20Mdefault +
679 priv->CCKPresentAttentuation_difference;
681 priv->CCKPresentAttentuation =
682 priv->CCKPresentAttentuation_40Mdefault +
683 priv->CCKPresentAttentuation_difference;
685 if (priv->CCKPresentAttentuation > (CCKTxBBGainTableLength-1))
686 priv->CCKPresentAttentuation = CCKTxBBGainTableLength-1;
687 if (priv->CCKPresentAttentuation < 0)
688 priv->CCKPresentAttentuation = 0;
690 if (priv->CCKPresentAttentuation > -1 &&
691 priv->CCKPresentAttentuation < CCKTxBBGainTableLength) {
692 if (priv->rtllib->current_network.channel == 14 &&
693 !priv->bcck_in_ch14) {
694 priv->bcck_in_ch14 = true;
695 dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
696 } else if (priv->rtllib->current_network.channel != 14 && priv->bcck_in_ch14) {
697 priv->bcck_in_ch14 = false;
698 dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
700 dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
702 RT_TRACE(COMP_POWER_TRACKING,
703 "priv->rfa_txpowertrackingindex = %d\n",
704 priv->rfa_txpowertrackingindex);
705 RT_TRACE(COMP_POWER_TRACKING,
706 "priv->rfa_txpowertrackingindex_real = %d\n",
707 priv->rfa_txpowertrackingindex_real);
708 RT_TRACE(COMP_POWER_TRACKING,
709 "priv->CCKPresentAttentuation_difference = %d\n",
710 priv->CCKPresentAttentuation_difference);
711 RT_TRACE(COMP_POWER_TRACKING,
712 "priv->CCKPresentAttentuation = %d\n",
713 priv->CCKPresentAttentuation);
715 if (priv->CCKPresentAttentuation_difference <= -12 || priv->CCKPresentAttentuation_difference >= 24) {
716 priv->rtllib->bdynamic_txpower_enable = true;
717 write_nic_byte(dev, Pw_Track_Flag, 0);
718 write_nic_byte(dev, FW_Busy_Flag, 0);
719 RT_TRACE(COMP_POWER_TRACKING, "tx power track--->limited\n");
723 write_nic_byte(dev, Pw_Track_Flag, 0);
724 Avg_TSSI_Meas_from_driver = 0;
725 for (k = 0; k < 5; k++)
729 write_nic_byte(dev, FW_Busy_Flag, 0);
731 priv->rtllib->bdynamic_txpower_enable = true;
732 write_nic_byte(dev, Pw_Track_Flag, 0);
735 static void dm_TXPowerTrackingCallback_ThermalMeter(struct net_device *dev)
737 #define ThermalMeterVal 9
738 struct r8192_priv *priv = rtllib_priv(dev);
739 u32 tmpRegA, TempCCk;
740 u8 tmpOFDMindex, tmpCCKindex, tmpCCK20Mindex, tmpCCK40Mindex, tmpval;
741 int i = 0, CCKSwingNeedUpdate = 0;
743 if (!priv->btxpower_trackingInit) {
744 tmpRegA = rtl8192_QueryBBReg(dev, rOFDM0_XATxIQImbalance, bMaskDWord);
745 for (i = 0; i < OFDM_Table_Length; i++) {
746 if (tmpRegA == OFDMSwingTable[i]) {
747 priv->OFDM_index[0] = (u8)i;
748 RT_TRACE(COMP_POWER_TRACKING, "Initial reg0x%x = 0x%x, OFDM_index = 0x%x\n",
749 rOFDM0_XATxIQImbalance, tmpRegA, priv->OFDM_index[0]);
753 TempCCk = rtl8192_QueryBBReg(dev, rCCK0_TxFilter1, bMaskByte2);
754 for (i = 0; i < CCK_Table_length; i++) {
755 if (TempCCk == (u32)CCKSwingTable_Ch1_Ch13[i][0]) {
756 priv->CCK_index = (u8) i;
757 RT_TRACE(COMP_POWER_TRACKING,
758 "Initial reg0x%x = 0x%x, CCK_index = 0x%x\n",
759 rCCK0_TxFilter1, TempCCk,
764 priv->btxpower_trackingInit = true;
768 tmpRegA = rtl8192_phy_QueryRFReg(dev, RF90_PATH_A, 0x12, 0x078);
769 RT_TRACE(COMP_POWER_TRACKING, "Readback ThermalMeterA = %d\n", tmpRegA);
770 if (tmpRegA < 3 || tmpRegA > 13)
774 RT_TRACE(COMP_POWER_TRACKING, "Valid ThermalMeterA = %d\n", tmpRegA);
775 priv->ThermalMeter[0] = ThermalMeterVal;
776 priv->ThermalMeter[1] = ThermalMeterVal;
778 if (priv->ThermalMeter[0] >= (u8)tmpRegA) {
779 tmpOFDMindex = tmpCCK20Mindex = 6+(priv->ThermalMeter[0] -
781 tmpCCK40Mindex = tmpCCK20Mindex - 6;
782 if (tmpOFDMindex >= OFDM_Table_Length)
783 tmpOFDMindex = OFDM_Table_Length-1;
784 if (tmpCCK20Mindex >= CCK_Table_length)
785 tmpCCK20Mindex = CCK_Table_length-1;
786 if (tmpCCK40Mindex >= CCK_Table_length)
787 tmpCCK40Mindex = CCK_Table_length-1;
789 tmpval = ((u8)tmpRegA - priv->ThermalMeter[0]);
791 tmpOFDMindex = tmpCCK20Mindex = 0;
793 tmpOFDMindex = tmpCCK20Mindex = 6 - tmpval;
796 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
797 tmpCCKindex = tmpCCK40Mindex;
799 tmpCCKindex = tmpCCK20Mindex;
801 priv->Record_CCK_20Mindex = tmpCCK20Mindex;
802 priv->Record_CCK_40Mindex = tmpCCK40Mindex;
803 RT_TRACE(COMP_POWER_TRACKING,
804 "Record_CCK_20Mindex / Record_CCK_40Mindex = %d / %d.\n",
805 priv->Record_CCK_20Mindex, priv->Record_CCK_40Mindex);
807 if (priv->rtllib->current_network.channel == 14 &&
808 !priv->bcck_in_ch14) {
809 priv->bcck_in_ch14 = true;
810 CCKSwingNeedUpdate = 1;
811 } else if (priv->rtllib->current_network.channel != 14 &&
812 priv->bcck_in_ch14) {
813 priv->bcck_in_ch14 = false;
814 CCKSwingNeedUpdate = 1;
817 if (priv->CCK_index != tmpCCKindex) {
818 priv->CCK_index = tmpCCKindex;
819 CCKSwingNeedUpdate = 1;
822 if (CCKSwingNeedUpdate)
823 dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
824 if (priv->OFDM_index[0] != tmpOFDMindex) {
825 priv->OFDM_index[0] = tmpOFDMindex;
826 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord,
827 OFDMSwingTable[priv->OFDM_index[0]]);
828 RT_TRACE(COMP_POWER_TRACKING, "Update OFDMSwing[%d] = 0x%x\n",
830 OFDMSwingTable[priv->OFDM_index[0]]);
832 priv->txpower_count = 0;
835 void dm_txpower_trackingcallback(void *data)
837 struct r8192_priv *priv = container_of_dwork_rsl(data,
838 struct r8192_priv, txpower_tracking_wq);
839 struct net_device *dev = priv->rtllib->dev;
841 if (priv->IC_Cut >= IC_VersionCut_D)
842 dm_TXPowerTrackingCallback_TSSI(dev);
844 dm_TXPowerTrackingCallback_ThermalMeter(dev);
847 static void dm_InitializeTXPowerTracking_TSSI(struct net_device *dev)
850 struct r8192_priv *priv = rtllib_priv(dev);
852 priv->txbbgain_table[0].txbb_iq_amplifygain = 12;
853 priv->txbbgain_table[0].txbbgain_value = 0x7f8001fe;
854 priv->txbbgain_table[1].txbb_iq_amplifygain = 11;
855 priv->txbbgain_table[1].txbbgain_value = 0x788001e2;
856 priv->txbbgain_table[2].txbb_iq_amplifygain = 10;
857 priv->txbbgain_table[2].txbbgain_value = 0x71c001c7;
858 priv->txbbgain_table[3].txbb_iq_amplifygain = 9;
859 priv->txbbgain_table[3].txbbgain_value = 0x6b8001ae;
860 priv->txbbgain_table[4].txbb_iq_amplifygain = 8;
861 priv->txbbgain_table[4].txbbgain_value = 0x65400195;
862 priv->txbbgain_table[5].txbb_iq_amplifygain = 7;
863 priv->txbbgain_table[5].txbbgain_value = 0x5fc0017f;
864 priv->txbbgain_table[6].txbb_iq_amplifygain = 6;
865 priv->txbbgain_table[6].txbbgain_value = 0x5a400169;
866 priv->txbbgain_table[7].txbb_iq_amplifygain = 5;
867 priv->txbbgain_table[7].txbbgain_value = 0x55400155;
868 priv->txbbgain_table[8].txbb_iq_amplifygain = 4;
869 priv->txbbgain_table[8].txbbgain_value = 0x50800142;
870 priv->txbbgain_table[9].txbb_iq_amplifygain = 3;
871 priv->txbbgain_table[9].txbbgain_value = 0x4c000130;
872 priv->txbbgain_table[10].txbb_iq_amplifygain = 2;
873 priv->txbbgain_table[10].txbbgain_value = 0x47c0011f;
874 priv->txbbgain_table[11].txbb_iq_amplifygain = 1;
875 priv->txbbgain_table[11].txbbgain_value = 0x43c0010f;
876 priv->txbbgain_table[12].txbb_iq_amplifygain = 0;
877 priv->txbbgain_table[12].txbbgain_value = 0x40000100;
878 priv->txbbgain_table[13].txbb_iq_amplifygain = -1;
879 priv->txbbgain_table[13].txbbgain_value = 0x3c8000f2;
880 priv->txbbgain_table[14].txbb_iq_amplifygain = -2;
881 priv->txbbgain_table[14].txbbgain_value = 0x390000e4;
882 priv->txbbgain_table[15].txbb_iq_amplifygain = -3;
883 priv->txbbgain_table[15].txbbgain_value = 0x35c000d7;
884 priv->txbbgain_table[16].txbb_iq_amplifygain = -4;
885 priv->txbbgain_table[16].txbbgain_value = 0x32c000cb;
886 priv->txbbgain_table[17].txbb_iq_amplifygain = -5;
887 priv->txbbgain_table[17].txbbgain_value = 0x300000c0;
888 priv->txbbgain_table[18].txbb_iq_amplifygain = -6;
889 priv->txbbgain_table[18].txbbgain_value = 0x2d4000b5;
890 priv->txbbgain_table[19].txbb_iq_amplifygain = -7;
891 priv->txbbgain_table[19].txbbgain_value = 0x2ac000ab;
892 priv->txbbgain_table[20].txbb_iq_amplifygain = -8;
893 priv->txbbgain_table[20].txbbgain_value = 0x288000a2;
894 priv->txbbgain_table[21].txbb_iq_amplifygain = -9;
895 priv->txbbgain_table[21].txbbgain_value = 0x26000098;
896 priv->txbbgain_table[22].txbb_iq_amplifygain = -10;
897 priv->txbbgain_table[22].txbbgain_value = 0x24000090;
898 priv->txbbgain_table[23].txbb_iq_amplifygain = -11;
899 priv->txbbgain_table[23].txbbgain_value = 0x22000088;
900 priv->txbbgain_table[24].txbb_iq_amplifygain = -12;
901 priv->txbbgain_table[24].txbbgain_value = 0x20000080;
902 priv->txbbgain_table[25].txbb_iq_amplifygain = -13;
903 priv->txbbgain_table[25].txbbgain_value = 0x1a00006c;
904 priv->txbbgain_table[26].txbb_iq_amplifygain = -14;
905 priv->txbbgain_table[26].txbbgain_value = 0x1c800072;
906 priv->txbbgain_table[27].txbb_iq_amplifygain = -15;
907 priv->txbbgain_table[27].txbbgain_value = 0x18000060;
908 priv->txbbgain_table[28].txbb_iq_amplifygain = -16;
909 priv->txbbgain_table[28].txbbgain_value = 0x19800066;
910 priv->txbbgain_table[29].txbb_iq_amplifygain = -17;
911 priv->txbbgain_table[29].txbbgain_value = 0x15800056;
912 priv->txbbgain_table[30].txbb_iq_amplifygain = -18;
913 priv->txbbgain_table[30].txbbgain_value = 0x26c0005b;
914 priv->txbbgain_table[31].txbb_iq_amplifygain = -19;
915 priv->txbbgain_table[31].txbbgain_value = 0x14400051;
916 priv->txbbgain_table[32].txbb_iq_amplifygain = -20;
917 priv->txbbgain_table[32].txbbgain_value = 0x24400051;
918 priv->txbbgain_table[33].txbb_iq_amplifygain = -21;
919 priv->txbbgain_table[33].txbbgain_value = 0x1300004c;
920 priv->txbbgain_table[34].txbb_iq_amplifygain = -22;
921 priv->txbbgain_table[34].txbbgain_value = 0x12000048;
922 priv->txbbgain_table[35].txbb_iq_amplifygain = -23;
923 priv->txbbgain_table[35].txbbgain_value = 0x11000044;
924 priv->txbbgain_table[36].txbb_iq_amplifygain = -24;
925 priv->txbbgain_table[36].txbbgain_value = 0x10000040;
927 priv->cck_txbbgain_table[0].ccktxbb_valuearray[0] = 0x36;
928 priv->cck_txbbgain_table[0].ccktxbb_valuearray[1] = 0x35;
929 priv->cck_txbbgain_table[0].ccktxbb_valuearray[2] = 0x2e;
930 priv->cck_txbbgain_table[0].ccktxbb_valuearray[3] = 0x25;
931 priv->cck_txbbgain_table[0].ccktxbb_valuearray[4] = 0x1c;
932 priv->cck_txbbgain_table[0].ccktxbb_valuearray[5] = 0x12;
933 priv->cck_txbbgain_table[0].ccktxbb_valuearray[6] = 0x09;
934 priv->cck_txbbgain_table[0].ccktxbb_valuearray[7] = 0x04;
936 priv->cck_txbbgain_table[1].ccktxbb_valuearray[0] = 0x33;
937 priv->cck_txbbgain_table[1].ccktxbb_valuearray[1] = 0x32;
938 priv->cck_txbbgain_table[1].ccktxbb_valuearray[2] = 0x2b;
939 priv->cck_txbbgain_table[1].ccktxbb_valuearray[3] = 0x23;
940 priv->cck_txbbgain_table[1].ccktxbb_valuearray[4] = 0x1a;
941 priv->cck_txbbgain_table[1].ccktxbb_valuearray[5] = 0x11;
942 priv->cck_txbbgain_table[1].ccktxbb_valuearray[6] = 0x08;
943 priv->cck_txbbgain_table[1].ccktxbb_valuearray[7] = 0x04;
945 priv->cck_txbbgain_table[2].ccktxbb_valuearray[0] = 0x30;
946 priv->cck_txbbgain_table[2].ccktxbb_valuearray[1] = 0x2f;
947 priv->cck_txbbgain_table[2].ccktxbb_valuearray[2] = 0x29;
948 priv->cck_txbbgain_table[2].ccktxbb_valuearray[3] = 0x21;
949 priv->cck_txbbgain_table[2].ccktxbb_valuearray[4] = 0x19;
950 priv->cck_txbbgain_table[2].ccktxbb_valuearray[5] = 0x10;
951 priv->cck_txbbgain_table[2].ccktxbb_valuearray[6] = 0x08;
952 priv->cck_txbbgain_table[2].ccktxbb_valuearray[7] = 0x03;
954 priv->cck_txbbgain_table[3].ccktxbb_valuearray[0] = 0x2d;
955 priv->cck_txbbgain_table[3].ccktxbb_valuearray[1] = 0x2d;
956 priv->cck_txbbgain_table[3].ccktxbb_valuearray[2] = 0x27;
957 priv->cck_txbbgain_table[3].ccktxbb_valuearray[3] = 0x1f;
958 priv->cck_txbbgain_table[3].ccktxbb_valuearray[4] = 0x18;
959 priv->cck_txbbgain_table[3].ccktxbb_valuearray[5] = 0x0f;
960 priv->cck_txbbgain_table[3].ccktxbb_valuearray[6] = 0x08;
961 priv->cck_txbbgain_table[3].ccktxbb_valuearray[7] = 0x03;
963 priv->cck_txbbgain_table[4].ccktxbb_valuearray[0] = 0x2b;
964 priv->cck_txbbgain_table[4].ccktxbb_valuearray[1] = 0x2a;
965 priv->cck_txbbgain_table[4].ccktxbb_valuearray[2] = 0x25;
966 priv->cck_txbbgain_table[4].ccktxbb_valuearray[3] = 0x1e;
967 priv->cck_txbbgain_table[4].ccktxbb_valuearray[4] = 0x16;
968 priv->cck_txbbgain_table[4].ccktxbb_valuearray[5] = 0x0e;
969 priv->cck_txbbgain_table[4].ccktxbb_valuearray[6] = 0x07;
970 priv->cck_txbbgain_table[4].ccktxbb_valuearray[7] = 0x03;
972 priv->cck_txbbgain_table[5].ccktxbb_valuearray[0] = 0x28;
973 priv->cck_txbbgain_table[5].ccktxbb_valuearray[1] = 0x28;
974 priv->cck_txbbgain_table[5].ccktxbb_valuearray[2] = 0x22;
975 priv->cck_txbbgain_table[5].ccktxbb_valuearray[3] = 0x1c;
976 priv->cck_txbbgain_table[5].ccktxbb_valuearray[4] = 0x15;
977 priv->cck_txbbgain_table[5].ccktxbb_valuearray[5] = 0x0d;
978 priv->cck_txbbgain_table[5].ccktxbb_valuearray[6] = 0x07;
979 priv->cck_txbbgain_table[5].ccktxbb_valuearray[7] = 0x03;
981 priv->cck_txbbgain_table[6].ccktxbb_valuearray[0] = 0x26;
982 priv->cck_txbbgain_table[6].ccktxbb_valuearray[1] = 0x25;
983 priv->cck_txbbgain_table[6].ccktxbb_valuearray[2] = 0x21;
984 priv->cck_txbbgain_table[6].ccktxbb_valuearray[3] = 0x1b;
985 priv->cck_txbbgain_table[6].ccktxbb_valuearray[4] = 0x14;
986 priv->cck_txbbgain_table[6].ccktxbb_valuearray[5] = 0x0d;
987 priv->cck_txbbgain_table[6].ccktxbb_valuearray[6] = 0x06;
988 priv->cck_txbbgain_table[6].ccktxbb_valuearray[7] = 0x03;
990 priv->cck_txbbgain_table[7].ccktxbb_valuearray[0] = 0x24;
991 priv->cck_txbbgain_table[7].ccktxbb_valuearray[1] = 0x23;
992 priv->cck_txbbgain_table[7].ccktxbb_valuearray[2] = 0x1f;
993 priv->cck_txbbgain_table[7].ccktxbb_valuearray[3] = 0x19;
994 priv->cck_txbbgain_table[7].ccktxbb_valuearray[4] = 0x13;
995 priv->cck_txbbgain_table[7].ccktxbb_valuearray[5] = 0x0c;
996 priv->cck_txbbgain_table[7].ccktxbb_valuearray[6] = 0x06;
997 priv->cck_txbbgain_table[7].ccktxbb_valuearray[7] = 0x03;
999 priv->cck_txbbgain_table[8].ccktxbb_valuearray[0] = 0x22;
1000 priv->cck_txbbgain_table[8].ccktxbb_valuearray[1] = 0x21;
1001 priv->cck_txbbgain_table[8].ccktxbb_valuearray[2] = 0x1d;
1002 priv->cck_txbbgain_table[8].ccktxbb_valuearray[3] = 0x18;
1003 priv->cck_txbbgain_table[8].ccktxbb_valuearray[4] = 0x11;
1004 priv->cck_txbbgain_table[8].ccktxbb_valuearray[5] = 0x0b;
1005 priv->cck_txbbgain_table[8].ccktxbb_valuearray[6] = 0x06;
1006 priv->cck_txbbgain_table[8].ccktxbb_valuearray[7] = 0x02;
1008 priv->cck_txbbgain_table[9].ccktxbb_valuearray[0] = 0x20;
1009 priv->cck_txbbgain_table[9].ccktxbb_valuearray[1] = 0x20;
1010 priv->cck_txbbgain_table[9].ccktxbb_valuearray[2] = 0x1b;
1011 priv->cck_txbbgain_table[9].ccktxbb_valuearray[3] = 0x16;
1012 priv->cck_txbbgain_table[9].ccktxbb_valuearray[4] = 0x11;
1013 priv->cck_txbbgain_table[9].ccktxbb_valuearray[5] = 0x08;
1014 priv->cck_txbbgain_table[9].ccktxbb_valuearray[6] = 0x05;
1015 priv->cck_txbbgain_table[9].ccktxbb_valuearray[7] = 0x02;
1017 priv->cck_txbbgain_table[10].ccktxbb_valuearray[0] = 0x1f;
1018 priv->cck_txbbgain_table[10].ccktxbb_valuearray[1] = 0x1e;
1019 priv->cck_txbbgain_table[10].ccktxbb_valuearray[2] = 0x1a;
1020 priv->cck_txbbgain_table[10].ccktxbb_valuearray[3] = 0x15;
1021 priv->cck_txbbgain_table[10].ccktxbb_valuearray[4] = 0x10;
1022 priv->cck_txbbgain_table[10].ccktxbb_valuearray[5] = 0x0a;
1023 priv->cck_txbbgain_table[10].ccktxbb_valuearray[6] = 0x05;
1024 priv->cck_txbbgain_table[10].ccktxbb_valuearray[7] = 0x02;
1026 priv->cck_txbbgain_table[11].ccktxbb_valuearray[0] = 0x1d;
1027 priv->cck_txbbgain_table[11].ccktxbb_valuearray[1] = 0x1c;
1028 priv->cck_txbbgain_table[11].ccktxbb_valuearray[2] = 0x18;
1029 priv->cck_txbbgain_table[11].ccktxbb_valuearray[3] = 0x14;
1030 priv->cck_txbbgain_table[11].ccktxbb_valuearray[4] = 0x0f;
1031 priv->cck_txbbgain_table[11].ccktxbb_valuearray[5] = 0x0a;
1032 priv->cck_txbbgain_table[11].ccktxbb_valuearray[6] = 0x05;
1033 priv->cck_txbbgain_table[11].ccktxbb_valuearray[7] = 0x02;
1035 priv->cck_txbbgain_table[12].ccktxbb_valuearray[0] = 0x1b;
1036 priv->cck_txbbgain_table[12].ccktxbb_valuearray[1] = 0x1a;
1037 priv->cck_txbbgain_table[12].ccktxbb_valuearray[2] = 0x17;
1038 priv->cck_txbbgain_table[12].ccktxbb_valuearray[3] = 0x13;
1039 priv->cck_txbbgain_table[12].ccktxbb_valuearray[4] = 0x0e;
1040 priv->cck_txbbgain_table[12].ccktxbb_valuearray[5] = 0x09;
1041 priv->cck_txbbgain_table[12].ccktxbb_valuearray[6] = 0x04;
1042 priv->cck_txbbgain_table[12].ccktxbb_valuearray[7] = 0x02;
1044 priv->cck_txbbgain_table[13].ccktxbb_valuearray[0] = 0x1a;
1045 priv->cck_txbbgain_table[13].ccktxbb_valuearray[1] = 0x19;
1046 priv->cck_txbbgain_table[13].ccktxbb_valuearray[2] = 0x16;
1047 priv->cck_txbbgain_table[13].ccktxbb_valuearray[3] = 0x12;
1048 priv->cck_txbbgain_table[13].ccktxbb_valuearray[4] = 0x0d;
1049 priv->cck_txbbgain_table[13].ccktxbb_valuearray[5] = 0x09;
1050 priv->cck_txbbgain_table[13].ccktxbb_valuearray[6] = 0x04;
1051 priv->cck_txbbgain_table[13].ccktxbb_valuearray[7] = 0x02;
1053 priv->cck_txbbgain_table[14].ccktxbb_valuearray[0] = 0x18;
1054 priv->cck_txbbgain_table[14].ccktxbb_valuearray[1] = 0x17;
1055 priv->cck_txbbgain_table[14].ccktxbb_valuearray[2] = 0x15;
1056 priv->cck_txbbgain_table[14].ccktxbb_valuearray[3] = 0x11;
1057 priv->cck_txbbgain_table[14].ccktxbb_valuearray[4] = 0x0c;
1058 priv->cck_txbbgain_table[14].ccktxbb_valuearray[5] = 0x08;
1059 priv->cck_txbbgain_table[14].ccktxbb_valuearray[6] = 0x04;
1060 priv->cck_txbbgain_table[14].ccktxbb_valuearray[7] = 0x02;
1062 priv->cck_txbbgain_table[15].ccktxbb_valuearray[0] = 0x17;
1063 priv->cck_txbbgain_table[15].ccktxbb_valuearray[1] = 0x16;
1064 priv->cck_txbbgain_table[15].ccktxbb_valuearray[2] = 0x13;
1065 priv->cck_txbbgain_table[15].ccktxbb_valuearray[3] = 0x10;
1066 priv->cck_txbbgain_table[15].ccktxbb_valuearray[4] = 0x0c;
1067 priv->cck_txbbgain_table[15].ccktxbb_valuearray[5] = 0x08;
1068 priv->cck_txbbgain_table[15].ccktxbb_valuearray[6] = 0x04;
1069 priv->cck_txbbgain_table[15].ccktxbb_valuearray[7] = 0x02;
1071 priv->cck_txbbgain_table[16].ccktxbb_valuearray[0] = 0x16;
1072 priv->cck_txbbgain_table[16].ccktxbb_valuearray[1] = 0x15;
1073 priv->cck_txbbgain_table[16].ccktxbb_valuearray[2] = 0x12;
1074 priv->cck_txbbgain_table[16].ccktxbb_valuearray[3] = 0x0f;
1075 priv->cck_txbbgain_table[16].ccktxbb_valuearray[4] = 0x0b;
1076 priv->cck_txbbgain_table[16].ccktxbb_valuearray[5] = 0x07;
1077 priv->cck_txbbgain_table[16].ccktxbb_valuearray[6] = 0x04;
1078 priv->cck_txbbgain_table[16].ccktxbb_valuearray[7] = 0x01;
1080 priv->cck_txbbgain_table[17].ccktxbb_valuearray[0] = 0x14;
1081 priv->cck_txbbgain_table[17].ccktxbb_valuearray[1] = 0x14;
1082 priv->cck_txbbgain_table[17].ccktxbb_valuearray[2] = 0x11;
1083 priv->cck_txbbgain_table[17].ccktxbb_valuearray[3] = 0x0e;
1084 priv->cck_txbbgain_table[17].ccktxbb_valuearray[4] = 0x0b;
1085 priv->cck_txbbgain_table[17].ccktxbb_valuearray[5] = 0x07;
1086 priv->cck_txbbgain_table[17].ccktxbb_valuearray[6] = 0x03;
1087 priv->cck_txbbgain_table[17].ccktxbb_valuearray[7] = 0x02;
1089 priv->cck_txbbgain_table[18].ccktxbb_valuearray[0] = 0x13;
1090 priv->cck_txbbgain_table[18].ccktxbb_valuearray[1] = 0x13;
1091 priv->cck_txbbgain_table[18].ccktxbb_valuearray[2] = 0x10;
1092 priv->cck_txbbgain_table[18].ccktxbb_valuearray[3] = 0x0d;
1093 priv->cck_txbbgain_table[18].ccktxbb_valuearray[4] = 0x0a;
1094 priv->cck_txbbgain_table[18].ccktxbb_valuearray[5] = 0x06;
1095 priv->cck_txbbgain_table[18].ccktxbb_valuearray[6] = 0x03;
1096 priv->cck_txbbgain_table[18].ccktxbb_valuearray[7] = 0x01;
1098 priv->cck_txbbgain_table[19].ccktxbb_valuearray[0] = 0x12;
1099 priv->cck_txbbgain_table[19].ccktxbb_valuearray[1] = 0x12;
1100 priv->cck_txbbgain_table[19].ccktxbb_valuearray[2] = 0x0f;
1101 priv->cck_txbbgain_table[19].ccktxbb_valuearray[3] = 0x0c;
1102 priv->cck_txbbgain_table[19].ccktxbb_valuearray[4] = 0x09;
1103 priv->cck_txbbgain_table[19].ccktxbb_valuearray[5] = 0x06;
1104 priv->cck_txbbgain_table[19].ccktxbb_valuearray[6] = 0x03;
1105 priv->cck_txbbgain_table[19].ccktxbb_valuearray[7] = 0x01;
1107 priv->cck_txbbgain_table[20].ccktxbb_valuearray[0] = 0x11;
1108 priv->cck_txbbgain_table[20].ccktxbb_valuearray[1] = 0x11;
1109 priv->cck_txbbgain_table[20].ccktxbb_valuearray[2] = 0x0f;
1110 priv->cck_txbbgain_table[20].ccktxbb_valuearray[3] = 0x0c;
1111 priv->cck_txbbgain_table[20].ccktxbb_valuearray[4] = 0x09;
1112 priv->cck_txbbgain_table[20].ccktxbb_valuearray[5] = 0x06;
1113 priv->cck_txbbgain_table[20].ccktxbb_valuearray[6] = 0x03;
1114 priv->cck_txbbgain_table[20].ccktxbb_valuearray[7] = 0x01;
1116 priv->cck_txbbgain_table[21].ccktxbb_valuearray[0] = 0x10;
1117 priv->cck_txbbgain_table[21].ccktxbb_valuearray[1] = 0x10;
1118 priv->cck_txbbgain_table[21].ccktxbb_valuearray[2] = 0x0e;
1119 priv->cck_txbbgain_table[21].ccktxbb_valuearray[3] = 0x0b;
1120 priv->cck_txbbgain_table[21].ccktxbb_valuearray[4] = 0x08;
1121 priv->cck_txbbgain_table[21].ccktxbb_valuearray[5] = 0x05;
1122 priv->cck_txbbgain_table[21].ccktxbb_valuearray[6] = 0x03;
1123 priv->cck_txbbgain_table[21].ccktxbb_valuearray[7] = 0x01;
1125 priv->cck_txbbgain_table[22].ccktxbb_valuearray[0] = 0x0f;
1126 priv->cck_txbbgain_table[22].ccktxbb_valuearray[1] = 0x0f;
1127 priv->cck_txbbgain_table[22].ccktxbb_valuearray[2] = 0x0d;
1128 priv->cck_txbbgain_table[22].ccktxbb_valuearray[3] = 0x0b;
1129 priv->cck_txbbgain_table[22].ccktxbb_valuearray[4] = 0x08;
1130 priv->cck_txbbgain_table[22].ccktxbb_valuearray[5] = 0x05;
1131 priv->cck_txbbgain_table[22].ccktxbb_valuearray[6] = 0x03;
1132 priv->cck_txbbgain_table[22].ccktxbb_valuearray[7] = 0x01;
1134 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[0] = 0x36;
1135 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[1] = 0x35;
1136 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[2] = 0x2e;
1137 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[3] = 0x1b;
1138 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[4] = 0x00;
1139 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[5] = 0x00;
1140 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[6] = 0x00;
1141 priv->cck_txbbgain_ch14_table[0].ccktxbb_valuearray[7] = 0x00;
1143 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[0] = 0x33;
1144 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[1] = 0x32;
1145 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[2] = 0x2b;
1146 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[3] = 0x19;
1147 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[4] = 0x00;
1148 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[5] = 0x00;
1149 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[6] = 0x00;
1150 priv->cck_txbbgain_ch14_table[1].ccktxbb_valuearray[7] = 0x00;
1152 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[0] = 0x30;
1153 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[1] = 0x2f;
1154 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[2] = 0x29;
1155 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[3] = 0x18;
1156 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[4] = 0x00;
1157 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[5] = 0x00;
1158 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[6] = 0x00;
1159 priv->cck_txbbgain_ch14_table[2].ccktxbb_valuearray[7] = 0x00;
1161 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[0] = 0x2d;
1162 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[1] = 0x2d;
1163 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[2] = 0x27;
1164 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[3] = 0x17;
1165 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[4] = 0x00;
1166 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[5] = 0x00;
1167 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[6] = 0x00;
1168 priv->cck_txbbgain_ch14_table[3].ccktxbb_valuearray[7] = 0x00;
1170 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[0] = 0x2b;
1171 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[1] = 0x2a;
1172 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[2] = 0x25;
1173 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[3] = 0x15;
1174 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[4] = 0x00;
1175 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[5] = 0x00;
1176 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[6] = 0x00;
1177 priv->cck_txbbgain_ch14_table[4].ccktxbb_valuearray[7] = 0x00;
1179 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[0] = 0x28;
1180 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[1] = 0x28;
1181 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[2] = 0x22;
1182 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[3] = 0x14;
1183 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[4] = 0x00;
1184 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[5] = 0x00;
1185 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[6] = 0x00;
1186 priv->cck_txbbgain_ch14_table[5].ccktxbb_valuearray[7] = 0x00;
1188 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[0] = 0x26;
1189 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[1] = 0x25;
1190 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[2] = 0x21;
1191 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[3] = 0x13;
1192 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[4] = 0x00;
1193 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[5] = 0x00;
1194 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[6] = 0x00;
1195 priv->cck_txbbgain_ch14_table[6].ccktxbb_valuearray[7] = 0x00;
1197 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[0] = 0x24;
1198 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[1] = 0x23;
1199 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[2] = 0x1f;
1200 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[3] = 0x12;
1201 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[4] = 0x00;
1202 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[5] = 0x00;
1203 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[6] = 0x00;
1204 priv->cck_txbbgain_ch14_table[7].ccktxbb_valuearray[7] = 0x00;
1206 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[0] = 0x22;
1207 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[1] = 0x21;
1208 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[2] = 0x1d;
1209 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[3] = 0x11;
1210 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[4] = 0x00;
1211 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[5] = 0x00;
1212 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[6] = 0x00;
1213 priv->cck_txbbgain_ch14_table[8].ccktxbb_valuearray[7] = 0x00;
1215 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[0] = 0x20;
1216 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[1] = 0x20;
1217 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[2] = 0x1b;
1218 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[3] = 0x10;
1219 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[4] = 0x00;
1220 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[5] = 0x00;
1221 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[6] = 0x00;
1222 priv->cck_txbbgain_ch14_table[9].ccktxbb_valuearray[7] = 0x00;
1224 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[0] = 0x1f;
1225 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[1] = 0x1e;
1226 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[2] = 0x1a;
1227 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[3] = 0x0f;
1228 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[4] = 0x00;
1229 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[5] = 0x00;
1230 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[6] = 0x00;
1231 priv->cck_txbbgain_ch14_table[10].ccktxbb_valuearray[7] = 0x00;
1233 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[0] = 0x1d;
1234 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[1] = 0x1c;
1235 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[2] = 0x18;
1236 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[3] = 0x0e;
1237 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[4] = 0x00;
1238 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[5] = 0x00;
1239 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[6] = 0x00;
1240 priv->cck_txbbgain_ch14_table[11].ccktxbb_valuearray[7] = 0x00;
1242 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[0] = 0x1b;
1243 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[1] = 0x1a;
1244 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[2] = 0x17;
1245 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[3] = 0x0e;
1246 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[4] = 0x00;
1247 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[5] = 0x00;
1248 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[6] = 0x00;
1249 priv->cck_txbbgain_ch14_table[12].ccktxbb_valuearray[7] = 0x00;
1251 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[0] = 0x1a;
1252 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[1] = 0x19;
1253 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[2] = 0x16;
1254 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[3] = 0x0d;
1255 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[4] = 0x00;
1256 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[5] = 0x00;
1257 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[6] = 0x00;
1258 priv->cck_txbbgain_ch14_table[13].ccktxbb_valuearray[7] = 0x00;
1260 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[0] = 0x18;
1261 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[1] = 0x17;
1262 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[2] = 0x15;
1263 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[3] = 0x0c;
1264 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[4] = 0x00;
1265 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[5] = 0x00;
1266 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[6] = 0x00;
1267 priv->cck_txbbgain_ch14_table[14].ccktxbb_valuearray[7] = 0x00;
1269 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[0] = 0x17;
1270 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[1] = 0x16;
1271 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[2] = 0x13;
1272 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[3] = 0x0b;
1273 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[4] = 0x00;
1274 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[5] = 0x00;
1275 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[6] = 0x00;
1276 priv->cck_txbbgain_ch14_table[15].ccktxbb_valuearray[7] = 0x00;
1278 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[0] = 0x16;
1279 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[1] = 0x15;
1280 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[2] = 0x12;
1281 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[3] = 0x0b;
1282 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[4] = 0x00;
1283 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[5] = 0x00;
1284 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[6] = 0x00;
1285 priv->cck_txbbgain_ch14_table[16].ccktxbb_valuearray[7] = 0x00;
1287 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[0] = 0x14;
1288 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[1] = 0x14;
1289 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[2] = 0x11;
1290 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[3] = 0x0a;
1291 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[4] = 0x00;
1292 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[5] = 0x00;
1293 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[6] = 0x00;
1294 priv->cck_txbbgain_ch14_table[17].ccktxbb_valuearray[7] = 0x00;
1296 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[0] = 0x13;
1297 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[1] = 0x13;
1298 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[2] = 0x10;
1299 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[3] = 0x0a;
1300 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[4] = 0x00;
1301 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[5] = 0x00;
1302 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[6] = 0x00;
1303 priv->cck_txbbgain_ch14_table[18].ccktxbb_valuearray[7] = 0x00;
1305 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[0] = 0x12;
1306 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[1] = 0x12;
1307 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[2] = 0x0f;
1308 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[3] = 0x09;
1309 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[4] = 0x00;
1310 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[5] = 0x00;
1311 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[6] = 0x00;
1312 priv->cck_txbbgain_ch14_table[19].ccktxbb_valuearray[7] = 0x00;
1314 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[0] = 0x11;
1315 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[1] = 0x11;
1316 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[2] = 0x0f;
1317 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[3] = 0x09;
1318 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[4] = 0x00;
1319 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[5] = 0x00;
1320 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[6] = 0x00;
1321 priv->cck_txbbgain_ch14_table[20].ccktxbb_valuearray[7] = 0x00;
1323 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[0] = 0x10;
1324 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[1] = 0x10;
1325 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[2] = 0x0e;
1326 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[3] = 0x08;
1327 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[4] = 0x00;
1328 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[5] = 0x00;
1329 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[6] = 0x00;
1330 priv->cck_txbbgain_ch14_table[21].ccktxbb_valuearray[7] = 0x00;
1332 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[0] = 0x0f;
1333 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[1] = 0x0f;
1334 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[2] = 0x0d;
1335 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[3] = 0x08;
1336 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[4] = 0x00;
1337 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[5] = 0x00;
1338 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[6] = 0x00;
1339 priv->cck_txbbgain_ch14_table[22].ccktxbb_valuearray[7] = 0x00;
1341 priv->btxpower_tracking = true;
1342 priv->txpower_count = 0;
1343 priv->btxpower_trackingInit = false;
1347 static void dm_InitializeTXPowerTracking_ThermalMeter(struct net_device *dev)
1349 struct r8192_priv *priv = rtllib_priv(dev);
1352 if (priv->rtllib->FwRWRF)
1353 priv->btxpower_tracking = true;
1355 priv->btxpower_tracking = false;
1356 priv->txpower_count = 0;
1357 priv->btxpower_trackingInit = false;
1358 RT_TRACE(COMP_POWER_TRACKING, "pMgntInfo->bTXPowerTracking = %d\n",
1359 priv->btxpower_tracking);
1362 void dm_initialize_txpower_tracking(struct net_device *dev)
1364 struct r8192_priv *priv = rtllib_priv(dev);
1366 if (priv->IC_Cut >= IC_VersionCut_D)
1367 dm_InitializeTXPowerTracking_TSSI(dev);
1369 dm_InitializeTXPowerTracking_ThermalMeter(dev);
1372 static void dm_CheckTXPowerTracking_TSSI(struct net_device *dev)
1374 struct r8192_priv *priv = rtllib_priv(dev);
1375 static u32 tx_power_track_counter;
1377 RT_TRACE(COMP_POWER_TRACKING, "%s()\n", __func__);
1378 if (read_nic_byte(dev, 0x11e) == 1)
1380 if (!priv->btxpower_tracking)
1382 tx_power_track_counter++;
1385 if (tx_power_track_counter >= 180) {
1386 queue_delayed_work_rsl(priv->priv_wq, &priv->txpower_tracking_wq, 0);
1387 tx_power_track_counter = 0;
1391 static void dm_CheckTXPowerTracking_ThermalMeter(struct net_device *dev)
1393 struct r8192_priv *priv = rtllib_priv(dev);
1394 static u8 TM_Trigger;
1395 u8 TxPowerCheckCnt = 0;
1397 if (IS_HARDWARE_TYPE_8192SE(dev))
1398 TxPowerCheckCnt = 5;
1400 TxPowerCheckCnt = 2;
1401 if (!priv->btxpower_tracking)
1404 if (priv->txpower_count <= TxPowerCheckCnt) {
1405 priv->txpower_count++;
1411 rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
1412 rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
1413 rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4d);
1414 rtl8192_phy_SetRFReg(dev, RF90_PATH_A, 0x02, bMask12Bits, 0x4f);
1419 netdev_info(dev, "===============>Schedule TxPowerTrackingWorkItem\n");
1420 queue_delayed_work_rsl(priv->priv_wq, &priv->txpower_tracking_wq, 0);
1425 static void dm_check_txpower_tracking(struct net_device *dev)
1427 struct r8192_priv *priv = rtllib_priv(dev);
1429 if (priv->IC_Cut >= IC_VersionCut_D)
1430 dm_CheckTXPowerTracking_TSSI(dev);
1432 dm_CheckTXPowerTracking_ThermalMeter(dev);
1435 static void dm_CCKTxPowerAdjust_TSSI(struct net_device *dev, bool bInCH14)
1438 struct r8192_priv *priv = rtllib_priv(dev);
1442 TempVal = (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[0] +
1443 (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[1]<<8));
1445 rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
1446 TempVal = (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[2] +
1447 (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[3]<<8) +
1448 (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[4]<<16)+
1449 (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[5]<<24));
1450 rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
1451 TempVal = (u32)(priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[6] +
1452 (priv->cck_txbbgain_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[7]<<8));
1454 rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
1456 TempVal = (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[0] +
1457 (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[1]<<8));
1459 rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
1460 TempVal = (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[2] +
1461 (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[3]<<8) +
1462 (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[4]<<16)+
1463 (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[5]<<24));
1464 rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
1465 TempVal = (u32)(priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[6] +
1466 (priv->cck_txbbgain_ch14_table[(u8)(priv->CCKPresentAttentuation)].ccktxbb_valuearray[7]<<8));
1468 rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
1474 static void dm_CCKTxPowerAdjust_ThermalMeter(struct net_device *dev, bool bInCH14)
1477 struct r8192_priv *priv = rtllib_priv(dev);
1481 TempVal = CCKSwingTable_Ch1_Ch13[priv->CCK_index][0] +
1482 (CCKSwingTable_Ch1_Ch13[priv->CCK_index][1]<<8);
1483 rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
1484 RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
1485 rCCK0_TxFilter1, TempVal);
1486 TempVal = CCKSwingTable_Ch1_Ch13[priv->CCK_index][2] +
1487 (CCKSwingTable_Ch1_Ch13[priv->CCK_index][3]<<8) +
1488 (CCKSwingTable_Ch1_Ch13[priv->CCK_index][4]<<16)+
1489 (CCKSwingTable_Ch1_Ch13[priv->CCK_index][5]<<24);
1490 rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
1491 RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
1492 rCCK0_TxFilter2, TempVal);
1493 TempVal = CCKSwingTable_Ch1_Ch13[priv->CCK_index][6] +
1494 (CCKSwingTable_Ch1_Ch13[priv->CCK_index][7]<<8);
1496 rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
1497 RT_TRACE(COMP_POWER_TRACKING, "CCK not chnl 14, reg 0x%x = 0x%x\n",
1498 rCCK0_DebugPort, TempVal);
1500 TempVal = CCKSwingTable_Ch14[priv->CCK_index][0] +
1501 (CCKSwingTable_Ch14[priv->CCK_index][1]<<8);
1503 rtl8192_setBBreg(dev, rCCK0_TxFilter1, bMaskHWord, TempVal);
1504 RT_TRACE(COMP_POWER_TRACKING, "CCK chnl 14, reg 0x%x = 0x%x\n",
1505 rCCK0_TxFilter1, TempVal);
1506 TempVal = CCKSwingTable_Ch14[priv->CCK_index][2] +
1507 (CCKSwingTable_Ch14[priv->CCK_index][3]<<8) +
1508 (CCKSwingTable_Ch14[priv->CCK_index][4]<<16)+
1509 (CCKSwingTable_Ch14[priv->CCK_index][5]<<24);
1510 rtl8192_setBBreg(dev, rCCK0_TxFilter2, bMaskDWord, TempVal);
1511 RT_TRACE(COMP_POWER_TRACKING, "CCK chnl 14, reg 0x%x = 0x%x\n",
1512 rCCK0_TxFilter2, TempVal);
1513 TempVal = CCKSwingTable_Ch14[priv->CCK_index][6] +
1514 (CCKSwingTable_Ch14[priv->CCK_index][7]<<8);
1516 rtl8192_setBBreg(dev, rCCK0_DebugPort, bMaskLWord, TempVal);
1517 RT_TRACE(COMP_POWER_TRACKING, "CCK chnl 14, reg 0x%x = 0x%x\n",
1518 rCCK0_DebugPort, TempVal);
1522 void dm_cck_txpower_adjust(struct net_device *dev, bool binch14)
1524 struct r8192_priv *priv = rtllib_priv(dev);
1526 if (priv->IC_Cut >= IC_VersionCut_D)
1527 dm_CCKTxPowerAdjust_TSSI(dev, binch14);
1529 dm_CCKTxPowerAdjust_ThermalMeter(dev, binch14);
1532 static void dm_txpower_reset_recovery(struct net_device *dev)
1534 struct r8192_priv *priv = rtllib_priv(dev);
1536 RT_TRACE(COMP_POWER_TRACKING, "Start Reset Recovery ==>\n");
1537 rtl8192_setBBreg(dev, rOFDM0_XATxIQImbalance, bMaskDWord,
1538 priv->txbbgain_table[priv->rfa_txpowertrackingindex].txbbgain_value);
1539 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery: Fill in 0xc80 is %08x\n",
1540 priv->txbbgain_table[priv->rfa_txpowertrackingindex].txbbgain_value);
1541 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery: Fill in RFA_txPowerTrackingIndex is %x\n",
1542 priv->rfa_txpowertrackingindex);
1543 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery : RF A I/Q Amplify Gain is %ld\n",
1544 priv->txbbgain_table[priv->rfa_txpowertrackingindex].txbb_iq_amplifygain);
1545 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery: CCK Attenuation is %d dB\n",
1546 priv->CCKPresentAttentuation);
1547 dm_cck_txpower_adjust(dev, priv->bcck_in_ch14);
1549 rtl8192_setBBreg(dev, rOFDM0_XCTxIQImbalance, bMaskDWord,
1550 priv->txbbgain_table[priv->rfc_txpowertrackingindex].txbbgain_value);
1551 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery: Fill in 0xc90 is %08x\n",
1552 priv->txbbgain_table[priv->rfc_txpowertrackingindex].txbbgain_value);
1553 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery: Fill in RFC_txPowerTrackingIndex is %x\n",
1554 priv->rfc_txpowertrackingindex);
1555 RT_TRACE(COMP_POWER_TRACKING, "Reset Recovery : RF C I/Q Amplify Gain is %ld\n",
1556 priv->txbbgain_table[priv->rfc_txpowertrackingindex].txbb_iq_amplifygain);
1560 void dm_restore_dynamic_mechanism_state(struct net_device *dev)
1562 struct r8192_priv *priv = rtllib_priv(dev);
1563 u32 reg_ratr = priv->rate_adaptive.last_ratr;
1567 RT_TRACE(COMP_RATE, "<---- dm_restore_dynamic_mechanism_state(): driver is going to unload\n");
1571 if (priv->rate_adaptive.rate_adaptive_disabled)
1573 if (!(priv->rtllib->mode == WIRELESS_MODE_N_24G ||
1574 priv->rtllib->mode == WIRELESS_MODE_N_5G))
1576 ratr_value = reg_ratr;
1577 if (priv->rf_type == RF_1T2R)
1578 ratr_value &= ~(RATE_ALL_OFDM_2SS);
1579 write_nic_dword(dev, RATR0, ratr_value);
1580 write_nic_byte(dev, UFWP, 1);
1581 if (priv->btxpower_trackingInit && priv->btxpower_tracking)
1582 dm_txpower_reset_recovery(dev);
1584 dm_bb_initialgain_restore(dev);
1588 static void dm_bb_initialgain_restore(struct net_device *dev)
1590 struct r8192_priv *priv = rtllib_priv(dev);
1591 u32 bit_mask = 0x7f;
1593 if (dm_digtable.dig_algorithm == DIG_ALGO_BY_RSSI)
1596 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);
1597 rtl8192_setBBreg(dev, rOFDM0_XAAGCCore1, bit_mask, (u32)priv->initgain_backup.xaagccore1);
1598 rtl8192_setBBreg(dev, rOFDM0_XBAGCCore1, bit_mask, (u32)priv->initgain_backup.xbagccore1);
1599 rtl8192_setBBreg(dev, rOFDM0_XCAGCCore1, bit_mask, (u32)priv->initgain_backup.xcagccore1);
1600 rtl8192_setBBreg(dev, rOFDM0_XDAGCCore1, bit_mask, (u32)priv->initgain_backup.xdagccore1);
1601 bit_mask = bMaskByte2;
1602 rtl8192_setBBreg(dev, rCCK0_CCA, bit_mask, (u32)priv->initgain_backup.cca);
1604 RT_TRACE(COMP_DIG, "dm_BBInitialGainRestore 0xc50 is %x\n", priv->initgain_backup.xaagccore1);
1605 RT_TRACE(COMP_DIG, "dm_BBInitialGainRestore 0xc58 is %x\n", priv->initgain_backup.xbagccore1);
1606 RT_TRACE(COMP_DIG, "dm_BBInitialGainRestore 0xc60 is %x\n", priv->initgain_backup.xcagccore1);
1607 RT_TRACE(COMP_DIG, "dm_BBInitialGainRestore 0xc68 is %x\n", priv->initgain_backup.xdagccore1);
1608 RT_TRACE(COMP_DIG, "dm_BBInitialGainRestore 0xa0a is %x\n", priv->initgain_backup.cca);
1609 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x1);
1614 void dm_backup_dynamic_mechanism_state(struct net_device *dev)
1616 struct r8192_priv *priv = rtllib_priv(dev);
1618 priv->bswitch_fsync = false;
1619 priv->bfsync_processing = false;
1620 dm_bb_initialgain_backup(dev);
1625 static void dm_bb_initialgain_backup(struct net_device *dev)
1627 struct r8192_priv *priv = rtllib_priv(dev);
1628 u32 bit_mask = bMaskByte0;
1630 if (dm_digtable.dig_algorithm == DIG_ALGO_BY_RSSI)
1633 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);
1634 priv->initgain_backup.xaagccore1 = (u8)rtl8192_QueryBBReg(dev, rOFDM0_XAAGCCore1, bit_mask);
1635 priv->initgain_backup.xbagccore1 = (u8)rtl8192_QueryBBReg(dev, rOFDM0_XBAGCCore1, bit_mask);
1636 priv->initgain_backup.xcagccore1 = (u8)rtl8192_QueryBBReg(dev, rOFDM0_XCAGCCore1, bit_mask);
1637 priv->initgain_backup.xdagccore1 = (u8)rtl8192_QueryBBReg(dev, rOFDM0_XDAGCCore1, bit_mask);
1638 bit_mask = bMaskByte2;
1639 priv->initgain_backup.cca = (u8)rtl8192_QueryBBReg(dev, rCCK0_CCA, bit_mask);
1641 RT_TRACE(COMP_DIG, "BBInitialGainBackup 0xc50 is %x\n", priv->initgain_backup.xaagccore1);
1642 RT_TRACE(COMP_DIG, "BBInitialGainBackup 0xc58 is %x\n", priv->initgain_backup.xbagccore1);
1643 RT_TRACE(COMP_DIG, "BBInitialGainBackup 0xc60 is %x\n", priv->initgain_backup.xcagccore1);
1644 RT_TRACE(COMP_DIG, "BBInitialGainBackup 0xc68 is %x\n", priv->initgain_backup.xdagccore1);
1645 RT_TRACE(COMP_DIG, "BBInitialGainBackup 0xa0a is %x\n", priv->initgain_backup.cca);
1649 void dm_change_dynamic_initgain_thresh(struct net_device *dev,
1650 u32 dm_type, u32 dm_value)
1652 if (dm_type == DIG_TYPE_THRESH_HIGH) {
1653 dm_digtable.rssi_high_thresh = dm_value;
1654 } else if (dm_type == DIG_TYPE_THRESH_LOW) {
1655 dm_digtable.rssi_low_thresh = dm_value;
1656 } else if (dm_type == DIG_TYPE_THRESH_HIGHPWR_HIGH) {
1657 dm_digtable.rssi_high_power_highthresh = dm_value;
1658 } else if (dm_type == DIG_TYPE_THRESH_HIGHPWR_LOW) {
1659 dm_digtable.rssi_high_power_lowthresh = dm_value;
1660 } else if (dm_type == DIG_TYPE_ENABLE) {
1661 dm_digtable.dig_state = DM_STA_DIG_MAX;
1662 dm_digtable.dig_enable_flag = true;
1663 } else if (dm_type == DIG_TYPE_DISABLE) {
1664 dm_digtable.dig_state = DM_STA_DIG_MAX;
1665 dm_digtable.dig_enable_flag = false;
1666 } else if (dm_type == DIG_TYPE_DBG_MODE) {
1667 if (dm_value >= DM_DBG_MAX)
1668 dm_value = DM_DBG_OFF;
1669 dm_digtable.dbg_mode = (u8)dm_value;
1670 } else if (dm_type == DIG_TYPE_RSSI) {
1673 dm_digtable.rssi_val = (long)dm_value;
1674 } else if (dm_type == DIG_TYPE_ALGORITHM) {
1675 if (dm_value >= DIG_ALGO_MAX)
1676 dm_value = DIG_ALGO_BY_FALSE_ALARM;
1677 if (dm_digtable.dig_algorithm != (u8)dm_value)
1678 dm_digtable.dig_algorithm_switch = 1;
1679 dm_digtable.dig_algorithm = (u8)dm_value;
1680 } else if (dm_type == DIG_TYPE_BACKOFF) {
1683 dm_digtable.backoff_val = (u8)dm_value;
1684 } else if (dm_type == DIG_TYPE_RX_GAIN_MIN) {
1687 dm_digtable.rx_gain_range_min = (u8)dm_value;
1688 } else if (dm_type == DIG_TYPE_RX_GAIN_MAX) {
1689 if (dm_value > 0x50)
1691 dm_digtable.rx_gain_range_max = (u8)dm_value;
1695 static void dm_dig_init(struct net_device *dev)
1697 struct r8192_priv *priv = rtllib_priv(dev);
1699 dm_digtable.dig_enable_flag = true;
1700 dm_digtable.Backoff_Enable_Flag = true;
1702 dm_digtable.dig_algorithm = DIG_ALGO_BY_RSSI;
1704 dm_digtable.Dig_TwoPort_Algorithm = DIG_TWO_PORT_ALGO_RSSI;
1705 dm_digtable.Dig_Ext_Port_Stage = DIG_EXT_PORT_STAGE_MAX;
1706 dm_digtable.dbg_mode = DM_DBG_OFF;
1707 dm_digtable.dig_algorithm_switch = 0;
1709 dm_digtable.dig_state = DM_STA_DIG_MAX;
1710 dm_digtable.dig_highpwr_state = DM_STA_DIG_MAX;
1711 dm_digtable.CurSTAConnectState = dm_digtable.PreSTAConnectState = DIG_STA_DISCONNECT;
1712 dm_digtable.CurAPConnectState = dm_digtable.PreAPConnectState = DIG_AP_DISCONNECT;
1713 dm_digtable.initialgain_lowerbound_state = false;
1715 dm_digtable.rssi_low_thresh = DM_DIG_THRESH_LOW;
1716 dm_digtable.rssi_high_thresh = DM_DIG_THRESH_HIGH;
1718 dm_digtable.FALowThresh = DM_FALSEALARM_THRESH_LOW;
1719 dm_digtable.FAHighThresh = DM_FALSEALARM_THRESH_HIGH;
1721 dm_digtable.rssi_high_power_lowthresh = DM_DIG_HIGH_PWR_THRESH_LOW;
1722 dm_digtable.rssi_high_power_highthresh = DM_DIG_HIGH_PWR_THRESH_HIGH;
1724 dm_digtable.rssi_val = 50;
1725 dm_digtable.backoff_val = DM_DIG_BACKOFF;
1726 dm_digtable.rx_gain_range_max = DM_DIG_MAX;
1727 if (priv->CustomerID == RT_CID_819x_Netcore)
1728 dm_digtable.rx_gain_range_min = DM_DIG_MIN_Netcore;
1730 dm_digtable.rx_gain_range_min = DM_DIG_MIN;
1732 dm_digtable.BackoffVal_range_max = DM_DIG_BACKOFF_MAX;
1733 dm_digtable.BackoffVal_range_min = DM_DIG_BACKOFF_MIN;
1736 static void dm_ctrl_initgain_byrssi(struct net_device *dev)
1739 if (dm_digtable.dig_enable_flag == false)
1742 if (dm_digtable.dig_algorithm == DIG_ALGO_BY_FALSE_ALARM)
1743 dm_ctrl_initgain_byrssi_by_fwfalse_alarm(dev);
1744 else if (dm_digtable.dig_algorithm == DIG_ALGO_BY_RSSI)
1745 dm_ctrl_initgain_byrssi_by_driverrssi(dev);
1750 /*-----------------------------------------------------------------------------
1751 * Function: dm_CtrlInitGainBeforeConnectByRssiAndFalseAlarm()
1753 * Overview: Driver monitor RSSI and False Alarm to change initial gain.
1754 Only change initial gain during link in progress.
1756 * Input: IN PADAPTER pAdapter
1764 * 03/04/2009 hpfan Create Version 0.
1766 *---------------------------------------------------------------------------*/
1768 static void dm_ctrl_initgain_byrssi_by_driverrssi(
1769 struct net_device *dev)
1771 struct r8192_priv *priv = rtllib_priv(dev);
1775 if (dm_digtable.dig_enable_flag == false)
1778 if (dm_digtable.dig_algorithm_switch)
1781 for (i = 0; i < 3; i++)
1782 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);
1784 dm_digtable.dig_state = DM_STA_DIG_OFF;
1787 if (priv->rtllib->state == RTLLIB_LINKED)
1788 dm_digtable.CurSTAConnectState = DIG_STA_CONNECT;
1790 dm_digtable.CurSTAConnectState = DIG_STA_DISCONNECT;
1793 if (dm_digtable.dbg_mode == DM_DBG_OFF)
1794 dm_digtable.rssi_val = priv->undecorated_smoothed_pwdb;
1795 dm_initial_gain(dev);
1798 if (dm_digtable.dig_algorithm_switch)
1799 dm_digtable.dig_algorithm_switch = 0;
1800 dm_digtable.PreSTAConnectState = dm_digtable.CurSTAConnectState;
1804 static void dm_ctrl_initgain_byrssi_by_fwfalse_alarm(
1805 struct net_device *dev)
1807 struct r8192_priv *priv = rtllib_priv(dev);
1808 static u32 reset_cnt;
1811 if (dm_digtable.dig_enable_flag == false)
1814 if (dm_digtable.dig_algorithm_switch) {
1815 dm_digtable.dig_state = DM_STA_DIG_MAX;
1816 for (i = 0; i < 3; i++)
1817 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x1);
1818 dm_digtable.dig_algorithm_switch = 0;
1821 if (priv->rtllib->state != RTLLIB_LINKED)
1824 if ((priv->undecorated_smoothed_pwdb > dm_digtable.rssi_low_thresh) &&
1825 (priv->undecorated_smoothed_pwdb < dm_digtable.rssi_high_thresh))
1827 if (priv->undecorated_smoothed_pwdb <= dm_digtable.rssi_low_thresh) {
1828 if (dm_digtable.dig_state == DM_STA_DIG_OFF &&
1829 (priv->reset_count == reset_cnt))
1831 reset_cnt = priv->reset_count;
1833 dm_digtable.dig_highpwr_state = DM_STA_DIG_MAX;
1834 dm_digtable.dig_state = DM_STA_DIG_OFF;
1836 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x8);
1838 write_nic_byte(dev, rOFDM0_XAAGCCore1, 0x17);
1839 write_nic_byte(dev, rOFDM0_XBAGCCore1, 0x17);
1840 write_nic_byte(dev, rOFDM0_XCAGCCore1, 0x17);
1841 write_nic_byte(dev, rOFDM0_XDAGCCore1, 0x17);
1843 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
1844 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x00);
1846 write_nic_byte(dev, rOFDM0_RxDetector1, 0x42);
1848 write_nic_byte(dev, 0xa0a, 0x08);
1853 if (priv->undecorated_smoothed_pwdb >= dm_digtable.rssi_high_thresh) {
1856 if (dm_digtable.dig_state == DM_STA_DIG_ON &&
1857 (priv->reset_count == reset_cnt)) {
1858 dm_ctrl_initgain_byrssi_highpwr(dev);
1861 if (priv->reset_count != reset_cnt)
1864 reset_cnt = priv->reset_count;
1866 dm_digtable.dig_state = DM_STA_DIG_ON;
1868 if (reset_flag == 1) {
1869 write_nic_byte(dev, rOFDM0_XAAGCCore1, 0x2c);
1870 write_nic_byte(dev, rOFDM0_XBAGCCore1, 0x2c);
1871 write_nic_byte(dev, rOFDM0_XCAGCCore1, 0x2c);
1872 write_nic_byte(dev, rOFDM0_XDAGCCore1, 0x2c);
1874 write_nic_byte(dev, rOFDM0_XAAGCCore1, 0x20);
1875 write_nic_byte(dev, rOFDM0_XBAGCCore1, 0x20);
1876 write_nic_byte(dev, rOFDM0_XCAGCCore1, 0x20);
1877 write_nic_byte(dev, rOFDM0_XDAGCCore1, 0x20);
1880 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
1881 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x20);
1883 write_nic_byte(dev, rOFDM0_RxDetector1, 0x44);
1885 write_nic_byte(dev, 0xa0a, 0xcd);
1887 rtl8192_setBBreg(dev, UFWP, bMaskByte1, 0x1);
1889 dm_ctrl_initgain_byrssi_highpwr(dev);
1893 static void dm_ctrl_initgain_byrssi_highpwr(struct net_device *dev)
1895 struct r8192_priv *priv = rtllib_priv(dev);
1896 static u32 reset_cnt_highpwr;
1898 if ((priv->undecorated_smoothed_pwdb > dm_digtable.rssi_high_power_lowthresh) &&
1899 (priv->undecorated_smoothed_pwdb < dm_digtable.rssi_high_power_highthresh))
1902 if (priv->undecorated_smoothed_pwdb >= dm_digtable.rssi_high_power_highthresh) {
1903 if (dm_digtable.dig_highpwr_state == DM_STA_DIG_ON &&
1904 (priv->reset_count == reset_cnt_highpwr))
1906 dm_digtable.dig_highpwr_state = DM_STA_DIG_ON;
1908 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
1909 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x10);
1911 write_nic_byte(dev, rOFDM0_RxDetector1, 0x43);
1913 if (dm_digtable.dig_highpwr_state == DM_STA_DIG_OFF &&
1914 (priv->reset_count == reset_cnt_highpwr))
1916 dm_digtable.dig_highpwr_state = DM_STA_DIG_OFF;
1918 if (priv->undecorated_smoothed_pwdb < dm_digtable.rssi_high_power_lowthresh &&
1919 priv->undecorated_smoothed_pwdb >= dm_digtable.rssi_high_thresh) {
1920 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
1921 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x20);
1923 write_nic_byte(dev, rOFDM0_RxDetector1, 0x44);
1926 reset_cnt_highpwr = priv->reset_count;
1929 static void dm_initial_gain(struct net_device *dev)
1931 struct r8192_priv *priv = rtllib_priv(dev);
1932 u8 initial_gain = 0;
1933 static u8 initialized, force_write;
1934 static u32 reset_cnt;
1936 if (dm_digtable.dig_algorithm_switch) {
1941 if (rtllib_act_scanning(priv->rtllib, true) == true) {
1946 if (dm_digtable.PreSTAConnectState == dm_digtable.CurSTAConnectState) {
1947 if (dm_digtable.CurSTAConnectState == DIG_STA_CONNECT) {
1948 if ((dm_digtable.rssi_val+10-dm_digtable.backoff_val) > dm_digtable.rx_gain_range_max)
1949 dm_digtable.cur_ig_value = dm_digtable.rx_gain_range_max;
1950 else if ((dm_digtable.rssi_val+10-dm_digtable.backoff_val) < dm_digtable.rx_gain_range_min)
1951 dm_digtable.cur_ig_value = dm_digtable.rx_gain_range_min;
1953 dm_digtable.cur_ig_value = dm_digtable.rssi_val+10-dm_digtable.backoff_val;
1955 if (dm_digtable.cur_ig_value == 0)
1956 dm_digtable.cur_ig_value = priv->DefaultInitialGain[0];
1958 dm_digtable.cur_ig_value = dm_digtable.pre_ig_value;
1961 dm_digtable.cur_ig_value = priv->DefaultInitialGain[0];
1962 dm_digtable.pre_ig_value = 0;
1965 if (priv->reset_count != reset_cnt) {
1967 reset_cnt = priv->reset_count;
1970 if (dm_digtable.pre_ig_value != read_nic_byte(dev, rOFDM0_XAAGCCore1))
1973 if ((dm_digtable.pre_ig_value != dm_digtable.cur_ig_value)
1974 || !initialized || force_write) {
1975 initial_gain = (u8)dm_digtable.cur_ig_value;
1976 write_nic_byte(dev, rOFDM0_XAAGCCore1, initial_gain);
1977 write_nic_byte(dev, rOFDM0_XBAGCCore1, initial_gain);
1978 write_nic_byte(dev, rOFDM0_XCAGCCore1, initial_gain);
1979 write_nic_byte(dev, rOFDM0_XDAGCCore1, initial_gain);
1980 dm_digtable.pre_ig_value = dm_digtable.cur_ig_value;
1986 static void dm_pd_th(struct net_device *dev)
1988 struct r8192_priv *priv = rtllib_priv(dev);
1989 static u8 initialized, force_write;
1990 static u32 reset_cnt;
1992 if (dm_digtable.dig_algorithm_switch) {
1997 if (dm_digtable.PreSTAConnectState == dm_digtable.CurSTAConnectState) {
1998 if (dm_digtable.CurSTAConnectState == DIG_STA_CONNECT) {
1999 if (dm_digtable.rssi_val >= dm_digtable.rssi_high_power_highthresh)
2000 dm_digtable.curpd_thstate = DIG_PD_AT_HIGH_POWER;
2001 else if (dm_digtable.rssi_val <= dm_digtable.rssi_low_thresh)
2002 dm_digtable.curpd_thstate = DIG_PD_AT_LOW_POWER;
2003 else if ((dm_digtable.rssi_val >= dm_digtable.rssi_high_thresh) &&
2004 (dm_digtable.rssi_val < dm_digtable.rssi_high_power_lowthresh))
2005 dm_digtable.curpd_thstate = DIG_PD_AT_NORMAL_POWER;
2007 dm_digtable.curpd_thstate = dm_digtable.prepd_thstate;
2009 dm_digtable.curpd_thstate = DIG_PD_AT_LOW_POWER;
2012 dm_digtable.curpd_thstate = DIG_PD_AT_LOW_POWER;
2015 if (priv->reset_count != reset_cnt) {
2017 reset_cnt = priv->reset_count;
2020 if ((dm_digtable.prepd_thstate != dm_digtable.curpd_thstate) ||
2021 (initialized <= 3) || force_write) {
2022 if (dm_digtable.curpd_thstate == DIG_PD_AT_LOW_POWER) {
2023 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
2024 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x00);
2026 write_nic_byte(dev, rOFDM0_RxDetector1, 0x42);
2027 } else if (dm_digtable.curpd_thstate == DIG_PD_AT_NORMAL_POWER) {
2028 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
2029 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x20);
2031 write_nic_byte(dev, rOFDM0_RxDetector1, 0x44);
2032 } else if (dm_digtable.curpd_thstate == DIG_PD_AT_HIGH_POWER) {
2033 if (priv->CurrentChannelBW != HT_CHANNEL_WIDTH_20)
2034 write_nic_byte(dev, (rOFDM0_XATxAFE+3), 0x10);
2036 write_nic_byte(dev, rOFDM0_RxDetector1, 0x43);
2038 dm_digtable.prepd_thstate = dm_digtable.curpd_thstate;
2039 if (initialized <= 3)
2045 static void dm_cs_ratio(struct net_device *dev)
2047 struct r8192_priv *priv = rtllib_priv(dev);
2048 static u8 initialized, force_write;
2049 static u32 reset_cnt;
2051 if (dm_digtable.dig_algorithm_switch) {
2056 if (dm_digtable.PreSTAConnectState == dm_digtable.CurSTAConnectState) {
2057 if (dm_digtable.CurSTAConnectState == DIG_STA_CONNECT) {
2058 if (dm_digtable.rssi_val <= dm_digtable.rssi_low_thresh)
2059 dm_digtable.curcs_ratio_state = DIG_CS_RATIO_LOWER;
2060 else if (dm_digtable.rssi_val >= dm_digtable.rssi_high_thresh)
2061 dm_digtable.curcs_ratio_state = DIG_CS_RATIO_HIGHER;
2063 dm_digtable.curcs_ratio_state = dm_digtable.precs_ratio_state;
2065 dm_digtable.curcs_ratio_state = DIG_CS_RATIO_LOWER;
2068 dm_digtable.curcs_ratio_state = DIG_CS_RATIO_LOWER;
2071 if (priv->reset_count != reset_cnt) {
2073 reset_cnt = priv->reset_count;
2077 if ((dm_digtable.precs_ratio_state != dm_digtable.curcs_ratio_state) ||
2078 !initialized || force_write) {
2079 if (dm_digtable.curcs_ratio_state == DIG_CS_RATIO_LOWER)
2080 write_nic_byte(dev, 0xa0a, 0x08);
2081 else if (dm_digtable.curcs_ratio_state == DIG_CS_RATIO_HIGHER)
2082 write_nic_byte(dev, 0xa0a, 0xcd);
2083 dm_digtable.precs_ratio_state = dm_digtable.curcs_ratio_state;
2089 void dm_init_edca_turbo(struct net_device *dev)
2091 struct r8192_priv *priv = rtllib_priv(dev);
2093 priv->bcurrent_turbo_EDCA = false;
2094 priv->rtllib->bis_any_nonbepkts = false;
2095 priv->bis_cur_rdlstate = false;
2098 static void dm_check_edca_turbo(struct net_device *dev)
2100 struct r8192_priv *priv = rtllib_priv(dev);
2101 struct rt_hi_throughput *pHTInfo = priv->rtllib->pHTInfo;
2103 static unsigned long lastTxOkCnt;
2104 static unsigned long lastRxOkCnt;
2105 unsigned long curTxOkCnt = 0;
2106 unsigned long curRxOkCnt = 0;
2108 if (priv->rtllib->iw_mode == IW_MODE_ADHOC)
2109 goto dm_CheckEdcaTurbo_EXIT;
2110 if (priv->rtllib->state != RTLLIB_LINKED)
2111 goto dm_CheckEdcaTurbo_EXIT;
2112 if (priv->rtllib->pHTInfo->IOTAction & HT_IOT_ACT_DISABLE_EDCA_TURBO)
2113 goto dm_CheckEdcaTurbo_EXIT;
2116 u8 *peername[11] = {
2117 "unknown", "realtek_90", "realtek_92se", "broadcom",
2118 "ralink", "atheros", "cisco", "marvell", "92u_softap",
2125 "%s():iot peer is %s, bssid: %pM\n",
2126 __func__, peername[pHTInfo->IOTPeer],
2127 priv->rtllib->current_network.bssid);
2131 if (!priv->rtllib->bis_any_nonbepkts) {
2132 curTxOkCnt = priv->stats.txbytesunicast - lastTxOkCnt;
2133 curRxOkCnt = priv->stats.rxbytesunicast - lastRxOkCnt;
2134 if (pHTInfo->IOTAction & HT_IOT_ACT_EDCA_BIAS_ON_RX) {
2135 if (curTxOkCnt > 4*curRxOkCnt) {
2136 if (priv->bis_cur_rdlstate ||
2137 !priv->bcurrent_turbo_EDCA) {
2138 write_nic_dword(dev, EDCAPARA_BE,
2139 edca_setting_UL[pHTInfo->IOTPeer]);
2140 priv->bis_cur_rdlstate = false;
2143 if (!priv->bis_cur_rdlstate ||
2144 !priv->bcurrent_turbo_EDCA) {
2145 if (priv->rtllib->mode == WIRELESS_MODE_G)
2146 write_nic_dword(dev, EDCAPARA_BE,
2147 edca_setting_DL_GMode[pHTInfo->IOTPeer]);
2149 write_nic_dword(dev, EDCAPARA_BE,
2150 edca_setting_DL[pHTInfo->IOTPeer]);
2151 priv->bis_cur_rdlstate = true;
2154 priv->bcurrent_turbo_EDCA = true;
2156 if (curRxOkCnt > 4*curTxOkCnt) {
2157 if (!priv->bis_cur_rdlstate || !priv->bcurrent_turbo_EDCA) {
2158 if (priv->rtllib->mode == WIRELESS_MODE_G)
2159 write_nic_dword(dev, EDCAPARA_BE,
2160 edca_setting_DL_GMode[pHTInfo->IOTPeer]);
2162 write_nic_dword(dev, EDCAPARA_BE,
2163 edca_setting_DL[pHTInfo->IOTPeer]);
2164 priv->bis_cur_rdlstate = true;
2167 if (priv->bis_cur_rdlstate ||
2168 !priv->bcurrent_turbo_EDCA) {
2169 write_nic_dword(dev, EDCAPARA_BE,
2170 edca_setting_UL[pHTInfo->IOTPeer]);
2171 priv->bis_cur_rdlstate = false;
2176 priv->bcurrent_turbo_EDCA = true;
2179 if (priv->bcurrent_turbo_EDCA) {
2182 priv->rtllib->SetHwRegHandler(dev, HW_VAR_AC_PARAM, (u8 *)(&tmp));
2183 priv->bcurrent_turbo_EDCA = false;
2188 dm_CheckEdcaTurbo_EXIT:
2189 priv->rtllib->bis_any_nonbepkts = false;
2190 lastTxOkCnt = priv->stats.txbytesunicast;
2191 lastRxOkCnt = priv->stats.rxbytesunicast;
2194 static void dm_init_ctstoself(struct net_device *dev)
2196 struct r8192_priv *priv = rtllib_priv((struct net_device *)dev);
2198 priv->rtllib->bCTSToSelfEnable = true;
2199 priv->rtllib->CTSToSelfTH = CTSToSelfTHVal;
2202 static void dm_ctstoself(struct net_device *dev)
2204 struct r8192_priv *priv = rtllib_priv((struct net_device *)dev);
2205 struct rt_hi_throughput *pHTInfo = priv->rtllib->pHTInfo;
2206 static unsigned long lastTxOkCnt;
2207 static unsigned long lastRxOkCnt;
2208 unsigned long curTxOkCnt = 0;
2209 unsigned long curRxOkCnt = 0;
2211 if (priv->rtllib->bCTSToSelfEnable != true) {
2212 pHTInfo->IOTAction &= ~HT_IOT_ACT_FORCED_CTS2SELF;
2215 if (pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM) {
2216 curTxOkCnt = priv->stats.txbytesunicast - lastTxOkCnt;
2217 curRxOkCnt = priv->stats.rxbytesunicast - lastRxOkCnt;
2218 if (curRxOkCnt > 4*curTxOkCnt)
2219 pHTInfo->IOTAction &= ~HT_IOT_ACT_FORCED_CTS2SELF;
2221 pHTInfo->IOTAction |= HT_IOT_ACT_FORCED_CTS2SELF;
2223 lastTxOkCnt = priv->stats.txbytesunicast;
2224 lastRxOkCnt = priv->stats.rxbytesunicast;
2229 static void dm_Init_WA_Broadcom_IOT(struct net_device *dev)
2231 struct r8192_priv *priv = rtllib_priv((struct net_device *)dev);
2232 struct rt_hi_throughput *pHTInfo = priv->rtllib->pHTInfo;
2234 pHTInfo->bWAIotBroadcom = false;
2235 pHTInfo->WAIotTH = WAIotTHVal;
2238 static void dm_check_pbc_gpio(struct net_device *dev)
2242 void dm_CheckRfCtrlGPIO(void *data)
2244 struct r8192_priv *priv = container_of_dwork_rsl(data,
2245 struct r8192_priv, gpio_change_rf_wq);
2246 struct net_device *dev = priv->rtllib->dev;
2248 enum rt_rf_power_state eRfPowerStateToSet;
2249 bool bActuallySet = false;
2251 static char *RadioPowerPath = "/etc/acpi/events/RadioPower.sh";
2252 static char *envp[] = {"HOME=/", "TERM=linux", "PATH=/usr/bin:/bin", NULL};
2254 bActuallySet = false;
2256 if ((priv->up_first_time == 1) || (priv->being_init_adapter))
2259 if (priv->bfirst_after_down) {
2260 priv->bfirst_after_down = true;
2264 tmp1byte = read_nic_byte(dev, GPI);
2266 eRfPowerStateToSet = (tmp1byte&BIT1) ? eRfOn : eRfOff;
2268 if (priv->bHwRadioOff && (eRfPowerStateToSet == eRfOn)) {
2269 RT_TRACE(COMP_RF, "gpiochangeRF - HW Radio ON\n");
2270 netdev_info(dev, "gpiochangeRF - HW Radio ON\n");
2271 priv->bHwRadioOff = false;
2272 bActuallySet = true;
2273 } else if (!priv->bHwRadioOff && (eRfPowerStateToSet == eRfOff)) {
2274 RT_TRACE(COMP_RF, "gpiochangeRF - HW Radio OFF\n");
2275 netdev_info(dev, "gpiochangeRF - HW Radio OFF\n");
2276 priv->bHwRadioOff = true;
2277 bActuallySet = true;
2282 priv->bHwRfOffAction = 1;
2283 MgntActSet_RF_State(dev, eRfPowerStateToSet, RF_CHANGE_BY_HW, true);
2284 if (priv->bHwRadioOff)
2289 argv[0] = RadioPowerPath;
2291 call_usermodehelper(RadioPowerPath, argv, envp, UMH_WAIT_PROC);
2295 void dm_rf_pathcheck_workitemcallback(void *data)
2297 struct r8192_priv *priv = container_of_dwork_rsl(data,
2300 struct net_device *dev = priv->rtllib->dev;
2303 rfpath = read_nic_byte(dev, 0xc04);
2305 for (i = 0; i < RF90_PATH_MAX; i++) {
2306 if (rfpath & (0x01<<i))
2307 priv->brfpath_rxenable[i] = true;
2309 priv->brfpath_rxenable[i] = false;
2311 if (!DM_RxPathSelTable.Enable)
2314 dm_rxpath_sel_byrssi(dev);
2317 static void dm_init_rxpath_selection(struct net_device *dev)
2320 struct r8192_priv *priv = rtllib_priv(dev);
2322 DM_RxPathSelTable.Enable = 1;
2323 DM_RxPathSelTable.SS_TH_low = RxPathSelection_SS_TH_low;
2324 DM_RxPathSelTable.diff_TH = RxPathSelection_diff_TH;
2325 if (priv->CustomerID == RT_CID_819x_Netcore)
2326 DM_RxPathSelTable.cck_method = CCK_Rx_Version_2;
2328 DM_RxPathSelTable.cck_method = CCK_Rx_Version_1;
2329 DM_RxPathSelTable.DbgMode = DM_DBG_OFF;
2330 DM_RxPathSelTable.disabledRF = 0;
2331 for (i = 0; i < 4; i++) {
2332 DM_RxPathSelTable.rf_rssi[i] = 50;
2333 DM_RxPathSelTable.cck_pwdb_sta[i] = -64;
2334 DM_RxPathSelTable.rf_enable_rssi_th[i] = 100;
2338 #define PWDB_IN_RANGE ((cur_cck_pwdb < tmp_cck_max_pwdb) && \
2339 (cur_cck_pwdb > tmp_cck_sec_pwdb))
2341 static void dm_rxpath_sel_byrssi(struct net_device *dev)
2343 struct r8192_priv *priv = rtllib_priv(dev);
2344 u8 i, max_rssi_index = 0, min_rssi_index = 0;
2345 u8 sec_rssi_index = 0, rf_num = 0;
2346 u8 tmp_max_rssi = 0, tmp_min_rssi = 0, tmp_sec_rssi = 0;
2347 u8 cck_default_Rx = 0x2;
2348 u8 cck_optional_Rx = 0x3;
2349 long tmp_cck_max_pwdb = 0, tmp_cck_min_pwdb = 0, tmp_cck_sec_pwdb = 0;
2350 u8 cck_rx_ver2_max_index = 0, cck_rx_ver2_min_index = 0;
2351 u8 cck_rx_ver2_sec_index = 0;
2354 static u8 disabled_rf_cnt, cck_Rx_Path_initialized;
2355 u8 update_cck_rx_path;
2357 if (priv->rf_type != RF_2T4R)
2360 if (!cck_Rx_Path_initialized) {
2361 DM_RxPathSelTable.cck_Rx_path = (read_nic_byte(dev, 0xa07)&0xf);
2362 cck_Rx_Path_initialized = 1;
2365 DM_RxPathSelTable.disabledRF = 0xf;
2366 DM_RxPathSelTable.disabledRF &= ~(read_nic_byte(dev, 0xc04));
2368 if (priv->rtllib->mode == WIRELESS_MODE_B)
2369 DM_RxPathSelTable.cck_method = CCK_Rx_Version_2;
2371 for (i = 0; i < RF90_PATH_MAX; i++) {
2372 if (!DM_RxPathSelTable.DbgMode)
2373 DM_RxPathSelTable.rf_rssi[i] = priv->stats.rx_rssi_percentage[i];
2375 if (priv->brfpath_rxenable[i]) {
2377 cur_rf_rssi = DM_RxPathSelTable.rf_rssi[i];
2380 max_rssi_index = min_rssi_index = sec_rssi_index = i;
2381 tmp_max_rssi = tmp_min_rssi = tmp_sec_rssi = cur_rf_rssi;
2382 } else if (rf_num == 2) {
2383 if (cur_rf_rssi >= tmp_max_rssi) {
2384 tmp_max_rssi = cur_rf_rssi;
2387 tmp_sec_rssi = tmp_min_rssi = cur_rf_rssi;
2388 sec_rssi_index = min_rssi_index = i;
2391 if (cur_rf_rssi > tmp_max_rssi) {
2392 tmp_sec_rssi = tmp_max_rssi;
2393 sec_rssi_index = max_rssi_index;
2394 tmp_max_rssi = cur_rf_rssi;
2396 } else if (cur_rf_rssi == tmp_max_rssi) {
2397 tmp_sec_rssi = cur_rf_rssi;
2399 } else if ((cur_rf_rssi < tmp_max_rssi) &&
2400 (cur_rf_rssi > tmp_sec_rssi)) {
2401 tmp_sec_rssi = cur_rf_rssi;
2403 } else if (cur_rf_rssi == tmp_sec_rssi) {
2404 if (tmp_sec_rssi == tmp_min_rssi) {
2405 tmp_sec_rssi = cur_rf_rssi;
2408 } else if ((cur_rf_rssi < tmp_sec_rssi) &&
2409 (cur_rf_rssi > tmp_min_rssi)) {
2411 } else if (cur_rf_rssi == tmp_min_rssi) {
2412 if (tmp_sec_rssi == tmp_min_rssi) {
2413 tmp_min_rssi = cur_rf_rssi;
2416 } else if (cur_rf_rssi < tmp_min_rssi) {
2417 tmp_min_rssi = cur_rf_rssi;
2425 if (DM_RxPathSelTable.cck_method == CCK_Rx_Version_2) {
2426 for (i = 0; i < RF90_PATH_MAX; i++) {
2427 if (priv->brfpath_rxenable[i]) {
2430 DM_RxPathSelTable.cck_pwdb_sta[i];
2433 cck_rx_ver2_max_index = i;
2434 cck_rx_ver2_min_index = i;
2435 cck_rx_ver2_sec_index = i;
2436 tmp_cck_max_pwdb = cur_cck_pwdb;
2437 tmp_cck_min_pwdb = cur_cck_pwdb;
2438 tmp_cck_sec_pwdb = cur_cck_pwdb;
2439 } else if (rf_num == 2) {
2440 if (cur_cck_pwdb >= tmp_cck_max_pwdb) {
2441 tmp_cck_max_pwdb = cur_cck_pwdb;
2442 cck_rx_ver2_max_index = i;
2444 tmp_cck_sec_pwdb = cur_cck_pwdb;
2445 tmp_cck_min_pwdb = cur_cck_pwdb;
2446 cck_rx_ver2_sec_index = i;
2447 cck_rx_ver2_min_index = i;
2450 if (cur_cck_pwdb > tmp_cck_max_pwdb) {
2453 cck_rx_ver2_sec_index =
2454 cck_rx_ver2_max_index;
2455 tmp_cck_max_pwdb = cur_cck_pwdb;
2456 cck_rx_ver2_max_index = i;
2457 } else if (cur_cck_pwdb ==
2459 tmp_cck_sec_pwdb = cur_cck_pwdb;
2460 cck_rx_ver2_sec_index = i;
2461 } else if (PWDB_IN_RANGE) {
2462 tmp_cck_sec_pwdb = cur_cck_pwdb;
2463 cck_rx_ver2_sec_index = i;
2464 } else if (cur_cck_pwdb ==
2466 if (tmp_cck_sec_pwdb ==
2470 cck_rx_ver2_sec_index =
2473 } else if ((cur_cck_pwdb < tmp_cck_sec_pwdb) &&
2474 (cur_cck_pwdb > tmp_cck_min_pwdb)) {
2476 } else if (cur_cck_pwdb == tmp_cck_min_pwdb) {
2477 if (tmp_cck_sec_pwdb == tmp_cck_min_pwdb) {
2478 tmp_cck_min_pwdb = cur_cck_pwdb;
2479 cck_rx_ver2_min_index = i;
2481 } else if (cur_cck_pwdb < tmp_cck_min_pwdb) {
2482 tmp_cck_min_pwdb = cur_cck_pwdb;
2483 cck_rx_ver2_min_index = i;
2491 update_cck_rx_path = 0;
2492 if (DM_RxPathSelTable.cck_method == CCK_Rx_Version_2) {
2493 cck_default_Rx = cck_rx_ver2_max_index;
2494 cck_optional_Rx = cck_rx_ver2_sec_index;
2495 if (tmp_cck_max_pwdb != -64)
2496 update_cck_rx_path = 1;
2499 if (tmp_min_rssi < DM_RxPathSelTable.SS_TH_low && disabled_rf_cnt < 2) {
2500 if ((tmp_max_rssi - tmp_min_rssi) >=
2501 DM_RxPathSelTable.diff_TH) {
2502 DM_RxPathSelTable.rf_enable_rssi_th[min_rssi_index] =
2504 rtl8192_setBBreg(dev, rOFDM0_TRxPathEnable,
2505 0x1<<min_rssi_index, 0x0);
2506 rtl8192_setBBreg(dev, rOFDM1_TRxPathEnable,
2507 0x1<<min_rssi_index, 0x0);
2510 if (DM_RxPathSelTable.cck_method == CCK_Rx_Version_1) {
2511 cck_default_Rx = max_rssi_index;
2512 cck_optional_Rx = sec_rssi_index;
2514 update_cck_rx_path = 1;
2518 if (update_cck_rx_path) {
2519 DM_RxPathSelTable.cck_Rx_path = (cck_default_Rx<<2) |
2521 rtl8192_setBBreg(dev, rCCK0_AFESetting, 0x0f000000,
2522 DM_RxPathSelTable.cck_Rx_path);
2525 if (DM_RxPathSelTable.disabledRF) {
2526 for (i = 0; i < 4; i++) {
2527 if ((DM_RxPathSelTable.disabledRF>>i) & 0x1) {
2529 DM_RxPathSelTable.rf_enable_rssi_th[i]) {
2530 rtl8192_setBBreg(dev,
2531 rOFDM0_TRxPathEnable, 0x1 << i,
2533 rtl8192_setBBreg(dev,
2534 rOFDM1_TRxPathEnable,
2536 DM_RxPathSelTable.rf_enable_rssi_th[i]
2545 static void dm_check_rx_path_selection(struct net_device *dev)
2547 struct r8192_priv *priv = rtllib_priv(dev);
2549 queue_delayed_work_rsl(priv->priv_wq, &priv->rfpath_check_wq, 0);
2553 static void dm_init_fsync(struct net_device *dev)
2555 struct r8192_priv *priv = rtllib_priv(dev);
2557 priv->rtllib->fsync_time_interval = 500;
2558 priv->rtllib->fsync_rate_bitmap = 0x0f000800;
2559 priv->rtllib->fsync_rssi_threshold = 30;
2560 priv->rtllib->bfsync_enable = false;
2561 priv->rtllib->fsync_multiple_timeinterval = 3;
2562 priv->rtllib->fsync_firstdiff_ratethreshold = 100;
2563 priv->rtllib->fsync_seconddiff_ratethreshold = 200;
2564 priv->rtllib->fsync_state = Default_Fsync;
2565 priv->framesyncMonitor = 1;
2567 init_timer(&priv->fsync_timer);
2568 setup_timer(&priv->fsync_timer, dm_fsync_timer_callback,
2569 (unsigned long) dev);
2573 static void dm_deInit_fsync(struct net_device *dev)
2575 struct r8192_priv *priv = rtllib_priv(dev);
2577 del_timer_sync(&priv->fsync_timer);
2580 void dm_fsync_timer_callback(unsigned long data)
2582 struct net_device *dev = (struct net_device *)data;
2583 struct r8192_priv *priv = rtllib_priv((struct net_device *)data);
2584 u32 rate_index, rate_count = 0, rate_count_diff = 0;
2585 bool bSwitchFromCountDiff = false;
2586 bool bDoubleTimeInterval = false;
2588 if (priv->rtllib->state == RTLLIB_LINKED &&
2589 priv->rtllib->bfsync_enable &&
2590 (priv->rtllib->pHTInfo->IOTAction & HT_IOT_ACT_CDD_FSYNC)) {
2593 for (rate_index = 0; rate_index <= 27; rate_index++) {
2594 rate_bitmap = 1 << rate_index;
2595 if (priv->rtllib->fsync_rate_bitmap & rate_bitmap)
2597 priv->stats.received_rate_histogram[1]
2601 if (rate_count < priv->rate_record)
2602 rate_count_diff = 0xffffffff - rate_count +
2605 rate_count_diff = rate_count - priv->rate_record;
2606 if (rate_count_diff < priv->rateCountDiffRecord) {
2608 u32 DiffNum = priv->rateCountDiffRecord -
2611 priv->rtllib->fsync_seconddiff_ratethreshold)
2612 priv->ContinueDiffCount++;
2614 priv->ContinueDiffCount = 0;
2616 if (priv->ContinueDiffCount >= 2) {
2617 bSwitchFromCountDiff = true;
2618 priv->ContinueDiffCount = 0;
2621 priv->ContinueDiffCount = 0;
2624 if (rate_count_diff <=
2625 priv->rtllib->fsync_firstdiff_ratethreshold) {
2626 bSwitchFromCountDiff = true;
2627 priv->ContinueDiffCount = 0;
2629 priv->rate_record = rate_count;
2630 priv->rateCountDiffRecord = rate_count_diff;
2631 RT_TRACE(COMP_HALDM,
2632 "rateRecord %d rateCount %d, rateCountdiff %d bSwitchFsync %d\n",
2633 priv->rate_record, rate_count, rate_count_diff,
2634 priv->bswitch_fsync);
2635 if (priv->undecorated_smoothed_pwdb >
2636 priv->rtllib->fsync_rssi_threshold &&
2637 bSwitchFromCountDiff) {
2638 bDoubleTimeInterval = true;
2639 priv->bswitch_fsync = !priv->bswitch_fsync;
2640 if (priv->bswitch_fsync) {
2641 write_nic_byte(dev, 0xC36, 0x1c);
2642 write_nic_byte(dev, 0xC3e, 0x90);
2644 write_nic_byte(dev, 0xC36, 0x5c);
2645 write_nic_byte(dev, 0xC3e, 0x96);
2647 } else if (priv->undecorated_smoothed_pwdb <=
2648 priv->rtllib->fsync_rssi_threshold) {
2649 if (priv->bswitch_fsync) {
2650 priv->bswitch_fsync = false;
2651 write_nic_byte(dev, 0xC36, 0x5c);
2652 write_nic_byte(dev, 0xC3e, 0x96);
2655 if (bDoubleTimeInterval) {
2656 if (timer_pending(&priv->fsync_timer))
2657 del_timer_sync(&priv->fsync_timer);
2658 priv->fsync_timer.expires = jiffies +
2659 msecs_to_jiffies(priv->rtllib->fsync_time_interval *
2660 priv->rtllib->fsync_multiple_timeinterval);
2661 add_timer(&priv->fsync_timer);
2663 if (timer_pending(&priv->fsync_timer))
2664 del_timer_sync(&priv->fsync_timer);
2665 priv->fsync_timer.expires = jiffies +
2666 msecs_to_jiffies(priv->rtllib->fsync_time_interval);
2667 add_timer(&priv->fsync_timer);
2670 if (priv->bswitch_fsync) {
2671 priv->bswitch_fsync = false;
2672 write_nic_byte(dev, 0xC36, 0x5c);
2673 write_nic_byte(dev, 0xC3e, 0x96);
2675 priv->ContinueDiffCount = 0;
2676 write_nic_dword(dev, rOFDM0_RxDetector2, 0x465c52cd);
2678 RT_TRACE(COMP_HALDM, "ContinueDiffCount %d\n", priv->ContinueDiffCount);
2679 RT_TRACE(COMP_HALDM,
2680 "rateRecord %d rateCount %d, rateCountdiff %d bSwitchFsync %d\n",
2681 priv->rate_record, rate_count, rate_count_diff,
2682 priv->bswitch_fsync);
2685 static void dm_StartHWFsync(struct net_device *dev)
2687 u8 rf_timing = 0x77;
2688 struct r8192_priv *priv = rtllib_priv(dev);
2690 RT_TRACE(COMP_HALDM, "%s\n", __func__);
2691 write_nic_dword(dev, rOFDM0_RxDetector2, 0x465c12cf);
2692 priv->rtllib->SetHwRegHandler(dev, HW_VAR_RF_TIMING,
2693 (u8 *)(&rf_timing));
2694 write_nic_byte(dev, 0xc3b, 0x41);
2697 static void dm_EndHWFsync(struct net_device *dev)
2699 u8 rf_timing = 0xaa;
2700 struct r8192_priv *priv = rtllib_priv(dev);
2702 RT_TRACE(COMP_HALDM, "%s\n", __func__);
2703 write_nic_dword(dev, rOFDM0_RxDetector2, 0x465c52cd);
2704 priv->rtllib->SetHwRegHandler(dev, HW_VAR_RF_TIMING, (u8 *)
2706 write_nic_byte(dev, 0xc3b, 0x49);
2709 static void dm_EndSWFsync(struct net_device *dev)
2711 struct r8192_priv *priv = rtllib_priv(dev);
2713 RT_TRACE(COMP_HALDM, "%s\n", __func__);
2714 del_timer_sync(&(priv->fsync_timer));
2716 if (priv->bswitch_fsync) {
2717 priv->bswitch_fsync = false;
2719 write_nic_byte(dev, 0xC36, 0x5c);
2721 write_nic_byte(dev, 0xC3e, 0x96);
2724 priv->ContinueDiffCount = 0;
2725 write_nic_dword(dev, rOFDM0_RxDetector2, 0x465c52cd);
2728 static void dm_StartSWFsync(struct net_device *dev)
2730 struct r8192_priv *priv = rtllib_priv(dev);
2734 RT_TRACE(COMP_HALDM, "%s\n", __func__);
2735 priv->rate_record = 0;
2736 priv->ContinueDiffCount = 0;
2737 priv->rateCountDiffRecord = 0;
2738 priv->bswitch_fsync = false;
2740 if (priv->rtllib->mode == WIRELESS_MODE_N_24G) {
2741 priv->rtllib->fsync_firstdiff_ratethreshold = 600;
2742 priv->rtllib->fsync_seconddiff_ratethreshold = 0xffff;
2744 priv->rtllib->fsync_firstdiff_ratethreshold = 200;
2745 priv->rtllib->fsync_seconddiff_ratethreshold = 200;
2747 for (rateIndex = 0; rateIndex <= 27; rateIndex++) {
2748 rateBitmap = 1 << rateIndex;
2749 if (priv->rtllib->fsync_rate_bitmap & rateBitmap)
2750 priv->rate_record +=
2751 priv->stats.received_rate_histogram[1]
2754 if (timer_pending(&priv->fsync_timer))
2755 del_timer_sync(&priv->fsync_timer);
2756 priv->fsync_timer.expires = jiffies +
2757 msecs_to_jiffies(priv->rtllib->fsync_time_interval);
2758 add_timer(&priv->fsync_timer);
2760 write_nic_dword(dev, rOFDM0_RxDetector2, 0x465c12cd);
2764 void dm_check_fsync(struct net_device *dev)
2766 #define RegC38_Default 0
2767 #define RegC38_NonFsync_Other_AP 1
2768 #define RegC38_Fsync_AP_BCM 2
2769 struct r8192_priv *priv = rtllib_priv(dev);
2770 static u8 reg_c38_State = RegC38_Default;
2771 static u32 reset_cnt;
2773 RT_TRACE(COMP_HALDM,
2774 "RSSI %d TimeInterval %d MultipleTimeInterval %d\n",
2775 priv->rtllib->fsync_rssi_threshold,
2776 priv->rtllib->fsync_time_interval,
2777 priv->rtllib->fsync_multiple_timeinterval);
2778 RT_TRACE(COMP_HALDM,
2779 "RateBitmap 0x%x FirstDiffRateThreshold %d SecondDiffRateThreshold %d\n",
2780 priv->rtllib->fsync_rate_bitmap,
2781 priv->rtllib->fsync_firstdiff_ratethreshold,
2782 priv->rtllib->fsync_seconddiff_ratethreshold);
2784 if (priv->rtllib->state == RTLLIB_LINKED &&
2785 priv->rtllib->pHTInfo->IOTPeer == HT_IOT_PEER_BROADCOM) {
2786 if (priv->rtllib->bfsync_enable == 0) {
2787 switch (priv->rtllib->fsync_state) {
2789 dm_StartHWFsync(dev);
2790 priv->rtllib->fsync_state = HW_Fsync;
2794 dm_StartHWFsync(dev);
2795 priv->rtllib->fsync_state = HW_Fsync;
2802 switch (priv->rtllib->fsync_state) {
2804 dm_StartSWFsync(dev);
2805 priv->rtllib->fsync_state = SW_Fsync;
2809 dm_StartSWFsync(dev);
2810 priv->rtllib->fsync_state = SW_Fsync;
2818 if (priv->framesyncMonitor) {
2819 if (reg_c38_State != RegC38_Fsync_AP_BCM) {
2820 write_nic_byte(dev, rOFDM0_RxDetector3, 0x95);
2822 reg_c38_State = RegC38_Fsync_AP_BCM;
2826 switch (priv->rtllib->fsync_state) {
2829 priv->rtllib->fsync_state = Default_Fsync;
2833 priv->rtllib->fsync_state = Default_Fsync;
2840 if (priv->framesyncMonitor) {
2841 if (priv->rtllib->state == RTLLIB_LINKED) {
2842 if (priv->undecorated_smoothed_pwdb <=
2844 if (reg_c38_State !=
2845 RegC38_NonFsync_Other_AP) {
2851 RegC38_NonFsync_Other_AP;
2853 } else if (priv->undecorated_smoothed_pwdb >=
2855 if (reg_c38_State) {
2859 reg_c38_State = RegC38_Default;
2863 if (reg_c38_State) {
2864 write_nic_byte(dev, rOFDM0_RxDetector3,
2866 reg_c38_State = RegC38_Default;
2871 if (priv->framesyncMonitor) {
2872 if (priv->reset_count != reset_cnt) {
2873 write_nic_byte(dev, rOFDM0_RxDetector3,
2875 reg_c38_State = RegC38_Default;
2876 reset_cnt = priv->reset_count;
2879 if (reg_c38_State) {
2880 write_nic_byte(dev, rOFDM0_RxDetector3,
2882 reg_c38_State = RegC38_Default;
2887 void dm_shadow_init(struct net_device *dev)
2892 for (page = 0; page < 5; page++)
2893 for (offset = 0; offset < 256; offset++)
2894 dm_shadow[page][offset] = read_nic_byte(dev,
2897 for (page = 8; page < 11; page++)
2898 for (offset = 0; offset < 256; offset++)
2899 dm_shadow[page][offset] = read_nic_byte(dev,
2902 for (page = 12; page < 15; page++)
2903 for (offset = 0; offset < 256; offset++)
2904 dm_shadow[page][offset] = read_nic_byte(dev,
2909 /*---------------------------Define function prototype------------------------*/
2910 static void dm_init_dynamic_txpower(struct net_device *dev)
2912 struct r8192_priv *priv = rtllib_priv(dev);
2914 priv->rtllib->bdynamic_txpower_enable = true;
2915 priv->bLastDTPFlag_High = false;
2916 priv->bLastDTPFlag_Low = false;
2917 priv->bDynamicTxHighPower = false;
2918 priv->bDynamicTxLowPower = false;
2921 static void dm_dynamic_txpower(struct net_device *dev)
2923 struct r8192_priv *priv = rtllib_priv(dev);
2924 unsigned int txhipower_threshhold = 0;
2925 unsigned int txlowpower_threshold = 0;
2927 if (priv->rtllib->bdynamic_txpower_enable != true) {
2928 priv->bDynamicTxHighPower = false;
2929 priv->bDynamicTxLowPower = false;
2932 if ((priv->rtllib->pHTInfo->IOTPeer == HT_IOT_PEER_ATHEROS) &&
2933 (priv->rtllib->mode == IEEE_G)) {
2934 txhipower_threshhold = TX_POWER_ATHEROAP_THRESH_HIGH;
2935 txlowpower_threshold = TX_POWER_ATHEROAP_THRESH_LOW;
2937 txhipower_threshhold = TX_POWER_NEAR_FIELD_THRESH_HIGH;
2938 txlowpower_threshold = TX_POWER_NEAR_FIELD_THRESH_LOW;
2941 RT_TRACE(COMP_TXAGC, "priv->undecorated_smoothed_pwdb = %ld\n",
2942 priv->undecorated_smoothed_pwdb);
2944 if (priv->rtllib->state == RTLLIB_LINKED) {
2945 if (priv->undecorated_smoothed_pwdb >= txhipower_threshhold) {
2946 priv->bDynamicTxHighPower = true;
2947 priv->bDynamicTxLowPower = false;
2949 if (priv->undecorated_smoothed_pwdb <
2950 txlowpower_threshold && priv->bDynamicTxHighPower)
2951 priv->bDynamicTxHighPower = false;
2952 if (priv->undecorated_smoothed_pwdb < 35)
2953 priv->bDynamicTxLowPower = true;
2954 else if (priv->undecorated_smoothed_pwdb >= 40)
2955 priv->bDynamicTxLowPower = false;
2958 priv->bDynamicTxHighPower = false;
2959 priv->bDynamicTxLowPower = false;
2962 if ((priv->bDynamicTxHighPower != priv->bLastDTPFlag_High) ||
2963 (priv->bDynamicTxLowPower != priv->bLastDTPFlag_Low)) {
2964 RT_TRACE(COMP_TXAGC, "SetTxPowerLevel8190() channel = %d\n",
2965 priv->rtllib->current_network.channel);
2967 rtl8192_phy_setTxPower(dev,
2968 priv->rtllib->current_network.channel);
2970 priv->bLastDTPFlag_High = priv->bDynamicTxHighPower;
2971 priv->bLastDTPFlag_Low = priv->bDynamicTxLowPower;
2975 static void dm_check_txrateandretrycount(struct net_device *dev)
2977 struct r8192_priv *priv = rtllib_priv(dev);
2978 struct rtllib_device *ieee = priv->rtllib;
2980 ieee->softmac_stats.CurrentShowTxate = read_nic_byte(dev,
2981 Current_Tx_Rate_Reg);
2983 ieee->softmac_stats.last_packet_rate = read_nic_byte(dev,
2984 Initial_Tx_Rate_Reg);
2986 ieee->softmac_stats.txretrycount = read_nic_dword(dev,
2987 Tx_Retry_Count_Reg);
2990 static void dm_send_rssi_tofw(struct net_device *dev)
2992 struct r8192_priv *priv = rtllib_priv(dev);
2994 write_nic_byte(dev, DRIVER_RSSI, (u8)priv->undecorated_smoothed_pwdb);