{
        struct rtw89_btc *btc = &rtwdev->btc;
        struct rtw89_btc_cx *cx = &btc->cx;
-       struct rtw89_btc_dm *dm = &btc->dm;
        struct rtw89_btc_bt_info *bt = &cx->bt;
+       struct rtw89_btc_wl_info *wl = &cx->wl;
+       struct rtw89_btc_dm *dm = &btc->dm;
 
        rtw89_debug(rtwdev, RTW89_DBG_BTC,
                    "[BTC], %s(): type:%d cnt:%d\n",
                    __func__, type, cnt);
 
        switch (type) {
+       case BTC_DCNT_WL_FW_VER_MATCH:
+               if ((wl->ver_info.fw_coex & 0xffff0000) !=
+                    rtwdev->chip->wlcx_desired) {
+                       wl->fw_ver_mismatch = true;
+                       dm->error.map.wl_ver_mismatch = true;
+               } else {
+                       wl->fw_ver_mismatch = false;
+                       dm->error.map.wl_ver_mismatch = false;
+               }
+               break;
        case BTC_DCNT_RPT_HANG:
                if (dm->cnt_dm[BTC_DCNT_RPT] == cnt && btc->fwinfo.rpt_en_map)
                        dm->cnt_dm[BTC_DCNT_RPT_HANG]++;
                else
                        dm->error.map.slot_no_sync = false;
                break;
+       case BTC_DCNT_BTTX_HANG:
+               cnt = cx->cnt_bt[BTC_BCNT_LOPRI_TX];
+
+               if (cnt == 0 && bt->link_info.slave_role)
+                       dm->cnt_dm[BTC_DCNT_BTTX_HANG]++;
+               else
+                       dm->cnt_dm[BTC_DCNT_BTTX_HANG] = 0;
+
+               if (dm->cnt_dm[BTC_DCNT_BTTX_HANG] >= BTC_CHK_HANG_MAX)
+                       dm->error.map.bt_tx_hang = true;
+               else
+                       dm->error.map.bt_tx_hang = false;
+               break;
        case BTC_DCNT_BTCNT_HANG:
                cnt = cx->cnt_bt[BTC_BCNT_HIPRI_RX] +
                      cx->cnt_bt[BTC_BCNT_HIPRI_TX] +
                        pcinfo->req_len = sizeof(pfwinfo->rpt_ctrl.finfo.v105);
                        pcinfo->req_fver = 5;
                        break;
+               } else if (ver->fcxbtcrpt == 8) {
+                       pfinfo = &pfwinfo->rpt_ctrl.finfo.v8;
+                       pcinfo->req_len = sizeof(pfwinfo->rpt_ctrl.finfo.v8);
+                       break;
                } else {
                        goto err;
                }
                                     pfwinfo->event[BTF_EVNT_RPT]);
 
                        dm->error.map.bt_rfk_timeout = bt->rfk_info.map.timeout;
+               } else if (ver->fcxbtcrpt == 8) {
+                       prpt->v8 = pfwinfo->rpt_ctrl.finfo.v8;
+                       pfwinfo->rpt_en_map = le32_to_cpu(prpt->v8.rpt_info.en);
+                       wl->ver_info.fw_coex = le32_to_cpu(prpt->v8.rpt_info.cx_ver);
+                       wl->ver_info.fw = le32_to_cpu(prpt->v8.rpt_info.fw_ver);
+
+                       for (i = RTW89_PHY_0; i < RTW89_PHY_MAX; i++)
+                               memcpy(&dm->gnt.band[i], &prpt->v8.gnt_val[i][0],
+                                      sizeof(dm->gnt.band[i]));
+
+                       btc->cx.cnt_bt[BTC_BCNT_HIPRI_TX] =
+                               le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_HI_TX_V105]);
+                       btc->cx.cnt_bt[BTC_BCNT_HIPRI_RX] =
+                               le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_HI_RX_V105]);
+                       btc->cx.cnt_bt[BTC_BCNT_LOPRI_TX] =
+                               le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_LO_TX_V105]);
+                       btc->cx.cnt_bt[BTC_BCNT_LOPRI_RX] =
+                               le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_LO_RX_V105]);
+
+                       val1 = le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_POLLUTED_V105]);
+                       if (val1 > btc->cx.cnt_bt[BTC_BCNT_POLUT_NOW])
+                               val1 -= btc->cx.cnt_bt[BTC_BCNT_POLUT_NOW]; /* diff */
+
+                       btc->cx.cnt_bt[BTC_BCNT_POLUT_DIFF] = val1;
+                       btc->cx.cnt_bt[BTC_BCNT_POLUT_NOW] =
+                               le16_to_cpu(prpt->v8.bt_cnt[BTC_BCNT_POLLUTED_V105]);
+
+                       val1 = pfwinfo->event[BTF_EVNT_RPT];
+                       if (((prpt->v8.rpt_len_max_h << 8) +
+                             prpt->v8.rpt_len_max_l) != ver->info_buf)
+                               dm->error.map.h2c_c2h_buffer_mismatch = true;
+                       else
+                               dm->error.map.h2c_c2h_buffer_mismatch = false;
+
+                       _chk_btc_err(rtwdev, BTC_DCNT_BTCNT_HANG, 0);
+                       _chk_btc_err(rtwdev, BTC_DCNT_RPT_HANG, val1);
+                       _chk_btc_err(rtwdev, BTC_DCNT_WL_FW_VER_MATCH, 0);
+                       _chk_btc_err(rtwdev, BTC_DCNT_BTTX_HANG, 0);
                } else {
                        goto err;
                }
                   cnt[BTC_NCNT_CUSTOMERIZE]);
 }
 
+static void _show_summary_v8(struct rtw89_dev *rtwdev, struct seq_file *m)
+{
+       struct rtw89_btc_btf_fwinfo *pfwinfo = &rtwdev->btc.fwinfo;
+       struct rtw89_btc_rpt_cmn_info *pcinfo = NULL;
+       struct rtw89_btc_fbtc_rpt_ctrl_v8 *prptctrl = NULL;
+       struct rtw89_btc_cx *cx = &rtwdev->btc.cx;
+       struct rtw89_btc_dm *dm = &rtwdev->btc.dm;
+       struct rtw89_btc_wl_info *wl = &cx->wl;
+       u32 *cnt = rtwdev->btc.dm.cnt_notify;
+       u32 cnt_sum = 0;
+       u8 i;
+
+       if (!(dm->coex_info_map & BTC_COEX_INFO_SUMMARY))
+               return;
+
+       seq_printf(m, "%s", "\n\r========== [Statistics] ==========");
+
+       pcinfo = &pfwinfo->rpt_ctrl.cinfo;
+       if (pcinfo->valid && wl->status.map.lps != BTC_LPS_RF_OFF &&
+           !wl->status.map.rf_off) {
+               prptctrl = &pfwinfo->rpt_ctrl.finfo.v8;
+
+               seq_printf(m,
+                          "\n\r %-15s : h2c_cnt=%d(fail:%d, fw_recv:%d), c2h_cnt=%d(fw_send:%d, len:%d, max:fw-%d/drv-%d), ",
+                          "[summary]", pfwinfo->cnt_h2c, pfwinfo->cnt_h2c_fail,
+                          le16_to_cpu(prptctrl->rpt_info.cnt_h2c), pfwinfo->cnt_c2h,
+                          le16_to_cpu(prptctrl->rpt_info.cnt_c2h),
+                          le16_to_cpu(prptctrl->rpt_info.len_c2h),
+                          (prptctrl->rpt_len_max_h << 8) + prptctrl->rpt_len_max_l,
+                          rtwdev->btc.ver->info_buf);
+
+               seq_printf(m, "rpt_cnt=%d(fw_send:%d), rpt_map=0x%x",
+                          pfwinfo->event[BTF_EVNT_RPT],
+                          le16_to_cpu(prptctrl->rpt_info.cnt),
+                          le32_to_cpu(prptctrl->rpt_info.en));
+
+               if (dm->error.map.wl_fw_hang)
+                       seq_puts(m, " (WL FW Hang!!)");
+
+               seq_printf(m, "\n\r %-15s : send_ok:%d, send_fail:%d, recv:%d, ",
+                          "[mailbox]", le32_to_cpu(prptctrl->bt_mbx_info.cnt_send_ok),
+                          le32_to_cpu(prptctrl->bt_mbx_info.cnt_send_fail),
+                          le32_to_cpu(prptctrl->bt_mbx_info.cnt_recv));
+
+               seq_printf(m, "A2DP_empty:%d(stop:%d/tx:%d/ack:%d/nack:%d)",
+                          le32_to_cpu(prptctrl->bt_mbx_info.a2dp.cnt_empty),
+                          le32_to_cpu(prptctrl->bt_mbx_info.a2dp.cnt_flowctrl),
+                          le32_to_cpu(prptctrl->bt_mbx_info.a2dp.cnt_tx),
+                          le32_to_cpu(prptctrl->bt_mbx_info.a2dp.cnt_ack),
+                          le32_to_cpu(prptctrl->bt_mbx_info.a2dp.cnt_nack));
+
+               seq_printf(m,
+                          "\n\r %-15s : wl_rfk[req:%d/go:%d/reject:%d/tout:%d/time:%dms]",
+                          "[RFK/LPS]", cx->cnt_wl[BTC_WCNT_RFK_REQ],
+                          cx->cnt_wl[BTC_WCNT_RFK_GO],
+                          cx->cnt_wl[BTC_WCNT_RFK_REJECT],
+                          cx->cnt_wl[BTC_WCNT_RFK_TIMEOUT],
+                          wl->rfk_info.proc_time);
+
+               seq_printf(m, ", bt_rfk[req:%d]",
+                          le16_to_cpu(prptctrl->bt_cnt[BTC_BCNT_RFK_REQ]));
+
+               seq_printf(m, ", AOAC[RF_on:%d/RF_off:%d]",
+                          le16_to_cpu(prptctrl->rpt_info.cnt_aoac_rf_on),
+                          le16_to_cpu(prptctrl->rpt_info.cnt_aoac_rf_off));
+       } else {
+               seq_printf(m,
+                          "\n\r %-15s : h2c_cnt=%d(fail:%d), c2h_cnt=%d (lps=%d/rf_off=%d)",
+                          "[summary]",
+                          pfwinfo->cnt_h2c, pfwinfo->cnt_h2c_fail,
+                          pfwinfo->cnt_c2h,
+                          wl->status.map.lps, wl->status.map.rf_off);
+       }
+
+       for (i = 0; i < BTC_NCNT_NUM; i++)
+               cnt_sum += dm->cnt_notify[i];
+
+       seq_printf(m,
+                  "\n\r %-15s : total=%d, show_coex_info=%d, power_on=%d, init_coex=%d, ",
+                  "[notify_cnt]",
+                  cnt_sum, cnt[BTC_NCNT_SHOW_COEX_INFO],
+                  cnt[BTC_NCNT_POWER_ON], cnt[BTC_NCNT_INIT_COEX]);
+
+       seq_printf(m,
+                  "power_off=%d, radio_state=%d, role_info=%d, wl_rfk=%d, wl_sta=%d",
+                  cnt[BTC_NCNT_POWER_OFF], cnt[BTC_NCNT_RADIO_STATE],
+                  cnt[BTC_NCNT_ROLE_INFO], cnt[BTC_NCNT_WL_RFK],
+                  cnt[BTC_NCNT_WL_STA]);
+
+       seq_printf(m,
+                  "\n\r %-15s : scan_start=%d, scan_finish=%d, switch_band=%d, switch_chbw=%d, special_pkt=%d, ",
+                  "[notify_cnt]",
+                  cnt[BTC_NCNT_SCAN_START], cnt[BTC_NCNT_SCAN_FINISH],
+                  cnt[BTC_NCNT_SWITCH_BAND], cnt[BTC_NCNT_SWITCH_CHBW],
+                  cnt[BTC_NCNT_SPECIAL_PACKET]);
+
+       seq_printf(m, "timer=%d, customerize=%d, hub_msg=%d, chg_fw=%d, send_cc=%d",
+                  cnt[BTC_NCNT_TIMER], cnt[BTC_NCNT_CUSTOMERIZE],
+                  rtwdev->btc.hubmsg_cnt, cnt[BTC_NCNT_RESUME_DL_FW],
+                  cnt[BTC_NCNT_COUNTRYCODE]);
+}
+
 void rtw89_btc_dump_info(struct rtw89_dev *rtwdev, struct seq_file *m)
 {
        struct rtw89_fw_suit *fw_suit = &rtwdev->fw.normal;
                _show_summary_v5(rtwdev, m);
        else if (ver->fcxbtcrpt == 105)
                _show_summary_v105(rtwdev, m);
+       else if (ver->fcxbtcrpt == 8)
+               _show_summary_v8(rtwdev, m);
 }
 
 void rtw89_coex_recognize_ver(struct rtw89_dev *rtwdev)