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

wifi: rtw89: use struct to access firmware C2H event header

Firmware C2H events contain two-word header which can indicate category,
class, function and length of received events. Use struct to access them,
and 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/20230728070252.66525-7-pkshih@realtek.com
parent c97683ff
...@@ -2809,12 +2809,13 @@ void rtw89_fw_free_all_early_h2c(struct rtw89_dev *rtwdev) ...@@ -2809,12 +2809,13 @@ void rtw89_fw_free_all_early_h2c(struct rtw89_dev *rtwdev)
static void rtw89_fw_c2h_parse_attr(struct sk_buff *c2h) static void rtw89_fw_c2h_parse_attr(struct sk_buff *c2h)
{ {
const struct rtw89_c2h_hdr *hdr = (const struct rtw89_c2h_hdr *)c2h->data;
struct rtw89_fw_c2h_attr *attr = RTW89_SKB_C2H_CB(c2h); struct rtw89_fw_c2h_attr *attr = RTW89_SKB_C2H_CB(c2h);
attr->category = RTW89_GET_C2H_CATEGORY(c2h->data); attr->category = le32_get_bits(hdr->w0, RTW89_C2H_HDR_W0_CATEGORY);
attr->class = RTW89_GET_C2H_CLASS(c2h->data); attr->class = le32_get_bits(hdr->w0, RTW89_C2H_HDR_W0_CLASS);
attr->func = RTW89_GET_C2H_FUNC(c2h->data); attr->func = le32_get_bits(hdr->w0, RTW89_C2H_HDR_W0_FUNC);
attr->len = RTW89_GET_C2H_LEN(c2h->data); attr->len = le32_get_bits(hdr->w1, RTW89_C2H_HDR_W1_LEN);
} }
static bool rtw89_fw_c2h_chk_atomic(struct rtw89_dev *rtwdev, static bool rtw89_fw_c2h_chk_atomic(struct rtw89_dev *rtwdev,
......
...@@ -3101,14 +3101,15 @@ inline void RTW89_SET_FWCMD_MCC_SET_DURATION_DURATION_Y(void *cmd, u32 val) ...@@ -3101,14 +3101,15 @@ inline void RTW89_SET_FWCMD_MCC_SET_DURATION_DURATION_Y(void *cmd, u32 val)
#define RTW89_C2H_HEADER_LEN 8 #define RTW89_C2H_HEADER_LEN 8
#define RTW89_GET_C2H_CATEGORY(c2h) \ struct rtw89_c2h_hdr {
le32_get_bits(*((const __le32 *)c2h), GENMASK(1, 0)) __le32 w0;
#define RTW89_GET_C2H_CLASS(c2h) \ __le32 w1;
le32_get_bits(*((const __le32 *)c2h), GENMASK(7, 2)) } __packed;
#define RTW89_GET_C2H_FUNC(c2h) \
le32_get_bits(*((const __le32 *)c2h), GENMASK(15, 8)) #define RTW89_C2H_HDR_W0_CATEGORY GENMASK(1, 0)
#define RTW89_GET_C2H_LEN(c2h) \ #define RTW89_C2H_HDR_W0_CLASS GENMASK(7, 2)
le32_get_bits(*((const __le32 *)(c2h) + 1), GENMASK(13, 0)) #define RTW89_C2H_HDR_W0_FUNC GENMASK(15, 8)
#define RTW89_C2H_HDR_W1_LEN GENMASK(13, 0)
struct rtw89_fw_c2h_attr { struct rtw89_fw_c2h_attr {
u8 category; u8 category;
......
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