Commit 31f12cff authored by Ching-Te Ku's avatar Ching-Te Ku Committed by Kalle Valo

wifi: rtw89: coex: refactor _chk_btc_report() to extend more features

Change the checking logic to switch case. Make the code more readable.
There are more feature including to common code, in order to commit the
following version of the features, switch case will make the logic more
clearly. This patch did not change logic.
Signed-off-by: default avatarChing-Te Ku <ku920601@realtek.com>
Signed-off-by: default avatarPing-Ke Shih <pkshih@realtek.com>
Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20221217141745.43291-7-pkshih@realtek.com
parent 0cdfcfce
...@@ -1006,7 +1006,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1006,7 +1006,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
struct rtw89_btc_fbtc_cysta_v1 *pcysta_v1 = NULL; struct rtw89_btc_fbtc_cysta_v1 *pcysta_v1 = NULL;
struct rtw89_btc_fbtc_cysta_cpu pcysta[1]; struct rtw89_btc_fbtc_cysta_cpu pcysta[1];
struct rtw89_btc_prpt *btc_prpt = NULL; struct rtw89_btc_prpt *btc_prpt = NULL;
struct rtw89_btc_fbtc_slot *rtp_slot = NULL;
void *rpt_content = NULL, *pfinfo = NULL; void *rpt_content = NULL, *pfinfo = NULL;
u8 rpt_type = 0; u8 rpt_type = 0;
u16 wl_slot_set = 0, wl_slot_real = 0; u16 wl_slot_set = 0, wl_slot_real = 0;
...@@ -1043,8 +1042,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1043,8 +1042,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
pcinfo->req_len = sizeof(pfwinfo->rpt_ctrl.finfo_v1); pcinfo->req_len = sizeof(pfwinfo->rpt_ctrl.finfo_v1);
} }
pcinfo->req_fver = ver->fcxbtcrpt; pcinfo->req_fver = ver->fcxbtcrpt;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_TDMA: case BTC_RPT_TYPE_TDMA:
pcinfo = &pfwinfo->rpt_fbtc_tdma.cinfo; pcinfo = &pfwinfo->rpt_fbtc_tdma.cinfo;
...@@ -1056,16 +1053,12 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1056,16 +1053,12 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_tdma.finfo_v1); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_tdma.finfo_v1);
} }
pcinfo->req_fver = ver->fcxtdma; pcinfo->req_fver = ver->fcxtdma;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_SLOT: case BTC_RPT_TYPE_SLOT:
pcinfo = &pfwinfo->rpt_fbtc_slots.cinfo; pcinfo = &pfwinfo->rpt_fbtc_slots.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_slots.finfo; pfinfo = &pfwinfo->rpt_fbtc_slots.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_slots.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_slots.finfo);
pcinfo->req_fver = ver->fcxslots; pcinfo->req_fver = ver->fcxslots;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_CYSTA: case BTC_RPT_TYPE_CYSTA:
pcinfo = &pfwinfo->rpt_fbtc_cysta.cinfo; pcinfo = &pfwinfo->rpt_fbtc_cysta.cinfo;
...@@ -1080,8 +1073,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1080,8 +1073,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_cysta.finfo_v1); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_cysta.finfo_v1);
} }
pcinfo->req_fver = ver->fcxcysta; pcinfo->req_fver = ver->fcxcysta;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_STEP: case BTC_RPT_TYPE_STEP:
pcinfo = &pfwinfo->rpt_fbtc_step.cinfo; pcinfo = &pfwinfo->rpt_fbtc_step.cinfo;
...@@ -1097,8 +1088,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1097,8 +1088,6 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
offsetof(struct rtw89_btc_fbtc_steps_v1, step); offsetof(struct rtw89_btc_fbtc_steps_v1, step);
} }
pcinfo->req_fver = ver->fcxstep; pcinfo->req_fver = ver->fcxstep;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_NULLSTA: case BTC_RPT_TYPE_NULLSTA:
pcinfo = &pfwinfo->rpt_fbtc_nullsta.cinfo; pcinfo = &pfwinfo->rpt_fbtc_nullsta.cinfo;
...@@ -1110,40 +1099,30 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1110,40 +1099,30 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_nullsta.finfo_v1); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_nullsta.finfo_v1);
} }
pcinfo->req_fver = ver->fcxnullsta; pcinfo->req_fver = ver->fcxnullsta;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_MREG: case BTC_RPT_TYPE_MREG:
pcinfo = &pfwinfo->rpt_fbtc_mregval.cinfo; pcinfo = &pfwinfo->rpt_fbtc_mregval.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_mregval.finfo; pfinfo = &pfwinfo->rpt_fbtc_mregval.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_mregval.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_mregval.finfo);
pcinfo->req_fver = ver->fcxmreg; pcinfo->req_fver = ver->fcxmreg;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_GPIO_DBG: case BTC_RPT_TYPE_GPIO_DBG:
pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo; pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_gpio_dbg.finfo; pfinfo = &pfwinfo->rpt_fbtc_gpio_dbg.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_gpio_dbg.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_gpio_dbg.finfo);
pcinfo->req_fver = ver->fcxgpiodbg; pcinfo->req_fver = ver->fcxgpiodbg;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_BT_VER: case BTC_RPT_TYPE_BT_VER:
pcinfo = &pfwinfo->rpt_fbtc_btver.cinfo; pcinfo = &pfwinfo->rpt_fbtc_btver.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_btver.finfo; pfinfo = &pfwinfo->rpt_fbtc_btver.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btver.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btver.finfo);
pcinfo->req_fver = ver->fcxbtver; pcinfo->req_fver = ver->fcxbtver;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_BT_SCAN: case BTC_RPT_TYPE_BT_SCAN:
pcinfo = &pfwinfo->rpt_fbtc_btscan.cinfo; pcinfo = &pfwinfo->rpt_fbtc_btscan.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_btscan.finfo; pfinfo = &pfwinfo->rpt_fbtc_btscan.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btscan.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btscan.finfo);
pcinfo->req_fver = ver->fcxbtscan; pcinfo->req_fver = ver->fcxbtscan;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_BT_AFH: case BTC_RPT_TYPE_BT_AFH:
pcinfo = &pfwinfo->rpt_fbtc_btafh.cinfo; pcinfo = &pfwinfo->rpt_fbtc_btafh.cinfo;
...@@ -1157,22 +1136,21 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1157,22 +1136,21 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
goto err; goto err;
} }
pcinfo->req_fver = ver->fcxbtafh; pcinfo->req_fver = ver->fcxbtafh;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
case BTC_RPT_TYPE_BT_DEVICE: case BTC_RPT_TYPE_BT_DEVICE:
pcinfo = &pfwinfo->rpt_fbtc_btdev.cinfo; pcinfo = &pfwinfo->rpt_fbtc_btdev.cinfo;
pfinfo = &pfwinfo->rpt_fbtc_btdev.finfo; pfinfo = &pfwinfo->rpt_fbtc_btdev.finfo;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btdev.finfo); pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btdev.finfo);
pcinfo->req_fver = ver->fcxbtdevinfo; pcinfo->req_fver = ver->fcxbtdevinfo;
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
break; break;
default: default:
pfwinfo->err[BTFRE_UNDEF_TYPE]++; pfwinfo->err[BTFRE_UNDEF_TYPE]++;
return 0; return 0;
} }
pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++;
if (rpt_len != pcinfo->req_len) { if (rpt_len != pcinfo->req_len) {
if (rpt_type < BTC_RPT_TYPE_MAX) if (rpt_type < BTC_RPT_TYPE_MAX)
pfwinfo->len_mismch |= (0x1 << rpt_type); pfwinfo->len_mismch |= (0x1 << rpt_type);
...@@ -1193,227 +1171,170 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1193,227 +1171,170 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
memcpy(pfinfo, rpt_content, pcinfo->req_len); memcpy(pfinfo, rpt_content, pcinfo->req_len);
pcinfo->valid = 1; pcinfo->valid = 1;
if (rpt_type == BTC_RPT_TYPE_TDMA && chip->chip_id == RTL8852A) { switch (rpt_type) {
rtw89_debug(rtwdev, RTW89_DBG_BTC, case BTC_RPT_TYPE_CTRL:
"[BTC], %s(): check %d %zu\n", __func__, if (chip->chip_id == RTL8852A) {
BTC_DCNT_TDMA_NONSYNC, sizeof(dm->tdma_now)); prpt = &pfwinfo->rpt_ctrl.finfo;
btc->fwinfo.rpt_en_map = prpt->rpt_enable;
if (memcmp(&dm->tdma_now, &pfwinfo->rpt_fbtc_tdma.finfo, wl->ver_info.fw_coex = prpt->wl_fw_coex_ver;
sizeof(dm->tdma_now)) != 0) { wl->ver_info.fw = prpt->wl_fw_ver;
rtw89_debug(rtwdev, RTW89_DBG_BTC, dm->wl_fw_cx_offload = !!prpt->wl_fw_cx_offload;
"[BTC], %s(): %d tdma_now %x %x %x %x %x %x %x %x\n",
__func__, BTC_DCNT_TDMA_NONSYNC, _chk_btc_err(rtwdev, BTC_DCNT_RPT_FREEZE,
dm->tdma_now.type, dm->tdma_now.rxflctrl, pfwinfo->event[BTF_EVNT_RPT]);
dm->tdma_now.txpause, dm->tdma_now.wtgle_n,
dm->tdma_now.leak_n, dm->tdma_now.ext_ctrl, /* To avoid I/O if WL LPS or power-off */
dm->tdma_now.rxflctrl_role, if (wl->status.map.lps != BTC_LPS_RF_OFF &&
dm->tdma_now.option_ctrl); !wl->status.map.rf_off) {
rtwdev->chip->ops->btc_update_bt_cnt(rtwdev);
rtw89_debug(rtwdev, RTW89_DBG_BTC, _chk_btc_err(rtwdev, BTC_DCNT_BTCNT_FREEZE, 0);
"[BTC], %s(): %d rpt_fbtc_tdma %x %x %x %x %x %x %x %x\n",
__func__, BTC_DCNT_TDMA_NONSYNC, btc->cx.cnt_bt[BTC_BCNT_POLUT] =
pfwinfo->rpt_fbtc_tdma.finfo.type, rtw89_mac_get_plt_cnt(rtwdev,
pfwinfo->rpt_fbtc_tdma.finfo.rxflctrl, RTW89_MAC_0);
pfwinfo->rpt_fbtc_tdma.finfo.txpause, }
pfwinfo->rpt_fbtc_tdma.finfo.wtgle_n, } else {
pfwinfo->rpt_fbtc_tdma.finfo.leak_n, prpt_v1 = &pfwinfo->rpt_ctrl.finfo_v1;
pfwinfo->rpt_fbtc_tdma.finfo.ext_ctrl, btc->fwinfo.rpt_en_map = le32_to_cpu(prpt_v1->rpt_info.en);
pfwinfo->rpt_fbtc_tdma.finfo.rxflctrl_role, wl->ver_info.fw_coex = le32_to_cpu(prpt_v1->wl_fw_info.cx_ver);
pfwinfo->rpt_fbtc_tdma.finfo.option_ctrl); wl->ver_info.fw = le32_to_cpu(prpt_v1->wl_fw_info.fw_ver);
} dm->wl_fw_cx_offload = !!le32_to_cpu(prpt_v1->wl_fw_info.cx_offload);
for (i = RTW89_PHY_0; i < RTW89_PHY_MAX; i++)
memcpy(&dm->gnt.band[i], &prpt_v1->gnt_val[i],
sizeof(dm->gnt.band[i]));
btc->cx.cnt_bt[BTC_BCNT_HIPRI_TX] =
le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_HI_TX]);
btc->cx.cnt_bt[BTC_BCNT_HIPRI_RX] =
le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_HI_RX]);
btc->cx.cnt_bt[BTC_BCNT_LOPRI_TX] =
le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_LO_TX]);
btc->cx.cnt_bt[BTC_BCNT_LOPRI_RX] =
le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_LO_RX]);
btc->cx.cnt_bt[BTC_BCNT_POLUT] =
le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_POLLUTED]);
_chk_btc_err(rtwdev, BTC_DCNT_TDMA_NONSYNC, _chk_btc_err(rtwdev, BTC_DCNT_BTCNT_FREEZE, 0);
memcmp(&dm->tdma_now, _chk_btc_err(rtwdev, BTC_DCNT_RPT_FREEZE,
&pfwinfo->rpt_fbtc_tdma.finfo, pfwinfo->event[BTF_EVNT_RPT]);
sizeof(dm->tdma_now)));
} else if (rpt_type == BTC_RPT_TYPE_TDMA) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): check %d %zu\n", __func__,
BTC_DCNT_TDMA_NONSYNC, sizeof(dm->tdma_now));
if (memcmp(&dm->tdma_now, &pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma,
sizeof(dm->tdma_now)) != 0) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): %d tdma_now %x %x %x %x %x %x %x %x\n",
__func__, BTC_DCNT_TDMA_NONSYNC,
dm->tdma_now.type, dm->tdma_now.rxflctrl,
dm->tdma_now.txpause, dm->tdma_now.wtgle_n,
dm->tdma_now.leak_n, dm->tdma_now.ext_ctrl,
dm->tdma_now.rxflctrl_role,
dm->tdma_now.option_ctrl);
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): %d rpt_fbtc_tdma %x %x %x %x %x %x %x %x\n",
__func__, BTC_DCNT_TDMA_NONSYNC,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.type,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.rxflctrl,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.txpause,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.wtgle_n,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.leak_n,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.ext_ctrl,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.rxflctrl_role,
pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma.option_ctrl);
}
_chk_btc_err(rtwdev, BTC_DCNT_TDMA_NONSYNC, if (le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_RFK_TIMEOUT]) > 0)
memcmp(&dm->tdma_now, bt->rfk_info.map.timeout = 1;
&pfwinfo->rpt_fbtc_tdma.finfo_v1.tdma, else
sizeof(dm->tdma_now))); bt->rfk_info.map.timeout = 0;
}
if (rpt_type == BTC_RPT_TYPE_SLOT) { dm->error.map.bt_rfk_timeout = bt->rfk_info.map.timeout;
}
break;
case BTC_RPT_TYPE_TDMA:
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): check %d %zu\n", __func__,
BTC_DCNT_TDMA_NONSYNC,
sizeof(dm->tdma_now));
if (chip->chip_id == RTL8852A)
_chk_btc_err(rtwdev, BTC_DCNT_TDMA_NONSYNC,
memcmp(&dm->tdma_now,
&pfwinfo->rpt_fbtc_tdma.finfo_v1,
sizeof(dm->tdma_now)));
else
_chk_btc_err(rtwdev, BTC_DCNT_TDMA_NONSYNC,
memcmp(&dm->tdma_now,
&pfwinfo->rpt_fbtc_tdma.finfo,
sizeof(dm->tdma_now)));
break;
case BTC_RPT_TYPE_SLOT:
rtw89_debug(rtwdev, RTW89_DBG_BTC, rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): check %d %zu\n", "[BTC], %s(): check %d %zu\n",
__func__, BTC_DCNT_SLOT_NONSYNC, __func__, BTC_DCNT_SLOT_NONSYNC,
sizeof(dm->slot_now)); sizeof(dm->slot_now));
if (memcmp(dm->slot_now, pfwinfo->rpt_fbtc_slots.finfo.slot,
sizeof(dm->slot_now)) != 0) {
for (i = 0; i < CXST_MAX; i++) {
rtp_slot =
&pfwinfo->rpt_fbtc_slots.finfo.slot[i];
if (memcmp(&dm->slot_now[i], rtp_slot,
sizeof(dm->slot_now[i])) != 0) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): %d slot_now[%d] dur=0x%04x tbl=%08x type=0x%04x\n",
__func__,
BTC_DCNT_SLOT_NONSYNC, i,
dm->slot_now[i].dur,
dm->slot_now[i].cxtbl,
dm->slot_now[i].cxtype);
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): %d rpt_fbtc_slots[%d] dur=0x%04x tbl=%08x type=0x%04x\n",
__func__,
BTC_DCNT_SLOT_NONSYNC, i,
rtp_slot->dur,
rtp_slot->cxtbl,
rtp_slot->cxtype);
}
}
}
_chk_btc_err(rtwdev, BTC_DCNT_SLOT_NONSYNC, _chk_btc_err(rtwdev, BTC_DCNT_SLOT_NONSYNC,
memcmp(dm->slot_now, memcmp(dm->slot_now,
pfwinfo->rpt_fbtc_slots.finfo.slot, pfwinfo->rpt_fbtc_slots.finfo.slot,
sizeof(dm->slot_now))); sizeof(dm->slot_now)));
} break;
case BTC_RPT_TYPE_CYSTA:
if (chip->chip_id == RTL8852A) {
if (pcysta->cycles < BTC_CYSTA_CHK_PERIOD)
break;
/* Check Leak-AP */
if (pcysta->slot_cnt[CXST_LK] != 0 &&
pcysta->leakrx_cnt != 0 && dm->tdma_now.rxflctrl) {
if (pcysta->slot_cnt[CXST_LK] <
BTC_LEAK_AP_TH * pcysta->leakrx_cnt)
dm->leak_ap = 1;
}
if (rpt_type == BTC_RPT_TYPE_CYSTA && chip->chip_id == RTL8852A && /* Check diff time between WL slot and W1/E2G slot */
pcysta->cycles >= BTC_CYSTA_CHK_PERIOD) { if (dm->tdma_now.type == CXTDMA_OFF &&
/* Check Leak-AP */ dm->tdma_now.ext_ctrl == CXECTL_EXT)
if (pcysta->slot_cnt[CXST_LK] != 0 && wl_slot_set = le16_to_cpu(dm->slot_now[CXST_E2G].dur);
pcysta->leakrx_cnt != 0 && dm->tdma_now.rxflctrl) { else
if (pcysta->slot_cnt[CXST_LK] < wl_slot_set = le16_to_cpu(dm->slot_now[CXST_W1].dur);
BTC_LEAK_AP_TH * pcysta->leakrx_cnt)
dm->leak_ap = 1;
}
/* Check diff time between WL slot and W1/E2G slot */ if (pcysta->tavg_cycle[CXT_WL] > wl_slot_set) {
if (dm->tdma_now.type == CXTDMA_OFF && diff_t = pcysta->tavg_cycle[CXT_WL] - wl_slot_set;
dm->tdma_now.ext_ctrl == CXECTL_EXT) _chk_btc_err(rtwdev,
wl_slot_set = le16_to_cpu(dm->slot_now[CXST_E2G].dur); BTC_DCNT_WL_SLOT_DRIFT, diff_t);
else }
wl_slot_set = le16_to_cpu(dm->slot_now[CXST_W1].dur);
if (pcysta->tavg_cycle[CXT_WL] > wl_slot_set) { _chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE,
diff_t = pcysta->tavg_cycle[CXT_WL] - wl_slot_set; pcysta->slot_cnt[CXST_W1]);
_chk_btc_err(rtwdev, BTC_DCNT_WL_SLOT_DRIFT, diff_t); _chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE,
} pcysta->slot_cnt[CXST_B1]);
_chk_btc_err(rtwdev, BTC_DCNT_CYCLE_FREEZE,
(u32)pcysta->cycles);
} else {
if (le16_to_cpu(pcysta_v1->cycles) < BTC_CYSTA_CHK_PERIOD)
break;
_chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE, pcysta->slot_cnt[CXST_W1]); cnt_leak_slot = le32_to_cpu(pcysta_v1->slot_cnt[CXST_LK]);
_chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE, pcysta->slot_cnt[CXST_B1]); cnt_rx_imr = le32_to_cpu(pcysta_v1->leak_slot.cnt_rximr);
_chk_btc_err(rtwdev, BTC_DCNT_CYCLE_FREEZE, (u32)pcysta->cycles);
} else if (rpt_type == BTC_RPT_TYPE_CYSTA && pcysta_v1 &&
le16_to_cpu(pcysta_v1->cycles) >= BTC_CYSTA_CHK_PERIOD) {
cnt_leak_slot = le32_to_cpu(pcysta_v1->slot_cnt[CXST_LK]);
cnt_rx_imr = le32_to_cpu(pcysta_v1->leak_slot.cnt_rximr);
/* Check Leak-AP */
if (cnt_leak_slot != 0 && cnt_rx_imr != 0 &&
dm->tdma_now.rxflctrl) {
if (cnt_leak_slot < BTC_LEAK_AP_TH * cnt_rx_imr)
dm->leak_ap = 1;
}
/* Check diff time between real WL slot and W1 slot */ /* Check Leak-AP */
if (dm->tdma_now.type == CXTDMA_OFF) { if (cnt_leak_slot != 0 && cnt_rx_imr != 0 &&
wl_slot_set = le16_to_cpu(dm->slot_now[CXST_W1].dur); dm->tdma_now.rxflctrl) {
wl_slot_real = le16_to_cpu(pcysta_v1->cycle_time.tavg[CXT_WL]); if (cnt_leak_slot < BTC_LEAK_AP_TH * cnt_rx_imr)
if (wl_slot_real > wl_slot_set) { dm->leak_ap = 1;
diff_t = wl_slot_real - wl_slot_set;
_chk_btc_err(rtwdev, BTC_DCNT_WL_SLOT_DRIFT, diff_t);
} }
}
/* Check diff time between real BT slot and EBT/E5G slot */
if (dm->tdma_now.type == CXTDMA_OFF &&
dm->tdma_now.ext_ctrl == CXECTL_EXT &&
btc->bt_req_len != 0) {
bt_slot_real = le16_to_cpu(pcysta_v1->cycle_time.tavg[CXT_BT]);
if (btc->bt_req_len > bt_slot_real) { /* Check diff time between real WL slot and W1 slot */
diff_t = btc->bt_req_len - bt_slot_real; if (dm->tdma_now.type == CXTDMA_OFF) {
_chk_btc_err(rtwdev, BTC_DCNT_BT_SLOT_DRIFT, diff_t); wl_slot_set = le16_to_cpu(dm->slot_now[CXST_W1].dur);
wl_slot_real = le16_to_cpu(pcysta_v1->cycle_time.tavg[CXT_WL]);
if (wl_slot_real > wl_slot_set) {
diff_t = wl_slot_real - wl_slot_set;
_chk_btc_err(rtwdev, BTC_DCNT_WL_SLOT_DRIFT, diff_t);
}
} }
}
_chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE, /* Check diff time between real BT slot and EBT/E5G slot */
le32_to_cpu(pcysta_v1->slot_cnt[CXST_W1])); if (dm->tdma_now.type == CXTDMA_OFF &&
_chk_btc_err(rtwdev, BTC_DCNT_B1_FREEZE, dm->tdma_now.ext_ctrl == CXECTL_EXT &&
le32_to_cpu(pcysta_v1->slot_cnt[CXST_B1])); btc->bt_req_len != 0) {
_chk_btc_err(rtwdev, BTC_DCNT_CYCLE_FREEZE, bt_slot_real = le16_to_cpu(pcysta_v1->cycle_time.tavg[CXT_BT]);
(u32)le16_to_cpu(pcysta_v1->cycles));
}
if (rpt_type == BTC_RPT_TYPE_CTRL && chip->chip_id == RTL8852A) {
prpt = &pfwinfo->rpt_ctrl.finfo;
btc->fwinfo.rpt_en_map = prpt->rpt_enable;
wl->ver_info.fw_coex = prpt->wl_fw_coex_ver;
wl->ver_info.fw = prpt->wl_fw_ver;
dm->wl_fw_cx_offload = !!prpt->wl_fw_cx_offload;
_chk_btc_err(rtwdev, BTC_DCNT_RPT_FREEZE, if (btc->bt_req_len > bt_slot_real) {
pfwinfo->event[BTF_EVNT_RPT]); diff_t = btc->bt_req_len - bt_slot_real;
_chk_btc_err(rtwdev, BTC_DCNT_BT_SLOT_DRIFT, diff_t);
/* To avoid I/O if WL LPS or power-off */ }
if (wl->status.map.lps != BTC_LPS_RF_OFF && !wl->status.map.rf_off) { }
rtwdev->chip->ops->btc_update_bt_cnt(rtwdev);
_chk_btc_err(rtwdev, BTC_DCNT_BTCNT_FREEZE, 0);
btc->cx.cnt_bt[BTC_BCNT_POLUT] = _chk_btc_err(rtwdev, BTC_DCNT_W1_FREEZE,
rtw89_mac_get_plt_cnt(rtwdev, RTW89_MAC_0); le32_to_cpu(pcysta_v1->slot_cnt[CXST_W1]));
_chk_btc_err(rtwdev, BTC_DCNT_B1_FREEZE,
le32_to_cpu(pcysta_v1->slot_cnt[CXST_B1]));
_chk_btc_err(rtwdev, BTC_DCNT_CYCLE_FREEZE,
(u32)le16_to_cpu(pcysta_v1->cycles));
} }
} else if (rpt_type == BTC_RPT_TYPE_CTRL) { break;
prpt_v1 = &pfwinfo->rpt_ctrl.finfo_v1; case BTC_RPT_TYPE_BT_VER:
btc->fwinfo.rpt_en_map = le32_to_cpu(prpt_v1->rpt_info.en); case BTC_RPT_TYPE_BT_SCAN:
wl->ver_info.fw_coex = le32_to_cpu(prpt_v1->wl_fw_info.cx_ver); case BTC_RPT_TYPE_BT_AFH:
wl->ver_info.fw = le32_to_cpu(prpt_v1->wl_fw_info.fw_ver); case BTC_RPT_TYPE_BT_DEVICE:
dm->wl_fw_cx_offload = !!le32_to_cpu(prpt_v1->wl_fw_info.cx_offload);
for (i = RTW89_PHY_0; i < RTW89_PHY_MAX; i++)
memcpy(&dm->gnt.band[i], &prpt_v1->gnt_val[i],
sizeof(dm->gnt.band[i]));
btc->cx.cnt_bt[BTC_BCNT_HIPRI_TX] = le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_HI_TX]);
btc->cx.cnt_bt[BTC_BCNT_HIPRI_RX] = le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_HI_RX]);
btc->cx.cnt_bt[BTC_BCNT_LOPRI_TX] = le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_LO_TX]);
btc->cx.cnt_bt[BTC_BCNT_LOPRI_RX] = le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_LO_RX]);
btc->cx.cnt_bt[BTC_BCNT_POLUT] = le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_POLLUTED]);
_chk_btc_err(rtwdev, BTC_DCNT_BTCNT_FREEZE, 0);
_chk_btc_err(rtwdev, BTC_DCNT_RPT_FREEZE,
pfwinfo->event[BTF_EVNT_RPT]);
if (le32_to_cpu(prpt_v1->bt_cnt[BTC_BCNT_RFK_TIMEOUT]) > 0)
bt->rfk_info.map.timeout = 1;
else
bt->rfk_info.map.timeout = 0;
dm->error.map.bt_rfk_timeout = bt->rfk_info.map.timeout;
}
if (rpt_type >= BTC_RPT_TYPE_BT_VER &&
rpt_type <= BTC_RPT_TYPE_BT_DEVICE)
_update_bt_report(rtwdev, rpt_type, pfinfo); _update_bt_report(rtwdev, rpt_type, pfinfo);
break;
}
return (rpt_len + BTC_RPT_HDR_SIZE); return (rpt_len + BTC_RPT_HDR_SIZE);
err: err:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment