Lines Matching +full:tx +full:- +full:swing +full:- +full:low
1 // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
2 /* Copyright(c) 2018-2019 Realtek Corporation
9 #include "tx.h"
26 ether_addr_copy(efuse->addr, map->e.mac_addr); in rtw8822be_efuse_parsing()
32 ether_addr_copy(efuse->addr, map->u.mac_addr); in rtw8822bu_efuse_parsing()
38 ether_addr_copy(efuse->addr, map->s.mac_addr); in rtw8822bs_efuse_parsing()
43 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_read_efuse()
49 efuse->usb_mode_switch = u8_get_bits(map->usb_mode, BIT(7)); in rtw8822b_read_efuse()
50 efuse->rfe_option = map->rfe_option; in rtw8822b_read_efuse()
51 efuse->rf_board_option = map->rf_board_option; in rtw8822b_read_efuse()
52 efuse->crystal_cap = map->xtal_k; in rtw8822b_read_efuse()
53 efuse->pa_type_2g = map->pa_type; in rtw8822b_read_efuse()
54 efuse->pa_type_5g = map->pa_type; in rtw8822b_read_efuse()
55 efuse->lna_type_2g = map->lna_type_2g[0]; in rtw8822b_read_efuse()
56 efuse->lna_type_5g = map->lna_type_5g[0]; in rtw8822b_read_efuse()
57 efuse->channel_plan = map->channel_plan; in rtw8822b_read_efuse()
58 efuse->country_code[0] = map->country_code[0]; in rtw8822b_read_efuse()
59 efuse->country_code[1] = map->country_code[1]; in rtw8822b_read_efuse()
60 efuse->bt_setting = map->rf_bt_setting; in rtw8822b_read_efuse()
61 efuse->regd = map->rf_board_option & 0x7; in rtw8822b_read_efuse()
62 efuse->thermal_meter[RF_PATH_A] = map->thermal_meter; in rtw8822b_read_efuse()
63 efuse->thermal_meter_k = map->thermal_meter; in rtw8822b_read_efuse()
66 efuse->txpwr_idx_table[i] = map->txpwr_idx_table[i]; in rtw8822b_read_efuse()
80 return -ENOTSUPP; in rtw8822b_read_efuse()
113 u32 swing, table_value; in rtw8822b_get_swing_index() local
115 swing = rtw_read32_mask(rtwdev, 0xc1c, 0xffe00000); in rtw8822b_get_swing_index()
118 if (swing == table_value) in rtw8822b_get_swing_index()
127 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_pwrtrack_init()
132 dm_info->default_ofdm_index = 24; in rtw8822b_pwrtrack_init()
134 dm_info->default_ofdm_index = swing_idx; in rtw8822b_pwrtrack_init()
136 for (path = RF_PATH_A; path < rtwdev->hal.rf_path_num; path++) { in rtw8822b_pwrtrack_init()
137 ewma_thermal_init(&dm_info->avg_thermal[path]); in rtw8822b_pwrtrack_init()
138 dm_info->delta_power_index[path] = 0; in rtw8822b_pwrtrack_init()
140 dm_info->pwr_trk_triggered = false; in rtw8822b_pwrtrack_init()
141 dm_info->pwr_trk_init_trigger = true; in rtw8822b_pwrtrack_init()
142 dm_info->thermal_meter_k = rtwdev->efuse.thermal_meter_k; in rtw8822b_pwrtrack_init()
154 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_phy_set_param()
170 crystal_cap = rtwdev->efuse.crystal_cap & 0x3F; in rtw8822b_phy_set_param()
178 rtw8822b_config_trx_mode(rtwdev, hal->antenna_tx, hal->antenna_rx, in rtw8822b_phy_set_param()
268 /* Set beacon cotnrol - enable TSF and other related functions */ in rtw8822b_mac_init()
292 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_channel_rfe_efem()
306 if (hal->antenna_rx == BB_PATH_AB || in rtw8822b_set_channel_rfe_efem()
307 hal->antenna_tx == BB_PATH_AB) { in rtw8822b_set_channel_rfe_efem()
308 /* 2TX or 2RX */ in rtw8822b_set_channel_rfe_efem()
310 } else if (hal->antenna_rx == hal->antenna_tx) { in rtw8822b_set_channel_rfe_efem()
321 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_channel_rfe_ifem()
336 if (hal->antenna_rx == BB_PATH_AB || in rtw8822b_set_channel_rfe_ifem()
337 hal->antenna_tx == BB_PATH_AB) { in rtw8822b_set_channel_rfe_ifem()
338 /* 2TX or 2RX */ in rtw8822b_set_channel_rfe_ifem()
340 } else if (hal->antenna_rx == hal->antenna_tx) { in rtw8822b_set_channel_rfe_ifem()
387 *reg82c = cca_ccut->reg82c[col]; in rtw8822b_get_cca_val()
388 *reg830 = cca_ccut->reg830[col]; in rtw8822b_get_cca_val()
389 *reg838 = cca_ccut->reg838[col]; in rtw8822b_get_cca_val()
424 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_channel_cca()
425 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_set_channel_cca()
432 cca_ccut = rfe_info->cca_ccut_2g; in rtw8822b_set_channel_cca()
434 if (hal->antenna_rx == BB_PATH_A || in rtw8822b_set_channel_cca()
435 hal->antenna_rx == BB_PATH_B) in rtw8822b_set_channel_cca()
440 cca_ccut = rfe_info->cca_ccut_5g; in rtw8822b_set_channel_cca()
442 if (hal->antenna_rx == BB_PATH_A || in rtw8822b_set_channel_cca()
443 hal->antenna_rx == BB_PATH_B) in rtw8822b_set_channel_cca()
451 switch (rfe_info->fem) { in rtw8822b_set_channel_cca()
455 if (rfe_info->ifem_ext) in rtw8822b_set_channel_cca()
470 if ((hal->cut_version == RTW_CHIP_VER_CUT_B && in rtw8822b_set_channel_cca()
475 (efuse->rfe_option == 5 && col == CCUT_IDX_2R_5G)) in rtw8822b_set_channel_cca()
483 if (is_efem_cca && !(hal->cut_version == RTW_CHIP_VER_CUT_B)) in rtw8822b_set_channel_cca()
513 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_channel_rf()
546 rf_reg_be = low_band[(channel - 36) >> 1]; in rtw8822b_set_channel_rf()
548 rf_reg_be = middle_band[(channel - 100) >> 1]; in rtw8822b_set_channel_rf()
550 rf_reg_be = high_band[(channel - 149) >> 1]; in rtw8822b_set_channel_rf()
563 if (hal->rf_type > RF_1T1R) in rtw8822b_set_channel_rf()
577 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_toggle_igi()
581 rtw_write32_mask(rtwdev, REG_RXIGI_A, 0x7f, igi - 2); in rtw8822b_toggle_igi()
583 rtw_write32_mask(rtwdev, REG_RXIGI_B, 0x7f, igi - 2); in rtw8822b_toggle_igi()
588 hal->antenna_rx | (hal->antenna_rx << 4)); in rtw8822b_toggle_igi()
614 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_set_channel_bb()
615 u8 rfe_option = efuse->rfe_option; in rtw8822b_set_channel_bb()
720 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_set_channel()
723 if (WARN(efuse->rfe_option >= ARRAY_SIZE(rtw8822b_rfe_info), in rtw8822b_set_channel()
724 "rfe_option %d is out of boundary\n", efuse->rfe_option)) in rtw8822b_set_channel()
727 rfe_info = &rtw8822b_rfe_info[efuse->rfe_option]; in rtw8822b_set_channel()
735 (*rfe_info->rtw_set_channel_rfe)(rtwdev, channel); in rtw8822b_set_channel()
741 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_config_trx_mode()
743 u8 ch = rtwdev->hal.current_channel; in rtw8822b_config_trx_mode()
747 if (WARN(efuse->rfe_option >= ARRAY_SIZE(rtw8822b_rfe_info), in rtw8822b_config_trx_mode()
748 "rfe_option %d is out of boundary\n", efuse->rfe_option)) in rtw8822b_config_trx_mode()
751 rfe_info = &rtw8822b_rfe_info[efuse->rfe_option]; in rtw8822b_config_trx_mode()
784 if (is_tx2_path || rtwdev->mp_mode) { in rtw8822b_config_trx_mode()
811 for (counter = 100; counter > 0; counter--) { in rtw8822b_config_trx_mode()
836 (*rfe_info->rtw_set_channel_rfe)(rtwdev, ch); in rtw8822b_config_trx_mode()
842 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in query_phy_status_page0()
843 s8 min_rx_power = -120; in query_phy_status_page0()
847 pkt_stat->rx_power[RF_PATH_A] = pwdb - 110; in query_phy_status_page0()
848 pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 1); in query_phy_status_page0()
849 pkt_stat->bw = RTW_CHANNEL_WIDTH_20; in query_phy_status_page0()
850 pkt_stat->signal_power = max(pkt_stat->rx_power[RF_PATH_A], in query_phy_status_page0()
852 dm_info->rssi[RF_PATH_A] = pkt_stat->rssi; in query_phy_status_page0()
858 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in query_phy_status_page1()
860 s8 min_rx_power = -120; in query_phy_status_page1()
866 if (pkt_stat->rate > DESC_RATE11M && pkt_stat->rate < DESC_RATEMCS0) in query_phy_status_page1()
880 pkt_stat->rx_power[RF_PATH_A] = GET_PHY_STAT_P1_PWDB_A(phy_status) - 110; in query_phy_status_page1()
881 pkt_stat->rx_power[RF_PATH_B] = GET_PHY_STAT_P1_PWDB_B(phy_status) - 110; in query_phy_status_page1()
882 pkt_stat->rssi = rtw_phy_rf_power_2_rssi(pkt_stat->rx_power, 2); in query_phy_status_page1()
883 pkt_stat->bw = bw; in query_phy_status_page1()
884 pkt_stat->signal_power = max3(pkt_stat->rx_power[RF_PATH_A], in query_phy_status_page1()
885 pkt_stat->rx_power[RF_PATH_B], in query_phy_status_page1()
888 dm_info->curr_rx_rate = pkt_stat->rate; in query_phy_status_page1()
890 pkt_stat->rx_evm[RF_PATH_A] = GET_PHY_STAT_P1_RXEVM_A(phy_status); in query_phy_status_page1()
891 pkt_stat->rx_evm[RF_PATH_B] = GET_PHY_STAT_P1_RXEVM_B(phy_status); in query_phy_status_page1()
893 pkt_stat->rx_snr[RF_PATH_A] = GET_PHY_STAT_P1_RXSNR_A(phy_status); in query_phy_status_page1()
894 pkt_stat->rx_snr[RF_PATH_B] = GET_PHY_STAT_P1_RXSNR_B(phy_status); in query_phy_status_page1()
896 pkt_stat->cfo_tail[RF_PATH_A] = GET_PHY_STAT_P1_CFO_TAIL_A(phy_status); in query_phy_status_page1()
897 pkt_stat->cfo_tail[RF_PATH_B] = GET_PHY_STAT_P1_CFO_TAIL_B(phy_status); in query_phy_status_page1()
899 for (path = 0; path <= rtwdev->hal.rf_path_num; path++) { in query_phy_status_page1()
900 rssi = rtw_phy_rf_power_2_rssi(&pkt_stat->rx_power[path], 1); in query_phy_status_page1()
901 dm_info->rssi[path] = rssi; in query_phy_status_page1()
902 dm_info->rx_snr[path] = pkt_stat->rx_snr[path] >> 1; in query_phy_status_page1()
903 dm_info->cfo_tail[path] = (pkt_stat->cfo_tail[path] * 5) >> 1; in query_phy_status_page1()
905 rx_evm = pkt_stat->rx_evm[path]; in query_phy_status_page1()
911 evm_dbm = ((u8)-rx_evm >> 1); in query_phy_status_page1()
913 dm_info->rx_evm_dbm[path] = evm_dbm; in query_phy_status_page1()
942 u32 desc_sz = rtwdev->chip->rx_pkt_desc_sz; in rtw8822b_query_rx_desc()
947 pkt_stat->phy_status = GET_RX_DESC_PHYST(rx_desc); in rtw8822b_query_rx_desc()
948 pkt_stat->icv_err = GET_RX_DESC_ICV_ERR(rx_desc); in rtw8822b_query_rx_desc()
949 pkt_stat->crc_err = GET_RX_DESC_CRC32(rx_desc); in rtw8822b_query_rx_desc()
950 pkt_stat->decrypted = !GET_RX_DESC_SWDEC(rx_desc) && in rtw8822b_query_rx_desc()
952 pkt_stat->is_c2h = GET_RX_DESC_C2H(rx_desc); in rtw8822b_query_rx_desc()
953 pkt_stat->pkt_len = GET_RX_DESC_PKT_LEN(rx_desc); in rtw8822b_query_rx_desc()
954 pkt_stat->drv_info_sz = GET_RX_DESC_DRV_INFO_SIZE(rx_desc); in rtw8822b_query_rx_desc()
955 pkt_stat->shift = GET_RX_DESC_SHIFT(rx_desc); in rtw8822b_query_rx_desc()
956 pkt_stat->rate = GET_RX_DESC_RX_RATE(rx_desc); in rtw8822b_query_rx_desc()
957 pkt_stat->cam_id = GET_RX_DESC_MACID(rx_desc); in rtw8822b_query_rx_desc()
958 pkt_stat->ppdu_cnt = GET_RX_DESC_PPDU_CNT(rx_desc); in rtw8822b_query_rx_desc()
959 pkt_stat->tsf_low = GET_RX_DESC_TSFL(rx_desc); in rtw8822b_query_rx_desc()
961 /* drv_info_sz is in unit of 8-bytes */ in rtw8822b_query_rx_desc()
962 pkt_stat->drv_info_sz *= 8; in rtw8822b_query_rx_desc()
965 if (pkt_stat->is_c2h) in rtw8822b_query_rx_desc()
968 hdr = (struct ieee80211_hdr *)(rx_desc + desc_sz + pkt_stat->shift + in rtw8822b_query_rx_desc()
969 pkt_stat->drv_info_sz); in rtw8822b_query_rx_desc()
970 if (pkt_stat->phy_status) { in rtw8822b_query_rx_desc()
971 phy_status = rx_desc + desc_sz + pkt_stat->shift; in rtw8822b_query_rx_desc()
981 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_tx_power_index_by_rate()
989 pwr_index = hal->tx_pwr_tbl[path][rate]; in rtw8822b_set_tx_power_index_by_rate()
1003 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_tx_power_index()
1006 for (path = 0; path < hal->rf_path_num; path++) { in rtw8822b_set_tx_power_index()
1028 struct rtw_hal *hal = &rtwdev->hal; in rtw8822b_set_antenna()
1030 rtw_dbg(rtwdev, RTW_DBG_PHY, "config RF path, tx=0x%x rx=0x%x\n", in rtw8822b_set_antenna()
1034 rtw_warn(rtwdev, "unsupported tx path 0x%x\n", antenna_tx); in rtw8822b_set_antenna()
1035 return -EINVAL; in rtw8822b_set_antenna()
1040 return -EINVAL; in rtw8822b_set_antenna()
1043 hal->antenna_tx = antenna_tx; in rtw8822b_set_antenna()
1044 hal->antenna_rx = antenna_rx; in rtw8822b_set_antenna()
1062 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_false_alarm_statistics()
1073 dm_info->cck_fa_cnt = cck_fa_cnt; in rtw8822b_false_alarm_statistics()
1074 dm_info->ofdm_fa_cnt = ofdm_fa_cnt; in rtw8822b_false_alarm_statistics()
1075 dm_info->total_fa_cnt = ofdm_fa_cnt; in rtw8822b_false_alarm_statistics()
1076 dm_info->total_fa_cnt += cck_enable ? cck_fa_cnt : 0; in rtw8822b_false_alarm_statistics()
1079 dm_info->cck_ok_cnt = crc32_cnt & 0xffff; in rtw8822b_false_alarm_statistics()
1080 dm_info->cck_err_cnt = (crc32_cnt & 0xffff0000) >> 16; in rtw8822b_false_alarm_statistics()
1082 dm_info->ofdm_ok_cnt = crc32_cnt & 0xffff; in rtw8822b_false_alarm_statistics()
1083 dm_info->ofdm_err_cnt = (crc32_cnt & 0xffff0000) >> 16; in rtw8822b_false_alarm_statistics()
1085 dm_info->ht_ok_cnt = crc32_cnt & 0xffff; in rtw8822b_false_alarm_statistics()
1086 dm_info->ht_err_cnt = (crc32_cnt & 0xffff0000) >> 16; in rtw8822b_false_alarm_statistics()
1088 dm_info->vht_ok_cnt = crc32_cnt & 0xffff; in rtw8822b_false_alarm_statistics()
1089 dm_info->vht_err_cnt = (crc32_cnt & 0xffff0000) >> 16; in rtw8822b_false_alarm_statistics()
1092 dm_info->ofdm_cca_cnt = ((cca32_cnt & 0xffff0000) >> 16); in rtw8822b_false_alarm_statistics()
1093 dm_info->total_cca_cnt = dm_info->ofdm_cca_cnt; in rtw8822b_false_alarm_statistics()
1096 dm_info->cck_cca_cnt = cca32_cnt & 0xffff; in rtw8822b_false_alarm_statistics()
1097 dm_info->total_cca_cnt += dm_info->cck_cca_cnt; in rtw8822b_false_alarm_statistics()
1150 /* enable PTA (3-wire function form BT side) */ in rtw8822b_coex_cfg_init()
1154 /* enable PTA (tx/rx signal form WiFi side) */ in rtw8822b_coex_cfg_init()
1156 /* wl tx signal to PTA not case EDCCA */ in rtw8822b_coex_cfg_init()
1165 struct rtw_coex *coex = &rtwdev->coex; in rtw8822b_coex_cfg_ant_switch()
1166 struct rtw_coex_dm *coex_dm = &coex->dm; in rtw8822b_coex_cfg_ant_switch()
1167 struct rtw_coex_rfe *coex_rfe = &coex->rfe; in rtw8822b_coex_cfg_ant_switch()
1171 if (((ctrl_type << 8) + pos_type) == coex_dm->cur_switch_status) in rtw8822b_coex_cfg_ant_switch()
1174 coex_dm->cur_switch_status = (ctrl_type << 8) + pos_type; in rtw8822b_coex_cfg_ant_switch()
1176 if (coex_rfe->ant_switch_diversity && in rtw8822b_coex_cfg_ant_switch()
1180 polarity_inverse = (coex_rfe->ant_switch_polarity == 1); in rtw8822b_coex_cfg_ant_switch()
1193 if (coex_rfe->rfe_module_type != 0x4 && in rtw8822b_coex_cfg_ant_switch()
1194 coex_rfe->rfe_module_type != 0x2) in rtw8822b_coex_cfg_ant_switch()
1261 struct rtw_coex *coex = &rtwdev->coex; in rtw8822b_coex_cfg_rfe_type()
1262 struct rtw_coex_rfe *coex_rfe = &coex->rfe; in rtw8822b_coex_cfg_rfe_type()
1263 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_coex_cfg_rfe_type()
1266 coex_rfe->rfe_module_type = rtwdev->efuse.rfe_option; in rtw8822b_coex_cfg_rfe_type()
1267 coex_rfe->ant_switch_polarity = 0; in rtw8822b_coex_cfg_rfe_type()
1268 coex_rfe->ant_switch_diversity = false; in rtw8822b_coex_cfg_rfe_type()
1269 if (coex_rfe->rfe_module_type == 0x12 || in rtw8822b_coex_cfg_rfe_type()
1270 coex_rfe->rfe_module_type == 0x15 || in rtw8822b_coex_cfg_rfe_type()
1271 coex_rfe->rfe_module_type == 0x16) in rtw8822b_coex_cfg_rfe_type()
1272 coex_rfe->ant_switch_exist = false; in rtw8822b_coex_cfg_rfe_type()
1274 coex_rfe->ant_switch_exist = true; in rtw8822b_coex_cfg_rfe_type()
1276 if (coex_rfe->rfe_module_type == 2 || in rtw8822b_coex_cfg_rfe_type()
1277 coex_rfe->rfe_module_type == 4) { in rtw8822b_coex_cfg_rfe_type()
1284 coex_rfe->wlg_at_btg = false; in rtw8822b_coex_cfg_rfe_type()
1286 if (efuse->share_ant && in rtw8822b_coex_cfg_rfe_type()
1287 coex_rfe->ant_switch_exist && !is_ext_fem) in rtw8822b_coex_cfg_rfe_type()
1288 coex_rfe->ant_switch_with_bt = true; in rtw8822b_coex_cfg_rfe_type()
1290 coex_rfe->ant_switch_with_bt = false; in rtw8822b_coex_cfg_rfe_type()
1309 struct rtw_coex *coex = &rtwdev->coex; in rtw8822b_coex_cfg_wl_tx_power()
1310 struct rtw_coex_dm *coex_dm = &coex->dm; in rtw8822b_coex_cfg_wl_tx_power()
1315 if (wl_pwr == coex_dm->cur_wl_pwr_lvl) in rtw8822b_coex_cfg_wl_tx_power()
1318 coex_dm->cur_wl_pwr_lvl = wl_pwr; in rtw8822b_coex_cfg_wl_tx_power()
1320 if (coex_dm->cur_wl_pwr_lvl >= ARRAY_SIZE(wl_tx_power)) in rtw8822b_coex_cfg_wl_tx_power()
1321 coex_dm->cur_wl_pwr_lvl = ARRAY_SIZE(wl_tx_power) - 1; in rtw8822b_coex_cfg_wl_tx_power()
1323 pwr = wl_tx_power[coex_dm->cur_wl_pwr_lvl]; in rtw8822b_coex_cfg_wl_tx_power()
1331 struct rtw_coex *coex = &rtwdev->coex; in rtw8822b_coex_cfg_wl_rx_gain()
1332 struct rtw_coex_dm *coex_dm = &coex->dm; in rtw8822b_coex_cfg_wl_rx_gain()
1333 /* WL Rx Low gain on */ in rtw8822b_coex_cfg_wl_rx_gain()
1346 /* WL Rx Low gain off */ in rtw8822b_coex_cfg_wl_rx_gain()
1360 if (low_gain == coex_dm->cur_wl_rx_low_gain_en) in rtw8822b_coex_cfg_wl_rx_gain()
1363 coex_dm->cur_wl_rx_low_gain_en = low_gain; in rtw8822b_coex_cfg_wl_rx_gain()
1365 if (coex_dm->cur_wl_rx_low_gain_en) { in rtw8822b_coex_cfg_wl_rx_gain()
1366 rtw_dbg(rtwdev, RTW_DBG_COEX, "[BTCoex], Hi-Li Table On!\n"); in rtw8822b_coex_cfg_wl_rx_gain()
1376 rtw_dbg(rtwdev, RTW_DBG_COEX, "[BTCoex], Hi-Li Table Off!\n"); in rtw8822b_coex_cfg_wl_rx_gain()
1392 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_txagc_swing_offset()
1393 s8 delta_pwr_idx = dm_info->delta_power_index[path]; in rtw8822b_txagc_swing_offset()
1394 u8 swing_upper_bound = dm_info->default_ofdm_index + 10; in rtw8822b_txagc_swing_offset()
1398 u8 swing_index = dm_info->default_ofdm_index; in rtw8822b_txagc_swing_offset()
1405 swing_index = dm_info->default_ofdm_index; in rtw8822b_txagc_swing_offset()
1408 swing_index = dm_info->default_ofdm_index + in rtw8822b_txagc_swing_offset()
1409 delta_pwr_idx - tx_pwr_idx_offset; in rtw8822b_txagc_swing_offset()
1413 if (dm_info->default_ofdm_index > abs(delta_pwr_idx)) in rtw8822b_txagc_swing_offset()
1415 dm_info->default_ofdm_index + delta_pwr_idx; in rtw8822b_txagc_swing_offset()
1424 rtw_warn(rtwdev, "swing index overflow\n"); in rtw8822b_txagc_swing_offset()
1425 swing_index = RTW_TXSCALE_SIZE - 1; in rtw8822b_txagc_swing_offset()
1457 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_pwrtrack_set()
1459 u8 channel = rtwdev->hal.current_channel; in rtw8822b_pwrtrack_set()
1460 u8 band_width = rtwdev->hal.current_band_width; in rtw8822b_pwrtrack_set()
1462 u8 tx_rate = dm_info->tx_rate; in rtw8822b_pwrtrack_set()
1463 u8 max_pwr_idx = rtwdev->chip->max_power_index; in rtw8822b_pwrtrack_set()
1470 pwr_idx_offset = max_pwr_idx - tx_pwr_idx; in rtw8822b_pwrtrack_set()
1479 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_phy_pwrtrack_path()
1486 power_idx_last = dm_info->delta_power_index[path]; in rtw8822b_phy_pwrtrack_path()
1494 dm_info->delta_power_index[path] = power_idx_cur; in rtw8822b_phy_pwrtrack_path()
1500 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_phy_pwrtrack()
1506 if (rtwdev->efuse.thermal_meter[RF_PATH_A] == 0xff) in rtw8822b_phy_pwrtrack()
1513 if (dm_info->pwr_trk_init_trigger) in rtw8822b_phy_pwrtrack()
1514 dm_info->pwr_trk_init_trigger = false; in rtw8822b_phy_pwrtrack()
1519 for (path = 0; path < rtwdev->hal.rf_path_num; path++) in rtw8822b_phy_pwrtrack()
1529 struct rtw_efuse *efuse = &rtwdev->efuse; in rtw8822b_pwr_track()
1530 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_pwr_track()
1532 if (efuse->power_track_type != 0) in rtw8822b_pwr_track()
1535 if (!dm_info->pwr_trk_triggered) { in rtw8822b_pwr_track()
1538 dm_info->pwr_trk_triggered = true; in rtw8822b_pwr_track()
1543 dm_info->pwr_trk_triggered = false; in rtw8822b_pwr_track()
1569 if (bfee->role == RTW_BFEE_SU) in rtw8822b_bf_config_bfee()
1571 else if (bfee->role == RTW_BFEE_MU) in rtw8822b_bf_config_bfee()
1594 struct rtw_dm_info *dm_info = &rtwdev->dm_info; in rtw8822b_adaptivity()
1598 igi = dm_info->igi_history[0]; in rtw8822b_adaptivity()
1599 if (dm_info->edcca_mode == RTW_EDCCA_NORMAL) { in rtw8822b_adaptivity()
1601 h2l = l2h - EDCCA_L2H_H2L_DIFF_NORMAL; in rtw8822b_adaptivity()
1603 l2h = min_t(s8, igi, dm_info->l2h_th_ini); in rtw8822b_adaptivity()
1604 h2l = l2h - EDCCA_L2H_H2L_DIFF; in rtw8822b_adaptivity()
2205 /* Shared-Antenna Coex Table */
2207 {0xffffffff, 0xffffffff}, /* case-0 */
2212 {0xfafafafa, 0xfafafafa}, /* case-5 */
2217 {0x66555555, 0x6a5a5a5a}, /* case-10 */
2222 {0x66555555, 0xaaaaaaaa}, /* case-15 */
2227 {0xaa5555aa, 0x6a5a5a5a}, /* case-20 */
2232 {0xffffffff, 0x6a5a5aaa}, /* case-25 */
2237 {0x66556aaa, 0x6a5a6aaa}, /* case-30 */
2242 /* Non-Shared-Antenna Coex Table */
2244 {0xffffffff, 0xffffffff}, /* case-100 */
2249 {0xfafafafa, 0xfafafafa}, /* case-105 */
2254 {0x66555555, 0x6a5a5a5a}, /* case-110 */
2259 {0xffff55ff, 0xffff55ff}, /* case-115 */
2264 {0xffffffff, 0xaaaaaaaa}, /* case-120 */
2270 /* Shared-Antenna TDMA */
2272 { {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-0 */
2277 { {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-5 */
2282 { {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-10 */
2287 { {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-15 */
2292 { {0x51, 0x10, 0x03, 0x10, 0x50} }, /* case-20 */
2297 { {0x51, 0x10, 0x03, 0x10, 0x51} }, /* case-25 */
2302 /* Non-Shared-Antenna TDMA */
2304 { {0x00, 0x00, 0x00, 0x00, 0x00} }, /* case-100 */
2305 { {0x61, 0x45, 0x03, 0x11, 0x11} }, /* case-101 */
2309 { {0x61, 0x10, 0x03, 0x11, 0x11} }, /* case-105 */
2314 { {0x61, 0x10, 0x03, 0x11, 0x10} }, /* case-110 */
2319 { {0x51, 0x08, 0x07, 0x10, 0x54} }, /* case-115 */
2324 { {0x51, 0x10, 0x03, 0x10, 0x50} }, /* case-120 */
2328 /* rssi in percentage % (dbm = % - 100) */
2335 {0, 16, false, 7}, /* for WL-CPT */
2344 {0, 16, false, 7}, /* for WL-CPT */
2581 .l2h_th_ini_ad = -14 + EDCCA_IGI_BASE,