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

rtw89: use inline function instead macro to set H2C and CAM

In order to use compiler to check if we do improper cast of const* on
arguments of inline function.
Signed-off-by: default avatarPing-Ke Shih <pkshih@realtek.com>
Tested-by: default avatarTakashi Iwai <tiwai@suse.de>
Tested-by: default avatarLarry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
Link: https://lore.kernel.org/r/20211119054512.10620-4-pkshih@realtek.com
parent 321e763c
......@@ -9,140 +9,340 @@
#define RTW89_SEC_CAM_LEN 20
#define FWCMD_SET_ADDR_IDX(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_OFFSET(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_LEN(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_VALID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, BIT(0))
#define FWCMD_SET_ADDR_NET_TYPE(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(2, 1))
#define FWCMD_SET_ADDR_BCN_HIT_COND(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(4, 3))
#define FWCMD_SET_ADDR_HIT_RULE(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(6, 5))
#define FWCMD_SET_ADDR_BB_SEL(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, BIT(7))
#define FWCMD_SET_ADDR_ADDR_MASK(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(13, 8))
#define FWCMD_SET_ADDR_MASK_SEL(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(15, 14))
#define FWCMD_SET_ADDR_SMA_HASH(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_TMA_HASH(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_BSSID_CAM_IDX(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 3, value, GENMASK(5, 0))
#define FWCMD_SET_ADDR_SMA0(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_SMA1(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_SMA2(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_SMA3(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_SMA4(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_SMA5(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_TMA0(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_TMA1(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_TMA2(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_TMA3(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_TMA4(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_TMA5(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_MACID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_PORT_INT(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(10, 8))
#define FWCMD_SET_ADDR_TSF_SYNC(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(13, 11))
#define FWCMD_SET_ADDR_TF_TRS(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, BIT(14))
#define FWCMD_SET_ADDR_LSIG_TXOP(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, BIT(15))
#define FWCMD_SET_ADDR_TGT_IND(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(26, 24))
#define FWCMD_SET_ADDR_FRM_TGT_IND(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(29, 27))
#define FWCMD_SET_ADDR_AID12(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(11, 0))
#define FWCMD_SET_ADDR_AID12_0(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_AID12_1(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(11, 8))
#define FWCMD_SET_ADDR_WOL_PATTERN(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(12))
#define FWCMD_SET_ADDR_WOL_UC(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(13))
#define FWCMD_SET_ADDR_WOL_MAGIC(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(14))
#define FWCMD_SET_ADDR_WAPI(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(15))
#define FWCMD_SET_ADDR_SEC_ENT_MODE(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(17, 16))
#define FWCMD_SET_ADDR_SEC_ENT0_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(19, 18))
#define FWCMD_SET_ADDR_SEC_ENT1_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(21, 20))
#define FWCMD_SET_ADDR_SEC_ENT2_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(23, 22))
#define FWCMD_SET_ADDR_SEC_ENT3_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(25, 24))
#define FWCMD_SET_ADDR_SEC_ENT4_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(27, 26))
#define FWCMD_SET_ADDR_SEC_ENT5_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(29, 28))
#define FWCMD_SET_ADDR_SEC_ENT6_KEYID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(31, 30))
#define FWCMD_SET_ADDR_SEC_ENT_VALID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_SEC_ENT0(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_SEC_ENT1(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_SEC_ENT2(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_SEC_ENT3(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_SEC_ENT4(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_SEC_ENT5(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_SEC_ENT6(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_BSSID_IDX(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_BSSID_OFFSET(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_BSSID_LEN(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_BSSID_VALID(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 13, value, BIT(0))
#define FWCMD_SET_ADDR_BSSID_BB_SEL(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 13, value, BIT(1))
#define FWCMD_SET_ADDR_BSSID_BSS_COLOR(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(13, 8))
#define FWCMD_SET_ADDR_BSSID_BSSID0(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_BSSID_BSSID1(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(31, 24))
#define FWCMD_SET_ADDR_BSSID_BSSID2(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(7, 0))
#define FWCMD_SET_ADDR_BSSID_BSSID3(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(15, 8))
#define FWCMD_SET_ADDR_BSSID_BSSID4(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(23, 16))
#define FWCMD_SET_ADDR_BSSID_BSSID5(cmd, value) \
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(31, 24))
static inline void FWCMD_SET_ADDR_IDX(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_OFFSET(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_LEN(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 1, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_VALID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, BIT(0));
}
static inline void FWCMD_SET_ADDR_NET_TYPE(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(2, 1));
}
static inline void FWCMD_SET_ADDR_BCN_HIT_COND(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(4, 3));
}
static inline void FWCMD_SET_ADDR_HIT_RULE(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(6, 5));
}
static inline void FWCMD_SET_ADDR_BB_SEL(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, BIT(7));
}
static inline void FWCMD_SET_ADDR_ADDR_MASK(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(13, 8));
}
static inline void FWCMD_SET_ADDR_MASK_SEL(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(15, 14));
}
static inline void FWCMD_SET_ADDR_SMA_HASH(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_TMA_HASH(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 2, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_BSSID_CAM_IDX(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 3, value, GENMASK(5, 0));
}
static inline void FWCMD_SET_ADDR_SMA0(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_SMA1(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_SMA2(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_SMA3(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 4, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_SMA4(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_SMA5(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_TMA0(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_TMA1(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 5, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_TMA2(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_TMA3(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_TMA4(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_TMA5(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 6, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_MACID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_PORT_INT(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(10, 8));
}
static inline void FWCMD_SET_ADDR_TSF_SYNC(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(13, 11));
}
static inline void FWCMD_SET_ADDR_TF_TRS(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, BIT(14));
}
static inline void FWCMD_SET_ADDR_LSIG_TXOP(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, BIT(15));
}
static inline void FWCMD_SET_ADDR_TGT_IND(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(26, 24));
}
static inline void FWCMD_SET_ADDR_FRM_TGT_IND(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 8, value, GENMASK(29, 27));
}
static inline void FWCMD_SET_ADDR_AID12(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(11, 0));
}
static inline void FWCMD_SET_ADDR_AID12_0(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_AID12_1(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(11, 8));
}
static inline void FWCMD_SET_ADDR_WOL_PATTERN(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(12));
}
static inline void FWCMD_SET_ADDR_WOL_UC(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(13));
}
static inline void FWCMD_SET_ADDR_WOL_MAGIC(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(14));
}
static inline void FWCMD_SET_ADDR_WAPI(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, BIT(15));
}
static inline void FWCMD_SET_ADDR_SEC_ENT_MODE(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(17, 16));
}
static inline void FWCMD_SET_ADDR_SEC_ENT0_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(19, 18));
}
static inline void FWCMD_SET_ADDR_SEC_ENT1_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(21, 20));
}
static inline void FWCMD_SET_ADDR_SEC_ENT2_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(23, 22));
}
static inline void FWCMD_SET_ADDR_SEC_ENT3_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(25, 24));
}
static inline void FWCMD_SET_ADDR_SEC_ENT4_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(27, 26));
}
static inline void FWCMD_SET_ADDR_SEC_ENT5_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(29, 28));
}
static inline void FWCMD_SET_ADDR_SEC_ENT6_KEYID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 9, value, GENMASK(31, 30));
}
static inline void FWCMD_SET_ADDR_SEC_ENT_VALID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_SEC_ENT0(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_SEC_ENT1(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_SEC_ENT2(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 10, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_SEC_ENT3(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_SEC_ENT4(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_SEC_ENT5(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_SEC_ENT6(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 11, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_BSSID_IDX(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_BSSID_OFFSET(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_BSSID_LEN(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 12, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_BSSID_VALID(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 13, value, BIT(0));
}
static inline void FWCMD_SET_ADDR_BSSID_BB_SEL(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 13, value, BIT(1));
}
static inline void FWCMD_SET_ADDR_BSSID_BSS_COLOR(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(13, 8));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID0(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID1(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 13, value, GENMASK(31, 24));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID2(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(7, 0));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID3(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(15, 8));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID4(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(23, 16));
}
static inline void FWCMD_SET_ADDR_BSSID_BSSID5(void *cmd, u32 value)
{
le32p_replace_bits((__le32 *)(cmd) + 14, value, GENMASK(31, 24));
}
int rtw89_cam_init(struct rtw89_dev *rtwdev, struct rtw89_vif *vif);
void rtw89_cam_deinit(struct rtw89_dev *rtwdev, struct rtw89_vif *vif);
......
......@@ -156,96 +156,225 @@ struct rtw89_h2creg_sch_tx_en {
u16 rsvd:15;
} __packed;
#define RTW89_SET_FWCMD_RA_IS_DIS(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(0))
#define RTW89_SET_FWCMD_RA_MODE(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(5, 1))
#define RTW89_SET_FWCMD_RA_BW_CAP(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(7, 6))
#define RTW89_SET_FWCMD_RA_MACID(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(15, 8))
#define RTW89_SET_FWCMD_RA_DCM(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(16))
#define RTW89_SET_FWCMD_RA_ER(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(17))
#define RTW89_SET_FWCMD_RA_INIT_RATE_LV(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(19, 18))
#define RTW89_SET_FWCMD_RA_UPD_ALL(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(20))
#define RTW89_SET_FWCMD_RA_SGI(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(21))
#define RTW89_SET_FWCMD_RA_LDPC(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(22))
#define RTW89_SET_FWCMD_RA_STBC(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(23))
#define RTW89_SET_FWCMD_RA_SS_NUM(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(26, 24))
#define RTW89_SET_FWCMD_RA_GILTF(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(29, 27))
#define RTW89_SET_FWCMD_RA_UPD_BW_NSS_MASK(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(30))
#define RTW89_SET_FWCMD_RA_UPD_MASK(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(31))
#define RTW89_SET_FWCMD_RA_MASK_0(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_RA_MASK_1(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(15, 8))
#define RTW89_SET_FWCMD_RA_MASK_2(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(23, 16))
#define RTW89_SET_FWCMD_RA_MASK_3(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(31, 24))
#define RTW89_SET_FWCMD_RA_MASK_4(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_RA_BFEE_CSI_CTL(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, BIT(31))
#define RTW89_SET_FWCMD_RA_BAND_NUM(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_RA_RA_CSI_RATE_EN(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(8))
#define RTW89_SET_FWCMD_RA_FIXED_CSI_RATE_EN(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(9))
#define RTW89_SET_FWCMD_RA_CR_TBL_SEL(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(10))
#define RTW89_SET_FWCMD_RA_FIXED_CSI_MCS_SS_IDX(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(23, 16))
#define RTW89_SET_FWCMD_RA_FIXED_CSI_MODE(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(25, 24))
#define RTW89_SET_FWCMD_RA_FIXED_CSI_GI_LTF(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(28, 26))
#define RTW89_SET_FWCMD_RA_FIXED_CSI_BW(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(31, 29))
#define RTW89_SET_FWCMD_SEC_IDX(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_SEC_OFFSET(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(15, 8))
#define RTW89_SET_FWCMD_SEC_LEN(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(23, 16))
#define RTW89_SET_FWCMD_SEC_TYPE(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(3, 0))
#define RTW89_SET_FWCMD_SEC_EXT_KEY(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, BIT(4))
#define RTW89_SET_FWCMD_SEC_SPP_MODE(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, BIT(5))
#define RTW89_SET_FWCMD_SEC_KEY0(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, GENMASK(31, 0))
#define RTW89_SET_FWCMD_SEC_KEY1(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(31, 0))
#define RTW89_SET_FWCMD_SEC_KEY2(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x04, val, GENMASK(31, 0))
#define RTW89_SET_FWCMD_SEC_KEY3(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x05, val, GENMASK(31, 0))
#define RTW89_SET_EDCA_SEL(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(1, 0))
#define RTW89_SET_EDCA_BAND(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(3))
#define RTW89_SET_EDCA_WMM(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(4))
#define RTW89_SET_EDCA_AC(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(6, 5))
#define RTW89_SET_EDCA_PARAM(cmd, val) \
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(31, 0))
static inline void RTW89_SET_FWCMD_RA_IS_DIS(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(0));
}
static inline void RTW89_SET_FWCMD_RA_MODE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(5, 1));
}
static inline void RTW89_SET_FWCMD_RA_BW_CAP(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(7, 6));
}
static inline void RTW89_SET_FWCMD_RA_MACID(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(15, 8));
}
static inline void RTW89_SET_FWCMD_RA_DCM(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(16));
}
static inline void RTW89_SET_FWCMD_RA_ER(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(17));
}
static inline void RTW89_SET_FWCMD_RA_INIT_RATE_LV(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(19, 18));
}
static inline void RTW89_SET_FWCMD_RA_UPD_ALL(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(20));
}
static inline void RTW89_SET_FWCMD_RA_SGI(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(21));
}
static inline void RTW89_SET_FWCMD_RA_LDPC(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(22));
}
static inline void RTW89_SET_FWCMD_RA_STBC(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(23));
}
static inline void RTW89_SET_FWCMD_RA_SS_NUM(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(26, 24));
}
static inline void RTW89_SET_FWCMD_RA_GILTF(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(29, 27));
}
static inline void RTW89_SET_FWCMD_RA_UPD_BW_NSS_MASK(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(30));
}
static inline void RTW89_SET_FWCMD_RA_UPD_MASK(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(31));
}
static inline void RTW89_SET_FWCMD_RA_MASK_0(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_RA_MASK_1(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(15, 8));
}
static inline void RTW89_SET_FWCMD_RA_MASK_2(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(23, 16));
}
static inline void RTW89_SET_FWCMD_RA_MASK_3(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(31, 24));
}
static inline void RTW89_SET_FWCMD_RA_MASK_4(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_RA_BFEE_CSI_CTL(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, BIT(31));
}
static inline void RTW89_SET_FWCMD_RA_BAND_NUM(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_RA_RA_CSI_RATE_EN(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(8));
}
static inline void RTW89_SET_FWCMD_RA_FIXED_CSI_RATE_EN(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(9));
}
static inline void RTW89_SET_FWCMD_RA_CR_TBL_SEL(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, BIT(10));
}
static inline void RTW89_SET_FWCMD_RA_FIXED_CSI_MCS_SS_IDX(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(23, 16));
}
static inline void RTW89_SET_FWCMD_RA_FIXED_CSI_MODE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(25, 24));
}
static inline void RTW89_SET_FWCMD_RA_FIXED_CSI_GI_LTF(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(28, 26));
}
static inline void RTW89_SET_FWCMD_RA_FIXED_CSI_BW(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(31, 29));
}
static inline void RTW89_SET_FWCMD_SEC_IDX(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_SEC_OFFSET(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(15, 8));
}
static inline void RTW89_SET_FWCMD_SEC_LEN(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(23, 16));
}
static inline void RTW89_SET_FWCMD_SEC_TYPE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(3, 0));
}
static inline void RTW89_SET_FWCMD_SEC_EXT_KEY(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, BIT(4));
}
static inline void RTW89_SET_FWCMD_SEC_SPP_MODE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, BIT(5));
}
static inline void RTW89_SET_FWCMD_SEC_KEY0(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x02, val, GENMASK(31, 0));
}
static inline void RTW89_SET_FWCMD_SEC_KEY1(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x03, val, GENMASK(31, 0));
}
static inline void RTW89_SET_FWCMD_SEC_KEY2(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x04, val, GENMASK(31, 0));
}
static inline void RTW89_SET_FWCMD_SEC_KEY3(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x05, val, GENMASK(31, 0));
}
static inline void RTW89_SET_EDCA_SEL(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(1, 0));
}
static inline void RTW89_SET_EDCA_BAND(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(3));
}
static inline void RTW89_SET_EDCA_WMM(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, BIT(4));
}
static inline void RTW89_SET_EDCA_AC(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x00, val, GENMASK(6, 5));
}
static inline void RTW89_SET_EDCA_PARAM(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)(cmd) + 0x01, val, GENMASK(31, 0));
}
#define FW_EDCA_PARAM_TXOPLMT_MSK GENMASK(26, 16)
#define FW_EDCA_PARAM_CWMAX_MSK GENMASK(15, 12)
#define FW_EDCA_PARAM_CWMIN_MSK GENMASK(11, 8)
......@@ -287,732 +416,865 @@ static inline void SET_FW_HDR_PART_SIZE(void *fwhdr, u32 val)
le32p_replace_bits((__le32 *)fwhdr + 7, val, GENMASK(15, 0));
}
#define SET_CTRL_INFO_MACID(table, val) \
le32p_replace_bits((__le32 *)(table) + 0, val, GENMASK(6, 0))
#define SET_CTRL_INFO_OPERATION(table, val) \
le32p_replace_bits((__le32 *)(table) + 0, val, BIT(7))
static inline void SET_CTRL_INFO_MACID(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 0, val, GENMASK(6, 0));
}
static inline void SET_CTRL_INFO_OPERATION(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 0, val, BIT(7));
}
#define SET_CMC_TBL_MASK_DATARATE GENMASK(8, 0)
#define SET_CMC_TBL_DATARATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(8, 0)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATARATE, \
GENMASK(8, 0)); \
} while (0)
static inline void SET_CMC_TBL_DATARATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(8, 0));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATARATE,
GENMASK(8, 0));
}
#define SET_CMC_TBL_MASK_FORCE_TXOP BIT(0)
#define SET_CMC_TBL_FORCE_TXOP(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(9)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_FORCE_TXOP, \
BIT(9)); \
} while (0)
static inline void SET_CMC_TBL_FORCE_TXOP(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(9));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_FORCE_TXOP,
BIT(9));
}
#define SET_CMC_TBL_MASK_DATA_BW GENMASK(1, 0)
#define SET_CMC_TBL_DATA_BW(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(11, 10)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATA_BW, \
GENMASK(11, 10)); \
} while (0)
static inline void SET_CMC_TBL_DATA_BW(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(11, 10));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATA_BW,
GENMASK(11, 10));
}
#define SET_CMC_TBL_MASK_DATA_GI_LTF GENMASK(2, 0)
#define SET_CMC_TBL_DATA_GI_LTF(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(14, 12)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATA_GI_LTF, \
GENMASK(14, 12)); \
} while (0)
static inline void SET_CMC_TBL_DATA_GI_LTF(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(14, 12));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DATA_GI_LTF,
GENMASK(14, 12));
}
#define SET_CMC_TBL_MASK_DARF_TC_INDEX BIT(0)
#define SET_CMC_TBL_DARF_TC_INDEX(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(15)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DARF_TC_INDEX, \
BIT(15)); \
} while (0)
static inline void SET_CMC_TBL_DARF_TC_INDEX(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(15));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DARF_TC_INDEX,
BIT(15));
}
#define SET_CMC_TBL_MASK_ARFR_CTRL GENMASK(3, 0)
#define SET_CMC_TBL_ARFR_CTRL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(19, 16)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ARFR_CTRL, \
GENMASK(19, 16)); \
} while (0)
static inline void SET_CMC_TBL_ARFR_CTRL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(19, 16));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ARFR_CTRL,
GENMASK(19, 16));
}
#define SET_CMC_TBL_MASK_ACQ_RPT_EN BIT(0)
#define SET_CMC_TBL_ACQ_RPT_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(20)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ACQ_RPT_EN, \
BIT(20)); \
} while (0)
static inline void SET_CMC_TBL_ACQ_RPT_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(20));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ACQ_RPT_EN,
BIT(20));
}
#define SET_CMC_TBL_MASK_MGQ_RPT_EN BIT(0)
#define SET_CMC_TBL_MGQ_RPT_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(21)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_MGQ_RPT_EN, \
BIT(21)); \
} while (0)
static inline void SET_CMC_TBL_MGQ_RPT_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(21));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_MGQ_RPT_EN,
BIT(21));
}
#define SET_CMC_TBL_MASK_ULQ_RPT_EN BIT(0)
#define SET_CMC_TBL_ULQ_RPT_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(22)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ULQ_RPT_EN, \
BIT(22)); \
} while (0)
static inline void SET_CMC_TBL_ULQ_RPT_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(22));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_ULQ_RPT_EN,
BIT(22));
}
#define SET_CMC_TBL_MASK_TWTQ_RPT_EN BIT(0)
#define SET_CMC_TBL_TWTQ_RPT_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(23)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_TWTQ_RPT_EN, \
BIT(23)); \
} while (0)
static inline void SET_CMC_TBL_TWTQ_RPT_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(23));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_TWTQ_RPT_EN,
BIT(23));
}
#define SET_CMC_TBL_MASK_DISRTSFB BIT(0)
#define SET_CMC_TBL_DISRTSFB(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(25)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DISRTSFB, \
BIT(25)); \
} while (0)
static inline void SET_CMC_TBL_DISRTSFB(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(25));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DISRTSFB,
BIT(25));
}
#define SET_CMC_TBL_MASK_DISDATAFB BIT(0)
#define SET_CMC_TBL_DISDATAFB(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(26)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DISDATAFB, \
BIT(26)); \
} while (0)
static inline void SET_CMC_TBL_DISDATAFB(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(26));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_DISDATAFB,
BIT(26));
}
#define SET_CMC_TBL_MASK_TRYRATE BIT(0)
#define SET_CMC_TBL_TRYRATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(27)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_TRYRATE, \
BIT(27)); \
} while (0)
static inline void SET_CMC_TBL_TRYRATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, BIT(27));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_TRYRATE,
BIT(27));
}
#define SET_CMC_TBL_MASK_AMPDU_DENSITY GENMASK(3, 0)
#define SET_CMC_TBL_AMPDU_DENSITY(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(31, 28)); \
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_AMPDU_DENSITY, \
GENMASK(31, 28)); \
} while (0)
static inline void SET_CMC_TBL_AMPDU_DENSITY(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 1, val, GENMASK(31, 28));
le32p_replace_bits((__le32 *)(table) + 9, SET_CMC_TBL_MASK_AMPDU_DENSITY,
GENMASK(31, 28));
}
#define SET_CMC_TBL_MASK_DATA_RTY_LOWEST_RATE GENMASK(8, 0)
#define SET_CMC_TBL_DATA_RTY_LOWEST_RATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(8, 0)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_DATA_RTY_LOWEST_RATE, \
GENMASK(8, 0)); \
} while (0)
static inline void SET_CMC_TBL_DATA_RTY_LOWEST_RATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(8, 0));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_DATA_RTY_LOWEST_RATE,
GENMASK(8, 0));
}
#define SET_CMC_TBL_MASK_AMPDU_TIME_SEL BIT(0)
#define SET_CMC_TBL_AMPDU_TIME_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(9)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_AMPDU_TIME_SEL, \
BIT(9)); \
} while (0)
static inline void SET_CMC_TBL_AMPDU_TIME_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(9));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_AMPDU_TIME_SEL,
BIT(9));
}
#define SET_CMC_TBL_MASK_AMPDU_LEN_SEL BIT(0)
#define SET_CMC_TBL_AMPDU_LEN_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(10)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_AMPDU_LEN_SEL, \
BIT(10)); \
} while (0)
static inline void SET_CMC_TBL_AMPDU_LEN_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(10));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_AMPDU_LEN_SEL,
BIT(10));
}
#define SET_CMC_TBL_MASK_RTS_TXCNT_LMT_SEL BIT(0)
#define SET_CMC_TBL_RTS_TXCNT_LMT_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(11)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_TXCNT_LMT_SEL, \
BIT(11)); \
} while (0)
static inline void SET_CMC_TBL_RTS_TXCNT_LMT_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(11));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_TXCNT_LMT_SEL,
BIT(11));
}
#define SET_CMC_TBL_MASK_RTS_TXCNT_LMT GENMASK(3, 0)
#define SET_CMC_TBL_RTS_TXCNT_LMT(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(15, 12)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_TXCNT_LMT, \
GENMASK(15, 12)); \
} while (0)
static inline void SET_CMC_TBL_RTS_TXCNT_LMT(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(15, 12));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_TXCNT_LMT,
GENMASK(15, 12));
}
#define SET_CMC_TBL_MASK_RTSRATE GENMASK(8, 0)
#define SET_CMC_TBL_RTSRATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(24, 16)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTSRATE, \
GENMASK(24, 16)); \
} while (0)
static inline void SET_CMC_TBL_RTSRATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(24, 16));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTSRATE,
GENMASK(24, 16));
}
#define SET_CMC_TBL_MASK_VCS_STBC BIT(0)
#define SET_CMC_TBL_VCS_STBC(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(27)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_VCS_STBC, \
BIT(27)); \
} while (0)
static inline void SET_CMC_TBL_VCS_STBC(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, BIT(27));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_VCS_STBC,
BIT(27));
}
#define SET_CMC_TBL_MASK_RTS_RTY_LOWEST_RATE GENMASK(3, 0)
#define SET_CMC_TBL_RTS_RTY_LOWEST_RATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(31, 28)); \
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_RTY_LOWEST_RATE, \
GENMASK(31, 28)); \
} while (0)
static inline void SET_CMC_TBL_RTS_RTY_LOWEST_RATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 2, val, GENMASK(31, 28));
le32p_replace_bits((__le32 *)(table) + 10, SET_CMC_TBL_MASK_RTS_RTY_LOWEST_RATE,
GENMASK(31, 28));
}
#define SET_CMC_TBL_MASK_DATA_TX_CNT_LMT GENMASK(5, 0)
#define SET_CMC_TBL_DATA_TX_CNT_LMT(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(5, 0)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_DATA_TX_CNT_LMT, \
GENMASK(5, 0)); \
} while (0)
static inline void SET_CMC_TBL_DATA_TX_CNT_LMT(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(5, 0));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_DATA_TX_CNT_LMT,
GENMASK(5, 0));
}
#define SET_CMC_TBL_MASK_DATA_TXCNT_LMT_SEL BIT(0)
#define SET_CMC_TBL_DATA_TXCNT_LMT_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(6)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_DATA_TXCNT_LMT_SEL, \
BIT(6)); \
} while (0)
static inline void SET_CMC_TBL_DATA_TXCNT_LMT_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(6));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_DATA_TXCNT_LMT_SEL,
BIT(6));
}
#define SET_CMC_TBL_MASK_MAX_AGG_NUM_SEL BIT(0)
#define SET_CMC_TBL_MAX_AGG_NUM_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(7)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_MAX_AGG_NUM_SEL, \
BIT(7)); \
} while (0)
static inline void SET_CMC_TBL_MAX_AGG_NUM_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(7));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_MAX_AGG_NUM_SEL,
BIT(7));
}
#define SET_CMC_TBL_MASK_RTS_EN BIT(0)
#define SET_CMC_TBL_RTS_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(8)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_RTS_EN, \
BIT(8)); \
} while (0)
static inline void SET_CMC_TBL_RTS_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(8));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_RTS_EN,
BIT(8));
}
#define SET_CMC_TBL_MASK_CTS2SELF_EN BIT(0)
#define SET_CMC_TBL_CTS2SELF_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(9)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_CTS2SELF_EN, \
BIT(9)); \
} while (0)
static inline void SET_CMC_TBL_CTS2SELF_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(9));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_CTS2SELF_EN,
BIT(9));
}
#define SET_CMC_TBL_MASK_CCA_RTS GENMASK(1, 0)
#define SET_CMC_TBL_CCA_RTS(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(11, 10)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_CCA_RTS, \
GENMASK(11, 10)); \
} while (0)
static inline void SET_CMC_TBL_CCA_RTS(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(11, 10));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_CCA_RTS,
GENMASK(11, 10));
}
#define SET_CMC_TBL_MASK_HW_RTS_EN BIT(0)
#define SET_CMC_TBL_HW_RTS_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(12)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_HW_RTS_EN, \
BIT(12)); \
} while (0)
static inline void SET_CMC_TBL_HW_RTS_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(12));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_HW_RTS_EN,
BIT(12));
}
#define SET_CMC_TBL_MASK_RTS_DROP_DATA_MODE GENMASK(1, 0)
#define SET_CMC_TBL_RTS_DROP_DATA_MODE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(14, 13)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_RTS_DROP_DATA_MODE, \
GENMASK(14, 13)); \
} while (0)
static inline void SET_CMC_TBL_RTS_DROP_DATA_MODE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(14, 13));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_RTS_DROP_DATA_MODE,
GENMASK(14, 13));
}
#define SET_CMC_TBL_MASK_AMPDU_MAX_LEN GENMASK(10, 0)
#define SET_CMC_TBL_AMPDU_MAX_LEN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(26, 16)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_AMPDU_MAX_LEN, \
GENMASK(26, 16)); \
} while (0)
static inline void SET_CMC_TBL_AMPDU_MAX_LEN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(26, 16));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_AMPDU_MAX_LEN,
GENMASK(26, 16));
}
#define SET_CMC_TBL_MASK_UL_MU_DIS BIT(0)
#define SET_CMC_TBL_UL_MU_DIS(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(27)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_UL_MU_DIS, \
BIT(27)); \
} while (0)
static inline void SET_CMC_TBL_UL_MU_DIS(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, BIT(27));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_UL_MU_DIS,
BIT(27));
}
#define SET_CMC_TBL_MASK_AMPDU_MAX_TIME GENMASK(3, 0)
#define SET_CMC_TBL_AMPDU_MAX_TIME(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(31, 28)); \
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_AMPDU_MAX_TIME, \
GENMASK(31, 28)); \
} while (0)
static inline void SET_CMC_TBL_AMPDU_MAX_TIME(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 3, val, GENMASK(31, 28));
le32p_replace_bits((__le32 *)(table) + 11, SET_CMC_TBL_MASK_AMPDU_MAX_TIME,
GENMASK(31, 28));
}
#define SET_CMC_TBL_MASK_MAX_AGG_NUM GENMASK(7, 0)
#define SET_CMC_TBL_MAX_AGG_NUM(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(7, 0)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_MAX_AGG_NUM, \
GENMASK(7, 0)); \
} while (0)
static inline void SET_CMC_TBL_MAX_AGG_NUM(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(7, 0));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_MAX_AGG_NUM,
GENMASK(7, 0));
}
#define SET_CMC_TBL_MASK_BA_BMAP GENMASK(1, 0)
#define SET_CMC_TBL_BA_BMAP(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(9, 8)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BA_BMAP, \
GENMASK(9, 8)); \
} while (0)
static inline void SET_CMC_TBL_BA_BMAP(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(9, 8));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BA_BMAP,
GENMASK(9, 8));
}
#define SET_CMC_TBL_MASK_VO_LFTIME_SEL GENMASK(2, 0)
#define SET_CMC_TBL_VO_LFTIME_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(18, 16)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_VO_LFTIME_SEL, \
GENMASK(18, 16)); \
} while (0)
static inline void SET_CMC_TBL_VO_LFTIME_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(18, 16));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_VO_LFTIME_SEL,
GENMASK(18, 16));
}
#define SET_CMC_TBL_MASK_VI_LFTIME_SEL GENMASK(2, 0)
#define SET_CMC_TBL_VI_LFTIME_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(21, 19)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_VI_LFTIME_SEL, \
GENMASK(21, 19)); \
} while (0)
static inline void SET_CMC_TBL_VI_LFTIME_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(21, 19));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_VI_LFTIME_SEL,
GENMASK(21, 19));
}
#define SET_CMC_TBL_MASK_BE_LFTIME_SEL GENMASK(2, 0)
#define SET_CMC_TBL_BE_LFTIME_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(24, 22)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BE_LFTIME_SEL, \
GENMASK(24, 22)); \
} while (0)
static inline void SET_CMC_TBL_BE_LFTIME_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(24, 22));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BE_LFTIME_SEL,
GENMASK(24, 22));
}
#define SET_CMC_TBL_MASK_BK_LFTIME_SEL GENMASK(2, 0)
#define SET_CMC_TBL_BK_LFTIME_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(27, 25)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BK_LFTIME_SEL, \
GENMASK(27, 25)); \
} while (0)
static inline void SET_CMC_TBL_BK_LFTIME_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(27, 25));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_BK_LFTIME_SEL,
GENMASK(27, 25));
}
#define SET_CMC_TBL_MASK_SECTYPE GENMASK(3, 0)
#define SET_CMC_TBL_SECTYPE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(31, 28)); \
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_SECTYPE, \
GENMASK(31, 28)); \
} while (0)
static inline void SET_CMC_TBL_SECTYPE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 4, val, GENMASK(31, 28));
le32p_replace_bits((__le32 *)(table) + 12, SET_CMC_TBL_MASK_SECTYPE,
GENMASK(31, 28));
}
#define SET_CMC_TBL_MASK_MULTI_PORT_ID GENMASK(2, 0)
#define SET_CMC_TBL_MULTI_PORT_ID(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(2, 0)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_MULTI_PORT_ID, \
GENMASK(2, 0)); \
} while (0)
static inline void SET_CMC_TBL_MULTI_PORT_ID(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(2, 0));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_MULTI_PORT_ID,
GENMASK(2, 0));
}
#define SET_CMC_TBL_MASK_BMC BIT(0)
#define SET_CMC_TBL_BMC(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(3)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_BMC, \
BIT(3)); \
} while (0)
static inline void SET_CMC_TBL_BMC(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(3));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_BMC,
BIT(3));
}
#define SET_CMC_TBL_MASK_MBSSID GENMASK(3, 0)
#define SET_CMC_TBL_MBSSID(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(7, 4)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_MBSSID, \
GENMASK(7, 4)); \
} while (0)
static inline void SET_CMC_TBL_MBSSID(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(7, 4));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_MBSSID,
GENMASK(7, 4));
}
#define SET_CMC_TBL_MASK_NAVUSEHDR BIT(0)
#define SET_CMC_TBL_NAVUSEHDR(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(8)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_NAVUSEHDR, \
BIT(8)); \
} while (0)
static inline void SET_CMC_TBL_NAVUSEHDR(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(8));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_NAVUSEHDR,
BIT(8));
}
#define SET_CMC_TBL_MASK_TXPWR_MODE GENMASK(2, 0)
#define SET_CMC_TBL_TXPWR_MODE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(11, 9)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_TXPWR_MODE, \
GENMASK(11, 9)); \
} while (0)
static inline void SET_CMC_TBL_TXPWR_MODE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(11, 9));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_TXPWR_MODE,
GENMASK(11, 9));
}
#define SET_CMC_TBL_MASK_DATA_DCM BIT(0)
#define SET_CMC_TBL_DATA_DCM(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(12)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_DCM, \
BIT(12)); \
} while (0)
static inline void SET_CMC_TBL_DATA_DCM(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(12));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_DCM,
BIT(12));
}
#define SET_CMC_TBL_MASK_DATA_ER BIT(0)
#define SET_CMC_TBL_DATA_ER(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(13)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_ER, \
BIT(13)); \
} while (0)
static inline void SET_CMC_TBL_DATA_ER(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(13));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_ER,
BIT(13));
}
#define SET_CMC_TBL_MASK_DATA_LDPC BIT(0)
#define SET_CMC_TBL_DATA_LDPC(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(14)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_LDPC, \
BIT(14)); \
} while (0)
static inline void SET_CMC_TBL_DATA_LDPC(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(14));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_LDPC,
BIT(14));
}
#define SET_CMC_TBL_MASK_DATA_STBC BIT(0)
#define SET_CMC_TBL_DATA_STBC(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(15)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_STBC, \
BIT(15)); \
} while (0)
static inline void SET_CMC_TBL_DATA_STBC(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(15));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_STBC,
BIT(15));
}
#define SET_CMC_TBL_MASK_A_CTRL_BQR BIT(0)
#define SET_CMC_TBL_A_CTRL_BQR(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(16)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_BQR, \
BIT(16)); \
} while (0)
static inline void SET_CMC_TBL_A_CTRL_BQR(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(16));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_BQR,
BIT(16));
}
#define SET_CMC_TBL_MASK_A_CTRL_UPH BIT(0)
#define SET_CMC_TBL_A_CTRL_UPH(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(17)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_UPH, \
BIT(17)); \
} while (0)
static inline void SET_CMC_TBL_A_CTRL_UPH(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(17));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_UPH,
BIT(17));
}
#define SET_CMC_TBL_MASK_A_CTRL_BSR BIT(0)
#define SET_CMC_TBL_A_CTRL_BSR(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(18)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_BSR, \
BIT(18)); \
} while (0)
static inline void SET_CMC_TBL_A_CTRL_BSR(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(18));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_BSR,
BIT(18));
}
#define SET_CMC_TBL_MASK_A_CTRL_CAS BIT(0)
#define SET_CMC_TBL_A_CTRL_CAS(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(19)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_CAS, \
BIT(19)); \
} while (0)
static inline void SET_CMC_TBL_A_CTRL_CAS(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(19));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_A_CTRL_CAS,
BIT(19));
}
#define SET_CMC_TBL_MASK_DATA_BW_ER BIT(0)
#define SET_CMC_TBL_DATA_BW_ER(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(20)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_BW_ER, \
BIT(20)); \
} while (0)
static inline void SET_CMC_TBL_DATA_BW_ER(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(20));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_DATA_BW_ER,
BIT(20));
}
#define SET_CMC_TBL_MASK_LSIG_TXOP_EN BIT(0)
#define SET_CMC_TBL_LSIG_TXOP_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(21)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_LSIG_TXOP_EN, \
BIT(21)); \
} while (0)
static inline void SET_CMC_TBL_LSIG_TXOP_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(21));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_LSIG_TXOP_EN,
BIT(21));
}
#define SET_CMC_TBL_MASK_CTRL_CNT_VLD BIT(0)
#define SET_CMC_TBL_CTRL_CNT_VLD(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(27)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_CTRL_CNT_VLD, \
BIT(27)); \
} while (0)
static inline void SET_CMC_TBL_CTRL_CNT_VLD(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, BIT(27));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_CTRL_CNT_VLD,
BIT(27));
}
#define SET_CMC_TBL_MASK_CTRL_CNT GENMASK(3, 0)
#define SET_CMC_TBL_CTRL_CNT(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(31, 28)); \
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_CTRL_CNT, \
GENMASK(31, 28)); \
} while (0)
static inline void SET_CMC_TBL_CTRL_CNT(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 5, val, GENMASK(31, 28));
le32p_replace_bits((__le32 *)(table) + 13, SET_CMC_TBL_MASK_CTRL_CNT,
GENMASK(31, 28));
}
#define SET_CMC_TBL_MASK_RESP_REF_RATE GENMASK(8, 0)
#define SET_CMC_TBL_RESP_REF_RATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(8, 0)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_RESP_REF_RATE, \
GENMASK(8, 0)); \
} while (0)
static inline void SET_CMC_TBL_RESP_REF_RATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(8, 0));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_RESP_REF_RATE,
GENMASK(8, 0));
}
#define SET_CMC_TBL_MASK_ALL_ACK_SUPPORT BIT(0)
#define SET_CMC_TBL_ALL_ACK_SUPPORT(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(12)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ALL_ACK_SUPPORT, \
BIT(12)); \
} while (0)
static inline void SET_CMC_TBL_ALL_ACK_SUPPORT(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(12));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ALL_ACK_SUPPORT,
BIT(12));
}
#define SET_CMC_TBL_MASK_BSR_QUEUE_SIZE_FORMAT BIT(0)
#define SET_CMC_TBL_BSR_QUEUE_SIZE_FORMAT(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(13)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_BSR_QUEUE_SIZE_FORMAT, \
BIT(13)); \
} while (0)
static inline void SET_CMC_TBL_BSR_QUEUE_SIZE_FORMAT(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(13));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_BSR_QUEUE_SIZE_FORMAT,
BIT(13));
}
#define SET_CMC_TBL_MASK_NTX_PATH_EN GENMASK(3, 0)
#define SET_CMC_TBL_NTX_PATH_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(19, 16)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_NTX_PATH_EN, \
GENMASK(19, 16)); \
} while (0)
static inline void SET_CMC_TBL_NTX_PATH_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(19, 16));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_NTX_PATH_EN,
GENMASK(19, 16));
}
#define SET_CMC_TBL_MASK_PATH_MAP_A GENMASK(1, 0)
#define SET_CMC_TBL_PATH_MAP_A(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(21, 20)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_A, \
GENMASK(21, 20)); \
} while (0)
static inline void SET_CMC_TBL_PATH_MAP_A(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(21, 20));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_A,
GENMASK(21, 20));
}
#define SET_CMC_TBL_MASK_PATH_MAP_B GENMASK(1, 0)
#define SET_CMC_TBL_PATH_MAP_B(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(23, 22)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_B, \
GENMASK(23, 22)); \
} while (0)
static inline void SET_CMC_TBL_PATH_MAP_B(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(23, 22));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_B,
GENMASK(23, 22));
}
#define SET_CMC_TBL_MASK_PATH_MAP_C GENMASK(1, 0)
#define SET_CMC_TBL_PATH_MAP_C(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(25, 24)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_C, \
GENMASK(25, 24)); \
} while (0)
static inline void SET_CMC_TBL_PATH_MAP_C(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(25, 24));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_C,
GENMASK(25, 24));
}
#define SET_CMC_TBL_MASK_PATH_MAP_D GENMASK(1, 0)
#define SET_CMC_TBL_PATH_MAP_D(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(27, 26)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_D, \
GENMASK(27, 26)); \
} while (0)
static inline void SET_CMC_TBL_PATH_MAP_D(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, GENMASK(27, 26));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_PATH_MAP_D,
GENMASK(27, 26));
}
#define SET_CMC_TBL_MASK_ANTSEL_A BIT(0)
#define SET_CMC_TBL_ANTSEL_A(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(28)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_A, \
BIT(28)); \
} while (0)
static inline void SET_CMC_TBL_ANTSEL_A(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(28));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_A,
BIT(28));
}
#define SET_CMC_TBL_MASK_ANTSEL_B BIT(0)
#define SET_CMC_TBL_ANTSEL_B(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(29)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_B, \
BIT(29)); \
} while (0)
static inline void SET_CMC_TBL_ANTSEL_B(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(29));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_B,
BIT(29));
}
#define SET_CMC_TBL_MASK_ANTSEL_C BIT(0)
#define SET_CMC_TBL_ANTSEL_C(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(30)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_C, \
BIT(30)); \
} while (0)
static inline void SET_CMC_TBL_ANTSEL_C(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(30));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_C,
BIT(30));
}
#define SET_CMC_TBL_MASK_ANTSEL_D BIT(0)
#define SET_CMC_TBL_ANTSEL_D(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(31)); \
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_D, \
BIT(31)); \
} while (0)
static inline void SET_CMC_TBL_ANTSEL_D(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 6, val, BIT(31));
le32p_replace_bits((__le32 *)(table) + 14, SET_CMC_TBL_MASK_ANTSEL_D,
BIT(31));
}
#define SET_CMC_TBL_MASK_ADDR_CAM_INDEX GENMASK(7, 0)
#define SET_CMC_TBL_ADDR_CAM_INDEX(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(7, 0)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_ADDR_CAM_INDEX, \
GENMASK(7, 0)); \
} while (0)
static inline void SET_CMC_TBL_ADDR_CAM_INDEX(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(7, 0));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_ADDR_CAM_INDEX,
GENMASK(7, 0));
}
#define SET_CMC_TBL_MASK_PAID GENMASK(8, 0)
#define SET_CMC_TBL_PAID(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(16, 8)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_PAID, \
GENMASK(16, 8)); \
} while (0)
static inline void SET_CMC_TBL_PAID(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(16, 8));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_PAID,
GENMASK(16, 8));
}
#define SET_CMC_TBL_MASK_ULDL BIT(0)
#define SET_CMC_TBL_ULDL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, BIT(17)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_ULDL, \
BIT(17)); \
} while (0)
static inline void SET_CMC_TBL_ULDL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, BIT(17));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_ULDL,
BIT(17));
}
#define SET_CMC_TBL_MASK_DOPPLER_CTRL GENMASK(1, 0)
#define SET_CMC_TBL_DOPPLER_CTRL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(19, 18)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_DOPPLER_CTRL, \
GENMASK(19, 18)); \
} while (0)
static inline void SET_CMC_TBL_DOPPLER_CTRL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(19, 18));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_DOPPLER_CTRL,
GENMASK(19, 18));
}
#define SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING GENMASK(1, 0)
#define SET_CMC_TBL_NOMINAL_PKT_PADDING(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(21, 20)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING, \
GENMASK(21, 20)); \
} while (0)
#define SET_CMC_TBL_NOMINAL_PKT_PADDING40(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(23, 22)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING, \
GENMASK(23, 22)); \
} while (0)
static inline void SET_CMC_TBL_NOMINAL_PKT_PADDING(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(21, 20));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING,
GENMASK(21, 20));
}
static inline void SET_CMC_TBL_NOMINAL_PKT_PADDING40(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(23, 22));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING,
GENMASK(23, 22));
}
#define SET_CMC_TBL_MASK_TXPWR_TOLERENCE GENMASK(3, 0)
#define SET_CMC_TBL_TXPWR_TOLERENCE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(27, 24)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_TXPWR_TOLERENCE, \
GENMASK(27, 24)); \
} while (0)
#define SET_CMC_TBL_NOMINAL_PKT_PADDING80(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(31, 30)); \
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING, \
GENMASK(31, 30)); \
} while (0)
static inline void SET_CMC_TBL_TXPWR_TOLERENCE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(27, 24));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_TXPWR_TOLERENCE,
GENMASK(27, 24));
}
static inline void SET_CMC_TBL_NOMINAL_PKT_PADDING80(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 7, val, GENMASK(31, 30));
le32p_replace_bits((__le32 *)(table) + 15, SET_CMC_TBL_MASK_NOMINAL_PKT_PADDING,
GENMASK(31, 30));
}
#define SET_CMC_TBL_MASK_NC GENMASK(2, 0)
#define SET_CMC_TBL_NC(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(2, 0)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NC, \
GENMASK(2, 0)); \
} while (0)
static inline void SET_CMC_TBL_NC(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(2, 0));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NC,
GENMASK(2, 0));
}
#define SET_CMC_TBL_MASK_NR GENMASK(2, 0)
#define SET_CMC_TBL_NR(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(5, 3)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NR, \
GENMASK(5, 3)); \
} while (0)
static inline void SET_CMC_TBL_NR(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(5, 3));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NR,
GENMASK(5, 3));
}
#define SET_CMC_TBL_MASK_NG GENMASK(1, 0)
#define SET_CMC_TBL_NG(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(7, 6)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NG, \
GENMASK(7, 6)); \
} while (0)
static inline void SET_CMC_TBL_NG(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(7, 6));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_NG,
GENMASK(7, 6));
}
#define SET_CMC_TBL_MASK_CB GENMASK(1, 0)
#define SET_CMC_TBL_CB(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(9, 8)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CB, \
GENMASK(9, 8)); \
} while (0)
static inline void SET_CMC_TBL_CB(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(9, 8));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CB,
GENMASK(9, 8));
}
#define SET_CMC_TBL_MASK_CS GENMASK(1, 0)
#define SET_CMC_TBL_CS(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(11, 10)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CS, \
GENMASK(11, 10)); \
} while (0)
static inline void SET_CMC_TBL_CS(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(11, 10));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CS,
GENMASK(11, 10));
}
#define SET_CMC_TBL_MASK_CSI_TXBF_EN BIT(0)
#define SET_CMC_TBL_CSI_TXBF_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(12)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_TXBF_EN, \
BIT(12)); \
} while (0)
static inline void SET_CMC_TBL_CSI_TXBF_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(12));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_TXBF_EN,
BIT(12));
}
#define SET_CMC_TBL_MASK_CSI_STBC_EN BIT(0)
#define SET_CMC_TBL_CSI_STBC_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(13)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_STBC_EN, \
BIT(13)); \
} while (0)
static inline void SET_CMC_TBL_CSI_STBC_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(13));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_STBC_EN,
BIT(13));
}
#define SET_CMC_TBL_MASK_CSI_LDPC_EN BIT(0)
#define SET_CMC_TBL_CSI_LDPC_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(14)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_LDPC_EN, \
BIT(14)); \
} while (0)
static inline void SET_CMC_TBL_CSI_LDPC_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(14));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_LDPC_EN,
BIT(14));
}
#define SET_CMC_TBL_MASK_CSI_PARA_EN BIT(0)
#define SET_CMC_TBL_CSI_PARA_EN(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(15)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_PARA_EN, \
BIT(15)); \
} while (0)
static inline void SET_CMC_TBL_CSI_PARA_EN(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(15));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_PARA_EN,
BIT(15));
}
#define SET_CMC_TBL_MASK_CSI_FIX_RATE GENMASK(8, 0)
#define SET_CMC_TBL_CSI_FIX_RATE(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(24, 16)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_FIX_RATE, \
GENMASK(24, 16)); \
} while (0)
static inline void SET_CMC_TBL_CSI_FIX_RATE(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(24, 16));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_FIX_RATE,
GENMASK(24, 16));
}
#define SET_CMC_TBL_MASK_CSI_GI_LTF GENMASK(2, 0)
#define SET_CMC_TBL_CSI_GI_LTF(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(27, 25)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_GI_LTF, \
GENMASK(27, 25)); \
} while (0)
static inline void SET_CMC_TBL_CSI_GI_LTF(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(27, 25));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_GI_LTF,
GENMASK(27, 25));
}
#define SET_CMC_TBL_MASK_CSI_GID_SEL BIT(0)
#define SET_CMC_TBL_CSI_GID_SEL(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(29)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_GID_SEL, \
BIT(29)); \
} while (0)
static inline void SET_CMC_TBL_CSI_GID_SEL(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, BIT(29));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_GID_SEL,
BIT(29));
}
#define SET_CMC_TBL_MASK_CSI_BW GENMASK(1, 0)
#define SET_CMC_TBL_CSI_BW(table, val) \
do { \
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(31, 30)); \
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_BW, \
GENMASK(31, 30)); \
} while (0)
#define SET_FWROLE_MAINTAIN_MACID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0))
#define SET_FWROLE_MAINTAIN_SELF_ROLE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(9, 8))
#define SET_FWROLE_MAINTAIN_UPD_MODE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(12, 10))
#define SET_FWROLE_MAINTAIN_WIFI_ROLE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(16, 13))
#define SET_JOININFO_MACID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0))
#define SET_JOININFO_OP(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(8))
#define SET_JOININFO_BAND(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(9))
#define SET_JOININFO_WMM(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(11, 10))
#define SET_JOININFO_TGR(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(12))
#define SET_JOININFO_ISHESTA(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(13))
#define SET_JOININFO_DLBW(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 14))
#define SET_JOININFO_TF_MAC_PAD(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(17, 16))
#define SET_JOININFO_DL_T_PE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(20, 18))
#define SET_JOININFO_PORT_ID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 21))
#define SET_JOININFO_NET_TYPE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(25, 24))
#define SET_JOININFO_WIFI_ROLE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(29, 26))
#define SET_JOININFO_SELF_ROLE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 30))
#define SET_GENERAL_PKT_MACID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0))
#define SET_GENERAL_PKT_PROBRSP_ID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8))
#define SET_GENERAL_PKT_PSPOLL_ID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 16))
#define SET_GENERAL_PKT_NULL_ID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 24))
#define SET_GENERAL_PKT_QOS_NULL_ID(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(7, 0))
#define SET_GENERAL_PKT_CTS2SELF_ID(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(15, 8))
#define SET_LOG_CFG_LEVEL(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0))
#define SET_LOG_CFG_PATH(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8))
#define SET_LOG_CFG_COMP(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(31, 0))
#define SET_LOG_CFG_COMP_EXT(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 2, val, GENMASK(31, 0))
#define SET_BA_CAM_VALID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(0))
#define SET_BA_CAM_INIT_REQ(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, BIT(1))
#define SET_BA_CAM_ENTRY_IDX(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(3, 2))
#define SET_BA_CAM_TID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 4))
#define SET_BA_CAM_MACID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8))
#define SET_BA_CAM_BMAP_SIZE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(19, 16))
#define SET_BA_CAM_SSN(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 20))
#define SET_LPS_PARM_MACID(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0))
#define SET_LPS_PARM_PSMODE(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8))
#define SET_LPS_PARM_RLBM(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(19, 16))
#define SET_LPS_PARM_SMARTPS(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 20))
#define SET_LPS_PARM_AWAKEINTERVAL(h2c, val) \
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 24))
#define SET_LPS_PARM_VOUAPSD(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(0))
#define SET_LPS_PARM_VIUAPSD(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(1))
#define SET_LPS_PARM_BEUAPSD(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(2))
#define SET_LPS_PARM_BKUAPSD(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(3))
#define SET_LPS_PARM_LASTRPWM(h2c, val) \
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(15, 8))
static inline void SET_CMC_TBL_CSI_BW(void *table, u32 val)
{
le32p_replace_bits((__le32 *)(table) + 8, val, GENMASK(31, 30));
le32p_replace_bits((__le32 *)(table) + 16, SET_CMC_TBL_MASK_CSI_BW,
GENMASK(31, 30));
}
static inline void SET_FWROLE_MAINTAIN_MACID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0));
}
static inline void SET_FWROLE_MAINTAIN_SELF_ROLE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(9, 8));
}
static inline void SET_FWROLE_MAINTAIN_UPD_MODE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(12, 10));
}
static inline void SET_FWROLE_MAINTAIN_WIFI_ROLE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(16, 13));
}
static inline void SET_JOININFO_MACID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0));
}
static inline void SET_JOININFO_OP(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(8));
}
static inline void SET_JOININFO_BAND(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(9));
}
static inline void SET_JOININFO_WMM(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(11, 10));
}
static inline void SET_JOININFO_TGR(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(12));
}
static inline void SET_JOININFO_ISHESTA(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(13));
}
static inline void SET_JOININFO_DLBW(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 14));
}
static inline void SET_JOININFO_TF_MAC_PAD(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(17, 16));
}
static inline void SET_JOININFO_DL_T_PE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(20, 18));
}
static inline void SET_JOININFO_PORT_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 21));
}
static inline void SET_JOININFO_NET_TYPE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(25, 24));
}
static inline void SET_JOININFO_WIFI_ROLE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(29, 26));
}
static inline void SET_JOININFO_SELF_ROLE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 30));
}
static inline void SET_GENERAL_PKT_MACID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0));
}
static inline void SET_GENERAL_PKT_PROBRSP_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8));
}
static inline void SET_GENERAL_PKT_PSPOLL_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 16));
}
static inline void SET_GENERAL_PKT_NULL_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 24));
}
static inline void SET_GENERAL_PKT_QOS_NULL_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(7, 0));
}
static inline void SET_GENERAL_PKT_CTS2SELF_ID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(15, 8));
}
static inline void SET_LOG_CFG_LEVEL(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0));
}
static inline void SET_LOG_CFG_PATH(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8));
}
static inline void SET_LOG_CFG_COMP(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(31, 0));
}
static inline void SET_LOG_CFG_COMP_EXT(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 2, val, GENMASK(31, 0));
}
static inline void SET_BA_CAM_VALID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(0));
}
static inline void SET_BA_CAM_INIT_REQ(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, BIT(1));
}
static inline void SET_BA_CAM_ENTRY_IDX(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(3, 2));
}
static inline void SET_BA_CAM_TID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 4));
}
static inline void SET_BA_CAM_MACID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8));
}
static inline void SET_BA_CAM_BMAP_SIZE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(19, 16));
}
static inline void SET_BA_CAM_SSN(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 20));
}
static inline void SET_LPS_PARM_MACID(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(7, 0));
}
static inline void SET_LPS_PARM_PSMODE(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(15, 8));
}
static inline void SET_LPS_PARM_RLBM(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(19, 16));
}
static inline void SET_LPS_PARM_SMARTPS(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(23, 20));
}
static inline void SET_LPS_PARM_AWAKEINTERVAL(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)h2c, val, GENMASK(31, 24));
}
static inline void SET_LPS_PARM_VOUAPSD(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(0));
}
static inline void SET_LPS_PARM_VIUAPSD(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(1));
}
static inline void SET_LPS_PARM_BEUAPSD(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(2));
}
static inline void SET_LPS_PARM_BKUAPSD(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, BIT(3));
}
static inline void SET_LPS_PARM_LASTRPWM(void *h2c, u32 val)
{
le32p_replace_bits((__le32 *)(h2c) + 1, val, GENMASK(15, 8));
}
enum rtw89_btc_btf_h2c_class {
BTFC_SET = 0x10,
......@@ -1054,118 +1316,275 @@ enum rtw89_btc_cxdrvinfo {
CXDRVINFO_MAX,
};
#define RTW89_SET_FWCMD_CXHDR_TYPE(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 0, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXHDR_LEN(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 1, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_ANT_TYPE(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 2, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_ANT_NUM(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 3, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_ANT_ISO(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 4, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_ANT_POS(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 5, val, BIT(0))
#define RTW89_SET_FWCMD_CXINIT_ANT_DIVERSITY(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 5, val, BIT(1))
#define RTW89_SET_FWCMD_CXINIT_MOD_RFE(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 6, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_MOD_CV(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 7, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_MOD_BT_SOLO(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(0))
#define RTW89_SET_FWCMD_CXINIT_MOD_BT_POS(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(1))
#define RTW89_SET_FWCMD_CXINIT_MOD_SW_TYPE(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(2))
#define RTW89_SET_FWCMD_CXINIT_WL_GCH(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 10, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXINIT_WL_ONLY(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(0))
#define RTW89_SET_FWCMD_CXINIT_WL_INITOK(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(1))
#define RTW89_SET_FWCMD_CXINIT_DBCC_EN(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(2))
#define RTW89_SET_FWCMD_CXINIT_CX_OTHER(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(3))
#define RTW89_SET_FWCMD_CXINIT_BT_ONLY(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(4))
#define RTW89_SET_FWCMD_CXROLE_CONNECT_CNT(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 2, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXROLE_LINK_MODE(cmd, val) \
u8p_replace_bits((u8 *)(cmd) + 3, val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXROLE_ROLE_NONE(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(0))
#define RTW89_SET_FWCMD_CXROLE_ROLE_STA(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(1))
#define RTW89_SET_FWCMD_CXROLE_ROLE_AP(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(2))
#define RTW89_SET_FWCMD_CXROLE_ROLE_VAP(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(3))
#define RTW89_SET_FWCMD_CXROLE_ROLE_ADHOC(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(4))
#define RTW89_SET_FWCMD_CXROLE_ROLE_ADHOC_MASTER(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(5))
#define RTW89_SET_FWCMD_CXROLE_ROLE_MESH(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(6))
#define RTW89_SET_FWCMD_CXROLE_ROLE_MONITOR(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(7))
#define RTW89_SET_FWCMD_CXROLE_ROLE_P2P_DEV(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(8))
#define RTW89_SET_FWCMD_CXROLE_ROLE_P2P_GC(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(9))
#define RTW89_SET_FWCMD_CXROLE_ROLE_P2P_GO(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(10))
#define RTW89_SET_FWCMD_CXROLE_ROLE_NAN(cmd, val) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(11))
#define RTW89_SET_FWCMD_CXROLE_ACT_CONNECTED(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(0))
#define RTW89_SET_FWCMD_CXROLE_ACT_PID(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, GENMASK(3, 1))
#define RTW89_SET_FWCMD_CXROLE_ACT_PHY(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(4))
#define RTW89_SET_FWCMD_CXROLE_ACT_NOA(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(5))
#define RTW89_SET_FWCMD_CXROLE_ACT_BAND(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, GENMASK(7, 6))
#define RTW89_SET_FWCMD_CXROLE_ACT_CLIENT_PS(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (7 + 12 * (n)), val, BIT(0))
#define RTW89_SET_FWCMD_CXROLE_ACT_BW(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (7 + 12 * (n)), val, GENMASK(7, 1))
#define RTW89_SET_FWCMD_CXROLE_ACT_ROLE(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (8 + 12 * (n)), val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXROLE_ACT_CH(cmd, val, n) \
u8p_replace_bits((u8 *)(cmd) + (9 + 12 * (n)), val, GENMASK(7, 0))
#define RTW89_SET_FWCMD_CXROLE_ACT_TX_LVL(cmd, val, n) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (10 + 12 * (n))), val, GENMASK(15, 0))
#define RTW89_SET_FWCMD_CXROLE_ACT_RX_LVL(cmd, val, n) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (12 + 12 * (n))), val, GENMASK(15, 0))
#define RTW89_SET_FWCMD_CXROLE_ACT_TX_RATE(cmd, val, n) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (14 + 12 * (n))), val, GENMASK(15, 0))
#define RTW89_SET_FWCMD_CXROLE_ACT_RX_RATE(cmd, val, n) \
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (16 + 12 * (n))), val, GENMASK(15, 0))
#define RTW89_SET_FWCMD_CXCTRL_MANUAL(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(0))
#define RTW89_SET_FWCMD_CXCTRL_IGNORE_BT(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(1))
#define RTW89_SET_FWCMD_CXCTRL_ALWAYS_FREERUN(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(2))
#define RTW89_SET_FWCMD_CXCTRL_TRACE_STEP(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(18, 3))
#define RTW89_SET_FWCMD_CXRFK_STATE(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(1, 0))
#define RTW89_SET_FWCMD_CXRFK_PATH_MAP(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(5, 2))
#define RTW89_SET_FWCMD_CXRFK_PHY_MAP(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(7, 6))
#define RTW89_SET_FWCMD_CXRFK_BAND(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(9, 8))
#define RTW89_SET_FWCMD_CXRFK_TYPE(cmd, val) \
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(17, 10))
static inline void RTW89_SET_FWCMD_CXHDR_TYPE(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 0, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXHDR_LEN(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 1, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_ANT_TYPE(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 2, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_ANT_NUM(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 3, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_ANT_ISO(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 4, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_ANT_POS(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 5, val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXINIT_ANT_DIVERSITY(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 5, val, BIT(1));
}
static inline void RTW89_SET_FWCMD_CXINIT_MOD_RFE(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 6, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_MOD_CV(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 7, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_MOD_BT_SOLO(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXINIT_MOD_BT_POS(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(1));
}
static inline void RTW89_SET_FWCMD_CXINIT_MOD_SW_TYPE(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 8, val, BIT(2));
}
static inline void RTW89_SET_FWCMD_CXINIT_WL_GCH(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 10, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXINIT_WL_ONLY(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXINIT_WL_INITOK(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(1));
}
static inline void RTW89_SET_FWCMD_CXINIT_DBCC_EN(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(2));
}
static inline void RTW89_SET_FWCMD_CXINIT_CX_OTHER(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(3));
}
static inline void RTW89_SET_FWCMD_CXINIT_BT_ONLY(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 11, val, BIT(4));
}
static inline void RTW89_SET_FWCMD_CXROLE_CONNECT_CNT(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 2, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_LINK_MODE(void *cmd, u8 val)
{
u8p_replace_bits((u8 *)(cmd) + 3, val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_NONE(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_STA(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(1));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_AP(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(2));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_VAP(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(3));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_ADHOC(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(4));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_ADHOC_MASTER(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(5));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_MESH(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(6));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_MONITOR(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(7));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_P2P_DEV(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(8));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_P2P_GC(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(9));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_P2P_GO(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(10));
}
static inline void RTW89_SET_FWCMD_CXROLE_ROLE_NAN(void *cmd, u16 val)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + 4), val, BIT(11));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_CONNECTED(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_PID(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, GENMASK(3, 1));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_PHY(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(4));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_NOA(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, BIT(5));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_BAND(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (6 + 12 * (n)), val, GENMASK(7, 6));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_CLIENT_PS(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (7 + 12 * (n)), val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_BW(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (7 + 12 * (n)), val, GENMASK(7, 1));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_ROLE(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (8 + 12 * (n)), val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_CH(void *cmd, u8 val, int n)
{
u8p_replace_bits((u8 *)(cmd) + (9 + 12 * (n)), val, GENMASK(7, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_TX_LVL(void *cmd, u16 val, int n)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (10 + 12 * (n))), val, GENMASK(15, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_RX_LVL(void *cmd, u16 val, int n)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (12 + 12 * (n))), val, GENMASK(15, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_TX_RATE(void *cmd, u16 val, int n)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (14 + 12 * (n))), val, GENMASK(15, 0));
}
static inline void RTW89_SET_FWCMD_CXROLE_ACT_RX_RATE(void *cmd, u16 val, int n)
{
le16p_replace_bits((__le16 *)((u8 *)(cmd) + (16 + 12 * (n))), val, GENMASK(15, 0));
}
static inline void RTW89_SET_FWCMD_CXCTRL_MANUAL(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(0));
}
static inline void RTW89_SET_FWCMD_CXCTRL_IGNORE_BT(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(1));
}
static inline void RTW89_SET_FWCMD_CXCTRL_ALWAYS_FREERUN(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, BIT(2));
}
static inline void RTW89_SET_FWCMD_CXCTRL_TRACE_STEP(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(18, 3));
}
static inline void RTW89_SET_FWCMD_CXRFK_STATE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(1, 0));
}
static inline void RTW89_SET_FWCMD_CXRFK_PATH_MAP(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(5, 2));
}
static inline void RTW89_SET_FWCMD_CXRFK_PHY_MAP(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(7, 6));
}
static inline void RTW89_SET_FWCMD_CXRFK_BAND(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(9, 8));
}
static inline void RTW89_SET_FWCMD_CXRFK_TYPE(void *cmd, u32 val)
{
le32p_replace_bits((__le32 *)((u8 *)(cmd) + 2), val, GENMASK(17, 10));
}
#define RTW89_C2H_HEADER_LEN 8
......
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