Lines Matching +full:120 +full:- +full:db

1 // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
2 /* Copyright(c) 2018-2019 Realtek Corporation
113 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
118 dm_info->cck_pd_lv[i][j] = CCK_PD_LV0;
121 dm_info->cck_fa_avg = CCK_FA_AVG_RESET;
126 struct rtw_hw_reg_offset *edcca_th = rtwdev->chip->edcca_th;
141 const struct rtw_chip_info *chip = rtwdev->chip;
142 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
146 dm_info->edcca_mode = RTW_EDCCA_NORMAL;
151 switch (rtwdev->regd.dfs_region) {
153 dm_info->edcca_mode = RTW_EDCCA_ADAPTIVITY;
154 dm_info->l2h_th_ini = chip->l2h_th_ini_ad;
157 dm_info->edcca_mode = RTW_EDCCA_ADAPTIVITY;
158 dm_info->l2h_th_ini = chip->l2h_th_ini_cs;
161 dm_info->edcca_mode = RTW_EDCCA_NORMAL;
168 const struct rtw_chip_info *chip = rtwdev->chip;
171 if (chip->ops->adaptivity_init)
172 chip->ops->adaptivity_init(rtwdev);
177 if (rtwdev->chip->ops->adaptivity)
178 rtwdev->chip->ops->adaptivity(rtwdev);
183 const struct rtw_chip_info *chip = rtwdev->chip;
185 if (chip->ops->cfo_init)
186 chip->ops->cfo_init(rtwdev);
191 struct rtw_path_div *path_div = &rtwdev->dm_path_div;
193 path_div->current_tx_path = rtwdev->chip->default_1ss_tx_path;
194 path_div->path_a_cnt = 0;
195 path_div->path_a_sum = 0;
196 path_div->path_b_cnt = 0;
197 path_div->path_b_sum = 0;
202 const struct rtw_chip_info *chip = rtwdev->chip;
203 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
206 dm_info->fa_history[3] = 0;
207 dm_info->fa_history[2] = 0;
208 dm_info->fa_history[1] = 0;
209 dm_info->fa_history[0] = 0;
210 dm_info->igi_bitmap = 0;
211 dm_info->igi_history[3] = 0;
212 dm_info->igi_history[2] = 0;
213 dm_info->igi_history[1] = 0;
215 addr = chip->dig[0].addr;
216 mask = chip->dig[0].mask;
217 dm_info->igi_history[0] = rtw_read32_mask(rtwdev, addr, mask);
220 dm_info->iqk.done = false;
229 const struct rtw_chip_info *chip = rtwdev->chip;
230 struct rtw_hal *hal = &rtwdev->hal;
234 if (chip->dig_cck) {
235 const struct rtw_hw_reg *dig_cck = &chip->dig_cck[0];
236 rtw_write32_mask(rtwdev, dig_cck->addr, dig_cck->mask, igi >> 1);
239 for (path = 0; path < hal->rf_path_num; path++) {
240 addr = chip->dig[path].addr;
241 mask = chip->dig[path].mask;
248 const struct rtw_chip_info *chip = rtwdev->chip;
250 chip->ops->false_alarm_statistics(rtwdev);
284 struct rtw_dev *rtwdev = iter_data->rtwdev;
285 struct rtw_sta_info *si = (struct rtw_sta_info *)sta->drv_priv;
288 rssi = ewma_rssi_read(&si->avg_rssi);
289 si->rssi_level = rtw_phy_get_rssi_level(si->rssi_level, rssi);
293 iter_data->min_rssi = min_t(u8, rssi, iter_data->min_rssi);
298 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
305 dm_info->pre_min_rssi = dm_info->min_rssi;
306 dm_info->min_rssi = data.min_rssi;
311 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
313 dm_info->last_pkt_count = dm_info->cur_pkt_count;
314 memset(&dm_info->cur_pkt_count, 0, sizeof(dm_info->cur_pkt_count));
350 min_rssi = dm_info->min_rssi;
351 if (dm_info->damping) {
352 damping_rssi = dm_info->damping_rssi;
353 diff = min_rssi > damping_rssi ? min_rssi - damping_rssi :
354 damping_rssi - min_rssi;
355 if (diff > 3 || dm_info->damping_cnt++ > 20) {
356 dm_info->damping = false;
363 igi_history = dm_info->igi_history;
364 fa_history = dm_info->fa_history;
365 igi_bitmap = dm_info->igi_bitmap & 0xf;
368 /* down -> up -> down -> up */
371 igi_history[0] - igi_history[1] >= 2 &&
372 igi_history[2] - igi_history[3] >= 2 &&
378 /* up -> down -> down -> up */
381 igi_history[0] - igi_history[1] >= 4 &&
382 igi_history[3] - igi_history[2] >= 2 &&
392 dm_info->damping = true;
393 dm_info->damping_cnt = 0;
394 dm_info->damping_rssi = min_rssi;
410 dig_min = rtwdev->chip->dig_min;
411 min_rssi = max_t(u8, dm_info->min_rssi, dig_min);
431 min_rssi = dm_info->min_rssi;
432 pre_min_rssi = dm_info->pre_min_rssi;
460 igi_bitmap = dm_info->igi_bitmap << 1 & 0xfe;
461 igi_history = dm_info->igi_history;
462 fa_history = dm_info->fa_history;
477 dm_info->igi_bitmap = igi_bitmap;
482 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
490 if (test_bit(RTW_FLAG_DIG_DISABLE, rtwdev->flags))
496 linked = !!rtwdev->sta_cnt;
498 fa_cnt = dm_info->total_fa_cnt;
499 pre_igi = dm_info->igi_history[0];
506 * note that the step size is offset by -2, compensate it afterall
515 cur_igi -= 2;
537 struct rtw_sta_info *si = (struct rtw_sta_info *)sta->drv_priv;
544 if (rtwdev->watch_dog_cnt & 0x3)
557 rate_order -= DESC_RATEVHT4SS_MCS0;
559 rate_order -= DESC_RATEVHT3SS_MCS0;
561 rate_order -= DESC_RATEVHT2SS_MCS0;
563 rate_order -= DESC_RATEVHT1SS_MCS0;
565 rate_order -= DESC_RATEMCS24;
567 rate_order -= DESC_RATEMCS16;
569 rate_order -= DESC_RATEMCS8;
571 rate_order -= DESC_RATEMCS0;
573 rate_order -= DESC_RATE6M;
575 rate_order -= DESC_RATE1M;
580 return GENMASK(rate_order + RRSR_RATE_ORDER_CCK_LEN - 1, 0);
586 struct rtw_sta_info *si = (struct rtw_sta_info *)sta->drv_priv;
587 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
590 mask = rtw_phy_get_rrsr_mask(rtwdev, si->ra_report.desc_rate);
591 if (mask < dm_info->rrsr_mask_min)
592 dm_info->rrsr_mask_min = mask;
597 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
599 dm_info->rrsr_mask_min = RRSR_RATE_ORDER_MAX;
601 rtw_write32(rtwdev, REG_RRSR, dm_info->rrsr_val_init & dm_info->rrsr_mask_min);
606 const struct rtw_chip_info *chip = rtwdev->chip;
608 if (chip->ops->dpk_track)
609 chip->ops->dpk_track(rtwdev);
623 struct rtw_dev *rtwdev = iter_data->rtwdev;
624 struct rtw_rx_pkt_stat *pkt_stat = iter_data->pkt_stat;
625 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
626 struct rtw_cfo_track *cfo = &dm_info->cfo_track;
627 u8 *bssid = iter_data->bssid;
630 if (!ether_addr_equal(vif->bss_conf.bssid, bssid))
633 for (i = 0; i < rtwdev->hal.rf_path_num; i++) {
634 cfo->cfo_tail[i] += pkt_stat->cfo_tail[i];
635 cfo->cfo_cnt[i]++;
638 cfo->packet_count++;
644 struct ieee80211_hdr *hdr = pkt_stat->hdr;
647 if (pkt_stat->crc_err || pkt_stat->icv_err || !pkt_stat->phy_status ||
648 ieee80211_is_ctl(hdr->frame_control))
662 const struct rtw_chip_info *chip = rtwdev->chip;
664 if (chip->ops->cfo_track)
665 chip->ops->cfo_track(rtwdev);
673 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
674 u32 cck_fa_avg = dm_info->cck_fa_avg;
694 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
695 u8 igi = dm_info->igi_history[0];
696 u8 rssi = dm_info->min_rssi;
697 u32 cck_fa_avg = dm_info->cck_fa_avg;
723 const struct rtw_chip_info *chip = rtwdev->chip;
724 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
725 u32 cck_fa = dm_info->cck_fa_cnt;
728 if (rtwdev->hal.current_band_type != RTW_BAND_2G)
731 if (dm_info->cck_fa_avg == CCK_FA_AVG_RESET)
732 dm_info->cck_fa_avg = cck_fa;
734 dm_info->cck_fa_avg = (dm_info->cck_fa_avg * 3 + cck_fa) >> 2;
737 dm_info->igi_history[0], dm_info->min_rssi,
738 dm_info->fa_history[0]);
740 dm_info->cck_fa_avg, dm_info->cck_pd_default);
747 if (chip->ops->cck_pd_set)
748 chip->ops->cck_pd_set(rtwdev, level);
753 rtwdev->chip->ops->pwr_track(rtwdev);
775 if (rtw_fw_feature_check(&rtwdev->fw, FW_FEATURE_ADAPTIVITY))
785 if (power <= -100 || power >= 20)
803 /* 1dB ~ 96dB */
804 i = (power_db - 1) >> 3;
805 j = (power_db - 1) - (i << 3);
817 u32 dB;
828 return 96; /* maximum 96 dB */
836 if (db_invert_table[i][0] - linear >
837 linear - db_invert_table[i - 1][7]) {
838 i = i - 1;
842 if (db_invert_table[3][0] - linear >
843 linear - db_invert_table[2][7]) {
849 if (db_invert_table[i][j] - linear >
850 linear - db_invert_table[i][j - 1]) {
851 j = j - 1;
855 dB = (i << 3) + j + 1;
857 return dB;
875 sum = (sum + (1 << (FRAC_BITS - 1))) >> FRAC_BITS;
897 struct rtw_hal *hal = &rtwdev->hal;
898 const struct rtw_chip_info *chip = rtwdev->chip;
899 const u32 *base_addr = chip->rf_base_addr;
902 if (rf_path >= hal->rf_phy_num) {
920 struct rtw_hal *hal = &rtwdev->hal;
921 const struct rtw_chip_info *chip = rtwdev->chip;
929 if (rf_path >= hal->rf_phy_num) {
934 if (!chip->rf_sipi_read_addr) {
939 rf_sipi_addr = &chip->rf_sipi_read_addr[rf_path];
940 rf_sipi_addr_a = &chip->rf_sipi_read_addr[RF_PATH_A];
944 val32 = rtw_read32(rtwdev, rf_sipi_addr->hssi_2);
946 rtw_write32(rtwdev, rf_sipi_addr->hssi_2, val32);
949 val32 = rtw_read32(rtwdev, rf_sipi_addr_a->hssi_2);
950 rtw_write32(rtwdev, rf_sipi_addr_a->hssi_2, val32 & ~LSSI_READ_EDGE_MASK);
951 rtw_write32(rtwdev, rf_sipi_addr_a->hssi_2, val32 | LSSI_READ_EDGE_MASK);
953 udelay(120);
955 en_pi = rtw_read32_mask(rtwdev, rf_sipi_addr->hssi_1, BIT(8));
956 r_addr = en_pi ? rf_sipi_addr->lssi_read_pi : rf_sipi_addr->lssi_read;
969 struct rtw_hal *hal = &rtwdev->hal;
970 const struct rtw_chip_info *chip = rtwdev->chip;
971 const u32 *sipi_addr = chip->rf_sipi_addr;
976 if (rf_path >= hal->rf_phy_num) {
985 old_data = chip->ops->read_rf(rtwdev, rf_path, addr, RFREG_MASK);
1009 struct rtw_hal *hal = &rtwdev->hal;
1010 const struct rtw_chip_info *chip = rtwdev->chip;
1011 const u32 *base_addr = chip->rf_base_addr;
1014 if (rf_path >= hal->rf_phy_num) {
1042 struct rtw_hal *hal = &rtwdev->hal;
1043 struct rtw_efuse *efuse = &rtwdev->efuse;
1046 cond.cut = hal->cut_version ? hal->cut_version : 15;
1049 cond.rfe = efuse->rfe_option;
1064 hal->phy_cond = cond;
1066 rtw_dbg(rtwdev, RTW_DBG_PHY, "phy cond=0x%08x\n", *((u32 *)&hal->phy_cond));
1071 struct rtw_hal *hal = &rtwdev->hal;
1072 struct rtw_phy_cond drv_cond = hal->phy_cond;
1091 const union phy_table_tile *p = tbl->data;
1092 const union phy_table_tile *end = p + tbl->size / 2;
1099 if (p->cond.pos) {
1100 switch (p->cond.branch) {
1111 pos_cond = p->cond;
1114 } else if (p->cond.neg) {
1127 (*tbl->do_cfg)(rtwdev, tbl, p->cfg.addr, p->cfg.data);
1137 if (rtwdev->chip->is_pwr_by_rate_dec)
1182 pwr_by_rate[i - 1] =
1236 pwr_by_rate[i - 1] = tbl_to_dec_pwr_by_rate(rtwdev,
1452 struct rtw_hal *hal = &rtwdev->hal;
1472 hal->tx_pwr_by_rate_offset_2g[rfpath][rate] = offset;
1474 hal->tx_pwr_by_rate_offset_5g[rfpath][rate] = offset;
1482 const struct rtw_phy_pg_cfg_pair *p = tbl->data;
1483 const struct rtw_phy_pg_cfg_pair *end = p + tbl->size;
1486 if (p->addr == 0xfe || p->addr == 0xffe) {
1490 rtw_phy_store_tx_power_by_rate(rtwdev, p->band, p->rf_path,
1491 p->tx_num, p->addr, p->bitmask,
1492 p->data);
1501 116, 118, 120, 122, 124, 126, 128, /* Band 3 */
1512 ch_idx = channel - 1;
1520 return -1;
1524 return -1;
1532 struct rtw_hal *hal = &rtwdev->hal;
1533 u8 max_power_index = rtwdev->chip->max_power_index;
1538 -max_power_index, max_power_index);
1550 hal->tx_pwr_limit_2g[regd][bw][rs][ch_idx] = pwr_limit;
1551 ww = hal->tx_pwr_limit_2g[RTW_REGD_WW][bw][rs][ch_idx];
1553 hal->tx_pwr_limit_2g[RTW_REGD_WW][bw][rs][ch_idx] = ww;
1555 hal->tx_pwr_limit_5g[regd][bw][rs][ch_idx] = pwr_limit;
1556 ww = hal->tx_pwr_limit_5g[RTW_REGD_WW][bw][rs][ch_idx];
1558 hal->tx_pwr_limit_5g[RTW_REGD_WW][bw][rs][ch_idx] = ww;
1562 /* cross-reference 5G power limits if values are not assigned */
1567 struct rtw_hal *hal = &rtwdev->hal;
1568 u8 max_power_index = rtwdev->chip->max_power_index;
1569 s8 lmt_ht = hal->tx_pwr_limit_5g[regd][bw][rs_ht][ch_idx];
1570 s8 lmt_vht = hal->tx_pwr_limit_5g[regd][bw][rs_vht][ch_idx];
1576 hal->tx_pwr_limit_5g[regd][bw][rs_ht][ch_idx] = lmt_vht;
1579 hal->tx_pwr_limit_5g[regd][bw][rs_vht][ch_idx] = lmt_ht;
1582 /* cross-reference power limits for ht and vht */
1598 /* cross-reference power limits for 5G channels */
1608 /* cross-reference power limits for 20/40M bandwidth */
1618 /* cross-reference power limits */
1633 hal->tx_pwr_limit_2g[regd][bw][rs][ch] =
1634 hal->tx_pwr_limit_2g[regd_alt][bw][rs][ch];
1637 hal->tx_pwr_limit_5g[regd][bw][rs][ch] =
1638 hal->tx_pwr_limit_5g[regd_alt][bw][rs][ch];
1648 __cfg_txpwr_lmt_by_alt(&rtwdev->hal, regd, regd_alt,
1655 const struct rtw_txpwr_lmt_cfg_pair *p = tbl->data;
1656 const struct rtw_txpwr_lmt_cfg_pair *end = p + tbl->size;
1662 regd_cfg_flag |= BIT(p->regd);
1663 rtw_phy_set_tx_power_limit(rtwdev, p->regd, p->band,
1664 p->bw, p->rs, p->ch, p->txpwr_lmt);
1737 rtw_write_rf(rtwdev, tbl->rf_path, addr, RFREG_MASK, data);
1745 const struct rtw_chip_info *chip = rtwdev->chip;
1746 struct rtw_dpk_info *dpk_info = &rtwdev->dm_info.dpk_info;
1748 if (!chip->rfk_init_tbl)
1757 rtw_load_table(rtwdev, chip->rfk_init_tbl);
1759 dpk_info->is_dpk_pwr_on = true;
1765 const struct rtw_chip_info *chip = rtwdev->chip;
1768 rtw_load_table(rtwdev, chip->mac_tbl);
1769 rtw_load_table(rtwdev, chip->bb_tbl);
1770 rtw_load_table(rtwdev, chip->agc_tbl);
1771 if (rfe_def->agc_btg_tbl)
1772 rtw_load_table(rtwdev, rfe_def->agc_btg_tbl);
1775 for (rf_path = 0; rf_path < rtwdev->hal.rf_path_num; rf_path++) {
1778 tbl = chip->rf_tbl[rf_path];
1836 case 120:
1876 const struct rtw_chip_info *chip = rtwdev->chip;
1879 if (!chip->en_dis_dpd)
1884 if (DIS_DPD_RATE ## _rate & chip->dpd_ratemask) \
1885 dpd_diff = -6 * chip->txgi_factor; \
1910 const struct rtw_chip_info *chip = rtwdev->chip;
1914 u8 factor = chip->txgi_factor;
1917 tx_power = pwr_idx_2g->cck_base[group];
1919 tx_power = pwr_idx_2g->bw40_base[group];
1922 tx_power += pwr_idx_2g->ht_1s_diff.ofdm * factor;
1938 tx_power += pwr_idx_2g->ht_1s_diff.bw20 * factor;
1940 tx_power += pwr_idx_2g->ht_2s_diff.bw20 * factor;
1945 tx_power += pwr_idx_2g->ht_2s_diff.bw40 * factor;
1957 const struct rtw_chip_info *chip = rtwdev->chip;
1962 u8 factor = chip->txgi_factor;
1964 tx_power = pwr_idx_5g->bw40_base[group];
1973 tx_power += pwr_idx_5g->ht_1s_diff.ofdm * factor;
1982 tx_power += pwr_idx_5g->ht_1s_diff.bw20 * factor;
1984 tx_power += pwr_idx_5g->ht_2s_diff.bw20 * factor;
1989 tx_power += pwr_idx_5g->ht_2s_diff.bw40 * factor;
1992 /* the base idx of bw80 is the average of bw40+/bw40- */
1993 lower = pwr_idx_5g->bw40_base[group];
1994 upper = pwr_idx_5g->bw40_base[group + 1];
1997 tx_power += pwr_idx_5g->vht_1s_diff.bw80 * factor;
1999 tx_power += pwr_idx_5g->vht_2s_diff.bw80 * factor;
2029 struct rtw_hal *hal = &rtwdev->hal;
2030 u8 *cch_by_bw = hal->cch_by_bw;
2031 s8 power_limit = (s8)rtwdev->chip->max_power_index;
2060 hal->tx_pwr_limit_2g[regd][cur_bw][rs][ch_idx] :
2061 hal->tx_pwr_limit_5g[regd][cur_bw][rs][ch_idx];
2071 return (s8)rtwdev->chip->max_power_index;
2092 return (s8)rtwdev->chip->max_power_index;
2098 struct rtw_hal *hal = &rtwdev->hal;
2099 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2102 u8 *base = &pwr_param->pwr_base;
2103 s8 *offset = &pwr_param->pwr_offset;
2104 s8 *limit = &pwr_param->pwr_limit;
2105 s8 *remnant = &pwr_param->pwr_remnant;
2106 s8 *sar = &pwr_param->pwr_sar;
2108 pwr_idx = &rtwdev->efuse.txpwr_idx_table[path];
2115 &pwr_idx->pwr_idx_2g,
2117 *offset = hal->tx_pwr_by_rate_offset_2g[path][rate];
2121 &pwr_idx->pwr_idx_5g,
2123 *offset = hal->tx_pwr_by_rate_offset_5g[path][rate];
2128 *remnant = (rate <= DESC_RATE11M ? dm_info->txagc_remnant_cck :
2129 dm_info->txagc_remnant_ofdm);
2130 *sar = rtw_phy_get_tx_power_sar(rtwdev, hal->sar_band, path, rate);
2149 if (rtwdev->chip->en_dis_dpd)
2154 if (tx_power > rtwdev->chip->max_power_index)
2155 tx_power = rtwdev->chip->max_power_index;
2164 struct rtw_hal *hal = &rtwdev->hal;
2178 bw = hal->current_band_width;
2183 hal->tx_pwr_tbl[path][rate] = pwr_idx;
2189 * power index into a four-byte power index register, and calls set_tx_agc to
2195 struct rtw_hal *hal = &rtwdev->hal;
2199 if (hal->current_band_type == RTW_BAND_2G)
2210 const struct rtw_chip_info *chip = rtwdev->chip;
2211 struct rtw_hal *hal = &rtwdev->hal;
2214 mutex_lock(&hal->tx_power_mutex);
2216 for (path = 0; path < hal->rf_path_num; path++)
2219 chip->ops->set_tx_power_index(rtwdev);
2220 mutex_unlock(&hal->tx_power_mutex);
2233 base_idx = rates[size - 3];
2235 base_idx = rates[size - 1];
2236 base_2g = hal->tx_pwr_by_rate_offset_2g[path][base_idx];
2237 base_5g = hal->tx_pwr_by_rate_offset_5g[path][base_idx];
2238 hal->tx_pwr_by_rate_base_2g[path][rs] = base_2g;
2239 hal->tx_pwr_by_rate_base_5g[path][rs] = base_5g;
2242 hal->tx_pwr_by_rate_offset_2g[path][rate_idx] -= base_2g;
2243 hal->tx_pwr_by_rate_offset_5g[path][rate_idx] -= base_5g;
2280 base = hal->tx_pwr_by_rate_base_2g[0][rs];
2281 hal->tx_pwr_limit_2g[regd][bw][rs][ch] -= base;
2285 base = hal->tx_pwr_by_rate_base_5g[0][rs];
2286 hal->tx_pwr_limit_5g[regd][bw][rs][ch] -= base;
2295 hal->cch_by_bw[RTW_CHANNEL_WIDTH_20] = 1;
2306 struct rtw_hal *hal = &rtwdev->hal;
2307 s8 max_power_index = (s8)rtwdev->chip->max_power_index;
2312 hal->tx_pwr_limit_2g[regd][bw][rs][ch] = max_power_index;
2316 hal->tx_pwr_limit_5g[regd][bw][rs][ch] = max_power_index;
2321 struct rtw_hal *hal = &rtwdev->hal;
2327 hal->tx_pwr_by_rate_offset_2g[path][rate] = 0;
2328 hal->tx_pwr_by_rate_offset_5g[path][rate] = 0;
2343 const struct rtw_pwr_track_tbl *tbl = rtwdev->chip->pwr_track_tbl;
2344 u8 channel = rtwdev->hal.current_channel;
2347 if (rtwdev->dm_info.tx_rate <= DESC_RATE11M) {
2348 swing_table->p[RF_PATH_A] = tbl->pwrtrk_2g_ccka_p;
2349 swing_table->n[RF_PATH_A] = tbl->pwrtrk_2g_ccka_n;
2350 swing_table->p[RF_PATH_B] = tbl->pwrtrk_2g_cckb_p;
2351 swing_table->n[RF_PATH_B] = tbl->pwrtrk_2g_cckb_n;
2353 swing_table->p[RF_PATH_A] = tbl->pwrtrk_2ga_p;
2354 swing_table->n[RF_PATH_A] = tbl->pwrtrk_2ga_n;
2355 swing_table->p[RF_PATH_B] = tbl->pwrtrk_2gb_p;
2356 swing_table->n[RF_PATH_B] = tbl->pwrtrk_2gb_n;
2359 swing_table->p[RF_PATH_A] = tbl->pwrtrk_5ga_p[RTW_PWR_TRK_5G_1];
2360 swing_table->n[RF_PATH_A] = tbl->pwrtrk_5ga_n[RTW_PWR_TRK_5G_1];
2361 swing_table->p[RF_PATH_B] = tbl->pwrtrk_5gb_p[RTW_PWR_TRK_5G_1];
2362 swing_table->n[RF_PATH_B] = tbl->pwrtrk_5gb_n[RTW_PWR_TRK_5G_1];
2364 swing_table->p[RF_PATH_A] = tbl->pwrtrk_5ga_p[RTW_PWR_TRK_5G_2];
2365 swing_table->n[RF_PATH_A] = tbl->pwrtrk_5ga_n[RTW_PWR_TRK_5G_2];
2366 swing_table->p[RF_PATH_B] = tbl->pwrtrk_5gb_p[RTW_PWR_TRK_5G_2];
2367 swing_table->n[RF_PATH_B] = tbl->pwrtrk_5gb_n[RTW_PWR_TRK_5G_2];
2369 swing_table->p[RF_PATH_A] = tbl->pwrtrk_5ga_p[RTW_PWR_TRK_5G_3];
2370 swing_table->n[RF_PATH_A] = tbl->pwrtrk_5ga_n[RTW_PWR_TRK_5G_3];
2371 swing_table->p[RF_PATH_B] = tbl->pwrtrk_5gb_p[RTW_PWR_TRK_5G_3];
2372 swing_table->n[RF_PATH_B] = tbl->pwrtrk_5gb_n[RTW_PWR_TRK_5G_3];
2374 swing_table->p[RF_PATH_A] = tbl->pwrtrk_2ga_p;
2375 swing_table->n[RF_PATH_A] = tbl->pwrtrk_2ga_n;
2376 swing_table->p[RF_PATH_B] = tbl->pwrtrk_2gb_p;
2377 swing_table->n[RF_PATH_B] = tbl->pwrtrk_2gb_n;
2384 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2386 ewma_thermal_add(&dm_info->avg_thermal[path], thermal);
2387 dm_info->thermal_avg[path] =
2388 ewma_thermal_read(&dm_info->avg_thermal[path]);
2395 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2396 u8 avg = ewma_thermal_read(&dm_info->avg_thermal[path]);
2407 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2410 therm_avg = dm_info->thermal_avg[path];
2411 therm_efuse = rtwdev->efuse.thermal_meter[path];
2412 therm_delta = abs(therm_avg - therm_efuse);
2414 return min_t(u8, therm_delta, RTW_PWR_TRK_TBL_SZ - 1);
2422 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2436 delta_swing_table_idx_pos = swing_table->p[tbl_path];
2437 delta_swing_table_idx_neg = swing_table->n[tbl_path];
2444 if (dm_info->thermal_avg[therm_path] >
2445 rtwdev->efuse.thermal_meter[therm_path])
2448 return -delta_swing_table_idx_neg[delta];
2454 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2457 delta_lck = abs(dm_info->thermal_avg[0] - dm_info->thermal_meter_lck);
2458 if (delta_lck >= rtwdev->chip->lck_threshold) {
2459 dm_info->thermal_meter_lck = dm_info->thermal_avg[0];
2468 struct rtw_dm_info *dm_info = &rtwdev->dm_info;
2471 delta_iqk = abs(dm_info->thermal_avg[0] - dm_info->thermal_meter_k);
2472 if (delta_iqk >= rtwdev->chip->iqk_threshold) {
2473 dm_info->thermal_meter_k = dm_info->thermal_avg[0];
2483 struct rtw_path_div *path_div = &rtwdev->dm_path_div;
2485 const struct rtw_chip_info *chip = rtwdev->chip;
2487 if (tx_path_sel_1ss == path_div->current_tx_path)
2490 path_div->current_tx_path = tx_path_sel_1ss;
2493 chip->ops->config_tx_path(rtwdev, rtwdev->hal.antenna_tx,
2499 struct rtw_path_div *path_div = &rtwdev->dm_path_div;
2500 enum rtw_bb_path path = path_div->current_tx_path;
2503 if (path_div->path_a_cnt)
2504 rssi_a = path_div->path_a_sum / path_div->path_a_cnt;
2507 if (path_div->path_b_cnt)
2508 rssi_b = path_div->path_b_sum / path_div->path_b_cnt;
2515 path_div->path_a_cnt = 0;
2516 path_div->path_a_sum = 0;
2517 path_div->path_b_cnt = 0;
2518 path_div->path_b_sum = 0;
2524 if (rtwdev->hal.antenna_rx != BB_PATH_AB) {
2527 rtwdev->hal.antenna_tx, rtwdev->hal.antenna_rx);
2530 if (rtwdev->sta_cnt == 0) {
2540 const struct rtw_chip_info *chip = rtwdev->chip;
2542 if (!chip->path_div_supported)