Commit 0cdfcfce authored by Ching-Te Ku's avatar Ching-Te Ku Committed by Kalle Valo

wifi: rtw89: coex: Add v2 BT AFH report and related variable

Wi-Fi firmware update AFH report feature to version 2. If there is BT BLE
device connect to DUT, the mechanism will send H2C to request BT BLE
channel map, it will help to debug.
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-6-pkshih@realtek.com
parent 52c7c983
...@@ -854,17 +854,18 @@ static void _chk_btc_err(struct rtw89_dev *rtwdev, u8 type, u32 cnt) ...@@ -854,17 +854,18 @@ static void _chk_btc_err(struct rtw89_dev *rtwdev, u8 type, u32 cnt)
static void _update_bt_report(struct rtw89_dev *rtwdev, u8 rpt_type, u8 *pfinfo) static void _update_bt_report(struct rtw89_dev *rtwdev, u8 rpt_type, u8 *pfinfo)
{ {
struct rtw89_btc *btc = &rtwdev->btc; 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_info *bt = &btc->cx.bt;
struct rtw89_btc_bt_link_info *bt_linfo = &bt->link_info; 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_bt_a2dp_desc *a2dp = &bt_linfo->a2dp_desc;
struct rtw89_btc_fbtc_btver *pver = NULL; struct rtw89_btc_fbtc_btver *pver = NULL;
struct rtw89_btc_fbtc_btscan *pscan = 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; struct rtw89_btc_fbtc_btdevinfo *pdev = NULL;
pver = (struct rtw89_btc_fbtc_btver *)pfinfo; pver = (struct rtw89_btc_fbtc_btver *)pfinfo;
pscan = (struct rtw89_btc_fbtc_btscan *)pfinfo; pscan = (struct rtw89_btc_fbtc_btscan *)pfinfo;
pafh = (struct rtw89_btc_fbtc_btafh *)pfinfo;
pdev = (struct rtw89_btc_fbtc_btdevinfo *)pfinfo; pdev = (struct rtw89_btc_fbtc_btdevinfo *)pfinfo;
rtw89_debug(rtwdev, RTW89_DBG_BTC, rtw89_debug(rtwdev, RTW89_DBG_BTC,
...@@ -881,9 +882,23 @@ static void _update_bt_report(struct rtw89_dev *rtwdev, u8 rpt_type, u8 *pfinfo) ...@@ -881,9 +882,23 @@ static void _update_bt_report(struct rtw89_dev *rtwdev, u8 rpt_type, u8 *pfinfo)
memcpy(bt->scan_info, pscan->scan, BTC_SCAN_MAX1); memcpy(bt->scan_info, pscan->scan, BTC_SCAN_MAX1);
break; break;
case BTC_RPT_TYPE_BT_AFH: case BTC_RPT_TYPE_BT_AFH:
memcpy(&bt_linfo->afh_map[0], pafh->afh_l, 4); if (ver->fcxbtafh == 2) {
memcpy(&bt_linfo->afh_map[4], pafh->afh_m, 4); pafh_v2 = (struct rtw89_btc_fbtc_btafh_v2 *)pfinfo;
memcpy(&bt_linfo->afh_map[8], pafh->afh_h, 2); 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; break;
case BTC_RPT_TYPE_BT_DEVICE: case BTC_RPT_TYPE_BT_DEVICE:
a2dp->device_name = le32_to_cpu(pdev->dev_name); a2dp->device_name = le32_to_cpu(pdev->dev_name);
...@@ -1132,8 +1147,15 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1132,8 +1147,15 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
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;
pfinfo = &pfwinfo->rpt_fbtc_btafh.finfo; if (ver->fcxbtafh == 1) {
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_btafh.finfo); 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->req_fver = ver->fcxbtafh;
pcinfo->rx_len = rpt_len; pcinfo->rx_len = rpt_len;
pcinfo->rx_cnt++; pcinfo->rx_cnt++;
...@@ -1393,6 +1415,11 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1393,6 +1415,11 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
_update_bt_report(rtwdev, rpt_type, pfinfo); _update_bt_report(rtwdev, rpt_type, pfinfo);
return (rpt_len + BTC_RPT_HDR_SIZE); 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 _parse_btc_report(struct rtw89_dev *rtwdev,
...@@ -5919,12 +5946,14 @@ static void _show_bt_profile_info(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -5919,12 +5946,14 @@ static void _show_bt_profile_info(struct rtw89_dev *rtwdev, struct seq_file *m)
static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m) static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m)
{ {
struct rtw89_btc *btc = &rtwdev->btc; struct rtw89_btc *btc = &rtwdev->btc;
const struct rtw89_btc_ver *ver = btc->ver;
struct rtw89_btc_cx *cx = &btc->cx; struct rtw89_btc_cx *cx = &btc->cx;
struct rtw89_btc_bt_info *bt = &cx->bt; struct rtw89_btc_bt_info *bt = &cx->bt;
struct rtw89_btc_wl_info *wl = &cx->wl; struct rtw89_btc_wl_info *wl = &cx->wl;
struct rtw89_btc_module *module = &btc->mdinfo; struct rtw89_btc_module *module = &btc->mdinfo;
struct rtw89_btc_bt_link_info *bt_linfo = &bt->link_info; struct rtw89_btc_bt_link_info *bt_linfo = &bt->link_info;
u8 *afh = bt_linfo->afh_map; u8 *afh = bt_linfo->afh_map;
u8 *afh_le = bt_linfo->afh_map_le;
if (!(btc->dm.coex_info_map & BTC_COEX_INFO_BT)) if (!(btc->dm.coex_info_map & BTC_COEX_INFO_BT))
return; return;
...@@ -5974,6 +6003,12 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -5974,6 +6003,12 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m)
afh[0], afh[1], afh[2], afh[3], afh[4], afh[0], afh[1], afh[2], afh[3], afh[4],
afh[5], afh[6], afh[7], afh[8], afh[9]); 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", 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); wl->afh_info.en, wl->afh_info.ch, wl->afh_info.bw);
...@@ -6016,6 +6051,11 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -6016,6 +6051,11 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m)
else else
rtw89_btc_fw_en_rpt(rtwdev, RPT_EN_BT_AFH_MAP, false); 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 && if (bt_linfo->a2dp_desc.exist &&
(bt_linfo->a2dp_desc.flush_time == 0 || (bt_linfo->a2dp_desc.flush_time == 0 ||
bt_linfo->a2dp_desc.vendor_id == 0 || bt_linfo->a2dp_desc.vendor_id == 0 ||
......
...@@ -1264,6 +1264,7 @@ union rtw89_btc_bt_state_map { ...@@ -1264,6 +1264,7 @@ union rtw89_btc_bt_state_map {
#define BTC_BT_RSSI_THMAX 4 #define BTC_BT_RSSI_THMAX 4
#define BTC_BT_AFH_GROUP 12 #define BTC_BT_AFH_GROUP 12
#define BTC_BT_AFH_LE_GROUP 5
struct rtw89_btc_bt_link_info { struct rtw89_btc_bt_link_info {
struct rtw89_btc_u8_sta_chg profile_cnt; struct rtw89_btc_u8_sta_chg profile_cnt;
...@@ -1279,6 +1280,7 @@ struct rtw89_btc_bt_link_info { ...@@ -1279,6 +1280,7 @@ struct rtw89_btc_bt_link_info {
u8 golden_rx_shift[BTC_PROFILE_MAX]; u8 golden_rx_shift[BTC_PROFILE_MAX];
u8 rssi_state[BTC_BT_RSSI_THMAX]; u8 rssi_state[BTC_BT_RSSI_THMAX];
u8 afh_map[BTC_BT_AFH_GROUP]; u8 afh_map[BTC_BT_AFH_GROUP];
u8 afh_map_le[BTC_BT_AFH_LE_GROUP];
u32 role_sw: 1; u32 role_sw: 1;
u32 slave_role: 1; u32 slave_role: 1;
...@@ -1605,6 +1607,11 @@ enum { /* STEP TYPE */ ...@@ -1605,6 +1607,11 @@ enum { /* STEP TYPE */
CXSTEP_MAX, 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 #define BTC_DBG_MAX1 32
struct rtw89_btc_fbtc_gpio_dbg { struct rtw89_btc_fbtc_gpio_dbg {
u8 fver; /* btc_ver::fcxgpiodbg */ u8 fver; /* btc_ver::fcxgpiodbg */
...@@ -1792,6 +1799,18 @@ struct rtw89_btc_fbtc_btafh { ...@@ -1792,6 +1799,18 @@ struct rtw89_btc_fbtc_btafh {
u8 afh_h[4]; /*bit0:2466, bit1:2467......bit14:2480 */ u8 afh_h[4]; /*bit0:2466, bit1:2467......bit14:2480 */
} __packed; } __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 { struct rtw89_btc_fbtc_btdevinfo {
u8 fver; /* btc_ver::fcxbtdevinfo */ u8 fver; /* btc_ver::fcxbtdevinfo */
u8 rsvd; u8 rsvd;
...@@ -1912,6 +1931,11 @@ struct rtw89_btc_rpt_cmn_info { ...@@ -1912,6 +1931,11 @@ struct rtw89_btc_rpt_cmn_info {
u8 valid; u8 valid;
} __packed; } __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_report_ctrl_state {
struct rtw89_btc_rpt_cmn_info cinfo; /* common info, by driver */ struct rtw89_btc_rpt_cmn_info cinfo; /* common info, by driver */
union { union {
...@@ -1979,7 +2003,7 @@ struct rtw89_btc_rpt_fbtc_btscan { ...@@ -1979,7 +2003,7 @@ struct rtw89_btc_rpt_fbtc_btscan {
struct rtw89_btc_rpt_fbtc_btafh { struct rtw89_btc_rpt_fbtc_btafh {
struct rtw89_btc_rpt_cmn_info cinfo; /* common info, by driver */ 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 { struct rtw89_btc_rpt_fbtc_btdev {
......
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