Commit 332debb8 authored by Ping-Ke Shih's avatar Ping-Ke Shih Committed by Kalle Valo

wifi: rtw89: use struct and le32_get_bits() to access received PHY status IEs

PHY status IEs generated by BB hardware is to provide more detail
information related to received packets, such as RSSI and bandwidth.

To avoid type casting, change buf type from u8* to void* as well.

This patch doesn't change logic at all.
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/20230522122513.13559-4-pkshih@realtek.com
parent 88bdc3ff
...@@ -1280,7 +1280,8 @@ static void rtw89_core_rx_process_phy_ppdu_iter(void *data, ...@@ -1280,7 +1280,8 @@ static void rtw89_core_rx_process_phy_ppdu_iter(void *data,
#define VAR_LEN 0xff #define VAR_LEN 0xff
#define VAR_LEN_UNIT 8 #define VAR_LEN_UNIT 8
static u16 rtw89_core_get_phy_status_ie_len(struct rtw89_dev *rtwdev, u8 *addr) static u16 rtw89_core_get_phy_status_ie_len(struct rtw89_dev *rtwdev,
const struct rtw89_phy_sts_iehdr *iehdr)
{ {
static const u8 physts_ie_len_tab[32] = { static const u8 physts_ie_len_tab[32] = {
16, 32, 24, 24, 8, 8, 8, 8, VAR_LEN, 8, VAR_LEN, 176, VAR_LEN, 16, 32, 24, 24, 8, 8, 8, 8, VAR_LEN, 8, VAR_LEN, 176, VAR_LEN,
...@@ -1290,19 +1291,20 @@ static u16 rtw89_core_get_phy_status_ie_len(struct rtw89_dev *rtwdev, u8 *addr) ...@@ -1290,19 +1291,20 @@ static u16 rtw89_core_get_phy_status_ie_len(struct rtw89_dev *rtwdev, u8 *addr)
u16 ie_len; u16 ie_len;
u8 ie; u8 ie;
ie = RTW89_GET_PHY_STS_IE_TYPE(addr); ie = le32_get_bits(iehdr->w0, RTW89_PHY_STS_IEHDR_TYPE);
if (physts_ie_len_tab[ie] != VAR_LEN) if (physts_ie_len_tab[ie] != VAR_LEN)
ie_len = physts_ie_len_tab[ie]; ie_len = physts_ie_len_tab[ie];
else else
ie_len = RTW89_GET_PHY_STS_IE_LEN(addr) * VAR_LEN_UNIT; ie_len = le32_get_bits(iehdr->w0, RTW89_PHY_STS_IEHDR_LEN) * VAR_LEN_UNIT;
return ie_len; return ie_len;
} }
static void rtw89_core_parse_phy_status_ie01(struct rtw89_dev *rtwdev, u8 *addr, static void rtw89_core_parse_phy_status_ie01(struct rtw89_dev *rtwdev,
const struct rtw89_phy_sts_iehdr *iehdr,
struct rtw89_rx_phy_ppdu *phy_ppdu) struct rtw89_rx_phy_ppdu *phy_ppdu)
{ {
const struct rtw89_phy_sts_ie0 *ie = (const struct rtw89_phy_sts_ie0 *)addr; const struct rtw89_phy_sts_ie0 *ie = (const struct rtw89_phy_sts_ie0 *)iehdr;
s16 cfo; s16 cfo;
u32 t; u32 t;
...@@ -1330,15 +1332,17 @@ static void rtw89_core_parse_phy_status_ie01(struct rtw89_dev *rtwdev, u8 *addr, ...@@ -1330,15 +1332,17 @@ static void rtw89_core_parse_phy_status_ie01(struct rtw89_dev *rtwdev, u8 *addr,
rtw89_phy_cfo_parse(rtwdev, cfo, phy_ppdu); rtw89_phy_cfo_parse(rtwdev, cfo, phy_ppdu);
} }
static int rtw89_core_process_phy_status_ie(struct rtw89_dev *rtwdev, u8 *addr, static int rtw89_core_process_phy_status_ie(struct rtw89_dev *rtwdev,
const struct rtw89_phy_sts_iehdr *iehdr,
struct rtw89_rx_phy_ppdu *phy_ppdu) struct rtw89_rx_phy_ppdu *phy_ppdu)
{ {
u8 ie; u8 ie;
ie = RTW89_GET_PHY_STS_IE_TYPE(addr); ie = le32_get_bits(iehdr->w0, RTW89_PHY_STS_IEHDR_TYPE);
switch (ie) { switch (ie) {
case RTW89_PHYSTS_IE01_CMN_OFDM: case RTW89_PHYSTS_IE01_CMN_OFDM:
rtw89_core_parse_phy_status_ie01(rtwdev, addr, phy_ppdu); rtw89_core_parse_phy_status_ie01(rtwdev, iehdr, phy_ppdu);
break; break;
default: default:
break; break;
...@@ -1349,21 +1353,26 @@ static int rtw89_core_process_phy_status_ie(struct rtw89_dev *rtwdev, u8 *addr, ...@@ -1349,21 +1353,26 @@ static int rtw89_core_process_phy_status_ie(struct rtw89_dev *rtwdev, u8 *addr,
static void rtw89_core_update_phy_ppdu(struct rtw89_rx_phy_ppdu *phy_ppdu) static void rtw89_core_update_phy_ppdu(struct rtw89_rx_phy_ppdu *phy_ppdu)
{ {
const struct rtw89_phy_sts_hdr *hdr = phy_ppdu->buf;
u8 *rssi = phy_ppdu->rssi; u8 *rssi = phy_ppdu->rssi;
u8 *buf = phy_ppdu->buf;
phy_ppdu->ie = RTW89_GET_PHY_STS_IE_MAP(buf); phy_ppdu->ie = le32_get_bits(hdr->w0, RTW89_PHY_STS_HDR_W0_IE_MAP);
phy_ppdu->rssi_avg = RTW89_GET_PHY_STS_RSSI_AVG(buf); phy_ppdu->rssi_avg = le32_get_bits(hdr->w0, RTW89_PHY_STS_HDR_W0_RSSI_AVG);
rssi[RF_PATH_A] = RTW89_GET_PHY_STS_RSSI_A(buf); rssi[RF_PATH_A] = le32_get_bits(hdr->w1, RTW89_PHY_STS_HDR_W1_RSSI_A);
rssi[RF_PATH_B] = RTW89_GET_PHY_STS_RSSI_B(buf); rssi[RF_PATH_B] = le32_get_bits(hdr->w1, RTW89_PHY_STS_HDR_W1_RSSI_B);
rssi[RF_PATH_C] = RTW89_GET_PHY_STS_RSSI_C(buf); rssi[RF_PATH_C] = le32_get_bits(hdr->w1, RTW89_PHY_STS_HDR_W1_RSSI_C);
rssi[RF_PATH_D] = RTW89_GET_PHY_STS_RSSI_D(buf); rssi[RF_PATH_D] = le32_get_bits(hdr->w1, RTW89_PHY_STS_HDR_W1_RSSI_D);
} }
static int rtw89_core_rx_process_phy_ppdu(struct rtw89_dev *rtwdev, static int rtw89_core_rx_process_phy_ppdu(struct rtw89_dev *rtwdev,
struct rtw89_rx_phy_ppdu *phy_ppdu) struct rtw89_rx_phy_ppdu *phy_ppdu)
{ {
if (RTW89_GET_PHY_STS_LEN(phy_ppdu->buf) << 3 != phy_ppdu->len) { const struct rtw89_phy_sts_hdr *hdr = phy_ppdu->buf;
u32 len_from_header;
len_from_header = le32_get_bits(hdr->w0, RTW89_PHY_STS_HDR_W0_LEN) << 3;
if (len_from_header != phy_ppdu->len) {
rtw89_debug(rtwdev, RTW89_DBG_UNEXP, "phy ppdu len mismatch\n"); rtw89_debug(rtwdev, RTW89_DBG_UNEXP, "phy ppdu len mismatch\n");
return -EINVAL; return -EINVAL;
} }
...@@ -1376,17 +1385,19 @@ static int rtw89_core_rx_parse_phy_sts(struct rtw89_dev *rtwdev, ...@@ -1376,17 +1385,19 @@ static int rtw89_core_rx_parse_phy_sts(struct rtw89_dev *rtwdev,
struct rtw89_rx_phy_ppdu *phy_ppdu) struct rtw89_rx_phy_ppdu *phy_ppdu)
{ {
u16 ie_len; u16 ie_len;
u8 *pos, *end; void *pos, *end;
/* mark invalid reports and bypass them */ /* mark invalid reports and bypass them */
if (phy_ppdu->ie < RTW89_CCK_PKT) if (phy_ppdu->ie < RTW89_CCK_PKT)
return -EINVAL; return -EINVAL;
pos = (u8 *)phy_ppdu->buf + PHY_STS_HDR_LEN; pos = phy_ppdu->buf + PHY_STS_HDR_LEN;
end = (u8 *)phy_ppdu->buf + phy_ppdu->len; end = phy_ppdu->buf + phy_ppdu->len;
while (pos < end) { while (pos < end) {
ie_len = rtw89_core_get_phy_status_ie_len(rtwdev, pos); const struct rtw89_phy_sts_iehdr *iehdr = pos;
rtw89_core_process_phy_status_ie(rtwdev, pos, phy_ppdu);
ie_len = rtw89_core_get_phy_status_ie_len(rtwdev, iehdr);
rtw89_core_process_phy_status_ie(rtwdev, iehdr, phy_ppdu);
pos += ie_len; pos += ie_len;
if (pos > end || ie_len == 0) { if (pos > end || ie_len == 0) {
rtw89_debug(rtwdev, RTW89_DBG_TXRX, rtw89_debug(rtwdev, RTW89_DBG_TXRX,
......
...@@ -550,7 +550,7 @@ struct rtw89_rate_desc { ...@@ -550,7 +550,7 @@ struct rtw89_rate_desc {
#define RF_PATH_MAX 4 #define RF_PATH_MAX 4
#define RTW89_MAX_PPDU_CNT 8 #define RTW89_MAX_PPDU_CNT 8
struct rtw89_rx_phy_ppdu { struct rtw89_rx_phy_ppdu {
u8 *buf; void *buf;
u32 len; u32 len;
u8 rssi_avg; u8 rssi_avg;
u8 rssi[RF_PATH_MAX]; u8 rssi[RF_PATH_MAX];
......
...@@ -277,24 +277,25 @@ struct rtw89_rxinfo { ...@@ -277,24 +277,25 @@ struct rtw89_rxinfo {
#define RTW89_RXINFO_W1_SERVICE GENMASK(15, 0) #define RTW89_RXINFO_W1_SERVICE GENMASK(15, 0)
#define RTW89_RXINFO_W1_PLCP_LEN GENMASK(23, 16) #define RTW89_RXINFO_W1_PLCP_LEN GENMASK(23, 16)
#define RTW89_GET_PHY_STS_IE_MAP(sts) \ struct rtw89_phy_sts_hdr {
le32_get_bits(*((const __le32 *)(sts)), GENMASK(4, 0)) __le32 w0;
#define RTW89_GET_PHY_STS_RSSI_A(sts) \ __le32 w1;
le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(7, 0)) } __packed;
#define RTW89_GET_PHY_STS_RSSI_B(sts) \
le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(15, 8)) #define RTW89_PHY_STS_HDR_W0_IE_MAP GENMASK(4, 0)
#define RTW89_GET_PHY_STS_RSSI_C(sts) \ #define RTW89_PHY_STS_HDR_W0_LEN GENMASK(15, 8)
le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(23, 16)) #define RTW89_PHY_STS_HDR_W0_RSSI_AVG GENMASK(31, 24)
#define RTW89_GET_PHY_STS_RSSI_D(sts) \ #define RTW89_PHY_STS_HDR_W1_RSSI_A GENMASK(7, 0)
le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(31, 24)) #define RTW89_PHY_STS_HDR_W1_RSSI_B GENMASK(15, 8)
#define RTW89_GET_PHY_STS_LEN(sts) \ #define RTW89_PHY_STS_HDR_W1_RSSI_C GENMASK(23, 16)
le32_get_bits(*((const __le32 *)sts), GENMASK(15, 8)) #define RTW89_PHY_STS_HDR_W1_RSSI_D GENMASK(31, 24)
#define RTW89_GET_PHY_STS_RSSI_AVG(sts) \
le32_get_bits(*((const __le32 *)sts), GENMASK(31, 24)) struct rtw89_phy_sts_iehdr {
#define RTW89_GET_PHY_STS_IE_TYPE(ie) \ __le32 w0;
le32_get_bits(*((const __le32 *)ie), GENMASK(4, 0)) };
#define RTW89_GET_PHY_STS_IE_LEN(ie) \
le32_get_bits(*((const __le32 *)ie), GENMASK(11, 5)) #define RTW89_PHY_STS_IEHDR_TYPE GENMASK(4, 0)
#define RTW89_PHY_STS_IEHDR_LEN GENMASK(11, 5)
struct rtw89_phy_sts_ie0 { struct rtw89_phy_sts_ie0 {
__le32 w0; __le32 w0;
......
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