struct rtw89_btc_fbtc_btscan_v7 *pscan_v7;
        struct rtw89_btc_fbtc_btafh *pafh_v1 = NULL;
        struct rtw89_btc_fbtc_btafh_v2 *pafh_v2 = NULL;
+       struct rtw89_btc_fbtc_btafh_v7 *pafh_v7 = NULL;
        struct rtw89_btc_fbtc_btdevinfo *pdev = NULL;
        bool scan_update = true;
        int i;
                                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 == 7) {
+                       pafh_v7 = (struct rtw89_btc_fbtc_btafh_v7 *)pfinfo;
+                       if (pafh_v7->map_type & RPT_BT_AFH_SEQ_LEGACY) {
+                               memcpy(&bt_linfo->afh_map[0], pafh_v7->afh_l, 4);
+                               memcpy(&bt_linfo->afh_map[4], pafh_v7->afh_m, 4);
+                               memcpy(&bt_linfo->afh_map[8], pafh_v7->afh_h, 2);
+                       }
+                       if (pafh_v7->map_type & RPT_BT_AFH_SEQ_LE) {
+                               memcpy(&bt_linfo->afh_map_le[0], pafh_v7->afh_le_a, 4);
+                               memcpy(&bt_linfo->afh_map_le[4], pafh_v7->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);
 
        u8 afh_le_b[4];
 } __packed;
 
+struct rtw89_btc_fbtc_btafh_v7 {
+       u8 fver;
+       u8 map_type;
+       u8 rsvd0;
+       u8 rsvd1;
+       u8 afh_l[4]; /*bit0:2402, bit1:2403.... bit31:2433 */
+       u8 afh_m[4]; /*bit0:2434, bit1:2435.... bit31:2465 */
+       u8 afh_h[4]; /*bit0:2466, bit1:2467.....bit14:2480 */
+       u8 afh_le_a[4];
+       u8 afh_le_b[4];
+} __packed;
+
 struct rtw89_btc_fbtc_btdevinfo {
        u8 fver; /* btc_ver::fcxbtdevinfo */
        u8 rsvd;