static void _update_bt_report(struct rtw89_dev *rtwdev, u8 rpt_type, u8 *pfinfo)
 {
        struct rtw89_btc *btc = &rtwdev->btc;
+       const struct rtw89_btc_ver *ver = btc->ver;
        struct rtw89_btc_bt_info *bt = &btc->cx.bt;
        struct rtw89_btc_bt_link_info *bt_linfo = &bt->link_info;
        struct rtw89_btc_bt_a2dp_desc *a2dp = &bt_linfo->a2dp_desc;
        struct rtw89_btc_fbtc_btver *pver = NULL;
        struct rtw89_btc_fbtc_btscan *pscan = NULL;
-       struct rtw89_btc_fbtc_btafh *pafh = NULL;
+       struct rtw89_btc_fbtc_btafh *pafh_v1 = NULL;
+       struct rtw89_btc_fbtc_btafh_v2 *pafh_v2 = NULL;
        struct rtw89_btc_fbtc_btdevinfo *pdev = NULL;
 
        pver = (struct rtw89_btc_fbtc_btver *)pfinfo;
        pscan = (struct rtw89_btc_fbtc_btscan *)pfinfo;
-       pafh = (struct rtw89_btc_fbtc_btafh *)pfinfo;
        pdev = (struct rtw89_btc_fbtc_btdevinfo *)pfinfo;
 
        rtw89_debug(rtwdev, RTW89_DBG_BTC,
                memcpy(bt->scan_info, pscan->scan, BTC_SCAN_MAX1);
                break;
        case BTC_RPT_TYPE_BT_AFH:
-               memcpy(&bt_linfo->afh_map[0], pafh->afh_l, 4);
-               memcpy(&bt_linfo->afh_map[4], pafh->afh_m, 4);
-               memcpy(&bt_linfo->afh_map[8], pafh->afh_h, 2);
+               if (ver->fcxbtafh == 2) {
+                       pafh_v2 = (struct rtw89_btc_fbtc_btafh_v2 *)pfinfo;
+                       if (pafh_v2->map_type & RPT_BT_AFH_SEQ_LEGACY) {
+                               memcpy(&bt_linfo->afh_map[0], pafh_v2->afh_l, 4);
+                               memcpy(&bt_linfo->afh_map[4], pafh_v2->afh_m, 4);
+                               memcpy(&bt_linfo->afh_map[8], pafh_v2->afh_h, 2);
+                       }
+                       if (pafh_v2->map_type & RPT_BT_AFH_SEQ_LE) {
+                               memcpy(&bt_linfo->afh_map_le[0], pafh_v2->afh_le_a, 4);
+                               memcpy(&bt_linfo->afh_map_le[4], pafh_v2->afh_le_b, 1);
+                       }
+               } else if (ver->fcxbtafh == 1) {
+                       pafh_v1 = (struct rtw89_btc_fbtc_btafh *)pfinfo;
+                       memcpy(&bt_linfo->afh_map[0], pafh_v1->afh_l, 4);
+                       memcpy(&bt_linfo->afh_map[4], pafh_v1->afh_m, 4);
+                       memcpy(&bt_linfo->afh_map[8], pafh_v1->afh_h, 2);
+               }
                break;
        case BTC_RPT_TYPE_BT_DEVICE:
                a2dp->device_name = le32_to_cpu(pdev->dev_name);
                break;
        case BTC_RPT_TYPE_BT_AFH:
                pcinfo = &pfwinfo->rpt_fbtc_btafh.cinfo;
-               pfinfo = &pfwinfo->rpt_fbtc_btafh.finfo;
-               pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btafh.finfo);
+               if (ver->fcxbtafh == 1) {
+                       pfinfo = &pfwinfo->rpt_fbtc_btafh.finfo.v1;
+                       pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btafh.finfo.v1);
+               } else if (ver->fcxbtafh == 2) {
+                       pfinfo = &pfwinfo->rpt_fbtc_btafh.finfo.v2;
+                       pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btafh.finfo.v2);
+               } else {
+                       goto err;
+               }
                pcinfo->req_fver = ver->fcxbtafh;
                pcinfo->rx_len = rpt_len;
                pcinfo->rx_cnt++;
                _update_bt_report(rtwdev, rpt_type, pfinfo);
 
        return (rpt_len + BTC_RPT_HDR_SIZE);
+
+err:
+       rtw89_debug(rtwdev, RTW89_DBG_BTC,
+                   "[BTC], %s(): Undefined version for type=%d\n", __func__, rpt_type);
+       return 0;
 }
 
 static void _parse_btc_report(struct rtw89_dev *rtwdev,
 static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m)
 {
        struct rtw89_btc *btc = &rtwdev->btc;
+       const struct rtw89_btc_ver *ver = btc->ver;
        struct rtw89_btc_cx *cx = &btc->cx;
        struct rtw89_btc_bt_info *bt = &cx->bt;
        struct rtw89_btc_wl_info *wl = &cx->wl;
        struct rtw89_btc_module *module = &btc->mdinfo;
        struct rtw89_btc_bt_link_info *bt_linfo = &bt->link_info;
        u8 *afh = bt_linfo->afh_map;
+       u8 *afh_le = bt_linfo->afh_map_le;
 
        if (!(btc->dm.coex_info_map & BTC_COEX_INFO_BT))
                return;
                   afh[0], afh[1], afh[2], afh[3], afh[4],
                   afh[5], afh[6], afh[7], afh[8], afh[9]);
 
+       if (ver->fcxbtafh == 2 && bt_linfo->status.map.ble_connect)
+               seq_printf(m,
+                          "LE[%02x%02x_%02x_%02x%02x]",
+                          afh_le[0], afh_le[1], afh_le[2],
+                          afh_le[3], afh_le[4]);
+
        seq_printf(m, "wl_ch_map[en:%d/ch:%d/bw:%d]\n",
                   wl->afh_info.en, wl->afh_info.ch, wl->afh_info.bw);
 
        else
                rtw89_btc_fw_en_rpt(rtwdev, RPT_EN_BT_AFH_MAP, false);
 
+       if (ver->fcxbtafh == 2 && bt_linfo->status.map.ble_connect)
+               rtw89_btc_fw_en_rpt(rtwdev, RPT_EN_BT_AFH_MAP_LE, true);
+       else
+               rtw89_btc_fw_en_rpt(rtwdev, RPT_EN_BT_AFH_MAP_LE, false);
+
        if (bt_linfo->a2dp_desc.exist &&
            (bt_linfo->a2dp_desc.flush_time == 0 ||
             bt_linfo->a2dp_desc.vendor_id == 0 ||
 
 
 #define BTC_BT_RSSI_THMAX 4
 #define BTC_BT_AFH_GROUP 12
+#define BTC_BT_AFH_LE_GROUP 5
 
 struct rtw89_btc_bt_link_info {
        struct rtw89_btc_u8_sta_chg profile_cnt;
        u8 golden_rx_shift[BTC_PROFILE_MAX];
        u8 rssi_state[BTC_BT_RSSI_THMAX];
        u8 afh_map[BTC_BT_AFH_GROUP];
+       u8 afh_map_le[BTC_BT_AFH_LE_GROUP];
 
        u32 role_sw: 1;
        u32 slave_role: 1;
        CXSTEP_MAX,
 };
 
+enum rtw89_btc_afh_map_type { /*AFH MAP TYPE */
+       RPT_BT_AFH_SEQ_LEGACY = 0x10,
+       RPT_BT_AFH_SEQ_LE = 0x20
+};
+
 #define BTC_DBG_MAX1  32
 struct rtw89_btc_fbtc_gpio_dbg {
        u8 fver; /* btc_ver::fcxgpiodbg */
        u8 afh_h[4]; /*bit0:2466, bit1:2467......bit14:2480 */
 } __packed;
 
+struct rtw89_btc_fbtc_btafh_v2 {
+       u8 fver; /* btc_ver::fcxbtafh */
+       u8 rsvd;
+       u8 rsvd2;
+       u8 map_type;
+       u8 afh_l[4];
+       u8 afh_m[4];
+       u8 afh_h[4];
+       u8 afh_le_a[4];
+       u8 afh_le_b[4];
+} __packed;
+
 struct rtw89_btc_fbtc_btdevinfo {
        u8 fver; /* btc_ver::fcxbtdevinfo */
        u8 rsvd;
        u8 valid;
 } __packed;
 
+union rtw89_btc_fbtc_btafh_info {
+       struct rtw89_btc_fbtc_btafh v1;
+       struct rtw89_btc_fbtc_btafh_v2 v2;
+};
+
 struct rtw89_btc_report_ctrl_state {
        struct rtw89_btc_rpt_cmn_info cinfo; /* common info, by driver */
        union {
 
 struct rtw89_btc_rpt_fbtc_btafh {
        struct rtw89_btc_rpt_cmn_info cinfo; /* common info, by driver */
-       struct rtw89_btc_fbtc_btafh finfo; /* info from fw */
+       union rtw89_btc_fbtc_btafh_info finfo;
 };
 
 struct rtw89_btc_rpt_fbtc_btdev {