Commit de656c77 authored by Ching-Te Ku's avatar Ching-Te Ku Committed by Ping-Ke Shih

wifi: rtw89: coex: Add GPIO signal control version 7

The feature can help to know how the firmware mechanism working.
There are several trigger point set in firmware. If driver send
the H2C command to firmware to enable the trigger, firmware will
toggle GPIO to perform the firmware mechanism.
Signed-off-by: default avatarChing-Te Ku <ku920601@realtek.com>
Signed-off-by: default avatarPing-Ke Shih <pkshih@realtek.com>
Link: https://msgid.link/20240418021207.32173-8-pkshih@realtek.com
parent b952cb0a
...@@ -1356,8 +1356,13 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev, ...@@ -1356,8 +1356,13 @@ static u32 _chk_btc_report(struct rtw89_dev *rtwdev,
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; if (ver->fcxgpiodbg == 7) {
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_gpio_dbg.finfo); pfinfo = &pfwinfo->rpt_fbtc_gpio_dbg.finfo.v7;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_gpio_dbg.finfo.v7);
} else {
pfinfo = &pfwinfo->rpt_fbtc_gpio_dbg.finfo.v1;
pcinfo->req_len = sizeof(pfwinfo->rpt_fbtc_gpio_dbg.finfo.v1);
}
pcinfo->req_fver = ver->fcxgpiodbg; pcinfo->req_fver = ver->fcxgpiodbg;
break; break;
case BTC_RPT_TYPE_BT_VER: case BTC_RPT_TYPE_BT_VER:
...@@ -7887,6 +7892,7 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -7887,6 +7892,7 @@ static void _show_bt_info(struct rtw89_dev *rtwdev, struct seq_file *m)
#define CASE_BTC_ANTPATH_STR(e) case BTC_ANT_##e: return #e #define CASE_BTC_ANTPATH_STR(e) case BTC_ANT_##e: return #e
#define CASE_BTC_POLUT_STR(e) case BTC_PLT_## e: return #e #define CASE_BTC_POLUT_STR(e) case BTC_PLT_## e: return #e
#define CASE_BTC_REGTYPE_STR(e) case REG_## e: return #e #define CASE_BTC_REGTYPE_STR(e) case REG_## e: return #e
#define CASE_BTC_GDBG_STR(e) case BTC_DBG_## e: return #e
static const char *id_to_polut(u32 id) static const char *id_to_polut(u32 id)
{ {
...@@ -7918,6 +7924,46 @@ static const char *id_to_regtype(u32 id) ...@@ -7918,6 +7924,46 @@ static const char *id_to_regtype(u32 id)
} }
} }
static const char *id_to_gdbg(u32 id)
{
switch (id) {
CASE_BTC_GDBG_STR(GNT_BT);
CASE_BTC_GDBG_STR(GNT_WL);
CASE_BTC_GDBG_STR(BCN_EARLY);
CASE_BTC_GDBG_STR(WL_NULL0);
CASE_BTC_GDBG_STR(WL_NULL1);
CASE_BTC_GDBG_STR(WL_RXISR);
CASE_BTC_GDBG_STR(TDMA_ENTRY);
CASE_BTC_GDBG_STR(A2DP_EMPTY);
CASE_BTC_GDBG_STR(BT_RETRY);
CASE_BTC_GDBG_STR(BT_RELINK);
CASE_BTC_GDBG_STR(SLOT_WL);
CASE_BTC_GDBG_STR(SLOT_BT);
CASE_BTC_GDBG_STR(WL_ERR);
CASE_BTC_GDBG_STR(WL_OK);
CASE_BTC_GDBG_STR(SLOT_B2W);
CASE_BTC_GDBG_STR(SLOT_W1);
CASE_BTC_GDBG_STR(SLOT_W2);
CASE_BTC_GDBG_STR(SLOT_W2B);
CASE_BTC_GDBG_STR(SLOT_B1);
CASE_BTC_GDBG_STR(SLOT_B2);
CASE_BTC_GDBG_STR(SLOT_B3);
CASE_BTC_GDBG_STR(SLOT_B4);
CASE_BTC_GDBG_STR(SLOT_LK);
CASE_BTC_GDBG_STR(SLOT_E2G);
CASE_BTC_GDBG_STR(SLOT_E5G);
CASE_BTC_GDBG_STR(SLOT_EBT);
CASE_BTC_GDBG_STR(SLOT_WLK);
CASE_BTC_GDBG_STR(SLOT_B1FDD);
CASE_BTC_GDBG_STR(BT_CHANGE);
CASE_BTC_GDBG_STR(WL_CCA);
CASE_BTC_GDBG_STR(BT_LEAUDIO);
CASE_BTC_GDBG_STR(USER_DEF);
default:
return "unknown";
}
}
static const char *steps_to_str(u16 step) static const char *steps_to_str(u16 step)
{ {
switch (step) { switch (step) {
...@@ -9286,6 +9332,47 @@ static void _get_gnt(struct rtw89_dev *rtwdev, struct rtw89_mac_ax_coex_gnt *gnt ...@@ -9286,6 +9332,47 @@ static void _get_gnt(struct rtw89_dev *rtwdev, struct rtw89_mac_ax_coex_gnt *gnt
} }
} }
static void _show_gpio_dbg(struct rtw89_dev *rtwdev, struct seq_file *m)
{
struct rtw89_btc_btf_fwinfo *pfwinfo = &rtwdev->btc.fwinfo;
const struct rtw89_btc_ver *ver = rtwdev->btc.ver;
struct rtw89_btc_rpt_cmn_info *pcinfo = NULL;
union rtw89_btc_fbtc_gpio_dbg *gdbg = NULL;
u8 *gpio_map, i;
u32 en_map;
pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo;
gdbg = &rtwdev->btc.fwinfo.rpt_fbtc_gpio_dbg.finfo;
if (!pcinfo->valid) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): stop due rpt_fbtc_gpio_dbg.cinfo\n",
__func__);
seq_puts(m, "\n");
return;
}
if (ver->fcxgpiodbg == 7) {
en_map = le32_to_cpu(gdbg->v7.en_map);
gpio_map = gdbg->v7.gpio_map;
} else {
en_map = le32_to_cpu(gdbg->v1.en_map);
gpio_map = gdbg->v1.gpio_map;
}
if (!en_map)
return;
seq_printf(m, " %-15s : enable_map:0x%08x",
"[gpio_dbg]", en_map);
for (i = 0; i < BTC_DBG_MAX1; i++) {
if (!(en_map & BIT(i)))
continue;
seq_printf(m, ", %s->GPIO%d", id_to_gdbg(i), gpio_map[i]);
}
seq_puts(m, "\n");
}
static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m) static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m)
{ {
const struct rtw89_chip_info *chip = rtwdev->chip; const struct rtw89_chip_info *chip = rtwdev->chip;
...@@ -9293,7 +9380,6 @@ static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9293,7 +9380,6 @@ static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m)
struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo; struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo;
struct rtw89_btc_rpt_cmn_info *pcinfo = NULL; struct rtw89_btc_rpt_cmn_info *pcinfo = NULL;
struct rtw89_btc_fbtc_mreg_val_v1 *pmreg = NULL; struct rtw89_btc_fbtc_mreg_val_v1 *pmreg = NULL;
struct rtw89_btc_fbtc_gpio_dbg *gdbg = NULL;
struct rtw89_btc_cx *cx = &btc->cx; struct rtw89_btc_cx *cx = &btc->cx;
struct rtw89_btc_wl_info *wl = &btc->cx.wl; struct rtw89_btc_wl_info *wl = &btc->cx.wl;
struct rtw89_btc_bt_info *bt = &btc->cx.bt; struct rtw89_btc_bt_info *bt = &btc->cx.bt;
...@@ -9363,29 +9449,6 @@ static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9363,29 +9449,6 @@ static void _show_mreg_v1(struct rtw89_dev *rtwdev, struct seq_file *m)
if (i >= pmreg->reg_num) if (i >= pmreg->reg_num)
seq_puts(m, "\n"); seq_puts(m, "\n");
} }
pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo;
if (!pcinfo->valid) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): stop due rpt_fbtc_gpio_dbg.cinfo\n",
__func__);
seq_puts(m, "\n");
return;
}
gdbg = &pfwinfo->rpt_fbtc_gpio_dbg.finfo;
if (!gdbg->en_map)
return;
seq_printf(m, " %-15s : enable_map:0x%08x",
"[gpio_dbg]", gdbg->en_map);
for (i = 0; i < BTC_DBG_MAX1; i++) {
if (!(gdbg->en_map & BIT(i)))
continue;
seq_printf(m, ", %d->GPIO%d", (u32)i, gdbg->gpio_map[i]);
}
seq_puts(m, "\n");
} }
static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m) static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m)
...@@ -9395,7 +9458,6 @@ static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9395,7 +9458,6 @@ static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m)
struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo; struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo;
struct rtw89_btc_rpt_cmn_info *pcinfo = NULL; struct rtw89_btc_rpt_cmn_info *pcinfo = NULL;
struct rtw89_btc_fbtc_mreg_val_v2 *pmreg = NULL; struct rtw89_btc_fbtc_mreg_val_v2 *pmreg = NULL;
struct rtw89_btc_fbtc_gpio_dbg *gdbg = NULL;
struct rtw89_btc_cx *cx = &btc->cx; struct rtw89_btc_cx *cx = &btc->cx;
struct rtw89_btc_wl_info *wl = &btc->cx.wl; struct rtw89_btc_wl_info *wl = &btc->cx.wl;
struct rtw89_btc_bt_info *bt = &btc->cx.bt; struct rtw89_btc_bt_info *bt = &btc->cx.bt;
...@@ -9466,29 +9528,6 @@ static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9466,29 +9528,6 @@ static void _show_mreg_v2(struct rtw89_dev *rtwdev, struct seq_file *m)
if (i >= pmreg->reg_num) if (i >= pmreg->reg_num)
seq_puts(m, "\n"); seq_puts(m, "\n");
} }
pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo;
if (!pcinfo->valid) {
rtw89_debug(rtwdev, RTW89_DBG_BTC,
"[BTC], %s(): stop due rpt_fbtc_gpio_dbg.cinfo\n",
__func__);
seq_puts(m, "\n");
return;
}
gdbg = &pfwinfo->rpt_fbtc_gpio_dbg.finfo;
if (!gdbg->en_map)
return;
seq_printf(m, " %-15s : enable_map:0x%08x",
"[gpio_dbg]", gdbg->en_map);
for (i = 0; i < BTC_DBG_MAX1; i++) {
if (!(gdbg->en_map & BIT(i)))
continue;
seq_printf(m, ", %d->GPIO%d", (u32)i, gdbg->gpio_map[i]);
}
seq_puts(m, "\n");
} }
static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m) static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m)
...@@ -9497,7 +9536,6 @@ static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9497,7 +9536,6 @@ static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m)
struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo; struct rtw89_btc_btf_fwinfo *pfwinfo = &btc->fwinfo;
struct rtw89_btc_fbtc_mreg_val_v7 *pmreg = NULL; struct rtw89_btc_fbtc_mreg_val_v7 *pmreg = NULL;
struct rtw89_btc_rpt_cmn_info *pcinfo = NULL; struct rtw89_btc_rpt_cmn_info *pcinfo = NULL;
struct rtw89_btc_fbtc_gpio_dbg *gdbg = NULL;
struct rtw89_btc_cx *cx = &btc->cx; struct rtw89_btc_cx *cx = &btc->cx;
struct rtw89_btc_wl_info *wl = &cx->wl; struct rtw89_btc_wl_info *wl = &cx->wl;
struct rtw89_btc_bt_info *bt = &cx->bt; struct rtw89_btc_bt_info *bt = &cx->bt;
...@@ -9559,23 +9597,7 @@ static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -9559,23 +9597,7 @@ static void _show_mreg_v7(struct rtw89_dev *rtwdev, struct seq_file *m)
id_to_regtype(type), offset, val); id_to_regtype(type), offset, val);
cnt++; cnt++;
} }
seq_puts(m, "\n");
pcinfo = &pfwinfo->rpt_fbtc_gpio_dbg.cinfo;
if (!pcinfo->valid)
return;
gdbg = &pfwinfo->rpt_fbtc_gpio_dbg.finfo;
if (!gdbg->en_map)
return;
seq_printf(m, "\n\r %-15s : enable_map:0x%08x", "[gpio_dbg]", gdbg->en_map);
for (i = 0; i < BTC_DBG_MAX1; i++) {
if (!(gdbg->en_map & BIT(i)))
continue;
seq_printf(m, ", %d->GPIO%d",
i, gdbg->gpio_map[i]);
}
} }
static void _show_summary_v1(struct rtw89_dev *rtwdev, struct seq_file *m) static void _show_summary_v1(struct rtw89_dev *rtwdev, struct seq_file *m)
...@@ -10064,6 +10086,8 @@ void rtw89_btc_dump_info(struct rtw89_dev *rtwdev, struct seq_file *m) ...@@ -10064,6 +10086,8 @@ void rtw89_btc_dump_info(struct rtw89_dev *rtwdev, struct seq_file *m)
else if (ver->fcxmreg == 7) else if (ver->fcxmreg == 7)
_show_mreg_v7(rtwdev, m); _show_mreg_v7(rtwdev, m);
_show_gpio_dbg(rtwdev, m);
if (ver->fcxbtcrpt == 1) if (ver->fcxbtcrpt == 1)
_show_summary_v1(rtwdev, m); _show_summary_v1(rtwdev, m);
else if (ver->fcxbtcrpt == 4) else if (ver->fcxbtcrpt == 4)
......
...@@ -222,6 +222,41 @@ enum btc_wl_mode { ...@@ -222,6 +222,41 @@ enum btc_wl_mode {
BTC_WL_MODE_NUM, BTC_WL_MODE_NUM,
}; };
enum btc_wl_gpio_debug {
BTC_DBG_GNT_BT = 0,
BTC_DBG_GNT_WL = 1,
BTC_DBG_BCN_EARLY = 2,
BTC_DBG_WL_NULL0 = 3,
BTC_DBG_WL_NULL1 = 4,
BTC_DBG_WL_RXISR = 5,
BTC_DBG_TDMA_ENTRY = 6,
BTC_DBG_A2DP_EMPTY = 7,
BTC_DBG_BT_RETRY = 8,
BTC_DBG_BT_RELINK = 9,
BTC_DBG_SLOT_WL = 10,
BTC_DBG_SLOT_BT = 11,
BTC_DBG_WL_ERR = 12,
BTC_DBG_WL_OK = 13,
BTC_DBG_SLOT_B2W = 14,
BTC_DBG_SLOT_W1 = 15,
BTC_DBG_SLOT_W2 = 16,
BTC_DBG_SLOT_W2B = 17,
BTC_DBG_SLOT_B1 = 18,
BTC_DBG_SLOT_B2 = 19,
BTC_DBG_SLOT_B3 = 20,
BTC_DBG_SLOT_B4 = 21,
BTC_DBG_SLOT_LK = 22,
BTC_DBG_SLOT_E2G = 23,
BTC_DBG_SLOT_E5G = 24,
BTC_DBG_SLOT_EBT = 25,
BTC_DBG_SLOT_WLK = 26,
BTC_DBG_SLOT_B1FDD = 27,
BTC_DBG_BT_CHANGE = 28,
BTC_DBG_WL_CCA = 29,
BTC_DBG_BT_LEAUDIO = 30,
BTC_DBG_USER_DEF = 31,
};
void rtw89_btc_ntfy_poweron(struct rtw89_dev *rtwdev); void rtw89_btc_ntfy_poweron(struct rtw89_dev *rtwdev);
void rtw89_btc_ntfy_poweroff(struct rtw89_dev *rtwdev); void rtw89_btc_ntfy_poweroff(struct rtw89_dev *rtwdev);
void rtw89_btc_ntfy_init(struct rtw89_dev *rtwdev, u8 mode); void rtw89_btc_ntfy_init(struct rtw89_dev *rtwdev, u8 mode);
......
...@@ -2251,15 +2251,32 @@ enum rtw89_btc_afh_map_type { /*AFH MAP TYPE */ ...@@ -2251,15 +2251,32 @@ enum rtw89_btc_afh_map_type { /*AFH MAP TYPE */
}; };
#define BTC_DBG_MAX1 32 #define BTC_DBG_MAX1 32
struct rtw89_btc_fbtc_gpio_dbg { struct rtw89_btc_fbtc_gpio_dbg_v1 {
u8 fver; /* btc_ver::fcxgpiodbg */ u8 fver; /* btc_ver::fcxgpiodbg */
u8 rsvd; u8 rsvd;
u16 rsvd2; __le16 rsvd2;
u32 en_map; /* which debug signal (see btc_wl_gpio_debug) is enable */ __le32 en_map; /* which debug signal (see btc_wl_gpio_debug) is enable */
u32 pre_state; /* the debug signal is 1 or 0 */ __le32 pre_state; /* the debug signal is 1 or 0 */
u8 gpio_map[BTC_DBG_MAX1]; /*the debug signals to GPIO-Position */ u8 gpio_map[BTC_DBG_MAX1]; /*the debug signals to GPIO-Position */
} __packed; } __packed;
struct rtw89_btc_fbtc_gpio_dbg_v7 {
u8 fver;
u8 rsvd0;
u8 rsvd1;
u8 rsvd2;
u8 gpio_map[BTC_DBG_MAX1];
__le32 en_map;
__le32 pre_state;
} __packed;
union rtw89_btc_fbtc_gpio_dbg {
struct rtw89_btc_fbtc_gpio_dbg_v1 v1;
struct rtw89_btc_fbtc_gpio_dbg_v7 v7;
};
struct rtw89_btc_fbtc_mreg_val_v1 { struct rtw89_btc_fbtc_mreg_val_v1 {
u8 fver; /* btc_ver::fcxmreg */ u8 fver; /* btc_ver::fcxmreg */
u8 reg_num; u8 reg_num;
...@@ -2870,7 +2887,7 @@ struct rtw89_btc_rpt_fbtc_mreg { ...@@ -2870,7 +2887,7 @@ struct rtw89_btc_rpt_fbtc_mreg {
struct rtw89_btc_rpt_fbtc_gpio_dbg { struct rtw89_btc_rpt_fbtc_gpio_dbg {
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_gpio_dbg finfo; /* info from fw */ union rtw89_btc_fbtc_gpio_dbg finfo; /* info from fw */
}; };
struct rtw89_btc_rpt_fbtc_btver { struct rtw89_btc_rpt_fbtc_btver {
......
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