| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918 |
- /******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- * The full GNU General Public License is included in this distribution in the
- * file called LICENSE.
- *
- * Contact Information:
- * wlanfae <wlanfae@realtek.com>
- * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
- * Hsinchu 300, Taiwan.
- *
- * Larry Finger <Larry.Finger@lwfinger.net>
- *
- *****************************************************************************/
- #include "mp_precomp.h"
- #include "phydm_precomp.h"
- #define CALCULATE_SWINGTALBE_OFFSET(_offset, _direction, _size, _delta_thermal)\
- do { \
- u32 __offset = (u32)_offset; \
- u32 __size = (u32)_size; \
- for (__offset = 0; __offset < __size; __offset++) { \
- if (_delta_thermal < \
- thermal_threshold[_direction][__offset]) { \
- if (__offset != 0) \
- __offset--; \
- break; \
- } \
- } \
- if (__offset >= __size) \
- __offset = __size - 1; \
- } while (0)
- void configure_txpower_track(void *dm_void, struct txpwrtrack_cfg *config)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- #if RTL8192E_SUPPORT
- if (dm->support_ic_type == ODM_RTL8192E)
- configure_txpower_track_8192e(config);
- #endif
- #if RTL8821A_SUPPORT
- if (dm->support_ic_type == ODM_RTL8821)
- configure_txpower_track_8821a(config);
- #endif
- #if RTL8812A_SUPPORT
- if (dm->support_ic_type == ODM_RTL8812)
- configure_txpower_track_8812a(config);
- #endif
- #if RTL8188E_SUPPORT
- if (dm->support_ic_type == ODM_RTL8188E)
- configure_txpower_track_8188e(config);
- #endif
- #if RTL8723B_SUPPORT
- if (dm->support_ic_type == ODM_RTL8723B)
- configure_txpower_track_8723b(config);
- #endif
- #if RTL8814A_SUPPORT
- if (dm->support_ic_type == ODM_RTL8814A)
- configure_txpower_track_8814a(config);
- #endif
- #if RTL8703B_SUPPORT
- if (dm->support_ic_type == ODM_RTL8703B)
- configure_txpower_track_8703b(config);
- #endif
- #if RTL8188F_SUPPORT
- if (dm->support_ic_type == ODM_RTL8188F)
- configure_txpower_track_8188f(config);
- #endif
- #if RTL8723D_SUPPORT
- if (dm->support_ic_type == ODM_RTL8723D)
- configure_txpower_track_8723d(config);
- #endif
- /* JJ ADD 20161014 */
- #if RTL8710B_SUPPORT
- if (dm->support_ic_type == ODM_RTL8710B)
- configure_txpower_track_8710b(config);
- #endif
- #if RTL8822B_SUPPORT
- if (dm->support_ic_type == ODM_RTL8822B)
- configure_txpower_track_8822b(config);
- #endif
- #if RTL8821C_SUPPORT
- if (dm->support_ic_type == ODM_RTL8821C)
- configure_txpower_track_8821c(config);
- #endif
- #if RTL8192F_SUPPORT
- if (dm->support_ic_type == ODM_RTL8192F)
- configure_txpower_track_8192f(config);
- #endif
- }
- /* **********************************************************************
- * <20121113, Kordan> This function should be called when tx_agc changed.
- * Otherwise the previous compensation is gone, because we record the
- * delta of temperature between two TxPowerTracking watch dogs.
- *
- * NOTE: If Tx BB swing or Tx scaling is varified during run-time, still
- * need to call this function.
- * **********************************************************************
- */
- void odm_clear_txpowertracking_state(void *dm_void)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- struct _hal_rf_ *rf = &dm->rf_table;
- u8 p = 0;
- struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
- cali_info->bb_swing_idx_cck_base = cali_info->default_cck_index;
- cali_info->bb_swing_idx_cck = cali_info->default_cck_index;
- dm->rf_calibrate_info.CCK_index = 0;
- for (p = RF_PATH_A; p < MAX_RF_PATH; ++p) {
- cali_info->bb_swing_idx_ofdm_base[p]
- = cali_info->default_ofdm_index;
- cali_info->bb_swing_idx_ofdm[p] = cali_info->default_ofdm_index;
- cali_info->OFDM_index[p] = cali_info->default_ofdm_index;
- cali_info->power_index_offset[p] = 0;
- cali_info->delta_power_index[p] = 0;
- cali_info->delta_power_index_last[p] = 0;
- /* Initial Mix mode power tracking*/
- cali_info->absolute_ofdm_swing_idx[p] = 0;
- cali_info->remnant_ofdm_swing_idx[p] = 0;
- cali_info->kfree_offset[p] = 0;
- }
- /* Initial Mix mode power tracking*/
- cali_info->modify_tx_agc_flag_path_a = false;
- cali_info->modify_tx_agc_flag_path_b = false;
- cali_info->modify_tx_agc_flag_path_c = false;
- cali_info->modify_tx_agc_flag_path_d = false;
- cali_info->remnant_cck_swing_idx = 0;
- cali_info->thermal_value = rf->eeprom_thermal;
- cali_info->modify_tx_agc_value_cck = 0;
- cali_info->modify_tx_agc_value_ofdm = 0;
- }
- void odm_get_tracking_table(void *dm_void, u8 thermal_value, u8 delta)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
- struct _hal_rf_ *rf = &dm->rf_table;
- struct txpwrtrack_cfg c = {0};
- u8 p;
- /* 4 1. TWO tables decide the final index of OFDM/CCK swing table. */
- u8 *pwrtrk_tab_up_a = NULL;
- u8 *pwrtrk_tab_down_a = NULL;
- u8 *pwrtrk_tab_up_b = NULL;
- u8 *pwrtrk_tab_down_b = NULL;
- /*for 8814 add by Yu Chen*/
- u8 *pwrtrk_tab_up_c = NULL;
- u8 *pwrtrk_tab_down_c = NULL;
- u8 *pwrtrk_tab_up_d = NULL;
- u8 *pwrtrk_tab_down_d = NULL;
- /*for Xtal Offset by James.Tung*/
- s8 *xtal_tab_up = NULL;
- s8 *xtal_tab_down = NULL;
- configure_txpower_track(dm, &c);
- (*c.get_delta_swing_table)(dm,
- (u8 **)&pwrtrk_tab_up_a,
- (u8 **)&pwrtrk_tab_down_a,
- (u8 **)&pwrtrk_tab_up_b,
- (u8 **)&pwrtrk_tab_down_b);
- if (dm->support_ic_type & ODM_RTL8814A) /*for 8814 path C & D*/
- (*c.get_delta_swing_table8814only)(dm,
- (u8 **)&pwrtrk_tab_up_c,
- (u8 **)&pwrtrk_tab_down_c,
- (u8 **)&pwrtrk_tab_up_d,
- (u8 **)&pwrtrk_tab_down_d);
- /*for Xtal Offset*/
- if (dm->support_ic_type &
- (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B | ODM_RTL8192F))
- (*c.get_delta_swing_xtal_table)(dm,
- (s8 **)&xtal_tab_up,
- (s8 **)&xtal_tab_down);
- if (thermal_value > rf->eeprom_thermal) {
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- /*recording power index offset*/
- cali_info->delta_power_index_last[p] =
- cali_info->delta_power_index[p];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "******Temp is higher******\n");
- switch (p) {
- case RF_PATH_B:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_up_b[%d] = %d\n", delta,
- pwrtrk_tab_up_b[delta]);
- cali_info->delta_power_index[p] =
- pwrtrk_tab_up_b[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- pwrtrk_tab_up_b[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_B] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- case RF_PATH_C:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_up_c[%d] = %d\n", delta,
- pwrtrk_tab_up_c[delta]);
- cali_info->delta_power_index[p] =
- pwrtrk_tab_up_c[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- pwrtrk_tab_up_c[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_C] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- case RF_PATH_D:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_up_d[%d] = %d\n", delta,
- pwrtrk_tab_up_d[delta]);
- cali_info->delta_power_index[p] =
- pwrtrk_tab_up_d[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- pwrtrk_tab_up_d[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_D] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- default:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_up_a[%d] = %d\n", delta,
- pwrtrk_tab_up_a[delta]);
- cali_info->delta_power_index[p] =
- pwrtrk_tab_up_a[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- pwrtrk_tab_up_a[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_A] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- }
- }
- /* JJ ADD 20161014 */
- /*Save xtal_offset from Xtal table*/
- if (dm->support_ic_type &
- (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
- ODM_RTL8192F)) {
- /*recording last Xtal offset*/
- cali_info->xtal_offset_last = cali_info->xtal_offset;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "[Xtal] xtal_tab_up[%d] = %d\n",
- delta, xtal_tab_up[delta]);
- cali_info->xtal_offset = xtal_tab_up[delta];
- if (cali_info->xtal_offset_last != xtal_tab_up[delta])
- cali_info->xtal_offset_eanble = 1;
- }
- } else {
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- /*recording power index offset*/
- cali_info->delta_power_index_last[p] =
- cali_info->delta_power_index[p];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "******Temp is lower******\n");
- switch (p) {
- case RF_PATH_B:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_down_b[%d] = %d\n", delta,
- pwrtrk_tab_down_b[delta]);
- cali_info->delta_power_index[p] =
- -1 * pwrtrk_tab_down_b[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- -1 * pwrtrk_tab_down_b[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_B] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- case RF_PATH_C:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_down_c[%d] = %d\n", delta,
- pwrtrk_tab_down_c[delta]);
- cali_info->delta_power_index[p] =
- -1 * pwrtrk_tab_down_c[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- -1 * pwrtrk_tab_down_c[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_C] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- case RF_PATH_D:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_down_d[%d] = %d\n", delta,
- pwrtrk_tab_down_d[delta]);
- cali_info->delta_power_index[p] =
- -1 * pwrtrk_tab_down_d[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- -1 * pwrtrk_tab_down_d[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_D] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- default:
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "pwrtrk_tab_down_a[%d] = %d\n", delta,
- pwrtrk_tab_down_a[delta]);
- cali_info->delta_power_index[p] =
- -1 * pwrtrk_tab_down_a[delta];
- cali_info->absolute_ofdm_swing_idx[p] =
- -1 * pwrtrk_tab_down_a[delta];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "absolute_ofdm_swing_idx[PATH_A] = %d\n",
- cali_info->absolute_ofdm_swing_idx[p]);
- break;
- }
- }
- /* JJ ADD 20161014 */
- if (dm->support_ic_type &
- (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8710B |
- ODM_RTL8192F)) {
- /*recording last Xtal offset*/
- cali_info->xtal_offset_last = cali_info->xtal_offset;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "[Xtal] xtal_tab_down[%d] = %d\n", delta,
- xtal_tab_down[delta]);
- /*Save xtal_offset from Xtal table*/
- cali_info->xtal_offset = xtal_tab_down[delta];
- if (cali_info->xtal_offset_last != xtal_tab_down[delta])
- cali_info->xtal_offset_eanble = 1;
- }
- }
- }
- void odm_pwrtrk_method(void *dm_void)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- u8 p, idxforchnl = 0;
- struct txpwrtrack_cfg c = {0};
- configure_txpower_track(dm, &c);
- if (dm->support_ic_type &
- (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8821 | ODM_RTL8812 |
- ODM_RTL8723B | ODM_RTL8814A | ODM_RTL8703B | ODM_RTL8188F |
- ODM_RTL8822B | ODM_RTL8723D | ODM_RTL8821C | ODM_RTL8710B |
- ODM_RTL8192F)) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk MIX_MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)(dm, MIX_MODE, p, 0);
- } else {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk BBSWING_MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)
- (dm, BBSWING, p, idxforchnl);
- }
- }
- #if (DM_ODM_SUPPORT_TYPE & ODM_AP)
- void odm_txpowertracking_callback_thermal_meter(struct dm_struct *dm)
- #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
- void odm_txpowertracking_callback_thermal_meter(void *dm_void)
- #else
- void odm_txpowertracking_callback_thermal_meter(void *adapter)
- #endif
- {
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- HAL_DATA_TYPE *hal_data = GET_HAL_DATA(((PADAPTER)adapter));
- struct dm_struct *dm = &hal_data->DM_OutSrc;
- #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- #endif
- struct _hal_rf_ *rf = &dm->rf_table;
- struct dm_rf_calibration_struct *cali_info = &dm->rf_calibrate_info;
- struct dm_iqk_info *iqk_info = &dm->IQK_info;
- u8 thermal_value = 0, delta, delta_lck, delta_iqk, p = 0, i = 0;
- u8 thermal_value_avg_count = 0;
- u32 thermal_value_avg = 0, regc80, regcd0, regcd4, regab4;
- /* OFDM BB Swing should be less than +3.0dB, required by Arthur */
- #if 0
- u8 OFDM_min_index = 0;
- #endif
- /* get_right_chnl_place_for_iqk(hal_data->current_channel) */
- u8 power_tracking_type = rf->pwt_type;
- s8 thermal_value_temp = 0;
- struct txpwrtrack_cfg c = {0};
- /* 4 2. Initialization ( 7 steps in total ) */
- configure_txpower_track(dm, &c);
- cali_info->txpowertracking_callback_cnt++;
- cali_info->is_txpowertracking_init = true;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "\n\n\n===>%s bbsw_idx_cck_base=%d\n",
- __func__, cali_info->bb_swing_idx_cck_base);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "bbsw_idx_ofdm_base[A]=%d default_ofdm_idx=%d\n",
- cali_info->bb_swing_idx_ofdm_base[RF_PATH_A],
- cali_info->default_ofdm_index);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "cali_info->txpowertrack_control=%d, rf->eeprom_thermal %d\n",
- cali_info->txpowertrack_control, rf->eeprom_thermal);
- /* 0x42: RF Reg[15:10] 88E */
- thermal_value =
- (u8)odm_get_rf_reg(dm, RF_PATH_A, c.thermal_reg_addr, 0xfc00);
- thermal_value_temp = thermal_value + phydm_get_thermal_offset(dm);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "thermal_value_temp(%d) = ther_value(%d) + pwr_trim_ther(%d)\n",
- thermal_value_temp, thermal_value,
- phydm_get_thermal_offset(dm));
- if (thermal_value_temp > 63)
- thermal_value = 63;
- else if (thermal_value_temp < 0)
- thermal_value = 0;
- else
- thermal_value = thermal_value_temp;
- /*add log by zhao he, check c80/c94/c14/ca0 value*/
- if (dm->support_ic_type &
- (ODM_RTL8723D | ODM_RTL8710B)) {
- regc80 = odm_get_bb_reg(dm, R_0xc80, MASKDWORD);
- regcd0 = odm_get_bb_reg(dm, R_0xcd0, MASKDWORD);
- regcd4 = odm_get_bb_reg(dm, R_0xcd4, MASKDWORD);
- regab4 = odm_get_bb_reg(dm, R_0xab4, 0x000007FF);
- RF_DBG(dm, DBG_RF_IQK,
- "0xc80 = 0x%x 0xcd0 = 0x%x 0xcd4 = 0x%x 0xab4 = 0x%x\n",
- regc80, regcd0, regcd4, regab4);
- }
- if (!cali_info->txpowertrack_control)
- return;
- if (rf->eeprom_thermal == 0xff) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "no pg, hal_data->eeprom_thermal_meter = 0x%x\n",
- rf->eeprom_thermal);
- return;
- }
- /*4 3. Initialize ThermalValues of rf_calibrate_info*/
- if (cali_info->is_reloadtxpowerindex)
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "reload ofdm index for band switch\n");
- /*4 4. Calculate average thermal meter*/
- cali_info->thermal_value_avg[cali_info->thermal_value_avg_index]
- = thermal_value;
- cali_info->thermal_value_avg_index++;
- /*Average times = c.average_thermal_num*/
- if (cali_info->thermal_value_avg_index == c.average_thermal_num)
- cali_info->thermal_value_avg_index = 0;
- for (i = 0; i < c.average_thermal_num; i++) {
- if (cali_info->thermal_value_avg[i]) {
- thermal_value_avg += cali_info->thermal_value_avg[i];
- thermal_value_avg_count++;
- }
- }
- /* Calculate Average thermal_value after average enough times */
- if (thermal_value_avg_count) {
- thermal_value =
- (u8)(thermal_value_avg / thermal_value_avg_count);
- cali_info->thermal_value_delta
- = thermal_value - rf->eeprom_thermal;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "AVG Thermal Meter = 0x%X, EFUSE Thermal base = 0x%X\n",
- thermal_value, rf->eeprom_thermal);
- }
- /* 4 5. Calculate delta, delta_lck, delta_iqk. */
- /* "delta" here is used to determine thermal value changes or not. */
- if (thermal_value > cali_info->thermal_value)
- delta = thermal_value - cali_info->thermal_value;
- else
- delta = cali_info->thermal_value - thermal_value;
- if (thermal_value > cali_info->thermal_value_lck)
- delta_lck = thermal_value - cali_info->thermal_value_lck;
- else
- delta_lck = cali_info->thermal_value_lck - thermal_value;
- if (thermal_value > cali_info->thermal_value_iqk)
- delta_iqk = thermal_value - cali_info->thermal_value_iqk;
- else
- delta_iqk = cali_info->thermal_value_iqk - thermal_value;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "(delta, delta_lck, delta_iqk) = (%d, %d, %d)\n", delta,
- delta_lck, delta_iqk);
- /*4 6. If necessary, do LCK.*/
- /* Wait sacn to do LCK by RF Jenyu*/
- if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden) {
- /* Delta temperature is equal to or larger than 20 centigrade.*/
- if (delta_lck >= c.threshold_iqk) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "delta_lck(%d) >= threshold_iqk(%d)\n",
- delta_lck, c.threshold_iqk);
- cali_info->thermal_value_lck = thermal_value;
- /*Use RTLCK, close power tracking driver LCK*/
- /*8821 don't do LCK*/
- if (!(dm->support_ic_type &
- (ODM_RTL8821 | ODM_RTL8814A | ODM_RTL8822B)) &&
- c.phy_lc_calibrate) {
- (*c.phy_lc_calibrate)(dm);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "do pwrtrk lck\n");
- }
- }
- }
- /*3 7. If necessary, move the index of swing table to adjust Tx power.*/
- /* "delta" here is used to record the absolute value of difference. */
- if (delta > 0 && cali_info->txpowertrack_control) {
- if (thermal_value > rf->eeprom_thermal)
- delta = thermal_value - rf->eeprom_thermal;
- else
- delta = rf->eeprom_thermal - thermal_value;
- if (delta >= TXPWR_TRACK_TABLE_SIZE)
- delta = TXPWR_TRACK_TABLE_SIZE - 1;
- odm_get_tracking_table(dm, thermal_value, delta);
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "\n[path-%d] Calculate pwr_idx_offset\n", p);
- /*If Thermal value changes but table value is the same*/
- if (cali_info->delta_power_index[p] ==
- cali_info->delta_power_index_last[p])
- cali_info->power_index_offset[p] = 0;
- else
- cali_info->power_index_offset[p] =
- cali_info->delta_power_index[p] -
- cali_info->delta_power_index_last[p];
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "path-%d pwridx_diff%d=pwr_idx%d - last_idx%d\n",
- p, cali_info->power_index_offset[p],
- cali_info->delta_power_index[p],
- cali_info->delta_power_index_last[p]);
- #if 0
- cali_info->OFDM_index[p] = cali_info->bb_swing_idx_ofdm_base[p] + cali_info->power_index_offset[p];
- cali_info->CCK_index = cali_info->bb_swing_idx_cck_base + cali_info->power_index_offset[p];
- cali_info->bb_swing_idx_cck = cali_info->CCK_index;
- cali_info->bb_swing_idx_ofdm[p] = cali_info->OFDM_index[p];
- /*************Print BB Swing base and index Offset*************/
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "The 'CCK' final index(%d) = BaseIndex(%d) + power_index_offset(%d)\n",
- cali_info->bb_swing_idx_cck,
- cali_info->bb_swing_idx_cck_base,
- cali_info->power_index_offset[p]);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "The 'OFDM' final index(%d) = BaseIndex[%d](%d) + power_index_offset(%d)\n",
- cali_info->bb_swing_idx_ofdm[p], p,
- cali_info->bb_swing_idx_ofdm_base[p],
- cali_info->power_index_offset[p]);
- /*4 7.1 Handle boundary conditions of index.*/
- if (cali_info->OFDM_index[p] > c.swing_table_size_ofdm - 1)
- cali_info->OFDM_index[p] = c.swing_table_size_ofdm - 1;
- else if (cali_info->OFDM_index[p] <= OFDM_min_index)
- cali_info->OFDM_index[p] = OFDM_min_index;
- #endif
- }
- #if 0
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "\n\n========================================================================================================\n");
- if (cali_info->CCK_index > c.swing_table_size_cck - 1)
- cali_info->CCK_index = c.swing_table_size_cck - 1;
- else if (cali_info->CCK_index <= 0)
- cali_info->CCK_index = 0;
- #endif
- } else {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Thermal is unchanged thermal=%d last_thermal=%d\n",
- thermal_value,
- cali_info->thermal_value);
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- cali_info->power_index_offset[p] = 0;
- }
- #if 0
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "TxPowerTracking: [CCK] Swing Current index: %d, Swing base index: %d\n",
- cali_info->CCK_index,
- cali_info->bb_swing_idx_cck_base); /*Print Swing base & current*/
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "TxPowerTracking: [OFDM] Swing Current index: %d, Swing base index[%d]: %d\n",
- cali_info->OFDM_index[p], p,
- cali_info->bb_swing_idx_ofdm_base[p]);
- }
- #endif
- if ((dm->support_ic_type & ODM_RTL8814A)) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "power_tracking_type=%d\n",
- power_tracking_type);
- if (power_tracking_type == 0) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk MIX_MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)
- (dm, MIX_MODE, p, 0);
- } else if (power_tracking_type == 1) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk MIX(2G) TSSI(5G) MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)
- (dm, MIX_2G_TSSI_5G_MODE, p, 0);
- } else if (power_tracking_type == 2) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk MIX(5G) TSSI(2G)MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)
- (dm, MIX_5G_TSSI_2G_MODE, p, 0);
- } else if (power_tracking_type == 3) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "***Enter PwrTrk TSSI MODE***\n");
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- (*c.odm_tx_pwr_track_set_pwr)
- (dm, TSSI_MODE, p, 0);
- }
- } else if ((cali_info->power_index_offset[RF_PATH_A] != 0 ||
- cali_info->power_index_offset[RF_PATH_B] != 0 ||
- cali_info->power_index_offset[RF_PATH_C] != 0 ||
- cali_info->power_index_offset[RF_PATH_D] != 0)) {
- #if 0
- /* 4 7.2 Configure the Swing Table to adjust Tx Power. */
- /*Always true after Tx Power is adjusted by power tracking.*/
- cali_info->is_tx_power_changed = true;
- /* 2012/04/23 MH According to Luke's suggestion, we can not write BB digital
- * to increase TX power. Otherwise, EVM will be bad.
- *
- * 2012/04/25 MH Add for tx power tracking to set tx power in tx agc for 88E.
- */
- if (thermal_value > cali_info->thermal_value) {
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature Increasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
- p, cali_info->power_index_offset[p],
- delta, thermal_value, rf->eeprom_thermal,
- cali_info->thermal_value);
- }
- } else if (thermal_value < cali_info->thermal_value) { /*Low temperature*/
- for (p = RF_PATH_A; p < c.rf_path_count; p++) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature Decreasing(%d): delta_pi: %d, delta_t: %d, Now_t: %d, EFUSE_t: %d, Last_t: %d\n",
- p, cali_info->power_index_offset[p],
- delta, thermal_value, rf->eeprom_thermal,
- cali_info->thermal_value);
- }
- }
- #endif
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- if (thermal_value > rf->eeprom_thermal) {
- #else
- if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
- #endif
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature(%d) higher than PG value(%d)\n",
- thermal_value, rf->eeprom_thermal);
- odm_pwrtrk_method(dm);
- } else {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature(%d) lower than PG value(%d)\n",
- thermal_value, rf->eeprom_thermal);
- odm_pwrtrk_method(dm);
- }
- #if 0
- /*Record last time Power Tracking result as base.*/
- cali_info->bb_swing_idx_cck_base = cali_info->bb_swing_idx_cck;
- for (p = RF_PATH_A; p < c.rf_path_count; p++)
- cali_info->bb_swing_idx_ofdm_base[p] = cali_info->bb_swing_idx_ofdm[p];
- #endif
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "cali_info->thermal_value = %d thermal_value= %d\n",
- cali_info->thermal_value, thermal_value);
- }
- /*Record last Power Tracking Thermal value*/
- cali_info->thermal_value = thermal_value;
- if (dm->support_ic_type &
- (ODM_RTL8703B | ODM_RTL8723D | ODM_RTL8192F | ODM_RTL8710B)) {
- if (cali_info->xtal_offset_eanble != 0 &&
- cali_info->txpowertrack_control &&
- rf->eeprom_thermal != 0xff) {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "**********Enter Xtal Tracking**********\n");
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- if (thermal_value > rf->eeprom_thermal) {
- #else
- if (thermal_value > dm->priv->pmib->dot11RFEntry.ther) {
- #endif
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature(%d) higher than PG (%d)\n",
- thermal_value, rf->eeprom_thermal);
- (*c.odm_txxtaltrack_set_xtal)(dm);
- } else {
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "Temperature(%d) lower than PG (%d)\n",
- thermal_value, rf->eeprom_thermal);
- (*c.odm_txxtaltrack_set_xtal)(dm);
- }
- }
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "**********End Xtal Tracking**********\n");
- }
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- /* Wait sacn to do IQK by RF Jenyu*/
- if (!(*dm->is_scan_in_process) && !iqk_info->rfk_forbidden &&
- !cali_info->is_iqk_in_progress) {
- if (!(dm->support_ic_type & ODM_RTL8723B)) {
- /*Delta temperature is equal or larger than 20 Celsius*/
- /*When threshold is 8*/
- if (delta_iqk >= c.threshold_iqk) {
- cali_info->thermal_value_iqk = thermal_value;
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "delta_iqk(%d) >= threshold_iqk(%d)\n",
- delta_iqk, c.threshold_iqk);
- (*c.do_iqk)(dm, delta_iqk, thermal_value, 8);
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK,
- "do pwrtrk iqk\n");
- }
- }
- }
- #if 0
- if (cali_info->dpk_thermal[RF_PATH_A] != 0) {
- if (diff_DPK[RF_PATH_A] >= c.threshold_dpk) {
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_A] / c.threshold_dpk));
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- } else if ((diff_DPK[RF_PATH_A] <= -1 * c.threshold_dpk)) {
- s32 value = 0x20 + (diff_DPK[RF_PATH_A] / c.threshold_dpk);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- } else {
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xcc4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- }
- }
- if (cali_info->dpk_thermal[RF_PATH_B] != 0) {
- if (diff_DPK[RF_PATH_B] >= c.threshold_dpk) {
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), (diff_DPK[RF_PATH_B] / c.threshold_dpk));
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- } else if ((diff_DPK[RF_PATH_B] <= -1 * c.threshold_dpk)) {
- s32 value = 0x20 + (diff_DPK[RF_PATH_B] / c.threshold_dpk);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), value);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- } else {
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x1);
- odm_set_bb_reg(dm, R_0xec4, BIT(14) | BIT(13) | BIT(12) | BIT(11) | BIT(10), 0);
- odm_set_bb_reg(dm, R_0x82c, BIT(31), 0x0);
- }
- }
- #endif
- #endif
- RF_DBG(dm, DBG_RF_TX_PWR_TRACK, "<===%s\n", __func__);
- cali_info->tx_powercount = 0;
- }
- /* 3============================================================
- * 3 IQ Calibration
- * 3============================================================
- */
- void odm_reset_iqk_result(void *dm_void)
- {
- }
- #if !(DM_ODM_SUPPORT_TYPE & ODM_AP)
- u8 odm_get_right_chnl_place_for_iqk(u8 chnl)
- {
- u8 channel_all[ODM_TARGET_CHNL_NUM_2G_5G] = {
- 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
- 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64,
- 100, 102, 104, 106, 108, 110, 112, 114, 116, 118, 120, 122,
- 124, 126, 128, 130, 132, 134, 136, 138, 140,
- 149, 151, 153, 155, 157, 159, 161, 163, 165};
- u8 place = chnl;
- if (chnl > 14) {
- for (place = 14; place < sizeof(channel_all); place++) {
- if (channel_all[place] == chnl)
- return place - 13;
- }
- }
- return 0;
- }
- #endif
- void odm_iq_calibrate(struct dm_struct *dm)
- {
- void *adapter = dm->adapter;
- struct dm_iqk_info *iqk_info = &dm->IQK_info;
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- if (*dm->is_fcs_mode_enable)
- return;
- #endif
- #if (DM_ODM_SUPPORT_TYPE & (ODM_CE))
- if (IS_HARDWARE_TYPE_8812AU(adapter))
- return;
- #endif
- if (dm->is_linked && !iqk_info->rfk_forbidden) {
- if ((*dm->channel != dm->pre_channel) &&
- (!*dm->is_scan_in_process)) {
- dm->pre_channel = *dm->channel;
- dm->linked_interval = 0;
- }
- if (dm->linked_interval < 3)
- dm->linked_interval++;
- if (dm->linked_interval == 2)
- halrf_iqk_trigger(dm, false);
- } else {
- dm->linked_interval = 0;
- }
- }
- void phydm_rf_init(void *dm_void)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- odm_txpowertracking_init(dm);
- #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
- odm_clear_txpowertracking_state(dm);
- #endif
- #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
- #if (RTL8814A_SUPPORT == 1)
- if (dm->support_ic_type & ODM_RTL8814A)
- phy_iq_calibrate_8814a_init(dm);
- #endif
- #endif
- }
- void phydm_rf_watchdog(void *dm_void)
- {
- struct dm_struct *dm = (struct dm_struct *)dm_void;
- #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
- odm_txpowertracking_check(dm);
- #if 0
- /*if (dm->support_ic_type & ODM_IC_11AC_SERIES)*/
- /*odm_iq_calibrate(dm);*/
- #endif
- #endif
- }
|