1 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2 /* Copyright(c) 2019-2020  Realtek Corporation
3  */
4 
5 #ifndef __RTW89_REG_H__
6 #define __RTW89_REG_H__
7 
8 #define R_AX_SYS_WL_EFUSE_CTRL 0x000A
9 #define B_AX_AUTOLOAD_SUS BIT(5)
10 
11 #define R_AX_SYS_ISO_CTRL 0x0000
12 #define B_AX_PWC_EV2EF_MASK GENMASK(15, 14)
13 #define B_AX_PWC_EV2EF_B15 BIT(15)
14 #define B_AX_PWC_EV2EF_B14 BIT(14)
15 #define B_AX_ISO_EB2CORE BIT(8)
16 
17 #define R_AX_SYS_FUNC_EN 0x0002
18 #define B_AX_FEN_BB_GLB_RSTN BIT(1)
19 #define B_AX_FEN_BBRSTB BIT(0)
20 
21 #define R_AX_SYS_PW_CTRL 0x0004
22 #define B_AX_XTAL_OFF_A_DIE BIT(22)
23 #define B_AX_DIS_WLBT_PDNSUSEN_SOPC BIT(18)
24 #define B_AX_RDY_SYSPWR BIT(17)
25 #define B_AX_EN_WLON BIT(16)
26 #define B_AX_APDM_HPDN BIT(15)
27 #define B_AX_PSUS_OFF_CAPC_EN BIT(14)
28 #define B_AX_AFSM_PCIE_SUS_EN BIT(12)
29 #define B_AX_AFSM_WLSUS_EN BIT(11)
30 #define B_AX_APFM_SWLPS BIT(10)
31 #define B_AX_APFM_OFFMAC BIT(9)
32 #define B_AX_APFN_ONMAC BIT(8)
33 
34 #define R_AX_SYS_CLK_CTRL 0x0008
35 #define B_AX_CPU_CLK_EN BIT(14)
36 
37 #define R_AX_SYS_SWR_CTRL1 0x0010
38 #define B_AX_SYM_CTRL_SPS_PWMFREQ BIT(10)
39 
40 #define R_AX_SYS_ADIE_PAD_PWR_CTRL 0x0018
41 #define B_AX_SYM_PADPDN_WL_PTA_1P3 BIT(6)
42 #define B_AX_SYM_PADPDN_WL_RFC_1P3 BIT(5)
43 
44 #define R_AX_RSV_CTRL 0x001C
45 #define B_AX_R_DIS_PRST BIT(6)
46 #define B_AX_WLOCK_1C_BIT6 BIT(5)
47 
48 #define R_AX_AFE_LDO_CTRL 0x0020
49 #define B_AX_AON_OFF_PC_EN BIT(23)
50 
51 #define R_AX_EFUSE_CTRL_1 0x0038
52 #define B_AX_EF_PGPD_MASK GENMASK(30, 28)
53 #define B_AX_EF_RDT BIT(27)
54 #define B_AX_EF_VDDQST_MASK GENMASK(26, 24)
55 #define B_AX_EF_PGTS_MASK GENMASK(23, 20)
56 #define B_AX_EF_PD_DIS BIT(11)
57 #define B_AX_EF_POR BIT(10)
58 #define B_AX_EF_CELL_SEL_MASK GENMASK(9, 8)
59 
60 #define R_AX_EFUSE_CTRL 0x0030
61 #define B_AX_EF_MODE_SEL_MASK GENMASK(31, 30)
62 #define B_AX_EF_RDY BIT(29)
63 #define B_AX_EF_COMP_RESULT BIT(28)
64 #define B_AX_EF_ADDR_MASK GENMASK(26, 16)
65 #define B_AX_EF_DATA_MASK GENMASK(15, 0)
66 
67 #define R_AX_EFUSE_CTRL_1_V1 0x0038
68 #define B_AX_EF_ENT BIT(31)
69 #define B_AX_EF_BURST BIT(19)
70 #define B_AX_EF_TEST_SEL_MASK GENMASK(18, 16)
71 #define B_AX_EF_TROW_EN BIT(15)
72 #define B_AX_EF_ERR_FLAG BIT(14)
73 #define B_AX_EF_DSB_EN BIT(11)
74 #define B_AX_PCIE_CALIB_EN_V1 BIT(12)
75 #define B_AX_WDT_WAKE_PCIE_EN BIT(10)
76 #define B_AX_WDT_WAKE_USB_EN BIT(9)
77 
78 #define R_AX_GPIO_MUXCFG 0x0040
79 #define B_AX_BOOT_MODE BIT(19)
80 #define B_AX_WL_EECS_EXT_32K_SEL BIT(18)
81 #define B_AX_WL_SEC_BONDING_OPT_STS BIT(17)
82 #define B_AX_SECSIC_SEL BIT(16)
83 #define B_AX_ENHTP BIT(14)
84 #define B_AX_BT_AOD_GPIO3 BIT(13)
85 #define B_AX_ENSIC BIT(12)
86 #define B_AX_SIC_SWRST BIT(11)
87 #define B_AX_PO_WIFI_PTA_PINS BIT(10)
88 #define B_AX_PO_BT_PTA_PINS BIT(9)
89 #define B_AX_ENUARTTX BIT(8)
90 #define B_AX_BTMODE_MASK GENMASK(7, 6)
91 #define MAC_AX_BT_MODE_0_3 0
92 #define MAC_AX_BT_MODE_2 2
93 #define MAC_AX_RTK_MODE 0
94 #define MAC_AX_CSR_MODE 1
95 #define B_AX_ENBT BIT(5)
96 #define B_AX_EROM_EN BIT(4)
97 #define B_AX_ENUARTRX BIT(2)
98 #define B_AX_GPIOSEL_MASK GENMASK(1, 0)
99 
100 #define R_AX_DBG_CTRL 0x0058
101 #define B_AX_DBG_SEL1_4BIT GENMASK(31, 30)
102 #define B_AX_DBG_SEL1_16BIT BIT(27)
103 #define B_AX_DBG_SEL1 GENMASK(23, 16)
104 #define B_AX_DBG_SEL0_4BIT GENMASK(15, 14)
105 #define B_AX_DBG_SEL0_16BIT BIT(11)
106 #define B_AX_DBG_SEL0 GENMASK(7, 0)
107 
108 #define R_AX_SYS_SDIO_CTRL 0x0070
109 #define B_AX_PCIE_DIS_L2_CTRL_LDO_HCI BIT(15)
110 #define B_AX_PCIE_DIS_WLSUS_AFT_PDN BIT(14)
111 #define B_AX_PCIE_FORCE_PWR_NGAT BIT(13)
112 #define B_AX_PCIE_CALIB_EN_V1 BIT(12)
113 #define B_AX_PCIE_AUXCLK_GATE BIT(11)
114 #define B_AX_LTE_MUX_CTRL_PATH BIT(26)
115 
116 #define R_AX_HCI_OPT_CTRL 0x0074
117 #define BIT_WAKE_CTRL BIT(5)
118 
119 #define R_AX_HCI_BG_CTRL 0x0078
120 #define B_AX_IBX_EN_VALUE BIT(15)
121 #define B_AX_IB_EN_VALUE BIT(14)
122 #define B_AX_FORCED_IB_EN BIT(4)
123 #define B_AX_EN_REGBG BIT(3)
124 #define B_AX_R_AX_BG_LPF BIT(2)
125 #define B_AX_R_AX_BG GENMASK(1, 0)
126 
127 #define R_AX_HCI_LDO_CTRL 0x007A
128 #define B_AX_R_AX_VADJ_MASK GENMASK(3, 0)
129 
130 #define R_AX_PLATFORM_ENABLE 0x0088
131 #define B_AX_AXIDMA_EN BIT(3)
132 #define B_AX_APB_WRAP_EN BIT(2)
133 #define B_AX_WCPU_EN BIT(1)
134 #define B_AX_PLATFORM_EN BIT(0)
135 
136 #define R_AX_WLLPS_CTRL 0x0090
137 #define B_AX_DIS_WLBT_LPSEN_LOPC BIT(1)
138 #define SW_LPS_OPTION 0x0001A0B2
139 
140 #define R_AX_SCOREBOARD  0x00AC
141 #define B_AX_TOGGLE BIT(31)
142 #define B_MAC_AX_SB_FW_MASK GENMASK(30, 24)
143 #define B_MAC_AX_SB_DRV_MASK GENMASK(23, 0)
144 #define B_MAC_AX_BTGS1_NOTIFY BIT(0)
145 #define MAC_AX_NOTIFY_TP_MAJOR 0x81
146 #define MAC_AX_NOTIFY_PWR_MAJOR 0x80
147 
148 #define R_AX_DBG_PORT_SEL 0x00C0
149 #define B_AX_DEBUG_ST_MASK GENMASK(31, 0)
150 
151 #define R_AX_PMC_DBG_CTRL2 0x00CC
152 #define B_AX_SYSON_DIS_PMCR_AX_WRMSK BIT(2)
153 
154 #define R_AX_PCIE_MIO_INTF 0x00E4
155 #define B_AX_PCIE_MIO_ADDR_PAGE_V1_MASK GENMASK(20, 16)
156 #define B_AX_PCIE_MIO_BYIOREG BIT(13)
157 #define B_AX_PCIE_MIO_RE BIT(12)
158 #define B_AX_PCIE_MIO_WE_MASK GENMASK(11, 8)
159 #define MIO_WRITE_BYTE_ALL 0xF
160 #define B_AX_PCIE_MIO_ADDR_MASK GENMASK(7, 0)
161 #define MIO_ADDR_PAGE_MASK GENMASK(12, 8)
162 
163 #define R_AX_PCIE_MIO_INTD 0x00E8
164 #define B_AX_PCIE_MIO_DATA_MASK GENMASK(31, 0)
165 
166 #define R_AX_SYS_CFG1 0x00F0
167 #define B_AX_CHIP_VER_MASK GENMASK(15, 12)
168 
169 #define R_AX_SYS_STATUS1 0x00F4
170 #define B_AX_SEL_0XC0_MASK GENMASK(17, 16)
171 #define B_AX_PAD_HCI_SEL_V2_MASK GENMASK(5, 3)
172 #define MAC_AX_HCI_SEL_SDIO_UART 0
173 #define MAC_AX_HCI_SEL_MULTI_USB 1
174 #define MAC_AX_HCI_SEL_PCIE_UART 2
175 #define MAC_AX_HCI_SEL_PCIE_USB 3
176 #define MAC_AX_HCI_SEL_MULTI_SDIO 4
177 
178 #define R_AX_HALT_H2C_CTRL 0x0160
179 #define R_AX_HALT_H2C 0x0168
180 #define B_AX_HALT_H2C_TRIGGER BIT(0)
181 #define R_AX_HALT_C2H_CTRL 0x0164
182 #define R_AX_HALT_C2H 0x016C
183 
184 #define R_AX_WCPU_FW_CTRL 0x01E0
185 #define B_AX_WCPU_FWDL_STS_MASK GENMASK(7, 5)
186 #define B_AX_FWDL_PATH_RDY BIT(2)
187 #define B_AX_H2C_PATH_RDY BIT(1)
188 #define B_AX_WCPU_FWDL_EN BIT(0)
189 
190 #define R_AX_RPWM 0x01E4
191 #define R_AX_PCIE_HRPWM 0x10C0
192 #define PS_RPWM_TOGGLE BIT(15)
193 #define PS_RPWM_ACK BIT(14)
194 #define PS_RPWM_SEQ_NUM GENMASK(13, 12)
195 #define PS_RPWM_NOTIFY_WAKE BIT(8)
196 #define PS_RPWM_STATE 0x7
197 #define RPWM_SEQ_NUM_MAX 3
198 #define PS_CPWM_SEQ_NUM GENMASK(13, 12)
199 #define PS_CPWM_RSP_SEQ_NUM GENMASK(9, 8)
200 #define PS_CPWM_STATE GENMASK(2, 0)
201 #define CPWM_SEQ_NUM_MAX 3
202 
203 #define R_AX_BOOT_REASON 0x01E6
204 #define B_AX_BOOT_REASON_MASK GENMASK(2, 0)
205 
206 #define R_AX_LDM 0x01E8
207 #define B_AX_EN_32K BIT(31)
208 
209 #define R_AX_UDM0 0x01F0
210 #define R_AX_UDM1 0x01F4
211 #define B_AX_UDM1_MASK GENMASK(31, 16)
212 #define B_AX_UDM1_HALMAC_C2H_ENQ_CNT_MASK GENMASK(15, 12)
213 #define B_AX_UDM1_HALMAC_H2C_DEQ_CNT_MASK GENMASK(11, 8)
214 #define B_AX_UDM1_WCPU_C2H_ENQ_CNT_MASK GENMASK(7, 4)
215 #define B_AX_UDM1_WCPU_H2C_DEQ_CNT_MASK GENMASK(3, 0)
216 #define R_AX_UDM2 0x01F8
217 #define R_AX_UDM3 0x01FC
218 
219 #define R_AX_SPS_DIG_ON_CTRL0 0x0200
220 #define B_AX_VREFPFM_L_MASK GENMASK(25, 22)
221 #define B_AX_REG_ZCDC_H_MASK GENMASK(18, 17)
222 #define B_AX_OCP_L1_MASK GENMASK(15, 13)
223 #define B_AX_VOL_L1_MASK GENMASK(3, 0)
224 
225 #define R_AX_LDO_AON_CTRL0 0x0218
226 #define B_AX_PD_REGU_L BIT(16)
227 
228 #define R_AX_WLAN_XTAL_SI_CTRL 0x0270
229 #define B_AX_WL_XTAL_SI_CMD_POLL BIT(31)
230 #define B_AX_BT_XTAL_SI_ERR_FLAG BIT(30)
231 #define B_AX_WL_XTAL_GNT BIT(29)
232 #define B_AX_BT_XTAL_GNT BIT(28)
233 #define B_AX_WL_XTAL_SI_MODE_MASK GENMASK(25, 24)
234 #define XTAL_SI_NORMAL_WRITE 0x00
235 #define XTAL_SI_NORMAL_READ 0x01
236 #define B_AX_WL_XTAL_SI_BITMASK_MASK GENMASK(23, 16)
237 #define B_AX_WL_XTAL_SI_DATA_MASK GENMASK(15, 8)
238 #define B_AX_WL_XTAL_SI_ADDR_MASK GENMASK(7, 0)
239 
240 #define R_AX_XTAL_ON_CTRL0 0x0280
241 #define B_AX_XTAL_SC_LPS BIT(31)
242 #define B_AX_XTAL_SC_XO_MASK GENMASK(23, 17)
243 #define B_AX_XTAL_SC_XI_MASK GENMASK(16, 10)
244 #define B_AX_XTAL_SC_MASK GENMASK(6, 0)
245 
246 #define R_AX_GPIO0_7_FUNC_SEL 0x02D0
247 
248 #define R_AX_EECS_EESK_FUNC_SEL 0x02D8
249 #define B_AX_PINMUX_EESK_FUNC_SEL_MASK GENMASK(7, 4)
250 
251 #define R_AX_LED1_FUNC_SEL 0x02DC
252 #define B_AX_PINMUX_EESK_FUNC_SEL_V1_MASK GENMASK(27, 24)
253 #define PINMUX_EESK_FUNC_SEL_BT_LOG 0x1
254 
255 #define R_AX_GPIO0_15_EECS_EESK_LED1_PULL_LOW_EN 0x02E4
256 #define B_AX_LED1_PULL_LOW_EN BIT(18)
257 #define B_AX_EESK_PULL_LOW_EN BIT(17)
258 #define B_AX_EECS_PULL_LOW_EN BIT(16)
259 
260 #define R_AX_WLRF_CTRL 0x02F0
261 #define B_AX_AFC_AFEDIG BIT(17)
262 #define B_AX_WLRF1_CTRL_7 BIT(15)
263 #define B_AX_WLRF1_CTRL_1 BIT(9)
264 #define B_AX_WLRF_CTRL_7 BIT(7)
265 #define B_AX_WLRF_CTRL_1 BIT(1)
266 
267 #define R_AX_IC_PWR_STATE 0x03F0
268 #define B_AX_WHOLE_SYS_PWR_STE_MASK GENMASK(25, 16)
269 #define B_AX_WLMAC_PWR_STE_MASK GENMASK(9, 8)
270 #define B_AX_UART_HCISYS_PWR_STE_MASK GENMASK(7, 6)
271 #define B_AX_SDIO_HCISYS_PWR_STE_MASK GENMASK(5, 4)
272 #define B_AX_USB_HCISYS_PWR_STE_MASK GENMASK(3, 2)
273 #define B_AX_PCIE_HCISYS_PWR_STE_MASK GENMASK(1, 0)
274 
275 #define R_AX_SPS_DIG_OFF_CTRL0 0x0400
276 #define B_AX_C3_L1_MASK GENMASK(5, 4)
277 #define B_AX_C1_L1_MASK GENMASK(1, 0)
278 
279 #define R_AX_AFE_OFF_CTRL1 0x0444
280 #define B_AX_S1_LDO_VSEL_F_MASK GENMASK(25, 24)
281 #define B_AX_S1_LDO2PWRCUT_F BIT(23)
282 #define B_AX_S0_LDO_VSEL_F_MASK GENMASK(22, 21)
283 
284 #define R_AX_SEC_CTRL 0x0C00
285 #define B_AX_SEC_IDMEM_SIZE_CONFIG_MASK GENMASK(17, 16)
286 
287 #define R_AX_FILTER_MODEL_ADDR 0x0C04
288 
289 #define R_AX_HAXI_INIT_CFG1 0x1000
290 #define B_AX_WD_ITVL_IDLE_V1_MASK GENMASK(31, 28)
291 #define B_AX_WD_ITVL_ACT_V1_MASK GENMASK(27, 24)
292 #define B_AX_DMA_MODE_MASK GENMASK(19, 18)
293 #define DMA_MOD_PCIE_1B 0x0
294 #define DMA_MOD_PCIE_4B 0x1
295 #define DMA_MOD_USB 0x2
296 #define DMA_MOD_SDIO 0x3
297 #define B_AX_STOP_AXI_MST BIT(17)
298 #define B_AX_HAXI_RST_KEEP_REG BIT(16)
299 #define B_AX_RXHCI_EN_V1 BIT(15)
300 #define B_AX_RXBD_MODE_V1 BIT(14)
301 #define B_AX_HAXI_MAX_RXDMA_MASK GENMASK(9, 8)
302 #define B_AX_TXHCI_EN_V1 BIT(7)
303 #define B_AX_FLUSH_AXI_MST BIT(4)
304 #define B_AX_RST_BDRAM BIT(3)
305 #define B_AX_HAXI_MAX_TXDMA_MASK GENMASK(1, 0)
306 
307 #define R_AX_HAXI_DMA_STOP1 0x1010
308 #define B_AX_STOP_WPDMA BIT(19)
309 #define B_AX_STOP_CH12 BIT(18)
310 #define B_AX_STOP_CH9 BIT(17)
311 #define B_AX_STOP_CH8 BIT(16)
312 #define B_AX_STOP_ACH7 BIT(15)
313 #define B_AX_STOP_ACH6 BIT(14)
314 #define B_AX_STOP_ACH5 BIT(13)
315 #define B_AX_STOP_ACH4 BIT(12)
316 #define B_AX_STOP_ACH3 BIT(11)
317 #define B_AX_STOP_ACH2 BIT(10)
318 #define B_AX_STOP_ACH1 BIT(9)
319 #define B_AX_STOP_ACH0 BIT(8)
320 
321 #define R_AX_HAXI_DMA_BUSY1 0x101C
322 #define B_AX_HAXIIO_BUSY BIT(20)
323 #define B_AX_WPDMA_BUSY BIT(19)
324 #define B_AX_CH12_BUSY BIT(18)
325 #define B_AX_CH9_BUSY BIT(17)
326 #define B_AX_CH8_BUSY BIT(16)
327 #define B_AX_ACH7_BUSY BIT(15)
328 #define B_AX_ACH6_BUSY BIT(14)
329 #define B_AX_ACH5_BUSY BIT(13)
330 #define B_AX_ACH4_BUSY BIT(12)
331 #define B_AX_ACH3_BUSY BIT(11)
332 #define B_AX_ACH2_BUSY BIT(10)
333 #define B_AX_ACH1_BUSY BIT(9)
334 #define B_AX_ACH0_BUSY BIT(8)
335 
336 #define R_AX_PCIE_DBG_CTRL 0x11C0
337 #define B_AX_DBG_DUMMY_MASK GENMASK(23, 16)
338 #define B_AX_PCIE_DBG_SEL_MASK GENMASK(15, 13)
339 #define B_AX_MRD_TIMEOUT_EN BIT(10)
340 #define B_AX_ASFF_FULL_NO_STK BIT(1)
341 #define B_AX_EN_STUCK_DBG BIT(0)
342 
343 #define R_AX_HAXI_DMA_STOP2 0x11C0
344 #define B_AX_STOP_CH11 BIT(1)
345 #define B_AX_STOP_CH10 BIT(0)
346 
347 #define R_AX_HAXI_DMA_BUSY2 0x11C8
348 #define B_AX_CH11_BUSY BIT(1)
349 #define B_AX_CH10_BUSY BIT(0)
350 
351 #define R_AX_HAXI_DMA_BUSY3 0x1208
352 #define B_AX_RPQ_BUSY BIT(1)
353 #define B_AX_RXQ_BUSY BIT(0)
354 
355 #define R_AX_LTR_DEC_CTRL 0x1600
356 #define B_AX_LTR_IDX_DRV_VLD BIT(16)
357 #define B_AX_LTR_CURR_IDX_DRV_MASK GENMASK(15, 14)
358 #define B_AX_LTR_IDX_FW_VLD BIT(13)
359 #define B_AX_LTR_CURR_IDX_FW_MASK GENMASK(12, 11)
360 #define B_AX_LTR_IDX_HW_VLD BIT(10)
361 #define B_AX_LTR_CURR_IDX_HW_MASK GENMASK(9, 8)
362 #define B_AX_LTR_REQ_DRV BIT(7)
363 #define B_AX_LTR_IDX_DRV_MASK GENMASK(6, 5)
364 #define PCIE_LTR_IDX_IDLE 3
365 #define B_AX_LTR_DRV_DEC_EN BIT(4)
366 #define B_AX_LTR_FW_DEC_EN BIT(3)
367 #define B_AX_LTR_HW_DEC_EN BIT(2)
368 #define B_AX_LTR_SPACE_IDX_V1_MASK GENMASK(1, 0)
369 #define LTR_EN_BITS (B_AX_LTR_HW_DEC_EN | B_AX_LTR_FW_DEC_EN | B_AX_LTR_DRV_DEC_EN)
370 
371 #define R_AX_LTR_LATENCY_IDX0 0x1604
372 #define R_AX_LTR_LATENCY_IDX1 0x1608
373 #define R_AX_LTR_LATENCY_IDX2 0x160C
374 #define R_AX_LTR_LATENCY_IDX3 0x1610
375 
376 #define R_AX_HCI_FC_CTRL_V1 0x1700
377 #define R_AX_CH_PAGE_CTRL_V1 0x1704
378 
379 #define R_AX_ACH0_PAGE_CTRL_V1 0x1710
380 #define R_AX_ACH1_PAGE_CTRL_V1 0x1714
381 #define R_AX_ACH2_PAGE_CTRL_V1 0x1718
382 #define R_AX_ACH3_PAGE_CTRL_V1 0x171C
383 #define R_AX_ACH4_PAGE_CTRL_V1 0x1720
384 #define R_AX_ACH5_PAGE_CTRL_V1 0x1724
385 #define R_AX_ACH6_PAGE_CTRL_V1 0x1728
386 #define R_AX_ACH7_PAGE_CTRL_V1 0x172C
387 #define R_AX_CH8_PAGE_CTRL_V1 0x1730
388 #define R_AX_CH9_PAGE_CTRL_V1 0x1734
389 #define R_AX_CH10_PAGE_CTRL_V1 0x1738
390 #define R_AX_CH11_PAGE_CTRL_V1 0x173C
391 
392 #define R_AX_ACH0_PAGE_INFO_V1 0x1750
393 #define R_AX_ACH1_PAGE_INFO_V1 0x1754
394 #define R_AX_ACH2_PAGE_INFO_V1 0x1758
395 #define R_AX_ACH3_PAGE_INFO_V1 0x175C
396 #define R_AX_ACH4_PAGE_INFO_V1 0x1760
397 #define R_AX_ACH5_PAGE_INFO_V1 0x1764
398 #define R_AX_ACH6_PAGE_INFO_V1 0x1768
399 #define R_AX_ACH7_PAGE_INFO_V1 0x176C
400 #define R_AX_CH8_PAGE_INFO_V1 0x1770
401 #define R_AX_CH9_PAGE_INFO_V1 0x1774
402 #define R_AX_CH10_PAGE_INFO_V1 0x1778
403 #define R_AX_CH11_PAGE_INFO_V1 0x177C
404 #define R_AX_CH12_PAGE_INFO_V1 0x1780
405 
406 #define R_AX_PUB_PAGE_INFO3_V1 0x178C
407 #define R_AX_PUB_PAGE_CTRL1_V1 0x1790
408 #define R_AX_PUB_PAGE_CTRL2_V1 0x1794
409 #define R_AX_PUB_PAGE_INFO1_V1 0x1798
410 #define R_AX_PUB_PAGE_INFO2_V1 0x179C
411 #define R_AX_WP_PAGE_CTRL1_V1 0x17A0
412 #define R_AX_WP_PAGE_CTRL2_V1 0x17A4
413 #define R_AX_WP_PAGE_INFO1_V1 0x17A8
414 
415 #define R_AX_H2CREG_DATA0_V1 0x7140
416 #define R_AX_H2CREG_DATA1_V1 0x7144
417 #define R_AX_H2CREG_DATA2_V1 0x7148
418 #define R_AX_H2CREG_DATA3_V1 0x714C
419 #define R_AX_C2HREG_DATA0_V1 0x7150
420 #define R_AX_C2HREG_DATA1_V1 0x7154
421 #define R_AX_C2HREG_DATA2_V1 0x7158
422 #define R_AX_C2HREG_DATA3_V1 0x715C
423 #define R_AX_H2CREG_CTRL_V1 0x7160
424 #define R_AX_C2HREG_CTRL_V1 0x7164
425 
426 #define R_AX_HCI_FUNC_EN_V1 0x7880
427 
428 #define R_AX_PHYREG_SET 0x8040
429 #define PHYREG_SET_ALL_CYCLE 0x8
430 #define PHYREG_SET_XYN_CYCLE 0xE
431 
432 #define R_AX_HD0IMR 0x8110
433 #define B_AX_WDT_PTFM_INT_EN BIT(5)
434 #define B_AX_CPWM_INT_EN BIT(2)
435 #define B_AX_GT3_INT_EN BIT(1)
436 #define B_AX_C2H_INT_EN BIT(0)
437 #define R_AX_HD0ISR 0x8114
438 #define B_AX_C2H_INT BIT(0)
439 
440 #define R_AX_H2CREG_DATA0 0x8140
441 #define R_AX_H2CREG_DATA1 0x8144
442 #define R_AX_H2CREG_DATA2 0x8148
443 #define R_AX_H2CREG_DATA3 0x814C
444 #define R_AX_C2HREG_DATA0 0x8150
445 #define R_AX_C2HREG_DATA1 0x8154
446 #define R_AX_C2HREG_DATA2 0x8158
447 #define R_AX_C2HREG_DATA3 0x815C
448 #define R_AX_H2CREG_CTRL 0x8160
449 #define B_AX_H2CREG_TRIGGER BIT(0)
450 #define R_AX_C2HREG_CTRL 0x8164
451 #define B_AX_C2HREG_TRIGGER BIT(0)
452 #define R_AX_CPWM 0x8170
453 
454 #define R_AX_HCI_FUNC_EN 0x8380
455 #define B_AX_HCI_RXDMA_EN BIT(1)
456 #define B_AX_HCI_TXDMA_EN BIT(0)
457 
458 #define R_AX_BOOT_DBG 0x83F0
459 
460 #define R_AX_DMAC_FUNC_EN 0x8400
461 #define B_AX_DMAC_CRPRT BIT(31)
462 #define B_AX_MAC_FUNC_EN BIT(30)
463 #define B_AX_DMAC_FUNC_EN BIT(29)
464 #define B_AX_MPDU_PROC_EN BIT(28)
465 #define B_AX_WD_RLS_EN BIT(27)
466 #define B_AX_DLE_WDE_EN BIT(26)
467 #define B_AX_TXPKT_CTRL_EN BIT(25)
468 #define B_AX_STA_SCH_EN BIT(24)
469 #define B_AX_DLE_PLE_EN BIT(23)
470 #define B_AX_PKT_BUF_EN BIT(22)
471 #define B_AX_DMAC_TBL_EN BIT(21)
472 #define B_AX_PKT_IN_EN BIT(20)
473 #define B_AX_DLE_CPUIO_EN BIT(19)
474 #define B_AX_DISPATCHER_EN BIT(18)
475 #define B_AX_BBRPT_EN BIT(17)
476 #define B_AX_MAC_SEC_EN BIT(16)
477 #define B_AX_DMACREG_GCKEN BIT(15)
478 #define B_AX_MAC_UN_EN BIT(15)
479 #define B_AX_H_AXIDMA_EN BIT(14)
480 
481 #define R_AX_DMAC_CLK_EN 0x8404
482 #define B_AX_WD_RLS_CLK_EN BIT(27)
483 #define B_AX_DLE_WDE_CLK_EN BIT(26)
484 #define B_AX_TXPKT_CTRL_CLK_EN BIT(25)
485 #define B_AX_STA_SCH_CLK_EN BIT(24)
486 #define B_AX_DLE_PLE_CLK_EN BIT(23)
487 #define B_AX_PKT_IN_CLK_EN BIT(20)
488 #define B_AX_DLE_CPUIO_CLK_EN BIT(19)
489 #define B_AX_DISPATCHER_CLK_EN BIT(18)
490 #define B_AX_BBRPT_CLK_EN BIT(17)
491 #define B_AX_MAC_SEC_CLK_EN BIT(16)
492 #define B_AX_AXIDMA_CLK_EN BIT(9)
493 
494 #define PCI_LTR_IDLE_TIMER_1US 0
495 #define PCI_LTR_IDLE_TIMER_10US 1
496 #define PCI_LTR_IDLE_TIMER_100US 2
497 #define PCI_LTR_IDLE_TIMER_200US 3
498 #define PCI_LTR_IDLE_TIMER_400US 4
499 #define PCI_LTR_IDLE_TIMER_800US 5
500 #define PCI_LTR_IDLE_TIMER_1_6MS 6
501 #define PCI_LTR_IDLE_TIMER_3_2MS 7
502 #define PCI_LTR_IDLE_TIMER_R_ERR 0xFD
503 #define PCI_LTR_IDLE_TIMER_DEF 0xFE
504 #define PCI_LTR_IDLE_TIMER_IGNORE 0xFF
505 
506 #define PCI_LTR_SPC_10US 0
507 #define PCI_LTR_SPC_100US 1
508 #define PCI_LTR_SPC_500US 2
509 #define PCI_LTR_SPC_1MS 3
510 #define PCI_LTR_SPC_R_ERR 0xFD
511 #define PCI_LTR_SPC_DEF 0xFE
512 #define PCI_LTR_SPC_IGNORE 0xFF
513 
514 #define R_AX_LTR_CTRL_0 0x8410
515 #define B_AX_LTR_SPACE_IDX_MASK GENMASK(13, 12)
516 #define B_AX_LTR_IDLE_TIMER_IDX_MASK GENMASK(10, 8)
517 #define B_AX_LTR_WD_NOEMP_CHK BIT(6)
518 #define B_AX_APP_LTR_ACT BIT(5)
519 #define B_AX_APP_LTR_IDLE BIT(4)
520 #define B_AX_LTR_EN BIT(1)
521 #define B_AX_LTR_WD_NOEMP_CHK_V1 BIT(1)
522 #define B_AX_LTR_HW_EN BIT(0)
523 
524 #define R_AX_LTR_CTRL_1 0x8414
525 #define B_AX_LTR_RX1_TH_MASK GENMASK(27, 16)
526 #define B_AX_LTR_RX0_TH_MASK GENMASK(11, 0)
527 
528 #define R_AX_LTR_IDLE_LATENCY 0x8418
529 
530 #define R_AX_LTR_ACTIVE_LATENCY 0x841C
531 
532 #define R_AX_SER_DBG_INFO 0x8424
533 #define B_AX_L0_TO_L1_EVENT_MASK GENMASK(31, 28)
534 
535 #define R_AX_DLE_EMPTY0 0x8430
536 #define B_AX_PLE_EMPTY_QTA_DMAC_CPUIO BIT(26)
537 #define B_AX_PLE_EMPTY_QTA_DMAC_MPDU_TX BIT(25)
538 #define B_AX_PLE_EMPTY_QTA_DMAC_WLAN_CPU BIT(24)
539 #define B_AX_PLE_EMPTY_QTA_DMAC_H2C BIT(23)
540 #define B_AX_PLE_EMPTY_QTA_DMAC_B1_TXPL BIT(22)
541 #define B_AX_PLE_EMPTY_QTA_DMAC_B0_TXPL BIT(21)
542 #define B_AX_WDE_EMPTY_QTA_DMAC_CPUIO BIT(20)
543 #define B_AX_WDE_EMPTY_QTA_DMAC_PKTIN BIT(19)
544 #define B_AX_WDE_EMPTY_QTA_DMAC_DATA_CPU BIT(18)
545 #define B_AX_WDE_EMPTY_QTA_DMAC_WLAN_CPU BIT(17)
546 #define B_AX_WDE_EMPTY_QTA_DMAC_HIF BIT(16)
547 #define B_AX_WDE_EMPTY_QUE_DMAC_PKTIN BIT(10)
548 #define B_AX_PLE_EMPTY_QUE_DMAC_SEC_TX BIT(9)
549 #define B_AX_PLE_EMPTY_QUE_DMAC_MPDU_TX BIT(8)
550 #define B_AX_WDE_EMPTY_QUE_OTHERS BIT(7)
551 #define B_AX_WDE_EMPTY_QUE_CMAC0_WMM1 BIT(4)
552 #define B_AX_WDE_EMPTY_QUE_CMAC0_WMM0 BIT(3)
553 #define B_AX_WDE_EMPTY_QUE_CMAC1_MBH BIT(2)
554 #define B_AX_WDE_EMPTY_QUE_CMAC0_MBH BIT(1)
555 #define B_AX_WDE_EMPTY_QUE_CMAC0_ALL_AC BIT(0)
556 
557 #define R_AX_DLE_EMPTY1 0x8434
558 #define B_AX_PLE_EMPTY_QTA_DMAC_WDRLS BIT(20)
559 #define B_AX_PLE_EMPTY_QTA_CMAC1_DMA_BBRPT BIT(19)
560 #define B_AX_PLE_EMPTY_QTA_CMAC1_DMA_RX BIT(18)
561 #define B_AX_PLE_EMPTY_QTA_CMAC0_DMA_RX BIT(17)
562 #define B_AX_PLE_EMPTY_QTA_DMAC_C2H BIT(16)
563 #define B_AX_PLE_EMPTY_QUE_DMAC_PLRLS BIT(5)
564 #define B_AX_PLE_EMPTY_QUE_DMAC_CPUIO BIT(4)
565 #define B_AX_PLE_EMPTY_QUE_DMAC_SEC_RX BIT(3)
566 #define B_AX_PLE_EMPTY_QUE_DMAC_MPDU_RX BIT(2)
567 #define B_AX_PLE_EMPTY_QUE_DMAC_HDP BIT(1)
568 #define B_AX_WDE_EMPTY_QUE_DMAC_WDRLS BIT(0)
569 
570 #define R_AX_DMAC_ERR_IMR 0x8520
571 #define B_AX_DLE_CPUIO_ERR_INT_EN BIT(10)
572 #define B_AX_APB_BRIDGE_ERR_INT_EN BIT(9)
573 #define B_AX_DISPATCH_ERR_INT_EN BIT(8)
574 #define B_AX_PKTIN_ERR_INT_EN BIT(7)
575 #define B_AX_PLE_DLE_ERR_INT_EN BIT(6)
576 #define B_AX_TXPKTCTRL_ERR_INT_EN BIT(5)
577 #define B_AX_WDE_DLE_ERR_INT_EN BIT(4)
578 #define B_AX_STA_SCHEDULER_ERR_INT_EN BIT(3)
579 #define B_AX_MPDU_ERR_INT_EN BIT(2)
580 #define B_AX_WSEC_ERR_INT_EN BIT(1)
581 #define B_AX_WDRLS_ERR_INT_EN BIT(0)
582 #define DMAC_ERR_IMR_EN GENMASK(31, 0)
583 #define DMAC_ERR_IMR_DIS 0
584 
585 #define R_AX_DMAC_ERR_ISR 0x8524
586 #define B_AX_HAXIDMA_ERR_FLAG BIT(14)
587 #define B_AX_PAXIDMA_ERR_FLAG BIT(13)
588 #define B_AX_HCI_BUF_ERR_FLAG BIT(12)
589 #define B_AX_BBRPT_ERR_FLAG BIT(11)
590 #define B_AX_DLE_CPUIO_ERR_FLAG BIT(10)
591 #define B_AX_APB_BRIDGE_ERR_FLAG BIT(9)
592 #define B_AX_DISPATCH_ERR_FLAG BIT(8)
593 #define B_AX_PKTIN_ERR_FLAG BIT(7)
594 #define B_AX_PLE_DLE_ERR_FLAG BIT(6)
595 #define B_AX_TXPKTCTRL_ERR_FLAG BIT(5)
596 #define B_AX_WDE_DLE_ERR_FLAG BIT(4)
597 #define B_AX_STA_SCHEDULER_ERR_FLAG BIT(3)
598 #define B_AX_MPDU_ERR_FLAG BIT(2)
599 #define B_AX_WSEC_ERR_FLAG BIT(1)
600 #define B_AX_WDRLS_ERR_FLAG BIT(0)
601 
602 #define R_AX_DISPATCHER_GLOBAL_SETTING_0 0x8800
603 #define B_AX_PL_PAGE_128B_SEL BIT(9)
604 #define B_AX_WD_PAGE_64B_SEL BIT(8)
605 #define R_AX_OTHER_DISPATCHER_ERR_ISR 0x8804
606 #define R_AX_HOST_DISPATCHER_ERR_ISR 0x8808
607 #define R_AX_CPU_DISPATCHER_ERR_ISR 0x880C
608 #define R_AX_TX_ADDRESS_INFO_MODE_SETTING 0x8810
609 #define B_AX_HOST_ADDR_INFO_8B_SEL BIT(0)
610 
611 #define R_AX_HOST_DISPATCHER_ERR_IMR 0x8850
612 #define B_AX_HDT_RX_WRITE_UNDERFLOW_INT_EN BIT(31)
613 #define B_AX_HDT_RX_WRITE_OVERFLOW_INT_EN BIT(30)
614 #define B_AX_HDT_CHKSUM_FSM_ERR_INT_EN BIT(29)
615 #define B_AX_HDT_SHIFT_DMA_CFG_ERR_INT_EN BIT(28)
616 #define B_AX_HDT_DMA_PROCESS_ERR_INT_EN BIT(27)
617 #define B_AX_HDT_TOTAL_LEN_ERR_INT_EN BIT(26)
618 #define B_AX_HDT_SHIFT_EN_ERR_INT_EN BIT(25)
619 #define B_AX_HDT_RXAGG_CFG_ERR_INT_EN BIT(24)
620 #define B_AX_HDT_OUTPUT_ERR_INT_EN BIT(21)
621 #define B_AX_HDT_RES_ERR_INT_EN BIT(20)
622 #define B_AX_HDT_BURST_NUM_ERR_INT_EN BIT(19)
623 #define B_AX_HDT_NULLPKT_ERR_INT_EN BIT(18)
624 #define B_AX_HDT_FLOW_CTRL_ERR_INT_EN BIT(17)
625 #define B_AX_HDT_PLD_CMD_UNDERFLOW_INT_EN BIT(16)
626 #define B_AX_HDT_PLD_CMD_OVERLOW_INT_EN BIT(15)
627 #define B_AX_HDT_TX_WRITE_UNDERFLOW_INT_EN BIT(14)
628 #define B_AX_HDT_TX_WRITE_OVERFLOW_INT_EN BIT(13)
629 #define B_AX_HDT_TCP_CHK_ERR_INT_EN BIT(12)
630 #define B_AX_HDT_TXPKTSIZE_ERR_INT_EN BIT(11)
631 #define B_AX_HDT_PRE_COST_ERR_INT_EN BIT(10)
632 #define B_AX_HDT_WD_CHK_ERR_INT_EN BIT(9)
633 #define B_AX_HDT_CHANNEL_DMA_ERR_INT_EN BIT(8)
634 #define B_AX_HDT_OFFSET_UNMATCH_INT_EN BIT(7)
635 #define B_AX_HDT_PAYLOAD_UNDERFLOW_INT_EN BIT(6)
636 #define B_AX_HDT_PAYLOAD_OVERFLOW_INT_EN BIT(5)
637 #define B_AX_HDT_PERMU_UNDERFLOW_INT_EN BIT(4)
638 #define B_AX_HDT_PERMU_OVERFLOW_INT_EN BIT(3)
639 #define B_AX_HDT_PKT_FAIL_DBG_INT_EN BIT(2)
640 #define B_AX_HDT_CHANNEL_ID_ERR_INT_EN BIT(1)
641 #define B_AX_HDT_CHANNEL_DIFF_ERR_INT_EN BIT(0)
642 #define B_AX_HOST_DISP_IMR_CLR (B_AX_HDT_CHANNEL_DIFF_ERR_INT_EN | \
643 				B_AX_HDT_CHANNEL_ID_ERR_INT_EN | \
644 				B_AX_HDT_PKT_FAIL_DBG_INT_EN | \
645 				B_AX_HDT_PERMU_OVERFLOW_INT_EN | \
646 				B_AX_HDT_PERMU_UNDERFLOW_INT_EN | \
647 				B_AX_HDT_PAYLOAD_OVERFLOW_INT_EN | \
648 				B_AX_HDT_PAYLOAD_UNDERFLOW_INT_EN | \
649 				B_AX_HDT_OFFSET_UNMATCH_INT_EN | \
650 				B_AX_HDT_CHANNEL_DMA_ERR_INT_EN | \
651 				B_AX_HDT_WD_CHK_ERR_INT_EN | \
652 				B_AX_HDT_PRE_COST_ERR_INT_EN | \
653 				B_AX_HDT_TXPKTSIZE_ERR_INT_EN | \
654 				B_AX_HDT_TCP_CHK_ERR_INT_EN | \
655 				B_AX_HDT_TX_WRITE_OVERFLOW_INT_EN | \
656 				B_AX_HDT_TX_WRITE_UNDERFLOW_INT_EN | \
657 				B_AX_HDT_PLD_CMD_OVERLOW_INT_EN | \
658 				B_AX_HDT_PLD_CMD_UNDERFLOW_INT_EN | \
659 				B_AX_HDT_FLOW_CTRL_ERR_INT_EN | \
660 				B_AX_HDT_NULLPKT_ERR_INT_EN | \
661 				B_AX_HDT_BURST_NUM_ERR_INT_EN | \
662 				B_AX_HDT_RXAGG_CFG_ERR_INT_EN | \
663 				B_AX_HDT_SHIFT_EN_ERR_INT_EN | \
664 				B_AX_HDT_TOTAL_LEN_ERR_INT_EN | \
665 				B_AX_HDT_DMA_PROCESS_ERR_INT_EN | \
666 				B_AX_HDT_SHIFT_DMA_CFG_ERR_INT_EN | \
667 				B_AX_HDT_CHKSUM_FSM_ERR_INT_EN | \
668 				B_AX_HDT_RX_WRITE_OVERFLOW_INT_EN | \
669 				B_AX_HDT_RX_WRITE_UNDERFLOW_INT_EN)
670 #define B_AX_HOST_DISP_IMR_SET (B_AX_HDT_CHANNEL_DIFF_ERR_INT_EN | \
671 				B_AX_HDT_PAYLOAD_OVERFLOW_INT_EN | \
672 				B_AX_HDT_PAYLOAD_UNDERFLOW_INT_EN | \
673 				B_AX_HDT_CHANNEL_DMA_ERR_INT_EN | \
674 				B_AX_HDT_TOTAL_LEN_ERR_INT_EN | \
675 				B_AX_HDT_DMA_PROCESS_ERR_INT_EN)
676 
677 #define B_AX_HR_WRFF_UNDERFLOW_ERR_INT_EN BIT(31)
678 #define B_AX_HR_WRFF_OVERFLOW_ERR_INT_EN BIT(30)
679 #define B_AX_HR_CHKSUM_FSM_ERR_INT_EN BIT(29)
680 #define B_AX_HR_SHIFT_DMA_CFG_ERR_INT_EN BIT(28)
681 #define B_AX_HR_DMA_PROCESS_ERR_INT_EN BIT(27)
682 #define B_AX_HR_TOTAL_LEN_UNDER_ERR_INT_EN BIT(26)
683 #define B_AX_HR_SHIFT_EN_ERR_INT_EN BIT(25)
684 #define B_AX_HR_AGG_CFG_ERR_INT_EN BIT(24)
685 #define B_AX_HR_DMA_RD_CNT_DEQ_ERR_INT_EN BIT(23)
686 #define B_AX_HR_PLD_LEN_ZERO_ERR_INT_EN BIT(22)
687 #define B_AX_HT_ILL_CH_ERR_INT_EN BIT(20)
688 #define B_AX_HT_ADDR_INFO_LEN_ERR_INT_EN BIT(18)
689 #define B_AX_HT_WD_LEN_OVER_ERR_INT_EN BIT(17)
690 #define B_AX_HT_PLD_CMD_UNDERFLOW_ERR_INT_EN BIT(16)
691 #define B_AX_HT_PLD_CMD_OVERFLOW_ERR_INT_EN BIT(15)
692 #define B_AX_HT_WRFF_UNDERFLOW_ERR_INT_EN BIT(14)
693 #define B_AX_HT_WRFF_OVERFLOW_ERR_INT_EN BIT(13)
694 #define B_AX_HT_CHKSUM_FSM_ERR_INT_EN BIT(12)
695 #define B_AX_HT_TXPKTSIZE_ERR_INT_EN BIT(11)
696 #define B_AX_HT_PRE_SUB_ERR_INT_EN BIT(10)
697 #define B_AX_HT_WD_CHKSUM_ERR_INT_EN BIT(9)
698 #define B_AX_HT_CHANNEL_DMA_ERR_INT_EN BIT(8)
699 #define B_AX_HT_OFFSET_UNMATCH_ERR_INT_EN BIT(7)
700 #define B_AX_HT_PAYLOAD_UNDER_ERR_INT_EN BIT(6)
701 #define B_AX_HT_PAYLOAD_OVER_ERR_INT_EN BIT(5)
702 #define B_AX_HT_PERMU_FF_UNDERFLOW_ERR_INT_EN BIT(4)
703 #define B_AX_HT_PERMU_FF_OVERFLOW_ERR_INT_EN BIT(3)
704 #define B_AX_HT_PKT_FAIL_ERR_INT_EN BIT(2)
705 #define B_AX_HT_CH_ID_ERR_INT_EN BIT(1)
706 #define B_AX_HT_EP_CH_DIFF_ERR_INT_EN BIT(0)
707 #define B_AX_HOST_DISP_IMR_CLR_V1 (B_AX_HT_EP_CH_DIFF_ERR_INT_EN | \
708 				   B_AX_HT_CH_ID_ERR_INT_EN | \
709 				   B_AX_HT_PKT_FAIL_ERR_INT_EN | \
710 				   B_AX_HT_PERMU_FF_OVERFLOW_ERR_INT_EN | \
711 				   B_AX_HT_PERMU_FF_UNDERFLOW_ERR_INT_EN | \
712 				   B_AX_HT_PAYLOAD_OVER_ERR_INT_EN | \
713 				   B_AX_HT_PAYLOAD_UNDER_ERR_INT_EN | \
714 				   B_AX_HT_OFFSET_UNMATCH_ERR_INT_EN | \
715 				   B_AX_HT_CHANNEL_DMA_ERR_INT_EN | \
716 				   B_AX_HT_WD_CHKSUM_ERR_INT_EN | \
717 				   B_AX_HT_PRE_SUB_ERR_INT_EN | \
718 				   B_AX_HT_TXPKTSIZE_ERR_INT_EN | \
719 				   B_AX_HT_CHKSUM_FSM_ERR_INT_EN | \
720 				   B_AX_HT_WRFF_OVERFLOW_ERR_INT_EN | \
721 				   B_AX_HT_WRFF_UNDERFLOW_ERR_INT_EN | \
722 				   B_AX_HT_PLD_CMD_OVERFLOW_ERR_INT_EN | \
723 				   B_AX_HT_PLD_CMD_UNDERFLOW_ERR_INT_EN | \
724 				   B_AX_HT_WD_LEN_OVER_ERR_INT_EN | \
725 				   B_AX_HT_ADDR_INFO_LEN_ERR_INT_EN | \
726 				   B_AX_HT_ILL_CH_ERR_INT_EN | \
727 				   B_AX_HR_PLD_LEN_ZERO_ERR_INT_EN | \
728 				   B_AX_HR_DMA_RD_CNT_DEQ_ERR_INT_EN | \
729 				   B_AX_HR_AGG_CFG_ERR_INT_EN | \
730 				   B_AX_HR_SHIFT_EN_ERR_INT_EN | \
731 				   B_AX_HR_TOTAL_LEN_UNDER_ERR_INT_EN | \
732 				   B_AX_HR_DMA_PROCESS_ERR_INT_EN | \
733 				   B_AX_HR_SHIFT_DMA_CFG_ERR_INT_EN | \
734 				   B_AX_HR_CHKSUM_FSM_ERR_INT_EN | \
735 				   B_AX_HR_WRFF_OVERFLOW_ERR_INT_EN | \
736 				   B_AX_HR_WRFF_UNDERFLOW_ERR_INT_EN)
737 #define B_AX_HOST_DISP_IMR_SET_V1 (B_AX_HT_PAYLOAD_OVER_ERR_INT_EN | \
738 				   B_AX_HT_PAYLOAD_UNDER_ERR_INT_EN | \
739 				   B_AX_HT_ILL_CH_ERR_INT_EN | \
740 				   B_AX_HR_TOTAL_LEN_UNDER_ERR_INT_EN | \
741 				   B_AX_HR_DMA_PROCESS_ERR_INT_EN)
742 
743 #define R_AX_CPU_DISPATCHER_ERR_IMR 0x8854
744 #define B_AX_CPU_RX_WRITE_UNDERFLOW_INT_EN BIT(31)
745 #define B_AX_CPU_RX_WRITE_OVERFLOW_INT_EN BIT(30)
746 #define B_AX_CPU_CHKSUM_FSM_ERR_INT_EN BIT(29)
747 #define B_AX_CPU_SHIFT_DMA_CFG_ERR_INT_EN BIT(28)
748 #define B_AX_CPU_DMA_PROCESS_ERR_INT_EN BIT(27)
749 #define B_AX_CPU_TOTAL_LEN_ERR_INT_EN BIT(26)
750 #define B_AX_CPU_SHIFT_EN_ERR_INT_EN BIT(25)
751 #define B_AX_CPU_RXAGG_CFG_ERR_INT_EN BIT(24)
752 #define B_AX_CPU_OUTPUT_ERR_INT_EN BIT(20)
753 #define B_AX_CPU_RESP_ERR_INT_EN BIT(19)
754 #define B_AX_CPU_BURST_NUM_ERR_INT_EN BIT(18)
755 #define B_AX_CPU_NULLPKT_ERR_INT_EN BIT(17)
756 #define B_AX_CPU_FLOW_CTRL_ERR_INT_EN BIT(16)
757 #define B_AX_CPU_F2P_SEQ_ERR_INT_EN BIT(15)
758 #define B_AX_CPU_F2P_QSEL_ERR_INT_EN BIT(14)
759 #define B_AX_CPU_PLD_CMD_UNDERFLOW_INT_EN BIT(13)
760 #define B_AX_CPU_PLD_CMD_OVERLOW_INT_EN BIT(12)
761 #define B_AX_CPU_PRE_COST_ERR_INT_EN BIT(11)
762 #define B_AX_CPU_WD_CHK_ERR_INT_EN BIT(10)
763 #define B_AX_CPU_CHANNEL_DMA_ERR_INT_EN BIT(9)
764 #define B_AX_CPU_OFFSET_UNMATCH_INT_EN BIT(8)
765 #define B_AX_CPU_PAYLOAD_CHKSUM_ERR_INT_EN BIT(7)
766 #define B_AX_CPU_PAYLOAD_UNDERFLOW_INT_EN BIT(6)
767 #define B_AX_CPU_PAYLOAD_OVERFLOW_INT_EN BIT(5)
768 #define B_AX_CPU_PERMU_UNDERFLOW_INT_EN BIT(4)
769 #define B_AX_CPU_PERMU_OVERFLOW_INT_EN BIT(3)
770 #define B_AX_CPU_CHANNEL_ID_ERR_INT_EN BIT(2)
771 #define B_AX_CPU_PKT_FAIL_DBG_INT_EN BIT(1)
772 #define B_AX_CPU_CHANNEL_DIFF_ERR_INT_EN BIT(0)
773 #define B_AX_CPU_DISP_IMR_CLR (B_AX_CPU_CHANNEL_DIFF_ERR_INT_EN | \
774 			       B_AX_CPU_PKT_FAIL_DBG_INT_EN | \
775 			       B_AX_CPU_CHANNEL_ID_ERR_INT_EN | \
776 			       B_AX_CPU_PERMU_OVERFLOW_INT_EN | \
777 			       B_AX_CPU_PERMU_UNDERFLOW_INT_EN | \
778 			       B_AX_CPU_PAYLOAD_OVERFLOW_INT_EN | \
779 			       B_AX_CPU_PAYLOAD_UNDERFLOW_INT_EN | \
780 			       B_AX_CPU_PAYLOAD_CHKSUM_ERR_INT_EN | \
781 			       B_AX_CPU_OFFSET_UNMATCH_INT_EN | \
782 			       B_AX_CPU_CHANNEL_DMA_ERR_INT_EN | \
783 			       B_AX_CPU_WD_CHK_ERR_INT_EN | \
784 			       B_AX_CPU_PRE_COST_ERR_INT_EN | \
785 			       B_AX_CPU_PLD_CMD_OVERLOW_INT_EN | \
786 			       B_AX_CPU_PLD_CMD_UNDERFLOW_INT_EN | \
787 			       B_AX_CPU_F2P_QSEL_ERR_INT_EN | \
788 			       B_AX_CPU_F2P_SEQ_ERR_INT_EN | \
789 			       B_AX_CPU_FLOW_CTRL_ERR_INT_EN | \
790 			       B_AX_CPU_NULLPKT_ERR_INT_EN | \
791 			       B_AX_CPU_BURST_NUM_ERR_INT_EN | \
792 			       B_AX_CPU_RXAGG_CFG_ERR_INT_EN | \
793 			       B_AX_CPU_SHIFT_EN_ERR_INT_EN | \
794 			       B_AX_CPU_TOTAL_LEN_ERR_INT_EN | \
795 			       B_AX_CPU_DMA_PROCESS_ERR_INT_EN | \
796 			       B_AX_CPU_SHIFT_DMA_CFG_ERR_INT_EN | \
797 			       B_AX_CPU_CHKSUM_FSM_ERR_INT_EN | \
798 			       B_AX_CPU_RX_WRITE_OVERFLOW_INT_EN | \
799 			       B_AX_CPU_RX_WRITE_UNDERFLOW_INT_EN)
800 #define B_AX_CPU_DISP_IMR_SET (B_AX_CPU_PKT_FAIL_DBG_INT_EN | \
801 			       B_AX_CPU_PAYLOAD_OVERFLOW_INT_EN | \
802 			       B_AX_CPU_PAYLOAD_UNDERFLOW_INT_EN | \
803 			       B_AX_CPU_TOTAL_LEN_ERR_INT_EN)
804 
805 #define B_AX_CR_PLD_LEN_ERR_INT_EN BIT(30)
806 #define B_AX_CR_WRFF_UNDERFLOW_ERR_INT_EN BIT(29)
807 #define B_AX_CR_WRFF_OVERFLOW_ERR_INT_EN BIT(28)
808 #define B_AX_CR_SHIFT_DMA_CFG_ERR_INT_EN BIT(27)
809 #define B_AX_CR_DMA_PROCESS_ERR_INT_EN BIT(26)
810 #define B_AX_CR_TOTAL_LEN_UNDER_ERR_INT_EN BIT(25)
811 #define B_AX_CR_SHIFT_EN_ERR_INT_EN BIT(24)
812 #define B_AX_REUSE_FIFO_B_UNDER_ERR_INT_EN BIT(22)
813 #define B_AX_REUSE_FIFO_B_OVER_ERR_INT_EN BIT(21)
814 #define B_AX_REUSE_FIFO_A_UNDER_ERR_INT_EN BIT(20)
815 #define B_AX_REUSE_FIFO_A_OVER_ERR_INT_EN BIT(19)
816 #define B_AX_CT_ADDR_INFO_LEN_MISS_ERR_INT_EN BIT(17)
817 #define B_AX_CT_WD_LEN_OVER_ERR_INT_EN BIT(16)
818 #define B_AX_CT_F2P_SEQ_ERR_INT_EN BIT(15)
819 #define B_AX_CT_F2P_QSEL_ERR_INT_EN BIT(14)
820 #define B_AX_CT_PLD_CMD_UNDERFLOW_ERR_INT_EN BIT(13)
821 #define B_AX_CT_PLD_CMD_OVERFLOW_ERR_INT_EN BIT(12)
822 #define B_AX_CT_PRE_SUB_ERR_INT_EN BIT(11)
823 #define B_AX_CT_WD_CHKSUM_ERR_INT_EN BIT(10)
824 #define B_AX_CT_CHANNEL_DMA_ERR_INT_EN BIT(9)
825 #define B_AX_CT_OFFSET_UNMATCH_ERR_INT_EN BIT(8)
826 #define B_AX_CT_PAYLOAD_CHKSUM_ERR_INT_EN BIT(7)
827 #define B_AX_CT_PAYLOAD_UNDER_ERR_INT_EN BIT(6)
828 #define B_AX_CT_PAYLOAD_OVER_ERR_INT_EN BIT(5)
829 #define B_AX_CT_PERMU_FF_UNDERFLOW_ERR_INT_EN BIT(4)
830 #define B_AX_CT_PERMU_FF_OVERFLOW_ERR_INT_EN BIT(3)
831 #define B_AX_CT_CH_ID_ERR_INT_EN BIT(2)
832 #define B_AX_CT_EP_CH_DIFF_ERR_INT_EN BIT(0)
833 #define B_AX_CPU_DISP_IMR_CLR_V1 (B_AX_CT_EP_CH_DIFF_ERR_INT_EN | \
834 				  B_AX_CT_CH_ID_ERR_INT_EN | \
835 				  B_AX_CT_PERMU_FF_OVERFLOW_ERR_INT_EN | \
836 				  B_AX_CT_PERMU_FF_UNDERFLOW_ERR_INT_EN | \
837 				  B_AX_CT_PAYLOAD_OVER_ERR_INT_EN | \
838 				  B_AX_CT_PAYLOAD_UNDER_ERR_INT_EN | \
839 				  B_AX_CT_PAYLOAD_CHKSUM_ERR_INT_EN | \
840 				  B_AX_CT_OFFSET_UNMATCH_ERR_INT_EN | \
841 				  B_AX_CT_CHANNEL_DMA_ERR_INT_EN | \
842 				  B_AX_CT_WD_CHKSUM_ERR_INT_EN | \
843 				  B_AX_CT_PRE_SUB_ERR_INT_EN | \
844 				  B_AX_CT_PLD_CMD_OVERFLOW_ERR_INT_EN | \
845 				  B_AX_CT_PLD_CMD_UNDERFLOW_ERR_INT_EN | \
846 				  B_AX_CT_F2P_QSEL_ERR_INT_EN | \
847 				  B_AX_CT_F2P_SEQ_ERR_INT_EN | \
848 				  B_AX_CT_WD_LEN_OVER_ERR_INT_EN | \
849 				  B_AX_CT_ADDR_INFO_LEN_MISS_ERR_INT_EN | \
850 				  B_AX_REUSE_FIFO_A_OVER_ERR_INT_EN | \
851 				  B_AX_REUSE_FIFO_A_UNDER_ERR_INT_EN | \
852 				  B_AX_REUSE_FIFO_B_OVER_ERR_INT_EN | \
853 				  B_AX_REUSE_FIFO_B_UNDER_ERR_INT_EN | \
854 				  B_AX_CR_SHIFT_EN_ERR_INT_EN | \
855 				  B_AX_CR_TOTAL_LEN_UNDER_ERR_INT_EN | \
856 				  B_AX_CR_DMA_PROCESS_ERR_INT_EN | \
857 				  B_AX_CR_SHIFT_DMA_CFG_ERR_INT_EN | \
858 				  B_AX_CR_WRFF_OVERFLOW_ERR_INT_EN | \
859 				  B_AX_CR_WRFF_UNDERFLOW_ERR_INT_EN | \
860 				  B_AX_CR_PLD_LEN_ERR_INT_EN)
861 #define B_AX_CPU_DISP_IMR_SET_V1 (B_AX_CT_PAYLOAD_OVER_ERR_INT_EN | \
862 				  B_AX_CT_PAYLOAD_UNDER_ERR_INT_EN | \
863 				  B_AX_CR_TOTAL_LEN_UNDER_ERR_INT_EN | \
864 				  B_AX_CR_DMA_PROCESS_ERR_INT_EN | \
865 				  B_AX_CR_WRFF_OVERFLOW_ERR_INT_EN | \
866 				  B_AX_CR_WRFF_UNDERFLOW_ERR_INT_EN)
867 
868 #define R_AX_OTHER_DISPATCHER_ERR_IMR 0x8858
869 #define B_AX_OTHER_STF_WROQT_UNDERFLOW_INT_EN BIT(29)
870 #define B_AX_OTHER_STF_WROQT_OVERFLOW_INT_EN BIT(28)
871 #define B_AX_OTHER_STF_WRFF_UNDERFLOW_INT_EN BIT(27)
872 #define B_AX_OTHER_STF_WRFF_OVERFLOW_INT_EN BIT(26)
873 #define B_AX_OTHER_STF_CMD_UNDERFLOW_INT_EN BIT(25)
874 #define B_AX_OTHER_STF_CMD_OVERFLOW_INT_EN BIT(24)
875 #define B_AX_HOST_ADDR_INFO_LEN_ZERO_ERR_INT_EN BIT(17)
876 #define B_AX_CPU_ADDR_INFO_LEN_ZERO_ERR_INT_EN BIT(16)
877 #define B_AX_PLE_OUTPUT_ERR_INT_EN BIT(12)
878 #define B_AX_PLE_RESP_ERR_INT_EN BIT(11)
879 #define B_AX_PLE_BURST_NUM_ERR_INT_EN BIT(10)
880 #define B_AX_PLE_NULL_PKT_ERR_INT_EN BIT(9)
881 #define B_AX_PLE_FLOW_CTRL_ERR_INT_EN BIT(8)
882 #define B_AX_WDE_OUTPUT_ERR_INT_EN BIT(4)
883 #define B_AX_WDE_RESP_ERR_INT_EN BIT(3)
884 #define B_AX_WDE_BURST_NUM_ERR_INT_EN BIT(2)
885 #define B_AX_WDE_NULL_PKT_ERR_INT_EN BIT(1)
886 #define B_AX_WDE_FLOW_CTRL_ERR_INT_EN BIT(0)
887 #define B_AX_OTHER_DISP_IMR_CLR (B_AX_OTHER_STF_WROQT_UNDERFLOW_INT_EN | \
888 				 B_AX_OTHER_STF_WROQT_OVERFLOW_INT_EN | \
889 				 B_AX_OTHER_STF_WRFF_UNDERFLOW_INT_EN | \
890 				 B_AX_OTHER_STF_WRFF_OVERFLOW_INT_EN | \
891 				 B_AX_OTHER_STF_CMD_UNDERFLOW_INT_EN | \
892 				 B_AX_OTHER_STF_CMD_OVERFLOW_INT_EN | \
893 				 B_AX_HOST_ADDR_INFO_LEN_ZERO_ERR_INT_EN | \
894 				 B_AX_CPU_ADDR_INFO_LEN_ZERO_ERR_INT_EN | \
895 				 B_AX_PLE_OUTPUT_ERR_INT_EN | \
896 				 B_AX_PLE_RESP_ERR_INT_EN | \
897 				 B_AX_PLE_BURST_NUM_ERR_INT_EN | \
898 				 B_AX_PLE_NULL_PKT_ERR_INT_EN | \
899 				 B_AX_PLE_FLOW_CTRL_ERR_INT_EN | \
900 				 B_AX_WDE_OUTPUT_ERR_INT_EN | \
901 				 B_AX_WDE_RESP_ERR_INT_EN | \
902 				 B_AX_WDE_BURST_NUM_ERR_INT_EN | \
903 				 B_AX_WDE_NULL_PKT_ERR_INT_EN | \
904 				 B_AX_WDE_FLOW_CTRL_ERR_INT_EN)
905 
906 #define B_AX_REUSE_SIZE_ERR_INT_EN BIT(31)
907 #define B_AX_REUSE_EN_ERR_INT_EN BIT(30)
908 #define B_AX_STF_OQT_UNDERFLOW_ERR_INT_EN BIT(29)
909 #define B_AX_STF_OQT_OVERFLOW_ERR_INT_EN BIT(28)
910 #define B_AX_STF_WRFF_UNDERFLOW_ERR_INT_EN BIT(27)
911 #define B_AX_STF_WRFF_OVERFLOW_ERR_INT_EN BIT(26)
912 #define B_AX_STF_CMD_UNDERFLOW_ERR_INT_EN BIT(25)
913 #define B_AX_STF_CMD_OVERFLOW_ERR_INT_EN BIT(24)
914 #define B_AX_REUSE_SIZE_ZERO_ERR_INT_EN BIT(23)
915 #define B_AX_REUSE_PKT_CNT_ERR_INT_EN BIT(22)
916 #define B_AX_CDT_PTR_TIMEOUT_ERR_INT_EN BIT(21)
917 #define B_AX_CDT_HCI_TIMEOUT_ERR_INT_EN BIT(20)
918 #define B_AX_HDT_PTR_TIMEOUT_ERR_INT_EN BIT(19)
919 #define B_AX_HDT_HCI_TIMEOUT_ERR_INT_EN BIT(18)
920 #define B_AX_CDT_ADDR_INFO_LEN_ERR_INT_EN BIT(17)
921 #define B_AX_HDT_ADDR_INFO_LEN_ERR_INT_EN BIT(16)
922 #define B_AX_CDR_DMA_TIMEOUT_ERR_INT_EN BIT(15)
923 #define B_AX_CDR_RX_TIMEOUT_ERR_INT_EN BIT(14)
924 #define B_AX_PLE_RESPOSE_ERR_INT_EN BIT(11)
925 #define B_AX_HDR_DMA_TIMEOUT_ERR_INT_EN BIT(7)
926 #define B_AX_HDR_RX_TIMEOUT_ERR_INT_EN BIT(6)
927 #define B_AX_WDE_RESPONSE_ERR_INT_EN BIT(3)
928 #define B_AX_OTHER_DISP_IMR_CLR_V1 (B_AX_CT_EP_CH_DIFF_ERR_INT_EN | \
929 				    B_AX_WDE_FLOW_CTRL_ERR_INT_EN | \
930 				    B_AX_WDE_NULL_PKT_ERR_INT_EN | \
931 				    B_AX_WDE_BURST_NUM_ERR_INT_EN | \
932 				    B_AX_WDE_RESPONSE_ERR_INT_EN | \
933 				    B_AX_WDE_OUTPUT_ERR_INT_EN | \
934 				    B_AX_HDR_RX_TIMEOUT_ERR_INT_EN | \
935 				    B_AX_HDR_DMA_TIMEOUT_ERR_INT_EN | \
936 				    B_AX_PLE_FLOW_CTRL_ERR_INT_EN | \
937 				    B_AX_PLE_NULL_PKT_ERR_INT_EN | \
938 				    B_AX_PLE_BURST_NUM_ERR_INT_EN | \
939 				    B_AX_PLE_RESPOSE_ERR_INT_EN | \
940 				    B_AX_PLE_OUTPUT_ERR_INT_EN | \
941 				    B_AX_CDR_RX_TIMEOUT_ERR_INT_EN | \
942 				    B_AX_CDR_DMA_TIMEOUT_ERR_INT_EN | \
943 				    B_AX_HDT_ADDR_INFO_LEN_ERR_INT_EN | \
944 				    B_AX_CDT_ADDR_INFO_LEN_ERR_INT_EN | \
945 				    B_AX_HDT_HCI_TIMEOUT_ERR_INT_EN | \
946 				    B_AX_HDT_PTR_TIMEOUT_ERR_INT_EN | \
947 				    B_AX_CDT_HCI_TIMEOUT_ERR_INT_EN | \
948 				    B_AX_CDT_PTR_TIMEOUT_ERR_INT_EN | \
949 				    B_AX_REUSE_PKT_CNT_ERR_INT_EN | \
950 				    B_AX_REUSE_SIZE_ZERO_ERR_INT_EN | \
951 				    B_AX_STF_CMD_OVERFLOW_ERR_INT_EN | \
952 				    B_AX_STF_CMD_UNDERFLOW_ERR_INT_EN | \
953 				    B_AX_STF_WRFF_OVERFLOW_ERR_INT_EN | \
954 				    B_AX_STF_WRFF_UNDERFLOW_ERR_INT_EN | \
955 				    B_AX_STF_OQT_OVERFLOW_ERR_INT_EN | \
956 				    B_AX_STF_OQT_UNDERFLOW_ERR_INT_EN | \
957 				    B_AX_REUSE_EN_ERR_INT_EN | \
958 				    B_AX_REUSE_SIZE_ERR_INT_EN)
959 #define B_AX_OTHER_DISP_IMR_SET_V1 (B_AX_CDR_RX_TIMEOUT_ERR_INT_EN | \
960 				    B_AX_CDR_DMA_TIMEOUT_ERR_INT_EN | \
961 				    B_AX_HDT_HCI_TIMEOUT_ERR_INT_EN | \
962 				    B_AX_HDT_PTR_TIMEOUT_ERR_INT_EN | \
963 				    B_AX_CDT_HCI_TIMEOUT_ERR_INT_EN | \
964 				    B_AX_CDT_PTR_TIMEOUT_ERR_INT_EN | \
965 				    B_AX_STF_OQT_OVERFLOW_ERR_INT_EN | \
966 				    B_AX_STF_OQT_UNDERFLOW_ERR_INT_EN)
967 
968 #define R_AX_DISPATCHER_DBG_PORT 0x8860
969 #define B_AX_DISPATCHER_DBG_SEL_MASK GENMASK(11, 8)
970 #define B_AX_DISPATCHER_INTN_SEL_MASK GENMASK(7, 4)
971 #define B_AX_DISPATCHER_CH_SEL_MASK GENMASK(3, 0)
972 
973 #define R_AX_RX_FUNCTION_STOP 0x8920
974 #define B_AX_HDR_RX_STOP BIT(0)
975 
976 #define R_AX_HCI_FC_CTRL 0x8A00
977 #define B_AX_HCI_FC_CH12_FULL_COND_MASK GENMASK(11, 10)
978 #define B_AX_HCI_FC_WP_CH811_FULL_COND_MASK GENMASK(9, 8)
979 #define B_AX_HCI_FC_WP_CH07_FULL_COND_MASK GENMASK(7, 6)
980 #define B_AX_HCI_FC_WD_FULL_COND_MASK GENMASK(5, 4)
981 #define B_AX_HCI_FC_CH12_EN BIT(3)
982 #define B_AX_HCI_FC_MODE_MASK GENMASK(2, 1)
983 #define B_AX_HCI_FC_EN BIT(0)
984 
985 #define R_AX_CH_PAGE_CTRL 0x8A04
986 #define B_AX_PREC_PAGE_CH12_MASK GENMASK(24, 16)
987 #define B_AX_PREC_PAGE_CH011_MASK GENMASK(8, 0)
988 
989 #define B_AX_MAX_PG_MASK GENMASK(28, 16)
990 #define B_AX_MIN_PG_MASK GENMASK(12, 0)
991 #define B_AX_GRP BIT(31)
992 #define R_AX_ACH0_PAGE_CTRL 0x8A10
993 #define R_AX_ACH1_PAGE_CTRL 0x8A14
994 #define R_AX_ACH2_PAGE_CTRL 0x8A18
995 #define R_AX_ACH3_PAGE_CTRL 0x8A1C
996 #define R_AX_ACH4_PAGE_CTRL 0x8A20
997 #define R_AX_ACH5_PAGE_CTRL 0x8A24
998 #define R_AX_ACH6_PAGE_CTRL 0x8A28
999 #define R_AX_ACH7_PAGE_CTRL 0x8A2C
1000 #define R_AX_CH8_PAGE_CTRL 0x8A30
1001 #define R_AX_CH9_PAGE_CTRL 0x8A34
1002 #define R_AX_CH10_PAGE_CTRL 0x8A38
1003 #define R_AX_CH11_PAGE_CTRL 0x8A3C
1004 
1005 #define B_AX_AVAL_PG_MASK GENMASK(27, 16)
1006 #define B_AX_USE_PG_MASK GENMASK(12, 0)
1007 #define R_AX_ACH0_PAGE_INFO 0x8A50
1008 #define R_AX_ACH1_PAGE_INFO 0x8A54
1009 #define R_AX_ACH2_PAGE_INFO 0x8A58
1010 #define R_AX_ACH3_PAGE_INFO 0x8A5C
1011 #define R_AX_ACH4_PAGE_INFO 0x8A60
1012 #define R_AX_ACH5_PAGE_INFO 0x8A64
1013 #define R_AX_ACH6_PAGE_INFO 0x8A68
1014 #define R_AX_ACH7_PAGE_INFO 0x8A6C
1015 #define R_AX_CH8_PAGE_INFO 0x8A70
1016 #define R_AX_CH9_PAGE_INFO 0x8A74
1017 #define R_AX_CH10_PAGE_INFO 0x8A78
1018 #define R_AX_CH11_PAGE_INFO 0x8A7C
1019 #define R_AX_CH12_PAGE_INFO 0x8A80
1020 
1021 #define R_AX_PUB_PAGE_INFO3 0x8A8C
1022 #define B_AX_G1_AVAL_PG_MASK GENMASK(28, 16)
1023 #define B_AX_G0_AVAL_PG_MASK GENMASK(12, 0)
1024 
1025 #define R_AX_PUB_PAGE_CTRL1 0x8A90
1026 #define B_AX_PUBPG_G1_MASK GENMASK(28, 16)
1027 #define B_AX_PUBPG_G0_MASK GENMASK(12, 0)
1028 
1029 #define R_AX_PUB_PAGE_CTRL2 0x8A94
1030 #define B_AX_PUBPG_ALL_MASK GENMASK(12, 0)
1031 
1032 #define R_AX_PUB_PAGE_INFO1 0x8A98
1033 #define B_AX_G1_USE_PG_MASK GENMASK(28, 16)
1034 #define B_AX_G0_USE_PG_MASK GENMASK(12, 0)
1035 
1036 #define R_AX_PUB_PAGE_INFO2 0x8A9C
1037 #define B_AX_PUB_AVAL_PG_MASK GENMASK(12, 0)
1038 
1039 #define R_AX_WP_PAGE_CTRL1 0x8AA0
1040 #define B_AX_PREC_PAGE_WP_CH811_MASK GENMASK(24, 16)
1041 #define B_AX_PREC_PAGE_WP_CH07_MASK GENMASK(8, 0)
1042 
1043 #define R_AX_WP_PAGE_CTRL2 0x8AA4
1044 #define B_AX_WP_THRD_MASK GENMASK(12, 0)
1045 
1046 #define R_AX_WP_PAGE_INFO1 0x8AA8
1047 #define B_AX_WP_AVAL_PG_MASK GENMASK(28, 16)
1048 
1049 #define R_AX_WDE_PKTBUF_CFG 0x8C08
1050 #define B_AX_WDE_START_BOUND_MASK GENMASK(13, 8)
1051 #define B_AX_WDE_PAGE_SEL_MASK GENMASK(1, 0)
1052 #define B_AX_WDE_FREE_PAGE_NUM_MASK GENMASK(28, 16)
1053 
1054 #define R_AX_WDE_ERRFLAG_MSG 0x8C30
1055 #define B_AX_WDE_ERR_FLAG_MSG_MASK GENMASK(31, 0)
1056 
1057 #define R_AX_WDE_ERR_FLAG_CFG_NUM1 0x8C34
1058 #define B_AX_WDE_ERR_FLAG_NUM1_VLD BIT(31)
1059 #define B_AX_WDE_ERR_FLAG_NUM1_MSTIDX_MASK GENMASK(27, 24)
1060 #define B_AX_WDE_ERR_FLAG_NUM1_ISRIDX_MASK GENMASK(20, 16)
1061 #define B_AX_WDE_DATCHN_FRZTMR_MODE BIT(2)
1062 #define B_AX_WDE_QUEMGN_FRZTMR_MODE BIT(1)
1063 #define B_AX_WDE_BUFMGN_FRZTMR_MODE BIT(0)
1064 
1065 #define R_AX_WDE_ERR_IMR 0x8C38
1066 #define B_AX_WDE_DATCHN_RRDY_ERR_INT_EN BIT(27)
1067 #define B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN BIT(26)
1068 #define B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN BIT(25)
1069 #define B_AX_WDE_DATCHN_ARBT_ERR_INT_EN BIT(24)
1070 #define B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN BIT(19)
1071 #define B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN BIT(18)
1072 #define B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN BIT(17)
1073 #define B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN BIT(16)
1074 #define B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN BIT(15)
1075 #define B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN BIT(14)
1076 #define B_AX_WDE_QUE_DSTQUEID_ERR_INT_EN BIT(13)
1077 #define B_AX_WDE_QUE_CMDTYPE_ERR_INT_EN BIT(12)
1078 #define B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN BIT(7)
1079 #define B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN BIT(6)
1080 #define B_AX_WDE_GETNPG_STRPG_ERR_INT_EN BIT(5)
1081 #define B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN BIT(4)
1082 #define B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN BIT(3)
1083 #define B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN BIT(2)
1084 #define B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN BIT(1)
1085 #define B_AX_WDE_BUFREQ_QTAID_ERR_INT_EN BIT(0)
1086 #define B_AX_WDE_IMR_CLR (B_AX_WDE_BUFREQ_QTAID_ERR_INT_EN | \
1087 			  B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN | \
1088 			  B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN | \
1089 			  B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN | \
1090 			  B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN | \
1091 			  B_AX_WDE_GETNPG_STRPG_ERR_INT_EN | \
1092 			  B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN | \
1093 			  B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN | \
1094 			  B_AX_WDE_QUE_CMDTYPE_ERR_INT_EN | \
1095 			  B_AX_WDE_QUE_DSTQUEID_ERR_INT_EN | \
1096 			  B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN | \
1097 			  B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1098 			  B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1099 			  B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN | \
1100 			  B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN | \
1101 			  B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN | \
1102 			  B_AX_WDE_DATCHN_ARBT_ERR_INT_EN | \
1103 			  B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN | \
1104 			  B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN)
1105 #define B_AX_WDE_IMR_SET (B_AX_WDE_BUFREQ_QTAID_ERR_INT_EN | \
1106 			  B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN | \
1107 			  B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN | \
1108 			  B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN | \
1109 			  B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN | \
1110 			  B_AX_WDE_GETNPG_STRPG_ERR_INT_EN | \
1111 			  B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN | \
1112 			  B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN | \
1113 			  B_AX_WDE_QUE_CMDTYPE_ERR_INT_EN | \
1114 			  B_AX_WDE_QUE_DSTQUEID_ERR_INT_EN | \
1115 			  B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN | \
1116 			  B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1117 			  B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1118 			  B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN | \
1119 			  B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN | \
1120 			  B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN | \
1121 			  B_AX_WDE_DATCHN_ARBT_ERR_INT_EN | \
1122 			  B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN | \
1123 			  B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN)
1124 
1125 #define B_AX_WDE_DATCHN_CAMREQ_ERR_INT_EN BIT(29)
1126 #define B_AX_WDE_DATCHN_ADRERR_ERR_INT_EN BIT(28)
1127 #define B_AX_WDE_DATCHN_RRDY_ERR_INT_EN BIT(27)
1128 #define B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN BIT(26)
1129 #define B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN BIT(25)
1130 #define B_AX_WDE_DATCHN_ARBT_ERR_INT_EN BIT(24)
1131 #define B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN BIT(19)
1132 #define B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN BIT(18)
1133 #define B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN BIT(17)
1134 #define B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN BIT(16)
1135 #define B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN BIT(15)
1136 #define B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN BIT(14)
1137 #define B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN_V1 BIT(9)
1138 #define B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN_V1 BIT(8)
1139 #define B_AX_WDE_GETNPG_STRPG_ERR_INT_EN_V1 BIT(7)
1140 #define B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 BIT(6)
1141 #define B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN_V1 BIT(5)
1142 #define B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 BIT(4)
1143 #define B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN_V1 BIT(3)
1144 #define B_AX_WDE_BUFREQ_SIZELMT_INT_EN BIT(2)
1145 #define B_AX_WDE_BUFREQ_SIZE0_INT_EN BIT(1)
1146 #define B_AX_WDE_IMR_CLR_V1 (B_AX_WDE_BUFREQ_QTAID_ERR_INT_EN | \
1147 			     B_AX_WDE_BUFREQ_SIZE0_INT_EN | \
1148 			     B_AX_WDE_BUFREQ_SIZELMT_INT_EN | \
1149 			     B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN_V1 | \
1150 			     B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 | \
1151 			     B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN_V1 | \
1152 			     B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 | \
1153 			     B_AX_WDE_GETNPG_STRPG_ERR_INT_EN_V1 | \
1154 			     B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN_V1 | \
1155 			     B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN_V1 | \
1156 			     B_AX_WDE_QUE_CMDTYPE_ERR_INT_EN | \
1157 			     B_AX_WDE_QUE_DSTQUEID_ERR_INT_EN | \
1158 			     B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN | \
1159 			     B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1160 			     B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1161 			     B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN | \
1162 			     B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN | \
1163 			     B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN | \
1164 			     B_AX_WDE_DATCHN_ARBT_ERR_INT_EN | \
1165 			     B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN | \
1166 			     B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN | \
1167 			     B_AX_WDE_DATCHN_RRDY_ERR_INT_EN | \
1168 			     B_AX_WDE_DATCHN_ADRERR_ERR_INT_EN | \
1169 			     B_AX_WDE_DATCHN_CAMREQ_ERR_INT_EN)
1170 #define B_AX_WDE_IMR_SET_V1 (B_AX_WDE_BUFREQ_QTAID_ERR_INT_EN | \
1171 			     B_AX_WDE_BUFREQ_SIZE0_INT_EN | \
1172 			     B_AX_WDE_BUFREQ_SIZELMT_INT_EN | \
1173 			     B_AX_WDE_BUFREQ_UNAVAL_ERR_INT_EN_V1 | \
1174 			     B_AX_WDE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 | \
1175 			     B_AX_WDE_BUFRTN_SIZE_ERR_INT_EN_V1 | \
1176 			     B_AX_WDE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 | \
1177 			     B_AX_WDE_GETNPG_STRPG_ERR_INT_EN_V1 | \
1178 			     B_AX_WDE_GETNPG_PGOFST_ERR_INT_EN_V1 | \
1179 			     B_AX_WDE_BUFMGN_FRZTO_ERR_INT_EN_V1 | \
1180 			     B_AX_WDE_QUE_CMDTYPE_ERR_INT_EN | \
1181 			     B_AX_WDE_QUE_DSTQUEID_ERR_INT_EN | \
1182 			     B_AX_WDE_QUE_SRCQUEID_ERR_INT_EN | \
1183 			     B_AX_WDE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1184 			     B_AX_WDE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1185 			     B_AX_WDE_PREPKTLLT_AD_ERR_INT_EN | \
1186 			     B_AX_WDE_NXTPKTLL_AD_ERR_INT_EN | \
1187 			     B_AX_WDE_QUEMGN_FRZTO_ERR_INT_EN | \
1188 			     B_AX_WDE_DATCHN_ARBT_ERR_INT_EN | \
1189 			     B_AX_WDE_DATCHN_NULLPG_ERR_INT_EN | \
1190 			     B_AX_WDE_DATCHN_FRZTO_ERR_INT_EN | \
1191 			     B_AX_WDE_DATCHN_RRDY_ERR_INT_EN | \
1192 			     B_AX_WDE_DATCHN_ADRERR_ERR_INT_EN | \
1193 			     B_AX_WDE_DATCHN_CAMREQ_ERR_INT_EN)
1194 
1195 #define R_AX_WDE_ERR_ISR 0x8C3C
1196 #define B_AX_WDE_DATCHN_RRDY_ERR BIT(27)
1197 #define B_AX_WDE_DATCHN_FRZTO_ERR BIT(26)
1198 #define B_AX_WDE_DATCHN_NULLPG_ERR BIT(25)
1199 #define B_AX_WDE_DATCHN_ARBT_ERR BIT(24)
1200 #define B_AX_WDE_QUEMGN_FRZTO_ERR BIT(19)
1201 #define B_AX_WDE_NXTPKTLL_AD_ERR BIT(18)
1202 #define B_AX_WDE_PREPKTLLT_AD_ERR BIT(17)
1203 #define B_AX_WDE_ENQ_PKTCNT_NVAL_ERR BIT(16)
1204 #define B_AX_WDE_ENQ_PKTCNT_OVRF_ERR BIT(15)
1205 #define B_AX_WDE_QUE_SRCQUEID_ERR BIT(14)
1206 #define B_AX_WDE_QUE_DSTQUEID_ERR BIT(13)
1207 #define B_AX_WDE_QUE_CMDTYPE_ERR BIT(12)
1208 #define B_AX_WDE_BUFMGN_FRZTO_ERR BIT(7)
1209 #define B_AX_WDE_GETNPG_PGOFST_ERR BIT(6)
1210 #define B_AX_WDE_GETNPG_STRPG_ERR BIT(5)
1211 #define B_AX_WDE_BUFREQ_SRCHTAILPG_ERR BIT(4)
1212 #define B_AX_WDE_BUFRTN_SIZE_ERR BIT(3)
1213 #define B_AX_WDE_BUFRTN_INVLD_PKTID_ERR BIT(2)
1214 #define B_AX_WDE_BUFREQ_UNAVAL_ERR BIT(1)
1215 #define B_AX_WDE_BUFREQ_QTAID_ERR BIT(0)
1216 
1217 #define B_AX_WDE_MAX_SIZE_MASK GENMASK(27, 16)
1218 #define B_AX_WDE_MIN_SIZE_MASK GENMASK(11, 0)
1219 #define R_AX_WDE_QTA0_CFG 0x8C40
1220 #define R_AX_WDE_QTA1_CFG 0x8C44
1221 #define R_AX_WDE_QTA2_CFG 0x8C48
1222 #define R_AX_WDE_QTA3_CFG 0x8C4C
1223 #define R_AX_WDE_QTA4_CFG 0x8C50
1224 
1225 #define B_AX_DLE_PUB_PGNUM GENMASK(12, 0)
1226 #define B_AX_DLE_FREE_HEADPG GENMASK(11, 0)
1227 #define B_AX_DLE_FREE_TAILPG GENMASK(27, 16)
1228 #define B_AX_DLE_USE_PGNUM GENMASK(27, 16)
1229 #define B_AX_DLE_RSV_PGNUM GENMASK(11, 0)
1230 #define B_AX_DLE_QEMPTY_GRP GENMASK(31, 0)
1231 
1232 #define R_AX_WDE_INI_STATUS 0x8D00
1233 #define B_AX_WDE_Q_MGN_INI_RDY BIT(1)
1234 #define B_AX_WDE_BUF_MGN_INI_RDY BIT(0)
1235 #define WDE_MGN_INI_RDY (B_AX_WDE_Q_MGN_INI_RDY | B_AX_WDE_BUF_MGN_INI_RDY)
1236 #define R_AX_WDE_DBG_FUN_INTF_CTL 0x8D10
1237 #define B_AX_WDE_DFI_ACTIVE BIT(31)
1238 #define B_AX_WDE_DFI_TRGSEL_MASK GENMASK(19, 16)
1239 #define B_AX_WDE_DFI_ADDR_MASK GENMASK(15, 0)
1240 #define R_AX_WDE_DBG_FUN_INTF_DATA 0x8D14
1241 #define B_AX_WDE_DFI_DATA_MASK GENMASK(31, 0)
1242 
1243 #define R_AX_PLE_PKTBUF_CFG 0x9008
1244 #define B_AX_PLE_START_BOUND_MASK GENMASK(13, 8)
1245 #define B_AX_PLE_PAGE_SEL_MASK GENMASK(1, 0)
1246 #define B_AX_PLE_FREE_PAGE_NUM_MASK GENMASK(28, 16)
1247 
1248 #define R_AX_PLE_DBGERR_LOCKEN 0x9020
1249 #define B_AX_PLE_LOCKEN_DLEPIF07 BIT(7)
1250 #define B_AX_PLE_LOCKEN_DLEPIF06 BIT(6)
1251 #define B_AX_PLE_LOCKEN_DLEPIF05 BIT(5)
1252 #define B_AX_PLE_LOCKEN_DLEPIF04 BIT(4)
1253 #define B_AX_PLE_LOCKEN_DLEPIF03 BIT(3)
1254 #define B_AX_PLE_LOCKEN_DLEPIF02 BIT(2)
1255 #define B_AX_PLE_LOCKEN_DLEPIF01 BIT(1)
1256 #define B_AX_PLE_LOCKEN_DLEPIF00 BIT(0)
1257 
1258 #define R_AX_PLE_DBGERR_STS 0x9024
1259 #define B_AX_PLE_LOCKON_DLEPIF07 BIT(7)
1260 #define B_AX_PLE_LOCKON_DLEPIF06 BIT(6)
1261 #define B_AX_PLE_LOCKON_DLEPIF05 BIT(5)
1262 #define B_AX_PLE_LOCKON_DLEPIF04 BIT(4)
1263 #define B_AX_PLE_LOCKON_DLEPIF03 BIT(3)
1264 #define B_AX_PLE_LOCKON_DLEPIF02 BIT(2)
1265 #define B_AX_PLE_LOCKON_DLEPIF01 BIT(1)
1266 #define B_AX_PLE_LOCKON_DLEPIF00 BIT(0)
1267 
1268 #define R_AX_PLE_ERR_FLAG_CFG_NUM1 0x9034
1269 #define B_AX_PLE_ERR_FLAG_NUM1_VLD BIT(31)
1270 #define B_AX_PLE_ERR_FLAG_NUM1_MSTIDX_MASK GENMASK(27, 24)
1271 #define B_AX_PLE_ERR_FLAG_NUM1_ISRIDX_MASK GENMASK(20, 16)
1272 #define B_AX_PLE_DATCHN_FRZTMR_MODE BIT(2)
1273 #define B_AX_PLE_QUEMGN_FRZTMR_MODE BIT(1)
1274 #define B_AX_PLE_BUFMGN_FRZTMR_MODE BIT(0)
1275 
1276 #define R_AX_PLE_ERRFLAG_MSG 0x9030
1277 #define B_AX_PLE_ERR_FLAG_MSG_MASK GENMASK(31, 0)
1278 #define B_AX_PLE_DATCHN_CAMREQ_ERR_INT_EN BIT(29)
1279 #define B_AX_PLE_DATCHN_ADRERR_ERR_INT_EN BIT(28)
1280 #define B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN_V1 BIT(9)
1281 #define B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN_V1 BIT(8)
1282 #define B_AX_PLE_GETNPG_STRPG_ERR_INT_EN_V1 BIT(7)
1283 #define B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 BIT(6)
1284 #define B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN_V1 BIT(5)
1285 #define B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 BIT(4)
1286 #define B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN_V1 BIT(3)
1287 #define B_AX_PLE_BUFREQ_SIZELMT_INT_EN BIT(2)
1288 #define B_AX_PLE_BUFREQ_SIZE0_INT_EN BIT(1)
1289 #define B_AX_PLE_DATCHN_CAMREQ_ERR BIT(29)
1290 #define B_AX_PLE_DATCHN_ADRERR_ERR BIT(28)
1291 #define B_AX_PLE_BUFMGN_FRZTO_ERR_V1 BIT(9)
1292 #define B_AX_PLE_GETNPG_PGOFST_ERR_V1 BIT(8)
1293 #define B_AX_PLE_GETNPG_STRPG_ERR_V1 BIT(7)
1294 #define B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_V1 BIT(6)
1295 #define B_AX_PLE_BUFRTN_SIZE_ERR_V1 BIT(5)
1296 #define B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_V1 BIT(4)
1297 #define B_AX_PLE_BUFREQ_UNAVAL_ERR_V1 BIT(3)
1298 #define B_AX_PLE_BUFREQ_SIZELMT_ERR BIT(2)
1299 #define B_AX_PLE_BUFREQ_SIZE0_ERR BIT(1)
1300 
1301 #define R_AX_PLE_ERR_IMR 0x9038
1302 #define B_AX_PLE_DATCHN_RRDY_ERR_INT_EN BIT(27)
1303 #define B_AX_PLE_DATCHN_FRZTO_ERR_INT_EN BIT(26)
1304 #define B_AX_PLE_DATCHN_NULLPG_ERR_INT_EN BIT(25)
1305 #define B_AX_PLE_DATCHN_ARBT_ERR_INT_EN BIT(24)
1306 #define B_AX_PLE_QUEMGN_FRZTO_ERR_INT_EN BIT(19)
1307 #define B_AX_PLE_NXTPKTLL_AD_ERR_INT_EN BIT(18)
1308 #define B_AX_PLE_PREPKTLLT_AD_ERR_INT_EN BIT(17)
1309 #define B_AX_PLE_ENQ_PKTCNT_NVAL_ERR_INT_EN BIT(16)
1310 #define B_AX_PLE_ENQ_PKTCNT_OVRF_ERR_INT_EN BIT(15)
1311 #define B_AX_PLE_QUE_SRCQUEID_ERR_INT_EN BIT(14)
1312 #define B_AX_PLE_QUE_DSTQUEID_ERR_INT_EN BIT(13)
1313 #define B_AX_PLE_QUE_CMDTYPE_ERR_INT_EN BIT(12)
1314 #define B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN BIT(7)
1315 #define B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN BIT(6)
1316 #define B_AX_PLE_GETNPG_STRPG_ERR_INT_EN BIT(5)
1317 #define B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN BIT(4)
1318 #define B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN BIT(3)
1319 #define B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN BIT(2)
1320 #define B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN BIT(1)
1321 #define B_AX_PLE_BUFREQ_QTAID_ERR_INT_EN BIT(0)
1322 #define B_AX_PLE_IMR_CLR (B_AX_PLE_BUFREQ_QTAID_ERR_INT_EN | \
1323 			  B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN | \
1324 			  B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN | \
1325 			  B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN | \
1326 			  B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN | \
1327 			  B_AX_PLE_GETNPG_STRPG_ERR_INT_EN | \
1328 			  B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN | \
1329 			  B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN | \
1330 			  B_AX_PLE_QUE_CMDTYPE_ERR_INT_EN | \
1331 			  B_AX_PLE_QUE_DSTQUEID_ERR_INT_EN | \
1332 			  B_AX_PLE_QUE_SRCQUEID_ERR_INT_EN | \
1333 			  B_AX_PLE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1334 			  B_AX_PLE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1335 			  B_AX_PLE_PREPKTLLT_AD_ERR_INT_EN | \
1336 			  B_AX_PLE_NXTPKTLL_AD_ERR_INT_EN | \
1337 			  B_AX_PLE_QUEMGN_FRZTO_ERR_INT_EN | \
1338 			  B_AX_PLE_DATCHN_ARBT_ERR_INT_EN | \
1339 			  B_AX_PLE_DATCHN_NULLPG_ERR_INT_EN | \
1340 			  B_AX_PLE_DATCHN_FRZTO_ERR_INT_EN)
1341 #define B_AX_PLE_IMR_SET (B_AX_PLE_BUFREQ_QTAID_ERR_INT_EN | \
1342 			  B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN | \
1343 			  B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN | \
1344 			  B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN | \
1345 			  B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN | \
1346 			  B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN | \
1347 			  B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN | \
1348 			  B_AX_PLE_QUE_CMDTYPE_ERR_INT_EN | \
1349 			  B_AX_PLE_QUE_DSTQUEID_ERR_INT_EN | \
1350 			  B_AX_PLE_QUE_SRCQUEID_ERR_INT_EN | \
1351 			  B_AX_PLE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1352 			  B_AX_PLE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1353 			  B_AX_PLE_PREPKTLLT_AD_ERR_INT_EN | \
1354 			  B_AX_PLE_NXTPKTLL_AD_ERR_INT_EN | \
1355 			  B_AX_PLE_QUEMGN_FRZTO_ERR_INT_EN | \
1356 			  B_AX_PLE_DATCHN_ARBT_ERR_INT_EN | \
1357 			  B_AX_PLE_DATCHN_NULLPG_ERR_INT_EN | \
1358 			  B_AX_PLE_DATCHN_FRZTO_ERR_INT_EN)
1359 
1360 #define B_AX_PLE_DATCHN_CAMREQ_ERR_INT_EN BIT(29)
1361 #define B_AX_PLE_DATCHN_ADRERR_ERR_INT_EN BIT(28)
1362 #define B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN_V1 BIT(9)
1363 #define B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN_V1 BIT(8)
1364 #define B_AX_PLE_GETNPG_STRPG_ERR_INT_EN_V1 BIT(7)
1365 #define B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 BIT(6)
1366 #define B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN_V1 BIT(5)
1367 #define B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 BIT(4)
1368 #define B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN_V1 BIT(3)
1369 #define B_AX_PLE_BUFREQ_SIZELMT_INT_EN BIT(2)
1370 #define B_AX_PLE_BUFREQ_SIZE0_INT_EN BIT(1)
1371 #define B_AX_PLE_IMR_CLR_V1 (B_AX_PLE_BUFREQ_QTAID_ERR_INT_EN | \
1372 			     B_AX_PLE_BUFREQ_SIZE0_INT_EN | \
1373 			     B_AX_PLE_BUFREQ_SIZELMT_INT_EN | \
1374 			     B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN_V1 | \
1375 			     B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 | \
1376 			     B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN_V1 | \
1377 			     B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 | \
1378 			     B_AX_PLE_GETNPG_STRPG_ERR_INT_EN_V1 | \
1379 			     B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN_V1 | \
1380 			     B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN_V1 | \
1381 			     B_AX_PLE_QUE_CMDTYPE_ERR_INT_EN | \
1382 			     B_AX_PLE_QUE_DSTQUEID_ERR_INT_EN | \
1383 			     B_AX_PLE_QUE_SRCQUEID_ERR_INT_EN | \
1384 			     B_AX_PLE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1385 			     B_AX_PLE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1386 			     B_AX_PLE_PREPKTLLT_AD_ERR_INT_EN | \
1387 			     B_AX_PLE_NXTPKTLL_AD_ERR_INT_EN | \
1388 			     B_AX_PLE_QUEMGN_FRZTO_ERR_INT_EN | \
1389 			     B_AX_PLE_DATCHN_ARBT_ERR_INT_EN | \
1390 			     B_AX_PLE_DATCHN_NULLPG_ERR_INT_EN | \
1391 			     B_AX_PLE_DATCHN_FRZTO_ERR_INT_EN | \
1392 			     B_AX_PLE_DATCHN_RRDY_ERR_INT_EN | \
1393 			     B_AX_PLE_DATCHN_ADRERR_ERR_INT_EN | \
1394 			     B_AX_PLE_DATCHN_CAMREQ_ERR_INT_EN)
1395 #define B_AX_PLE_IMR_SET_V1 (B_AX_PLE_BUFREQ_QTAID_ERR_INT_EN | \
1396 			     B_AX_PLE_BUFREQ_SIZE0_INT_EN | \
1397 			     B_AX_PLE_BUFREQ_SIZELMT_INT_EN | \
1398 			     B_AX_PLE_BUFREQ_UNAVAL_ERR_INT_EN_V1 | \
1399 			     B_AX_PLE_BUFRTN_INVLD_PKTID_ERR_INT_EN_V1 | \
1400 			     B_AX_PLE_BUFRTN_SIZE_ERR_INT_EN_V1 | \
1401 			     B_AX_PLE_BUFREQ_SRCHTAILPG_ERR_INT_EN_V1 | \
1402 			     B_AX_PLE_GETNPG_STRPG_ERR_INT_EN_V1 | \
1403 			     B_AX_PLE_GETNPG_PGOFST_ERR_INT_EN_V1 | \
1404 			     B_AX_PLE_BUFMGN_FRZTO_ERR_INT_EN_V1 | \
1405 			     B_AX_PLE_QUE_CMDTYPE_ERR_INT_EN | \
1406 			     B_AX_PLE_QUE_DSTQUEID_ERR_INT_EN | \
1407 			     B_AX_PLE_QUE_SRCQUEID_ERR_INT_EN | \
1408 			     B_AX_PLE_ENQ_PKTCNT_OVRF_ERR_INT_EN | \
1409 			     B_AX_PLE_ENQ_PKTCNT_NVAL_ERR_INT_EN | \
1410 			     B_AX_PLE_PREPKTLLT_AD_ERR_INT_EN | \
1411 			     B_AX_PLE_NXTPKTLL_AD_ERR_INT_EN | \
1412 			     B_AX_PLE_QUEMGN_FRZTO_ERR_INT_EN | \
1413 			     B_AX_PLE_DATCHN_ARBT_ERR_INT_EN | \
1414 			     B_AX_PLE_DATCHN_NULLPG_ERR_INT_EN | \
1415 			     B_AX_PLE_DATCHN_FRZTO_ERR_INT_EN | \
1416 			     B_AX_PLE_DATCHN_RRDY_ERR_INT_EN | \
1417 			     B_AX_PLE_DATCHN_ADRERR_ERR_INT_EN | \
1418 			     B_AX_PLE_DATCHN_CAMREQ_ERR_INT_EN)
1419 
1420 #define R_AX_PLE_ERR_FLAG_ISR 0x903C
1421 #define B_AX_PLE_MAX_SIZE_MASK GENMASK(27, 16)
1422 #define B_AX_PLE_MIN_SIZE_MASK GENMASK(11, 0)
1423 #define R_AX_PLE_QTA0_CFG 0x9040
1424 #define R_AX_PLE_QTA1_CFG 0x9044
1425 #define R_AX_PLE_QTA2_CFG 0x9048
1426 #define R_AX_PLE_QTA3_CFG 0x904C
1427 #define R_AX_PLE_QTA4_CFG 0x9050
1428 #define R_AX_PLE_QTA5_CFG 0x9054
1429 #define R_AX_PLE_QTA6_CFG 0x9058
1430 #define B_AX_PLE_Q6_MAX_SIZE_MASK GENMASK(27, 16)
1431 #define B_AX_PLE_Q6_MIN_SIZE_MASK GENMASK(11, 0)
1432 #define R_AX_PLE_QTA7_CFG 0x905C
1433 #define R_AX_PLE_QTA8_CFG 0x9060
1434 #define R_AX_PLE_QTA9_CFG 0x9064
1435 #define R_AX_PLE_QTA10_CFG 0x9068
1436 #define R_AX_PLE_QTA11_CFG 0x906C
1437 
1438 #define R_AX_PLE_INI_STATUS 0x9100
1439 #define B_AX_PLE_Q_MGN_INI_RDY BIT(1)
1440 #define B_AX_PLE_BUF_MGN_INI_RDY BIT(0)
1441 #define PLE_MGN_INI_RDY (B_AX_PLE_Q_MGN_INI_RDY | B_AX_PLE_BUF_MGN_INI_RDY)
1442 #define R_AX_PLE_DBG_FUN_INTF_CTL 0x9110
1443 #define B_AX_PLE_DFI_ACTIVE BIT(31)
1444 #define B_AX_PLE_DFI_TRGSEL_MASK GENMASK(19, 16)
1445 #define B_AX_PLE_DFI_ADDR_MASK GENMASK(15, 0)
1446 #define R_AX_PLE_DBG_FUN_INTF_DATA 0x9114
1447 #define B_AX_PLE_DFI_DATA_MASK GENMASK(31, 0)
1448 
1449 #define R_AX_WDRLS_CFG 0x9408
1450 #define B_AX_RLSRPT_BUFREQ_TO_MASK GENMASK(15, 8)
1451 #define B_AX_WDRLS_MODE_MASK GENMASK(1, 0)
1452 
1453 #define R_AX_RLSRPT0_CFG0 0x9410
1454 #define B_AX_RLSRPT0_FLTR_MAP_MASK GENMASK(27, 24)
1455 #define B_AX_RLSRPT0_PKTTYPE_MASK GENMASK(19, 16)
1456 #define B_AX_RLSRPT0_PID_MASK GENMASK(10, 8)
1457 #define B_AX_RLSRPT0_QID_MASK GENMASK(5, 0)
1458 
1459 #define R_AX_RLSRPT0_CFG1 0x9414
1460 #define B_AX_RLSRPT0_TO_MASK GENMASK(23, 16)
1461 #define B_AX_RLSRPT0_AGGNUM_MASK GENMASK(7, 0)
1462 
1463 #define R_AX_WDRLS_ERR_IMR 0x9430
1464 #define B_AX_WDRLS_RPT1_FRZTO_ERR_INT_EN BIT(13)
1465 #define B_AX_WDRLS_RPT1_AGGNUM0_ERR_INT_EN BIT(12)
1466 #define B_AX_WDRLS_RPT0_FRZTO_ERR_INT_EN BIT(9)
1467 #define B_AX_WDRLS_RPT0_AGGNUM0_ERR_INT_EN BIT(8)
1468 #define B_AX_WDRLS_PLEBREQ_PKTID_ISNULL_ERR_INT_EN BIT(5)
1469 #define B_AX_WDRLS_PLEBREQ_TO_ERR_INT_EN BIT(4)
1470 #define B_AX_WDRLS_CTL_FRZTO_ERR_INT_EN BIT(2)
1471 #define B_AX_WDRLS_CTL_PLPKTID_ISNULL_ERR_INT_EN BIT(1)
1472 #define B_AX_WDRLS_CTL_WDPKTID_ISNULL_ERR_INT_EN BIT(0)
1473 #define B_AX_WDRLS_IMR_EN_CLR (B_AX_WDRLS_CTL_WDPKTID_ISNULL_ERR_INT_EN | \
1474 			       B_AX_WDRLS_CTL_PLPKTID_ISNULL_ERR_INT_EN | \
1475 			       B_AX_WDRLS_CTL_FRZTO_ERR_INT_EN | \
1476 			       B_AX_WDRLS_PLEBREQ_TO_ERR_INT_EN | \
1477 			       B_AX_WDRLS_PLEBREQ_PKTID_ISNULL_ERR_INT_EN | \
1478 			       B_AX_WDRLS_RPT0_AGGNUM0_ERR_INT_EN | \
1479 			       B_AX_WDRLS_RPT0_FRZTO_ERR_INT_EN | \
1480 			       B_AX_WDRLS_RPT1_AGGNUM0_ERR_INT_EN | \
1481 			       B_AX_WDRLS_RPT1_FRZTO_ERR_INT_EN)
1482 #define B_AX_WDRLS_IMR_SET (B_AX_WDRLS_CTL_WDPKTID_ISNULL_ERR_INT_EN | \
1483 			    B_AX_WDRLS_CTL_PLPKTID_ISNULL_ERR_INT_EN | \
1484 			    B_AX_WDRLS_CTL_FRZTO_ERR_INT_EN | \
1485 			    B_AX_WDRLS_PLEBREQ_PKTID_ISNULL_ERR_INT_EN | \
1486 			    B_AX_WDRLS_RPT0_AGGNUM0_ERR_INT_EN | \
1487 			    B_AX_WDRLS_RPT0_FRZTO_ERR_INT_EN | \
1488 			    B_AX_WDRLS_RPT1_AGGNUM0_ERR_INT_EN | \
1489 			    B_AX_WDRLS_RPT1_FRZTO_ERR_INT_EN)
1490 #define B_AX_WDRLS_IMR_SET_V1 (B_AX_WDRLS_CTL_WDPKTID_ISNULL_ERR_INT_EN | \
1491 			      B_AX_WDRLS_CTL_PLPKTID_ISNULL_ERR_INT_EN | \
1492 			      B_AX_WDRLS_CTL_FRZTO_ERR_INT_EN | \
1493 			      B_AX_WDRLS_PLEBREQ_TO_ERR_INT_EN | \
1494 			      B_AX_WDRLS_PLEBREQ_PKTID_ISNULL_ERR_INT_EN | \
1495 			      B_AX_WDRLS_RPT0_AGGNUM0_ERR_INT_EN | \
1496 			      B_AX_WDRLS_RPT0_FRZTO_ERR_INT_EN | \
1497 			      B_AX_WDRLS_RPT1_AGGNUM0_ERR_INT_EN | \
1498 			      B_AX_WDRLS_RPT1_FRZTO_ERR_INT_EN)
1499 
1500 #define R_AX_WDRLS_ERR_ISR 0x9434
1501 
1502 #define R_AX_BBRPT_COM_ERR_IMR 0x9608
1503 #define B_AX_BBRPT_COM_HANG_EN BIT(1)
1504 #define B_AX_BBRPT_COM_NULL_PLPKTID_ERR_INT_EN BIT(0)
1505 
1506 #define R_AX_BBRPT_COM_ERR_IMR_ISR 0x960C
1507 #define B_AX_BBRPT_COM_NULL_PLPKTID_ERR BIT(16)
1508 #define B_AX_BBRPT_COM_NULL_PLPKTID_ERR_INT_EN BIT(0)
1509 
1510 #define R_AX_BBRPT_COM_ERR_ISR 0x960C
1511 #define B_AX_BBRPT_COM_NULL_PLPKTID_ERR_INT_V1 BIT(0)
1512 
1513 #define R_AX_BBRPT_CHINFO_ERR_ISR 0x962C
1514 #define B_AX_BBPRT_CHIF_TO_ERR_V1 BIT(7)
1515 #define B_AX_BBPRT_CHIF_NULL_ERR_V1 BIT(6)
1516 #define B_AX_BBPRT_CHIF_LEFT2_ERR_V1 BIT(5)
1517 #define B_AX_BBPRT_CHIF_LEFT1_ERR_V1 BIT(4)
1518 #define B_AX_BBPRT_CHIF_HDRL_ERR_V1 BIT(3)
1519 #define B_AX_BBPRT_CHIF_BOVF_ERR_V1 BIT(2)
1520 #define B_AX_BBPRT_CHIF_OVF_ERR_V1 BIT(1)
1521 #define B_AX_BBPRT_CHIF_BB_TO_ERR_V1 BIT(0)
1522 
1523 #define R_AX_BBRPT_CHINFO_ERR_IMR 0x9628
1524 #define B_AX_BBPRT_CHIF_TO_ERR_INT_EN BIT(7)
1525 #define B_AX_BBPRT_CHIF_NULL_ERR_INT_EN BIT(6)
1526 #define B_AX_BBPRT_CHIF_LEFT2_ERR_INT_EN BIT(5)
1527 #define B_AX_BBPRT_CHIF_LEFT1_ERR_INT_EN BIT(4)
1528 #define B_AX_BBPRT_CHIF_HDRL_ERR_INT_EN BIT(3)
1529 #define B_AX_BBPRT_CHIF_BOVF_ERR_INT_EN BIT(2)
1530 #define B_AX_BBPRT_CHIF_OVF_ERR_INT_EN BIT(1)
1531 #define B_AX_BBPRT_CHIF_BB_TO_ERR_INT_EN BIT(0)
1532 #define R_AX_BBRPT_CHINFO_IMR_SET_V1 (B_AX_BBPRT_CHIF_BB_TO_ERR_INT_EN | \
1533 				      B_AX_BBPRT_CHIF_OVF_ERR_INT_EN | \
1534 				      B_AX_BBPRT_CHIF_BOVF_ERR_INT_EN | \
1535 				      B_AX_BBPRT_CHIF_HDRL_ERR_INT_EN | \
1536 				      B_AX_BBPRT_CHIF_LEFT1_ERR_INT_EN | \
1537 				      B_AX_BBPRT_CHIF_LEFT2_ERR_INT_EN | \
1538 				      B_AX_BBPRT_CHIF_NULL_ERR_INT_EN | \
1539 				      B_AX_BBPRT_CHIF_TO_ERR_INT_EN)
1540 
1541 #define R_AX_BBRPT_CHINFO_ERR_IMR_ISR 0x962C
1542 #define B_AX_BBPRT_CHIF_TO_ERR BIT(23)
1543 #define B_AX_BBPRT_CHIF_NULL_ERR BIT(22)
1544 #define B_AX_BBPRT_CHIF_LEFT2_ERR BIT(21)
1545 #define B_AX_BBPRT_CHIF_LEFT1_ERR BIT(20)
1546 #define B_AX_BBPRT_CHIF_HDRL_ERR BIT(19)
1547 #define B_AX_BBPRT_CHIF_BOVF_ERR BIT(18)
1548 #define B_AX_BBPRT_CHIF_OVF_ERR BIT(17)
1549 #define B_AX_BBPRT_CHIF_BB_TO_ERR BIT(16)
1550 #define B_AX_BBPRT_CHIF_TO_ERR_INT_EN BIT(7)
1551 #define B_AX_BBPRT_CHIF_NULL_ERR_INT_EN BIT(6)
1552 #define B_AX_BBPRT_CHIF_LEFT2_ERR_INT_EN BIT(5)
1553 #define B_AX_BBPRT_CHIF_LEFT1_ERR_INT_EN BIT(4)
1554 #define B_AX_BBPRT_CHIF_HDRL_ERR_INT_EN BIT(3)
1555 #define B_AX_BBPRT_CHIF_BOVF_ERR_INT_EN BIT(2)
1556 #define B_AX_BBPRT_CHIF_OVF_ERR_INT_EN BIT(1)
1557 #define B_AX_BBPRT_CHIF_BB_TO_ERR_INT_EN BIT(0)
1558 #define B_AX_BBRPT_CHINFO_IMR_CLR (B_AX_BBPRT_CHIF_BB_TO_ERR_INT_EN | \
1559 				   B_AX_BBPRT_CHIF_OVF_ERR_INT_EN | \
1560 				   B_AX_BBPRT_CHIF_BOVF_ERR_INT_EN | \
1561 				   B_AX_BBPRT_CHIF_HDRL_ERR_INT_EN | \
1562 				   B_AX_BBPRT_CHIF_LEFT1_ERR_INT_EN | \
1563 				   B_AX_BBPRT_CHIF_LEFT2_ERR_INT_EN | \
1564 				   B_AX_BBPRT_CHIF_NULL_ERR_INT_EN | \
1565 				   B_AX_BBPRT_CHIF_TO_ERR_INT_EN)
1566 
1567 #define R_AX_BBRPT_DFS_ERR_IMR 0x9638
1568 #define B_AX_BBRPT_DFS_TO_ERR_INT_EN BIT(0)
1569 
1570 #define R_AX_BBRPT_DFS_ERR_IMR_ISR 0x963C
1571 #define B_AX_BBRPT_DFS_TO_ERR BIT(16)
1572 #define B_AX_BBRPT_DFS_TO_ERR_INT_EN BIT(0)
1573 
1574 #define R_AX_BBRPT_DFS_ERR_ISR 0x963C
1575 #define B_AX_BBRPT_DFS_TO_ERR_V1 BIT(0)
1576 
1577 #define R_AX_LA_ERRFLAG 0x966C
1578 #define B_AX_LA_ISR_DATA_LOSS_ERR BIT(16)
1579 #define B_AX_LA_IMR_DATA_LOSS_ERR BIT(0)
1580 
1581 #define R_AX_WD_BUF_REQ 0x9800
1582 #define R_AX_PL_BUF_REQ 0x9820
1583 #define B_AX_WD_BUF_REQ_EXEC BIT(31)
1584 #define B_AX_WD_BUF_REQ_QUOTA_ID_MASK GENMASK(23, 16)
1585 #define B_AX_WD_BUF_REQ_LEN_MASK GENMASK(15, 0)
1586 
1587 #define R_AX_WD_BUF_STATUS 0x9804
1588 #define R_AX_PL_BUF_STATUS 0x9824
1589 #define B_AX_WD_BUF_STAT_DONE BIT(31)
1590 #define B_AX_WD_BUF_STAT_PKTID_MASK GENMASK(11, 0)
1591 #define S_WD_BUF_STAT_PKTID_INVALID GENMASK(11, 0)
1592 
1593 #define R_AX_WD_CPUQ_OP_0 0x9810
1594 #define R_AX_PL_CPUQ_OP_0 0x9830
1595 #define B_AX_WD_CPUQ_OP_EXEC BIT(31)
1596 #define B_AX_CPUQ_OP_CMD_TYPE_MASK GENMASK(27, 24)
1597 #define B_AX_CPUQ_OP_MACID_MASK GENMASK(23, 16)
1598 #define B_AX_CPUQ_OP_PKTNUM_MASK GENMASK(7, 0)
1599 
1600 #define R_AX_WD_CPUQ_OP_1 0x9814
1601 #define R_AX_PL_CPUQ_OP_1 0x9834
1602 #define B_AX_CPUQ_OP_SRC_PID_MASK GENMASK(24, 22)
1603 #define B_AX_CPUQ_OP_SRC_QID_MASK GENMASK(21, 16)
1604 #define B_AX_CPUQ_OP_DST_PID_MASK GENMASK(8, 6)
1605 #define B_AX_CPUQ_OP_DST_QID_MASK GENMASK(5, 0)
1606 
1607 #define R_AX_WD_CPUQ_OP_2 0x9818
1608 #define R_AX_PL_CPUQ_OP_2 0x9838
1609 #define B_AX_WD_CPUQ_OP_STRT_PKTID_MASK GENMASK(27, 16)
1610 #define B_AX_WD_CPUQ_OP_END_PKTID_MASK GENMASK(11, 0)
1611 
1612 #define R_AX_WD_CPUQ_OP_STATUS 0x981C
1613 #define R_AX_PL_CPUQ_OP_STATUS 0x983C
1614 #define B_AX_WD_CPUQ_OP_STAT_DONE BIT(31)
1615 #define B_AX_WD_CPUQ_OP_PKTID_MASK GENMASK(11, 0)
1616 
1617 #define R_AX_CPUIO_ERR_IMR 0x9840
1618 #define B_AX_PLEQUE_OP_ERR_INT_EN BIT(12)
1619 #define B_AX_PLEBUF_OP_ERR_INT_EN BIT(8)
1620 #define B_AX_WDEQUE_OP_ERR_INT_EN BIT(4)
1621 #define B_AX_WDEBUF_OP_ERR_INT_EN BIT(0)
1622 #define B_AX_CPUIO_IMR_CLR (B_AX_WDEBUF_OP_ERR_INT_EN | \
1623 			    B_AX_WDEQUE_OP_ERR_INT_EN | \
1624 			    B_AX_PLEBUF_OP_ERR_INT_EN | \
1625 			    B_AX_PLEQUE_OP_ERR_INT_EN)
1626 #define B_AX_CPUIO_IMR_SET (B_AX_WDEBUF_OP_ERR_INT_EN | \
1627 			    B_AX_WDEQUE_OP_ERR_INT_EN | \
1628 			    B_AX_PLEBUF_OP_ERR_INT_EN | \
1629 			    B_AX_PLEQUE_OP_ERR_INT_EN)
1630 
1631 #define R_AX_CPUIO_ERR_ISR 0x9844
1632 
1633 #define R_AX_SEC_ERR_IMR_ISR 0x991C
1634 
1635 #define R_AX_PKTIN_SETTING 0x9A00
1636 #define B_AX_WD_ADDR_INFO_LENGTH BIT(1)
1637 
1638 #define R_AX_PKTIN_ERR_IMR 0x9A20
1639 #define B_AX_PKTIN_GETPKTID_ERR_INT_EN BIT(0)
1640 
1641 #define R_AX_PKTIN_ERR_ISR 0x9A24
1642 
1643 #define R_AX_MPDU_TX_ERR_ISR 0x9BF0
1644 #define R_AX_MPDU_TX_ERR_IMR 0x9BF4
1645 #define B_AX_TX_KSRCH_ERR_EN BIT(9)
1646 #define B_AX_TX_NW_TYPE_ERR_EN BIT(8)
1647 #define B_AX_TX_LLC_PRE_ERR_EN BIT(7)
1648 #define B_AX_TX_ETH_TYPE_ERR_EN BIT(6)
1649 #define B_AX_TX_HDR3_SIZE_ERR_INT_EN BIT(5)
1650 #define B_AX_TX_OFFSET_ERR_INT_EN BIT(4)
1651 #define B_AX_TX_MPDU_SIZE_ZERO_INT_EN BIT(3)
1652 #define B_AX_TX_NXT_ERRPKTID_INT_EN BIT(2)
1653 #define B_AX_TX_GET_ERRPKTID_INT_EN BIT(1)
1654 #define B_AX_MPDU_TX_IMR_SET_V1 (B_AX_TX_GET_ERRPKTID_INT_EN | \
1655 				 B_AX_TX_NXT_ERRPKTID_INT_EN | \
1656 				 B_AX_TX_MPDU_SIZE_ZERO_INT_EN | \
1657 				 B_AX_TX_HDR3_SIZE_ERR_INT_EN | \
1658 				 B_AX_TX_ETH_TYPE_ERR_EN | \
1659 				 B_AX_TX_NW_TYPE_ERR_EN | \
1660 				 B_AX_TX_KSRCH_ERR_EN)
1661 
1662 #define R_AX_MPDU_PROC 0x9C00
1663 #define B_AX_A_ICV_ERR BIT(1)
1664 #define B_AX_APPEND_FCS BIT(0)
1665 
1666 #define R_AX_ACTION_FWD0 0x9C04
1667 #define TRXCFG_MPDU_PROC_ACT_FRWD 0x02A95A95
1668 
1669 #define R_AX_ACTION_FWD1 0x9C08
1670 
1671 #define R_AX_TF_FWD 0x9C14
1672 #define TRXCFG_MPDU_PROC_TF_FRWD 0x0000AA55
1673 
1674 #define R_AX_HW_RPT_FWD 0x9C18
1675 #define B_AX_FWD_PPDU_STAT_MASK GENMASK(1, 0)
1676 #define RTW89_PRPT_DEST_HOST 1
1677 #define RTW89_PRPT_DEST_WLCPU 2
1678 
1679 #define R_AX_CUT_AMSDU_CTRL 0x9C40
1680 #define TRXCFG_MPDU_PROC_CUT_CTRL	0x010E05F0
1681 
1682 #define R_AX_WOW_CTRL 0x9C50
1683 #define B_AX_WOW_WOWEN BIT(1)
1684 
1685 #define R_AX_MPDU_RX_ERR_ISR 0x9CF0
1686 #define R_AX_MPDU_RX_ERR_IMR 0x9CF4
1687 #define B_AX_RPT_ERR_INT_EN BIT(3)
1688 #define B_AX_MHDRLEN_ERR_INT_EN BIT(1)
1689 #define B_AX_GETPKTID_ERR_INT_EN BIT(0)
1690 #define B_AX_MPDU_RX_IMR_SET_V1 B_AX_RPT_ERR_INT_EN
1691 
1692 #define R_AX_SEC_ENG_CTRL 0x9D00
1693 #define B_AX_SEC_DBG_PORT_FIELD_MASK GENMASK(19, 16)
1694 #define B_AX_TX_PARTIAL_MODE BIT(11)
1695 #define B_AX_CLK_EN_CGCMP BIT(10)
1696 #define B_AX_CLK_EN_WAPI BIT(9)
1697 #define B_AX_CLK_EN_WEP_TKIP BIT(8)
1698 #define B_AX_BMC_MGNT_DEC BIT(5)
1699 #define B_AX_UC_MGNT_DEC BIT(4)
1700 #define B_AX_MC_DEC BIT(3)
1701 #define B_AX_BC_DEC BIT(2)
1702 #define B_AX_SEC_RX_DEC BIT(1)
1703 #define B_AX_SEC_TX_ENC BIT(0)
1704 
1705 #define R_AX_SEC_MPDU_PROC 0x9D04
1706 #define B_AX_APPEND_ICV BIT(1)
1707 #define B_AX_APPEND_MIC BIT(0)
1708 
1709 #define R_AX_SEC_CAM_ACCESS 0x9D10
1710 #define R_AX_SEC_CAM_RDATA 0x9D14
1711 #define R_AX_SEC_CAM_WDATA 0x9D18
1712 
1713 #define R_AX_SEC_DEBUG 0x9D1C
1714 #define B_AX_IMR_ERROR BIT(3)
1715 
1716 #define R_AX_SEC_DEBUG1 0x9D1C
1717 #define B_AX_TX_TIMEOUT_SEL_MASK GENMASK(31, 30)
1718 #define AX_TX_TO_VAL  0x2
1719 
1720 #define R_AX_SEC_TX_DEBUG 0x9D20
1721 #define R_AX_SEC_RX_DEBUG 0x9D24
1722 #define R_AX_SEC_TRX_PKT_CNT 0x9D28
1723 
1724 #define R_AX_SEC_DEBUG2 0x9D28
1725 #define B_AX_DBG_READ_SH 2
1726 #define B_AX_DBG_READ_MSK 0x3fffffff
1727 
1728 #define R_AX_SEC_TRX_BLK_CNT 0x9D2C
1729 
1730 #define R_AX_SEC_ERROR_FLAG_IMR 0x9D2C
1731 #define B_AX_RX_HANG_IMR BIT(1)
1732 #define B_AX_TX_HANG_IMR BIT(0)
1733 
1734 #define R_AX_SEC_ERROR_FLAG 0x9D30
1735 #define B_AX_RX_HANG_ERROR_V1 BIT(1)
1736 #define B_AX_TX_HANG_ERROR_V1 BIT(0)
1737 
1738 #define R_AX_SS_CTRL 0x9E10
1739 #define B_AX_SS_INIT_DONE_1 BIT(31)
1740 #define B_AX_SS_WARM_INIT_FLG BIT(29)
1741 #define B_AX_SS_NONEMPTY_SS2FINFO_EN BIT(28)
1742 #define B_AX_SS_EN BIT(0)
1743 
1744 #define R_AX_SS2FINFO_PATH 0x9E50
1745 #define B_AX_SS_UL_REL BIT(31)
1746 #define B_AX_SS_REL_QUEUE_MASK GENMASK(29, 24)
1747 #define B_AX_SS_REL_PORT_MASK GENMASK(18, 16)
1748 #define B_AX_SS_DEST_QUEUE_MASK GENMASK(13, 8)
1749 #define SS2F_PATH_WLCPU 0x0A
1750 #define B_AX_SS_DEST_PORT_MASK GENMASK(2, 0)
1751 
1752 #define R_AX_SS_MACID_PAUSE_0 0x9EB0
1753 #define B_AX_SS_MACID31_0_PAUSE_SH 0
1754 #define B_AX_SS_MACID31_0_PAUSE_MASK GENMASK(31, 0)
1755 
1756 #define R_AX_SS_MACID_PAUSE_1 0x9EB4
1757 #define B_AX_SS_MACID63_32_PAUSE_SH 0
1758 #define B_AX_SS_MACID63_32_PAUSE_MASK GENMASK(31, 0)
1759 
1760 #define R_AX_SS_MACID_PAUSE_2 0x9EB8
1761 #define B_AX_SS_MACID95_64_PAUSE_SH 0
1762 #define B_AX_SS_MACID95_64_PAUSE_MASK GENMASK(31, 0)
1763 
1764 #define R_AX_SS_MACID_PAUSE_3 0x9EBC
1765 #define B_AX_SS_MACID127_96_PAUSE_SH 0
1766 #define B_AX_SS_MACID127_96_PAUSE_MASK GENMASK(31, 0)
1767 
1768 #define R_AX_STA_SCHEDULER_ERR_IMR 0x9EF0
1769 #define B_AX_PLE_B_PKTID_ERR_INT_EN BIT(2)
1770 #define B_AX_RPT_HANG_TIMEOUT_INT_EN BIT(1)
1771 #define B_AX_SEARCH_HANG_TIMEOUT_INT_EN BIT(0)
1772 #define B_AX_STA_SCHEDULER_IMR_SET (B_AX_SEARCH_HANG_TIMEOUT_INT_EN | \
1773 				    B_AX_RPT_HANG_TIMEOUT_INT_EN | \
1774 				    B_AX_PLE_B_PKTID_ERR_INT_EN)
1775 
1776 #define R_AX_STA_SCHEDULER_ERR_ISR 0x9EF4
1777 
1778 #define R_AX_TXPKTCTL_ERR_IMR_ISR 0x9F1C
1779 #define B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR BIT(25)
1780 #define B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR BIT(24)
1781 #define B_AX_TXPKTCTL_USRCTL_RLSBMPLEN_ERR BIT(19)
1782 #define B_AX_TXPKTCTL_USRCTL_RDNRLSCMD_ERR BIT(18)
1783 #define B_AX_TXPKTCTL_USRCTL_NOINIT_ERR BIT(17)
1784 #define B_AX_TXPKTCTL_USRCTL_REINIT_ERR BIT(16)
1785 #define B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR_INT_EN BIT(9)
1786 #define B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR_INT_EN BIT(8)
1787 #define B_AX_TXPKTCTL_USRCTL_RLSBMPLEN_ERR_INT_EN BIT(3)
1788 #define B_AX_TXPKTCTL_USRCTL_RDNRLSCMD_ERR_INT_EN BIT(2)
1789 #define B_AX_TXPKTCTL_USRCTL_NOINIT_ERR_INT_EN BIT(1)
1790 #define B_AX_TXPKTCTL_USRCTL_REINIT_ERR_INT_EN BIT(0)
1791 #define B_AX_TXPKTCTL_IMR_B0_CLR (B_AX_TXPKTCTL_USRCTL_REINIT_ERR_INT_EN | \
1792 				  B_AX_TXPKTCTL_USRCTL_NOINIT_ERR_INT_EN | \
1793 				  B_AX_TXPKTCTL_USRCTL_RDNRLSCMD_ERR_INT_EN | \
1794 				  B_AX_TXPKTCTL_USRCTL_RLSBMPLEN_ERR_INT_EN | \
1795 				  B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR_INT_EN | \
1796 				  B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR_INT_EN)
1797 #define B_AX_TXPKTCTL_IMR_B1_CLR (B_AX_TXPKTCTL_USRCTL_REINIT_ERR_INT_EN | \
1798 				  B_AX_TXPKTCTL_USRCTL_NOINIT_ERR_INT_EN | \
1799 				  B_AX_TXPKTCTL_USRCTL_RDNRLSCMD_ERR_INT_EN | \
1800 				  B_AX_TXPKTCTL_USRCTL_RLSBMPLEN_ERR_INT_EN | \
1801 				  B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR_INT_EN | \
1802 				  B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR_INT_EN)
1803 #define B_AX_TXPKTCTL_IMR_B0_SET (B_AX_TXPKTCTL_USRCTL_REINIT_ERR_INT_EN | \
1804 				  B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR_INT_EN)
1805 #define B_AX_TXPKTCTL_IMR_B1_SET (B_AX_TXPKTCTL_USRCTL_REINIT_ERR_INT_EN | \
1806 				  B_AX_TXPKTCTL_USRCTL_NOINIT_ERR_INT_EN | \
1807 				  B_AX_TXPKTCTL_CMDPSR_CMDTYPE_ERR_INT_EN | \
1808 				  B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR_INT_EN)
1809 
1810 #define R_AX_TXPKTCTL_ERR_IMR_ISR_B1 0x9F2C
1811 #define B_AX_TXPKTCTL_CMDPSR_FRZTO_ERR_INT_EN BIT(9)
1812 #define B_AX_TXPKTCTL_USRCTL_RLSBMPLEN_ERR_INT_EN BIT(3)
1813 #define B_AX_TXPKTCTL_USRCTL_RDNRLSCMD_ERR_INT_EN BIT(2)
1814 #define B_AX_TXPKTCTL_USRCTL_NOINIT_ERR_INT_EN BIT(1)
1815 
1816 #define R_AX_DBG_FUN_INTF_CTL 0x9F30
1817 #define B_AX_DFI_ACTIVE BIT(31)
1818 #define B_AX_DFI_TRGSEL_MASK GENMASK(19, 16)
1819 #define B_AX_DFI_ADDR_MASK GENMASK(15, 0)
1820 #define R_AX_DBG_FUN_INTF_DATA 0x9F34
1821 #define B_AX_DFI_DATA_MASK GENMASK(31, 0)
1822 
1823 #define R_AX_TXPKTCTL_B0_PRELD_CFG0 0x9F48
1824 #define B_AX_B0_PRELD_FEN BIT(31)
1825 #define B_AX_B0_PRELD_USEMAXSZ_MASK GENMASK(25, 16)
1826 #define PRELD_B0_ENT_NUM 10
1827 #define PRELD_AMSDU_SIZE 52
1828 #define B_AX_B0_PRELD_CAM_G1ENTNUM_MASK GENMASK(12, 8)
1829 #define B_AX_B0_PRELD_CAM_G0ENTNUM_MASK GENMASK(4, 0)
1830 
1831 #define R_AX_TXPKTCTL_B0_PRELD_CFG1 0x9F4C
1832 #define B_AX_B0_PRELD_NXT_TXENDWIN_MASK GENMASK(11, 8)
1833 #define PRELD_NEXT_WND 1
1834 #define B_AX_B0_PRELD_NXT_RSVMINSZ_MASK GENMASK(7, 0)
1835 
1836 #define R_AX_TXPKTCTL_B0_ERRFLAG_IMR 0x9F78
1837 #define B_AX_B0_IMR_ERR_PRELD_ENTNUMCFG BIT(21)
1838 #define B_AX_B0_IMR_ERR_PRELD_RLSPKTSZERR BIT(20)
1839 #define B_AX_B0_IMR_ERR_MPDUIF_DATAERR BIT(18)
1840 #define B_AX_B0_IMR_ERR_MPDUINFO_RECFG BIT(16)
1841 #define B_AX_B0_IMR_ERR_CMDPSR_TBLSZ BIT(11)
1842 #define B_AX_B0_IMR_ERR_CMDPSR_FRZTO BIT(10)
1843 #define B_AX_B0_IMR_ERR_CMDPSR_CMDTYPE BIT(9)
1844 #define B_AX_B0_IMR_ERR_CMDPSR_1STCMDERR BIT(8)
1845 #define B_AX_B0_IMR_ERR_USRCTL_RLSBMPLEN BIT(3)
1846 #define B_AX_B0_IMR_ERR_USRCTL_RDNRLSCMD BIT(2)
1847 #define B_AX_B0_IMR_ERR_USRCTL_NOINIT BIT(1)
1848 #define B_AX_B0_IMR_ERR_USRCTL_REINIT BIT(0)
1849 #define B_AX_TXPKTCTL_IMR_B0_CLR_V1 (B_AX_B0_IMR_ERR_USRCTL_REINIT | \
1850 				     B_AX_B0_IMR_ERR_USRCTL_NOINIT | \
1851 				     B_AX_B0_IMR_ERR_USRCTL_RDNRLSCMD | \
1852 				     B_AX_B0_IMR_ERR_USRCTL_RLSBMPLEN | \
1853 				     B_AX_B0_IMR_ERR_CMDPSR_1STCMDERR | \
1854 				     B_AX_B0_IMR_ERR_CMDPSR_CMDTYPE | \
1855 				     B_AX_B0_IMR_ERR_CMDPSR_FRZTO | \
1856 				     B_AX_B0_IMR_ERR_CMDPSR_TBLSZ | \
1857 				     B_AX_B0_IMR_ERR_MPDUINFO_RECFG | \
1858 				     B_AX_B0_IMR_ERR_MPDUIF_DATAERR | \
1859 				     B_AX_B0_IMR_ERR_PRELD_RLSPKTSZERR | \
1860 				     B_AX_B0_IMR_ERR_PRELD_ENTNUMCFG)
1861 #define B_AX_TXPKTCTL_IMR_B0_SET_V1 (B_AX_B0_IMR_ERR_USRCTL_REINIT | \
1862 				     B_AX_B0_IMR_ERR_USRCTL_NOINIT | \
1863 				     B_AX_B0_IMR_ERR_CMDPSR_1STCMDERR | \
1864 				     B_AX_B0_IMR_ERR_CMDPSR_CMDTYPE | \
1865 				     B_AX_B0_IMR_ERR_CMDPSR_FRZTO | \
1866 				     B_AX_B0_IMR_ERR_CMDPSR_TBLSZ | \
1867 				     B_AX_B0_IMR_ERR_MPDUINFO_RECFG | \
1868 				     B_AX_B0_IMR_ERR_MPDUIF_DATAERR | \
1869 				     B_AX_B0_IMR_ERR_PRELD_RLSPKTSZERR | \
1870 				     B_AX_B0_IMR_ERR_PRELD_ENTNUMCFG)
1871 
1872 #define R_AX_TXPKTCTL_B0_ERRFLAG_ISR 0x9F7C
1873 #define B_AX_B0_ISR_ERR_PRELD_EVT3 BIT(23)
1874 #define B_AX_B0_ISR_ERR_PRELD_EVT2 BIT(22)
1875 #define B_AX_B0_ISR_ERR_PRELD_ENTNUMCFG BIT(21)
1876 #define B_AX_B0_ISR_ERR_PRELD_RLSPKTSZERR BIT(20)
1877 #define B_AX_B0_ISR_ERR_MPDUIF_ERR1 BIT(19)
1878 #define B_AX_B0_ISR_ERR_MPDUIF_DATAERR BIT(18)
1879 #define B_AX_B0_ISR_ERR_MPDUINFO_ERR1 BIT(17)
1880 #define B_AX_B0_ISR_ERR_MPDUINFO_RECFG BIT(16)
1881 #define B_AX_B0_ISR_ERR_CMDPSR_TBLSZ BIT(11)
1882 #define B_AX_B0_ISR_ERR_CMDPSR_FRZTO BIT(10)
1883 #define B_AX_B0_ISR_ERR_CMDPSR_CMDTYPE BIT(9)
1884 #define B_AX_B0_ISR_ERR_CMDPSR_1STCMDERR BIT(8)
1885 #define B_AX_B0_ISR_ERR_USRCTL_EVT7 BIT(7)
1886 #define B_AX_B0_ISR_ERR_USRCTL_EVT6 BIT(6)
1887 #define B_AX_B0_ISR_ERR_USRCTL_EVT5 BIT(5)
1888 #define B_AX_B0_ISR_ERR_USRCTL_EVT4 BIT(4)
1889 #define B_AX_B0_ISR_ERR_USRCTL_RLSBMPLEN BIT(3)
1890 #define B_AX_B0_ISR_ERR_USRCTL_RDNRLSCMD BIT(2)
1891 #define B_AX_B0_ISR_ERR_USRCTL_NOINIT BIT(1)
1892 #define B_AX_B0_ISR_ERR_USRCTL_REINIT BIT(0)
1893 
1894 #define R_AX_TXPKTCTL_B1_PRELD_CFG0 0x9F88
1895 #define B_AX_B1_PRELD_FEN BIT(31)
1896 #define B_AX_B1_PRELD_USEMAXSZ_MASK GENMASK(25, 16)
1897 #define PRELD_B1_ENT_NUM 4
1898 #define B_AX_B1_PRELD_CAM_G1ENTNUM_MASK GENMASK(12, 8)
1899 #define B_AX_B1_PRELD_CAM_G0ENTNUM_MASK GENMASK(4, 0)
1900 
1901 #define R_AX_TXPKTCTL_B1_PRELD_CFG1 0x9F8C
1902 #define B_AX_B1_PRELD_NXT_TXENDWIN_MASK GENMASK(11, 8)
1903 #define B_AX_B1_PRELD_NXT_RSVMINSZ_MASK GENMASK(7, 0)
1904 
1905 #define R_AX_TXPKTCTL_B1_ERRFLAG_IMR 0x9FB8
1906 #define B_AX_B1_IMR_ERR_PRELD_ENTNUMCFG BIT(21)
1907 #define B_AX_B1_IMR_ERR_PRELD_RLSPKTSZERR BIT(20)
1908 #define B_AX_B1_IMR_ERR_MPDUIF_DATAERR BIT(18)
1909 #define B_AX_B1_IMR_ERR_MPDUINFO_RECFG BIT(16)
1910 #define B_AX_B1_IMR_ERR_CMDPSR_TBLSZ BIT(11)
1911 #define B_AX_B1_IMR_ERR_CMDPSR_FRZTO BIT(10)
1912 #define B_AX_B1_IMR_ERR_CMDPSR_CMDTYPE BIT(9)
1913 #define B_AX_B1_IMR_ERR_CMDPSR_1STCMDERR BIT(8)
1914 #define B_AX_B1_IMR_ERR_USRCTL_RLSBMPLEN BIT(3)
1915 #define B_AX_B1_IMR_ERR_USRCTL_RDNRLSCMD BIT(2)
1916 #define B_AX_B1_IMR_ERR_USRCTL_NOINIT BIT(1)
1917 #define B_AX_B1_IMR_ERR_USRCTL_REINIT BIT(0)
1918 #define B_AX_TXPKTCTL_IMR_B1_CLR_V1 (B_AX_B1_IMR_ERR_USRCTL_REINIT | \
1919 				     B_AX_B1_IMR_ERR_USRCTL_NOINIT | \
1920 				     B_AX_B1_IMR_ERR_USRCTL_RDNRLSCMD | \
1921 				     B_AX_B1_IMR_ERR_USRCTL_RLSBMPLEN | \
1922 				     B_AX_B1_IMR_ERR_CMDPSR_1STCMDERR | \
1923 				     B_AX_B1_IMR_ERR_CMDPSR_CMDTYPE | \
1924 				     B_AX_B1_IMR_ERR_CMDPSR_FRZTO | \
1925 				     B_AX_B1_IMR_ERR_CMDPSR_TBLSZ | \
1926 				     B_AX_B1_IMR_ERR_MPDUINFO_RECFG | \
1927 				     B_AX_B1_IMR_ERR_MPDUIF_DATAERR | \
1928 				     B_AX_B1_IMR_ERR_PRELD_RLSPKTSZERR | \
1929 				     B_AX_B1_IMR_ERR_PRELD_ENTNUMCFG)
1930 #define B_AX_TXPKTCTL_IMR_B1_SET_V1 (B_AX_B1_IMR_ERR_USRCTL_REINIT | \
1931 				     B_AX_B1_IMR_ERR_USRCTL_NOINIT | \
1932 				     B_AX_B1_IMR_ERR_CMDPSR_1STCMDERR | \
1933 				     B_AX_B1_IMR_ERR_CMDPSR_CMDTYPE | \
1934 				     B_AX_B1_IMR_ERR_CMDPSR_FRZTO | \
1935 				     B_AX_B1_IMR_ERR_CMDPSR_TBLSZ | \
1936 				     B_AX_B1_IMR_ERR_MPDUINFO_RECFG | \
1937 				     B_AX_B1_IMR_ERR_MPDUIF_DATAERR | \
1938 				     B_AX_B1_IMR_ERR_PRELD_RLSPKTSZERR | \
1939 				     B_AX_B1_IMR_ERR_PRELD_ENTNUMCFG)
1940 
1941 #define R_AX_TXPKTCTL_B1_ERRFLAG_ISR 0x9FBC
1942 #define B_AX_B1_ISR_ERR_PRELD_EVT3 BIT(23)
1943 #define B_AX_B1_ISR_ERR_PRELD_EVT2 BIT(22)
1944 #define B_AX_B1_ISR_ERR_PRELD_ENTNUMCFG BIT(21)
1945 #define B_AX_B1_ISR_ERR_PRELD_RLSPKTSZERR BIT(20)
1946 #define B_AX_B1_ISR_ERR_MPDUIF_ERR1 BIT(19)
1947 #define B_AX_B1_ISR_ERR_MPDUIF_DATAERR BIT(18)
1948 #define B_AX_B1_ISR_ERR_MPDUINFO_ERR1 BIT(17)
1949 #define B_AX_B1_ISR_ERR_MPDUINFO_RECFG BIT(16)
1950 #define B_AX_B1_ISR_ERR_CMDPSR_TBLSZ BIT(11)
1951 #define B_AX_B1_ISR_ERR_CMDPSR_FRZTO BIT(10)
1952 #define B_AX_B1_ISR_ERR_CMDPSR_CMDTYPE BIT(9)
1953 #define B_AX_B1_ISR_ERR_CMDPSR_1STCMDERR BIT(8)
1954 #define B_AX_B1_ISR_ERR_USRCTL_EVT7 BIT(7)
1955 #define B_AX_B1_ISR_ERR_USRCTL_EVT6 BIT(6)
1956 #define B_AX_B1_ISR_ERR_USRCTL_EVT5 BIT(5)
1957 #define B_AX_B1_ISR_ERR_USRCTL_EVT4 BIT(4)
1958 #define B_AX_B1_ISR_ERR_USRCTL_RLSBMPLEN BIT(3)
1959 #define B_AX_B1_ISR_ERR_USRCTL_RDNRLSCMD BIT(2)
1960 #define B_AX_B1_ISR_ERR_USRCTL_NOINIT BIT(1)
1961 #define B_AX_B1_ISR_ERR_USRCTL_REINIT BIT(0)
1962 
1963 #define R_AX_AFE_CTRL1 0x0024
1964 
1965 #define B_AX_R_SYM_WLCMAC1_P4_PC_EN BIT(4)
1966 #define B_AX_R_SYM_WLCMAC1_P3_PC_EN BIT(3)
1967 #define B_AX_R_SYM_WLCMAC1_P2_PC_EN BIT(2)
1968 #define B_AX_R_SYM_WLCMAC1_P1_PC_EN BIT(1)
1969 #define B_AX_R_SYM_WLCMAC1_PC_EN BIT(0)
1970 
1971 #define R_AX_SYS_ISO_CTRL_EXTEND 0x0080
1972 #define B_AX_CMAC1_FEN BIT(30)
1973 #define B_AX_R_SYM_FEN_WLBBGLB_1 BIT(17)
1974 #define B_AX_R_SYM_FEN_WLBBFUN_1 BIT(16)
1975 #define B_AX_R_SYM_ISO_CMAC12PP BIT(5)
1976 
1977 #define R_AX_CMAC_REG_START 0xC000
1978 
1979 #define R_AX_CMAC_FUNC_EN 0xC000
1980 #define R_AX_CMAC_FUNC_EN_C1 0xE000
1981 #define B_AX_CMAC_CRPRT BIT(31)
1982 #define B_AX_CMAC_EN BIT(30)
1983 #define B_AX_CMAC_TXEN BIT(29)
1984 #define B_AX_CMAC_RXEN BIT(28)
1985 #define B_AX_FORCE_CMACREG_GCKEN BIT(15)
1986 #define B_AX_PHYINTF_EN BIT(5)
1987 #define B_AX_CMAC_DMA_EN BIT(4)
1988 #define B_AX_PTCLTOP_EN BIT(3)
1989 #define B_AX_SCHEDULER_EN BIT(2)
1990 #define B_AX_TMAC_EN BIT(1)
1991 #define B_AX_RMAC_EN BIT(0)
1992 
1993 #define R_AX_CK_EN 0xC004
1994 #define R_AX_CK_EN_C1 0xE004
1995 #define B_AX_CMAC_ALLCKEN GENMASK(31, 0)
1996 #define B_AX_CMAC_CKEN BIT(30)
1997 #define B_AX_PHYINTF_CKEN BIT(5)
1998 #define B_AX_CMAC_DMA_CKEN BIT(4)
1999 #define B_AX_PTCLTOP_CKEN BIT(3)
2000 #define B_AX_SCHEDULER_CKEN BIT(2)
2001 #define B_AX_TMAC_CKEN BIT(1)
2002 #define B_AX_RMAC_CKEN BIT(0)
2003 
2004 #define R_AX_WMAC_RFMOD 0xC010
2005 #define R_AX_WMAC_RFMOD_C1 0xE010
2006 #define B_AX_WMAC_RFMOD_MASK GENMASK(1, 0)
2007 #define AX_WMAC_RFMOD_20M 0
2008 #define AX_WMAC_RFMOD_40M 1
2009 #define AX_WMAC_RFMOD_80M 2
2010 #define AX_WMAC_RFMOD_160M 3
2011 
2012 #define R_AX_GID_POSITION0 0xC070
2013 #define R_AX_GID_POSITION0_C1 0xE070
2014 #define R_AX_GID_POSITION1 0xC074
2015 #define R_AX_GID_POSITION1_C1 0xE074
2016 #define R_AX_GID_POSITION2 0xC078
2017 #define R_AX_GID_POSITION2_C1 0xE078
2018 #define R_AX_GID_POSITION3 0xC07C
2019 #define R_AX_GID_POSITION3_C1 0xE07C
2020 #define R_AX_GID_POSITION_EN0 0xC080
2021 #define R_AX_GID_POSITION_EN0_C1 0xE080
2022 #define R_AX_GID_POSITION_EN1 0xC084
2023 #define R_AX_GID_POSITION_EN1_C1 0xE084
2024 
2025 #define R_AX_TX_SUB_CARRIER_VALUE 0xC088
2026 #define R_AX_TX_SUB_CARRIER_VALUE_C1 0xE088
2027 #define B_AX_TXSC_80M_MASK GENMASK(11, 8)
2028 #define B_AX_TXSC_40M_MASK GENMASK(7, 4)
2029 #define B_AX_TXSC_20M_MASK GENMASK(3, 0)
2030 
2031 #define R_AX_PTCL_RRSR1 0xC090
2032 #define R_AX_PTCL_RRSR1_C1 0xE090
2033 #define B_AX_RRSR_RATE_EN_MASK GENMASK(11, 8)
2034 #define RRSR_OFDM_CCK_EN 3
2035 #define B_AX_RSC_MASK GENMASK(7, 6)
2036 #define B_AX_RRSR_CCK_MASK GENMASK(3, 0)
2037 
2038 #define R_AX_CMAC_ERR_IMR 0xC160
2039 #define R_AX_CMAC_ERR_IMR_C1 0xE160
2040 #define B_AX_WMAC_TX_ERR_IND_EN BIT(7)
2041 #define B_AX_WMAC_RX_ERR_IND_EN BIT(6)
2042 #define B_AX_TXPWR_CTRL_ERR_IND_EN BIT(5)
2043 #define B_AX_PHYINTF_ERR_IND_EN BIT(4)
2044 #define B_AX_DMA_TOP_ERR_IND_EN BIT(3)
2045 #define B_AX_PTCL_TOP_ERR_IND_EN BIT(1)
2046 #define B_AX_SCHEDULE_TOP_ERR_IND_EN BIT(0)
2047 #define CMAC0_ERR_IMR_EN GENMASK(31, 0)
2048 #define CMAC1_ERR_IMR_EN GENMASK(31, 0)
2049 #define CMAC0_ERR_IMR_DIS 0
2050 #define CMAC1_ERR_IMR_DIS 0
2051 
2052 #define R_AX_CMAC_ERR_ISR 0xC164
2053 #define R_AX_CMAC_ERR_ISR_C1 0xE164
2054 #define B_AX_WMAC_TX_ERR_IND BIT(7)
2055 #define B_AX_WMAC_RX_ERR_IND BIT(6)
2056 #define B_AX_TXPWR_CTRL_ERR_IND BIT(5)
2057 #define B_AX_PHYINTF_ERR_IND BIT(4)
2058 #define B_AX_DMA_TOP_ERR_IND BIT(3)
2059 #define B_AX_PTCL_TOP_ERR_IND BIT(1)
2060 #define B_AX_SCHEDULE_TOP_ERR_IND BIT(0)
2061 
2062 #define R_AX_PORT0_TSF_SYNC 0xC2A0
2063 #define R_AX_PORT0_TSF_SYNC_C1 0xE2A0
2064 #define R_AX_PORT1_TSF_SYNC 0xC2A4
2065 #define R_AX_PORT1_TSF_SYNC_C1 0xE2A4
2066 #define R_AX_PORT2_TSF_SYNC 0xC2A8
2067 #define R_AX_PORT2_TSF_SYNC_C1 0xE2A8
2068 #define R_AX_PORT3_TSF_SYNC 0xC2AC
2069 #define R_AX_PORT3_TSF_SYNC_C1 0xE2AC
2070 #define R_AX_PORT4_TSF_SYNC 0xC2B0
2071 #define R_AX_PORT4_TSF_SYNC_C1 0xE2B0
2072 #define B_AX_SYNC_NOW BIT(30)
2073 #define B_AX_SYNC_ONCE BIT(29)
2074 #define B_AX_SYNC_AUTO BIT(28)
2075 #define B_AX_SYNC_PORT_SRC GENMASK(26, 24)
2076 #define B_AX_SYNC_PORT_OFFSET_SIGN BIT(18)
2077 #define B_AX_SYNC_PORT_OFFSET_VAL GENMASK(17, 0)
2078 
2079 #define R_AX_MACID_SLEEP_0 0xC2C0
2080 #define R_AX_MACID_SLEEP_0_C1 0xE2C0
2081 #define B_AX_MACID31_0_SLEEP_SH 0
2082 #define B_AX_MACID31_0_SLEEP_MASK GENMASK(31, 0)
2083 
2084 #define R_AX_MACID_SLEEP_1 0xC2C4
2085 #define R_AX_MACID_SLEEP_1_C1 0xE2C4
2086 #define B_AX_MACID63_32_SLEEP_SH 0
2087 #define B_AX_MACID63_32_SLEEP_MASK GENMASK(31, 0)
2088 
2089 #define R_AX_MACID_SLEEP_2 0xC2C8
2090 #define R_AX_MACID_SLEEP_2_C1 0xE2C8
2091 #define B_AX_MACID95_64_SLEEP_SH 0
2092 #define B_AX_MACID95_64_SLEEP_MASK GENMASK(31, 0)
2093 
2094 #define R_AX_MACID_SLEEP_3 0xC2CC
2095 #define R_AX_MACID_SLEEP_3_C1 0xE2CC
2096 #define B_AX_MACID127_96_SLEEP_SH 0
2097 #define B_AX_MACID127_96_SLEEP_MASK GENMASK(31, 0)
2098 
2099 #define SCH_PREBKF_24US 0x18
2100 #define R_AX_PREBKF_CFG_0 0xC338
2101 #define R_AX_PREBKF_CFG_0_C1 0xE338
2102 #define B_AX_PREBKF_TIME_MASK GENMASK(4, 0)
2103 
2104 #define R_AX_PREBKF_CFG_1 0xC33C
2105 #define R_AX_PREBKF_CFG_1_C1 0xE33C
2106 #define B_AX_SIFS_TIMEOUT_TB_AGGR_MASK GENMASK(30, 24)
2107 #define B_AX_SIFS_PREBKF_MASK GENMASK(23, 16)
2108 #define B_AX_SIFS_TIMEOUT_T2_MASK GENMASK(14, 8)
2109 #define B_AX_SIFS_MACTXEN_T1_MASK GENMASK(6, 0)
2110 #define SIFS_MACTXEN_T1 0x47
2111 #define SIFS_MACTXEN_T1_V1 0x41
2112 
2113 #define R_AX_CCA_CFG_0 0xC340
2114 #define R_AX_CCA_CFG_0_C1 0xE340
2115 #define B_AX_BTCCA_BRK_TXOP_EN BIT(9)
2116 #define B_AX_BTCCA_EN BIT(5)
2117 #define B_AX_EDCCA_EN BIT(4)
2118 #define B_AX_SEC80_EN BIT(3)
2119 #define B_AX_SEC40_EN BIT(2)
2120 #define B_AX_SEC20_EN BIT(1)
2121 #define B_AX_CCA_EN BIT(0)
2122 
2123 #define R_AX_CTN_TXEN 0xC348
2124 #define R_AX_CTN_TXEN_C1 0xE348
2125 #define B_AX_CTN_TXEN_TWT_1 BIT(15)
2126 #define B_AX_CTN_TXEN_TWT_0 BIT(14)
2127 #define B_AX_CTN_TXEN_ULQ BIT(13)
2128 #define B_AX_CTN_TXEN_BCNQ BIT(12)
2129 #define B_AX_CTN_TXEN_HGQ BIT(11)
2130 #define B_AX_CTN_TXEN_CPUMGQ BIT(10)
2131 #define B_AX_CTN_TXEN_MGQ1 BIT(9)
2132 #define B_AX_CTN_TXEN_MGQ BIT(8)
2133 #define B_AX_CTN_TXEN_VO_1 BIT(7)
2134 #define B_AX_CTN_TXEN_VI_1 BIT(6)
2135 #define B_AX_CTN_TXEN_BK_1 BIT(5)
2136 #define B_AX_CTN_TXEN_BE_1 BIT(4)
2137 #define B_AX_CTN_TXEN_VO_0 BIT(3)
2138 #define B_AX_CTN_TXEN_VI_0 BIT(2)
2139 #define B_AX_CTN_TXEN_BK_0 BIT(1)
2140 #define B_AX_CTN_TXEN_BE_0 BIT(0)
2141 #define B_AX_CTN_TXEN_ALL_MASK GENMASK(15, 0)
2142 
2143 #define R_AX_MUEDCA_BE_PARAM_0 0xC350
2144 #define R_AX_MUEDCA_BE_PARAM_0_C1 0xE350
2145 #define B_AX_MUEDCA_BE_PARAM_0_TIMER_MASK GENMASK(31, 16)
2146 #define B_AX_MUEDCA_BE_PARAM_0_CW_MASK GENMASK(15, 8)
2147 #define B_AX_MUEDCA_BE_PARAM_0_AIFS_MASK GENMASK(7, 0)
2148 
2149 #define R_AX_MUEDCA_BK_PARAM_0 0xC354
2150 #define R_AX_MUEDCA_BK_PARAM_0_C1 0xE354
2151 #define R_AX_MUEDCA_VI_PARAM_0 0xC358
2152 #define R_AX_MUEDCA_VI_PARAM_0_C1 0xE358
2153 #define R_AX_MUEDCA_VO_PARAM_0 0xC35C
2154 #define R_AX_MUEDCA_VO_PARAM_0_C1 0xE35C
2155 
2156 #define R_AX_MUEDCA_EN 0xC370
2157 #define R_AX_MUEDCA_EN_C1 0xE370
2158 #define B_AX_MUEDCA_WMM_SEL BIT(8)
2159 #define B_AX_SET_MUEDCATIMER_TF_0 BIT(4)
2160 #define B_AX_MUEDCA_EN_0 BIT(0)
2161 
2162 #define R_AX_CCA_CONTROL 0xC390
2163 #define R_AX_CCA_CONTROL_C1 0xE390
2164 #define B_AX_TB_CHK_TX_NAV BIT(31)
2165 #define B_AX_TB_CHK_BASIC_NAV BIT(30)
2166 #define B_AX_TB_CHK_BTCCA BIT(29)
2167 #define B_AX_TB_CHK_EDCCA BIT(28)
2168 #define B_AX_TB_CHK_CCA_S80 BIT(27)
2169 #define B_AX_TB_CHK_CCA_S40 BIT(26)
2170 #define B_AX_TB_CHK_CCA_S20 BIT(25)
2171 #define B_AX_TB_CHK_CCA_P20 BIT(24)
2172 #define B_AX_SIFS_CHK_BTCCA BIT(21)
2173 #define B_AX_SIFS_CHK_EDCCA BIT(20)
2174 #define B_AX_SIFS_CHK_CCA_S80 BIT(19)
2175 #define B_AX_SIFS_CHK_CCA_S40 BIT(18)
2176 #define B_AX_SIFS_CHK_CCA_S20 BIT(17)
2177 #define B_AX_SIFS_CHK_CCA_P20 BIT(16)
2178 #define B_AX_CTN_CHK_TXNAV BIT(8)
2179 #define B_AX_CTN_CHK_INTRA_NAV BIT(7)
2180 #define B_AX_CTN_CHK_BASIC_NAV BIT(6)
2181 #define B_AX_CTN_CHK_BTCCA BIT(5)
2182 #define B_AX_CTN_CHK_EDCCA BIT(4)
2183 #define B_AX_CTN_CHK_CCA_S80 BIT(3)
2184 #define B_AX_CTN_CHK_CCA_S40 BIT(2)
2185 #define B_AX_CTN_CHK_CCA_S20 BIT(1)
2186 #define B_AX_CTN_CHK_CCA_P20 BIT(0)
2187 
2188 #define R_AX_CTN_DRV_TXEN 0xC398
2189 #define R_AX_CTN_DRV_TXEN_C1 0xE398
2190 #define B_AX_CTN_TXEN_TWT_3 BIT(17)
2191 #define B_AX_CTN_TXEN_TWT_2 BIT(16)
2192 #define B_AX_CTN_TXEN_ALL_MASK_V1 GENMASK(17, 0)
2193 
2194 #define R_AX_SCHEDULE_ERR_IMR 0xC3E8
2195 #define R_AX_SCHEDULE_ERR_IMR_C1 0xE3E8
2196 #define B_AX_SORT_NON_IDLE_ERR_INT_EN BIT(1)
2197 
2198 #define R_AX_SCHEDULE_ERR_ISR 0xC3EC
2199 #define R_AX_SCHEDULE_ERR_ISR_C1 0xE3EC
2200 
2201 #define R_AX_SCH_DBG_SEL 0xC3F4
2202 #define R_AX_SCH_DBG_SEL_C1 0xE3F4
2203 #define B_AX_SCH_DBG_EN BIT(16)
2204 #define B_AX_SCH_CFG_CMD_SEL GENMASK(15, 8)
2205 #define B_AX_SCH_DBG_SEL_MASK GENMASK(7, 0)
2206 
2207 #define R_AX_SCH_DBG 0xC3F8
2208 #define R_AX_SCH_DBG_C1 0xE3F8
2209 #define B_AX_SCHEDULER_DBG_MASK GENMASK(31, 0)
2210 
2211 #define R_AX_SCH_EXT_CTRL 0xC3FC
2212 #define R_AX_SCH_EXT_CTRL_C1 0xE3FC
2213 #define B_AX_PORT_RST_TSF_ADV BIT(1)
2214 
2215 #define R_AX_PORT_CFG_P0 0xC400
2216 #define R_AX_PORT_CFG_P1 0xC440
2217 #define R_AX_PORT_CFG_P2 0xC480
2218 #define R_AX_PORT_CFG_P3 0xC4C0
2219 #define R_AX_PORT_CFG_P4 0xC500
2220 #define B_AX_BRK_SETUP BIT(16)
2221 #define B_AX_TBTT_UPD_SHIFT_SEL BIT(15)
2222 #define B_AX_BCN_DROP_ALLOW BIT(14)
2223 #define B_AX_TBTT_PROHIB_EN BIT(13)
2224 #define B_AX_BCNTX_EN BIT(12)
2225 #define B_AX_NET_TYPE_MASK GENMASK(11, 10)
2226 #define B_AX_BCN_FORCETX_EN BIT(9)
2227 #define B_AX_TXBCN_BTCCA_EN BIT(8)
2228 #define B_AX_BCNERR_CNT_EN BIT(7)
2229 #define B_AX_BCN_AGRES BIT(6)
2230 #define B_AX_TSFTR_RST BIT(5)
2231 #define B_AX_RX_BSSID_FIT_EN BIT(4)
2232 #define B_AX_TSF_UDT_EN BIT(3)
2233 #define B_AX_PORT_FUNC_EN BIT(2)
2234 #define B_AX_TXBCN_RPT_EN BIT(1)
2235 #define B_AX_RXBCN_RPT_EN BIT(0)
2236 
2237 #define R_AX_TBTT_PROHIB_P0 0xC404
2238 #define R_AX_TBTT_PROHIB_P1 0xC444
2239 #define R_AX_TBTT_PROHIB_P2 0xC484
2240 #define R_AX_TBTT_PROHIB_P3 0xC4C4
2241 #define R_AX_TBTT_PROHIB_P4 0xC504
2242 #define B_AX_TBTT_HOLD_MASK GENMASK(27, 16)
2243 #define B_AX_TBTT_SETUP_MASK GENMASK(7, 0)
2244 
2245 #define R_AX_BCN_AREA_P0 0xC408
2246 #define R_AX_BCN_AREA_P1 0xC448
2247 #define R_AX_BCN_AREA_P2 0xC488
2248 #define R_AX_BCN_AREA_P3 0xC4C8
2249 #define R_AX_BCN_AREA_P4 0xC508
2250 #define B_AX_BCN_MSK_AREA_MASK GENMASK(27, 16)
2251 #define B_AX_BCN_CTN_AREA_MASK GENMASK(11, 0)
2252 
2253 #define R_AX_BCNERLYINT_CFG_P0 0xC40C
2254 #define R_AX_BCNERLYINT_CFG_P1 0xC44C
2255 #define R_AX_BCNERLYINT_CFG_P2 0xC48C
2256 #define R_AX_BCNERLYINT_CFG_P3 0xC4CC
2257 #define R_AX_BCNERLYINT_CFG_P4 0xC50C
2258 #define B_AX_BCNERLY_MASK GENMASK(11, 0)
2259 
2260 #define R_AX_TBTTERLYINT_CFG_P0 0xC40E
2261 #define R_AX_TBTTERLYINT_CFG_P1 0xC44E
2262 #define R_AX_TBTTERLYINT_CFG_P2 0xC48E
2263 #define R_AX_TBTTERLYINT_CFG_P3 0xC4CE
2264 #define R_AX_TBTTERLYINT_CFG_P4 0xC50E
2265 #define B_AX_TBTTERLY_MASK GENMASK(11, 0)
2266 
2267 #define R_AX_TBTT_AGG_P0 0xC412
2268 #define R_AX_TBTT_AGG_P1 0xC452
2269 #define R_AX_TBTT_AGG_P2 0xC492
2270 #define R_AX_TBTT_AGG_P3 0xC4D2
2271 #define R_AX_TBTT_AGG_P4 0xC512
2272 #define B_AX_TBTT_AGG_NUM_MASK GENMASK(15, 8)
2273 
2274 #define R_AX_BCN_SPACE_CFG_P0 0xC414
2275 #define R_AX_BCN_SPACE_CFG_P1 0xC454
2276 #define R_AX_BCN_SPACE_CFG_P2 0xC494
2277 #define R_AX_BCN_SPACE_CFG_P3 0xC4D4
2278 #define R_AX_BCN_SPACE_CFG_P4 0xC514
2279 #define B_AX_SUB_BCN_SPACE_MASK GENMASK(23, 16)
2280 #define B_AX_BCN_SPACE_MASK GENMASK(15, 0)
2281 
2282 #define R_AX_BCN_FORCETX_P0 0xC418
2283 #define R_AX_BCN_FORCETX_P1 0xC458
2284 #define R_AX_BCN_FORCETX_P2 0xC498
2285 #define R_AX_BCN_FORCETX_P3 0xC4D8
2286 #define R_AX_BCN_FORCETX_P4 0xC518
2287 #define B_AX_FORCE_BCN_CURRCNT_MASK GENMASK(23, 16)
2288 #define B_AX_FORCE_BCN_NUM_MASK GENMASK(15, 0)
2289 #define B_AX_BCN_MAX_ERR_MASK GENMASK(7, 0)
2290 
2291 #define R_AX_BCN_ERR_CNT_P0 0xC420
2292 #define R_AX_BCN_ERR_CNT_P1 0xC460
2293 #define R_AX_BCN_ERR_CNT_P2 0xC4A0
2294 #define R_AX_BCN_ERR_CNT_P3 0xC4E0
2295 #define R_AX_BCN_ERR_CNT_P4 0xC520
2296 #define B_AX_BCN_ERR_CNT_SUM_MASK GENMASK(31, 24)
2297 #define B_AX_BCN_ERR_CNT_NAV_MASK GENMASK(23, 16)
2298 #define B_AX_BCN_ERR_CNT_EDCCA_MASK GENMASK(15, 0)
2299 #define B_AX_BCN_ERR_CNT_CCA_MASK GENMASK(7, 0)
2300 
2301 #define R_AX_BCN_ERR_FLAG_P0 0xC424
2302 #define R_AX_BCN_ERR_FLAG_P1 0xC464
2303 #define R_AX_BCN_ERR_FLAG_P2 0xC4A4
2304 #define R_AX_BCN_ERR_FLAG_P3 0xC4E4
2305 #define R_AX_BCN_ERR_FLAG_P4 0xC524
2306 #define B_AX_BCN_ERR_FLAG_OTHERS BIT(6)
2307 #define B_AX_BCN_ERR_FLAG_MAC BIT(5)
2308 #define B_AX_BCN_ERR_FLAG_TXON BIT(4)
2309 #define B_AX_BCN_ERR_FLAG_SRCHEND BIT(3)
2310 #define B_AX_BCN_ERR_FLAG_INVALID BIT(2)
2311 #define B_AX_BCN_ERR_FLAG_CMP BIT(1)
2312 #define B_AX_BCN_ERR_FLAG_LOCK BIT(0)
2313 
2314 #define R_AX_DTIM_CTRL_P0 0xC426
2315 #define R_AX_DTIM_CTRL_P1 0xC466
2316 #define R_AX_DTIM_CTRL_P2 0xC4A6
2317 #define R_AX_DTIM_CTRL_P3 0xC4E6
2318 #define R_AX_DTIM_CTRL_P4 0xC526
2319 #define B_AX_DTIM_NUM_MASK GENMASK(15, 8)
2320 #define B_AX_DTIM_CURRCNT_MASK GENMASK(7, 0)
2321 
2322 #define R_AX_TBTT_SHIFT_P0 0xC428
2323 #define R_AX_TBTT_SHIFT_P1 0xC468
2324 #define R_AX_TBTT_SHIFT_P2 0xC4A8
2325 #define R_AX_TBTT_SHIFT_P3 0xC4E8
2326 #define R_AX_TBTT_SHIFT_P4 0xC528
2327 #define B_AX_TBTT_SHIFT_OFST_MASK GENMASK(11, 0)
2328 #define B_AX_TBTT_SHIFT_OFST_SIGN BIT(11)
2329 #define B_AX_TBTT_SHIFT_OFST_MAG GENMASK(10, 0)
2330 
2331 #define R_AX_BCN_CNT_TMR_P0 0xC434
2332 #define R_AX_BCN_CNT_TMR_P1 0xC474
2333 #define R_AX_BCN_CNT_TMR_P2 0xC4B4
2334 #define R_AX_BCN_CNT_TMR_P3 0xC4F4
2335 #define R_AX_BCN_CNT_TMR_P4 0xC534
2336 #define B_AX_BCN_CNT_TMR_MASK GENMASK(31, 0)
2337 
2338 #define R_AX_TSFTR_LOW_P0 0xC438
2339 #define R_AX_TSFTR_LOW_P1 0xC478
2340 #define R_AX_TSFTR_LOW_P2 0xC4B8
2341 #define R_AX_TSFTR_LOW_P3 0xC4F8
2342 #define R_AX_TSFTR_LOW_P4 0xC538
2343 #define B_AX_TSFTR_LOW_MASK GENMASK(31, 0)
2344 
2345 #define R_AX_TSFTR_HIGH_P0 0xC43C
2346 #define R_AX_TSFTR_HIGH_P1 0xC47C
2347 #define R_AX_TSFTR_HIGH_P2 0xC4BC
2348 #define R_AX_TSFTR_HIGH_P3 0xC4FC
2349 #define R_AX_TSFTR_HIGH_P4 0xC53C
2350 #define B_AX_TSFTR_HIGH_MASK GENMASK(31, 0)
2351 
2352 #define R_AX_MBSSID_CTRL 0xC568
2353 #define R_AX_MBSSID_CTRL_C1 0xE568
2354 #define B_AX_P0MB_ALL_MASK GENMASK(23, 1)
2355 #define B_AX_P0MB_NUM_MASK GENMASK(19, 16)
2356 #define B_AX_P0MB15_EN BIT(15)
2357 #define B_AX_P0MB14_EN BIT(14)
2358 #define B_AX_P0MB13_EN BIT(13)
2359 #define B_AX_P0MB12_EN BIT(12)
2360 #define B_AX_P0MB11_EN BIT(11)
2361 #define B_AX_P0MB10_EN BIT(10)
2362 #define B_AX_P0MB9_EN BIT(9)
2363 #define B_AX_P0MB8_EN BIT(8)
2364 #define B_AX_P0MB7_EN BIT(7)
2365 #define B_AX_P0MB6_EN BIT(6)
2366 #define B_AX_P0MB5_EN BIT(5)
2367 #define B_AX_P0MB4_EN BIT(4)
2368 #define B_AX_P0MB3_EN BIT(3)
2369 #define B_AX_P0MB2_EN BIT(2)
2370 #define B_AX_P0MB1_EN BIT(1)
2371 
2372 #define R_AX_P0MB_HGQ_WINDOW_CFG_0 0xC590
2373 #define R_AX_P0MB_HGQ_WINDOW_CFG_0_C1 0xE590
2374 #define R_AX_PORT_HGQ_WINDOW_CFG 0xC5A0
2375 #define R_AX_PORT_HGQ_WINDOW_CFG_C1 0xE5A0
2376 
2377 #define R_AX_PTCL_COMMON_SETTING_0 0xC600
2378 #define R_AX_PTCL_COMMON_SETTING_0_C1 0xE600
2379 #define B_AX_PCIE_MODE_MASK GENMASK(15, 14)
2380 #define B_AX_CPUMGQ_LIFETIME_EN BIT(8)
2381 #define B_AX_MGQ_LIFETIME_EN BIT(7)
2382 #define B_AX_LIFETIME_EN BIT(6)
2383 #define B_AX_PTCL_TRIGGER_SS_EN_UL BIT(4)
2384 #define B_AX_PTCL_TRIGGER_SS_EN_1 BIT(3)
2385 #define B_AX_PTCL_TRIGGER_SS_EN_0 BIT(2)
2386 #define B_AX_CMAC_TX_MODE_1 BIT(1)
2387 #define B_AX_CMAC_TX_MODE_0 BIT(0)
2388 
2389 #define R_AX_AMPDU_AGG_LIMIT 0xC610
2390 #define B_AX_AMPDU_MAX_TIME_MASK GENMASK(31, 24)
2391 #define B_AX_RA_TRY_RATE_AGG_LMT_MASK GENMASK(23, 16)
2392 #define B_AX_RTS_MAX_AGG_NUM_MASK GENMASK(15, 8)
2393 #define B_AX_MAX_AGG_NUM_MASK GENMASK(7, 0)
2394 
2395 #define R_AX_AGG_LEN_HT_0 0xC614
2396 #define R_AX_AGG_LEN_HT_0_C1 0xE614
2397 #define B_AX_AMPDU_MAX_LEN_HT_MASK GENMASK(31, 16)
2398 #define B_AX_RTS_TXTIME_TH_MASK GENMASK(15, 8)
2399 #define B_AX_RTS_LEN_TH_MASK GENMASK(7, 0)
2400 
2401 #define S_AX_CTS2S_TH_SEC_256B 1
2402 #define R_AX_SIFS_SETTING 0xC624
2403 #define R_AX_SIFS_SETTING_C1 0xE624
2404 #define B_AX_HW_CTS2SELF_PKT_LEN_TH_MASK GENMASK(31, 24)
2405 #define B_AX_HW_CTS2SELF_PKT_LEN_TH_TWW_MASK GENMASK(23, 18)
2406 #define B_AX_HW_CTS2SELF_EN BIT(16)
2407 #define B_AX_SPEC_SIFS_OFDM_PTCL_SH 8
2408 #define B_AX_SPEC_SIFS_OFDM_PTCL_MASK GENMASK(15, 8)
2409 #define B_AX_SPEC_SIFS_CCK_PTCL_MASK GENMASK(7, 0)
2410 #define S_AX_CTS2S_TH_1K 4
2411 
2412 #define R_AX_TXRATE_CHK 0xC628
2413 #define R_AX_TXRATE_CHK_C1 0xE628
2414 #define B_AX_DEFT_RATE_MASK GENMASK(15, 7)
2415 #define B_AX_BAND_MODE BIT(4)
2416 #define B_AX_MAX_TXNSS_MASK GENMASK(3, 2)
2417 #define B_AX_RTS_LIMIT_IN_OFDM6 BIT(1)
2418 #define B_AX_CHECK_CCK_EN BIT(0)
2419 
2420 #define R_AX_TXCNT 0xC62C
2421 #define R_AX_TXCNT_C1 0xE62C
2422 #define B_AX_ADD_TXCNT_BY BIT(31)
2423 #define B_AX_S_TXCNT_LMT_MASK GENMASK(29, 24)
2424 #define B_AX_L_TXCNT_LMT_MASK GENMASK(21, 16)
2425 
2426 #define R_AX_MBSSID_DROP_0 0xC63C
2427 #define R_AX_MBSSID_DROP_0_C1 0xE63C
2428 #define B_AX_GI_LTF_FB_SEL BIT(30)
2429 #define B_AX_RATE_SEL_MASK GENMASK(29, 24)
2430 #define B_AX_PORT_DROP_4_0_MASK GENMASK(20, 16)
2431 #define B_AX_MBSSID_DROP_15_0_MASK GENMASK(15, 0)
2432 
2433 #define R_AX_PTCLRPT_FULL_HDL 0xC660
2434 #define R_AX_PTCLRPT_FULL_HDL_C1 0xE660
2435 #define B_AX_RPT_LATCH_PHY_TIME_MASK GENMASK(15, 12)
2436 #define B_AX_F2PCMD_FWWD_RLS_MODE BIT(9)
2437 #define B_AX_F2PCMD_RPT_EN BIT(8)
2438 #define B_AX_BCN_RPT_PATH_MASK GENMASK(7, 6)
2439 #define B_AX_SPE_RPT_PATH_MASK GENMASK(5, 4)
2440 #define FWD_TO_WLCPU 1
2441 #define B_AX_TX_RPT_PATH_MASK GENMASK(3, 2)
2442 #define B_AX_F2PCMDRPT_FULL_DROP BIT(1)
2443 #define B_AX_NON_F2PCMDRPT_FULL_DROP BIT(0)
2444 
2445 #define R_AX_BT_PLT 0xC67C
2446 #define R_AX_BT_PLT_C1 0xE67C
2447 #define B_AX_BT_PLT_PKT_CNT_MASK GENMASK(31, 16)
2448 #define B_AX_BT_PLT_RST BIT(9)
2449 #define B_AX_PLT_EN BIT(8)
2450 #define B_AX_RX_PLT_GNT_LTE_RX BIT(7)
2451 #define B_AX_RX_PLT_GNT_BT_RX BIT(6)
2452 #define B_AX_RX_PLT_GNT_BT_TX BIT(5)
2453 #define B_AX_RX_PLT_GNT_WL BIT(4)
2454 #define B_AX_TX_PLT_GNT_LTE_RX BIT(3)
2455 #define B_AX_TX_PLT_GNT_BT_RX BIT(2)
2456 #define B_AX_TX_PLT_GNT_BT_TX BIT(1)
2457 #define B_AX_TX_PLT_GNT_WL BIT(0)
2458 
2459 #define R_AX_PTCL_BSS_COLOR_0 0xC6A0
2460 #define R_AX_PTCL_BSS_COLOR_0_C1 0xE6A0
2461 #define B_AX_BSS_COLOB_AX_PORT_3_MASK GENMASK(29, 24)
2462 #define B_AX_BSS_COLOB_AX_PORT_2_MASK GENMASK(21, 16)
2463 #define B_AX_BSS_COLOB_AX_PORT_1_MASK GENMASK(13, 8)
2464 #define B_AX_BSS_COLOB_AX_PORT_0_MASK GENMASK(5, 0)
2465 
2466 #define R_AX_PTCL_BSS_COLOR_1 0xC6A4
2467 #define R_AX_PTCL_BSS_COLOR_1_C1 0xE6A4
2468 #define B_AX_BSS_COLOB_AX_PORT_4_MASK GENMASK(5, 0)
2469 
2470 #define R_AX_PTCL_IMR0 0xC6C0
2471 #define R_AX_PTCL_IMR0_C1 0xE6C0
2472 #define B_AX_F2PCMD_PKTID_ERR_INT_EN BIT(31)
2473 #define B_AX_F2PCMD_RD_PKTID_ERR_INT_EN BIT(30)
2474 #define B_AX_F2PCMD_ASSIGN_PKTID_ERR_INT_EN BIT(29)
2475 #define B_AX_F2PCMD_USER_ALLC_ERR_INT_EN BIT(28)
2476 #define B_AX_RX_SPF_U0_PKTID_ERR_INT_EN BIT(27)
2477 #define B_AX_TX_SPF_U1_PKTID_ERR_INT_EN BIT(26)
2478 #define B_AX_TX_SPF_U2_PKTID_ERR_INT_EN BIT(25)
2479 #define B_AX_TX_SPF_U3_PKTID_ERR_INT_EN BIT(24)
2480 #define B_AX_TX_RECORD_PKTID_ERR_INT_EN BIT(23)
2481 #define B_AX_F2PCMD_EMPTY_ERR_INT_EN BIT(15)
2482 #define B_AX_TWTSP_QSEL_ERR_INT_EN BIT(14)
2483 #define B_AX_BCNQ_ORDER_ERR_INT_EN BIT(12)
2484 #define B_AX_Q_PKTID_ERR_INT_EN BIT(11)
2485 #define B_AX_D_PKTID_ERR_INT_EN BIT(10)
2486 #define B_AX_TXPRT_FULL_DROP_ERR_INT_EN BIT(9)
2487 #define B_AX_F2PCMDRPT_FULL_DROP_ERR_INT_EN BIT(8)
2488 #define B_AX_FSM1_TIMEOUT_ERR_INT_EN BIT(1)
2489 #define B_AX_FSM_TIMEOUT_ERR_INT_EN BIT(0)
2490 #define B_AX_PTCL_IMR_CLR_ALL GENMASK(31, 0)
2491 #define B_AX_PTCL_IMR_CLR (B_AX_FSM_TIMEOUT_ERR_INT_EN | \
2492 			   B_AX_F2PCMDRPT_FULL_DROP_ERR_INT_EN | \
2493 			   B_AX_TXPRT_FULL_DROP_ERR_INT_EN | \
2494 			   B_AX_D_PKTID_ERR_INT_EN | \
2495 			   B_AX_Q_PKTID_ERR_INT_EN | \
2496 			   B_AX_BCNQ_ORDER_ERR_INT_EN | \
2497 			   B_AX_TWTSP_QSEL_ERR_INT_EN | \
2498 			   B_AX_F2PCMD_EMPTY_ERR_INT_EN | \
2499 			   B_AX_TX_RECORD_PKTID_ERR_INT_EN | \
2500 			   B_AX_TX_SPF_U3_PKTID_ERR_INT_EN | \
2501 			   B_AX_TX_SPF_U2_PKTID_ERR_INT_EN | \
2502 			   B_AX_TX_SPF_U1_PKTID_ERR_INT_EN | \
2503 			   B_AX_RX_SPF_U0_PKTID_ERR_INT_EN | \
2504 			   B_AX_F2PCMD_USER_ALLC_ERR_INT_EN | \
2505 			   B_AX_F2PCMD_ASSIGN_PKTID_ERR_INT_EN | \
2506 			   B_AX_F2PCMD_RD_PKTID_ERR_INT_EN | \
2507 			   B_AX_F2PCMD_PKTID_ERR_INT_EN)
2508 #define B_AX_PTCL_IMR_SET (B_AX_FSM_TIMEOUT_ERR_INT_EN | \
2509 			   B_AX_TX_RECORD_PKTID_ERR_INT_EN | \
2510 			   B_AX_F2PCMD_USER_ALLC_ERR_INT_EN)
2511 #define B_AX_PTCL_IMR_CLR_V1 (B_AX_FSM1_TIMEOUT_ERR_INT_EN | \
2512 			      B_AX_FSM_TIMEOUT_ERR_INT_EN)
2513 #define B_AX_PTCL_IMR_SET_V1 (B_AX_FSM1_TIMEOUT_ERR_INT_EN | \
2514 			      B_AX_FSM_TIMEOUT_ERR_INT_EN)
2515 
2516 #define R_AX_PTCL_ISR0 0xC6C4
2517 #define R_AX_PTCL_ISR0_C1 0xE6C4
2518 
2519 #define S_AX_PTCL_TO_2MS 0x3F
2520 #define R_AX_PTCL_FSM_MON 0xC6E8
2521 #define R_AX_PTCL_FSM_MON_C1 0xE6E8
2522 #define B_AX_PTCL_TX_ARB_TO_MODE BIT(6)
2523 #define B_AX_PTCL_TX_ARB_TO_THR_MASK GENMASK(5, 0)
2524 
2525 #define R_AX_PTCL_TX_CTN_SEL 0xC6EC
2526 #define R_AX_PTCL_TX_CTN_SEL_C1 0xE6EC
2527 #define B_AX_PTCL_TX_ON_STAT BIT(7)
2528 
2529 #define R_AX_PTCL_DBG_INFO 0xC6F0
2530 #define R_AX_PTCL_DBG_INFO_C1 0xE6F0
2531 #define B_AX_PTCL_DBG_INFO_MASK GENMASK(31, 0)
2532 #define R_AX_PTCL_DBG 0xC6F4
2533 #define R_AX_PTCL_DBG_C1 0xE6F4
2534 #define B_AX_PTCL_DBG_EN BIT(8)
2535 #define B_AX_PTCL_DBG_SEL_MASK GENMASK(7, 0)
2536 
2537 #define R_AX_DLE_CTRL 0xC800
2538 #define R_AX_DLE_CTRL_C1 0xE800
2539 #define B_AX_NO_RESERVE_PAGE_ERR_IMR BIT(23)
2540 #define B_AX_RXDATA_FSM_HANG_ERROR_IMR BIT(15)
2541 #define B_AX_RXSTS_FSM_HANG_ERROR_IMR BIT(14)
2542 #define B_AX_DLE_IMR_CLR (B_AX_RXSTS_FSM_HANG_ERROR_IMR | \
2543 			  B_AX_RXDATA_FSM_HANG_ERROR_IMR | \
2544 			  B_AX_NO_RESERVE_PAGE_ERR_IMR)
2545 #define B_AX_DLE_IMR_SET (B_AX_RXSTS_FSM_HANG_ERROR_IMR | \
2546 			  B_AX_RXDATA_FSM_HANG_ERROR_IMR)
2547 
2548 #define R_AX_RX_ERR_FLAG 0xC800
2549 #define R_AX_RX_ERR_FLAG_C1 0xE800
2550 #define B_AX_RX_GET_NO_PAGE_ERR BIT(31)
2551 #define B_AX_RX_GET_NULL_PKT_ERR BIT(30)
2552 #define B_AX_RX_RU0_FSM_HANG_ERR BIT(29)
2553 #define B_AX_RX_RU1_FSM_HANG_ERR BIT(28)
2554 #define B_AX_RX_RU2_FSM_HANG_ERR BIT(27)
2555 #define B_AX_RX_RU3_FSM_HANG_ERR BIT(26)
2556 #define B_AX_RX_RU4_FSM_HANG_ERR BIT(25)
2557 #define B_AX_RX_RU5_FSM_HANG_ERR BIT(24)
2558 #define B_AX_RX_RU6_FSM_HANG_ERR BIT(23)
2559 #define B_AX_RX_RU7_FSM_HANG_ERR BIT(22)
2560 #define B_AX_RX_RXSTS_FSM_HANG_ERR BIT(21)
2561 #define B_AX_RX_CSI_FSM_HANG_ERR BIT(20)
2562 #define B_AX_RX_TXRPT_FSM_HANG_ERR BIT(19)
2563 #define B_AX_RX_F2PCMD_FSM_HANG_ERR BIT(18)
2564 #define B_AX_RX_RU0_ZERO_LEN_ERR BIT(17)
2565 #define B_AX_RX_RU1_ZERO_LEN_ERR BIT(16)
2566 #define B_AX_RX_RU2_ZERO_LEN_ERR BIT(15)
2567 #define B_AX_RX_RU3_ZERO_LEN_ERR BIT(14)
2568 #define B_AX_RX_RU4_ZERO_LEN_ERR BIT(13)
2569 #define B_AX_RX_RU5_ZERO_LEN_ERR BIT(12)
2570 #define B_AX_RX_RU6_ZERO_LEN_ERR BIT(11)
2571 #define B_AX_RX_RU7_ZERO_LEN_ERR BIT(10)
2572 #define B_AX_RX_RXSTS_ZERO_LEN_ERR BIT(9)
2573 #define B_AX_RX_CSI_ZERO_LEN_ERR BIT(8)
2574 #define B_AX_PLE_DATA_OPT_FSM_HANG BIT(7)
2575 #define B_AX_PLE_RXDATA_REQ_BUF_FSM_HANG BIT(6)
2576 #define B_AX_PLE_TXRPT_REQ_BUF_FSM_HANG BIT(5)
2577 #define B_AX_PLE_WD_OPT_FSM_HANG BIT(4)
2578 #define B_AX_PLE_ENQ_FSM_HANG BIT(3)
2579 #define B_AX_RXDATA_ENQUE_ORDER_ERR BIT(2)
2580 #define B_AX_RXSTS_ENQUE_ORDER_ERR BIT(1)
2581 #define B_AX_RX_CSI_PKT_NUM_ERR BIT(0)
2582 
2583 #define R_AX_RXDMA_CTRL_0 0xC804
2584 #define R_AX_RXDMA_CTRL_0_C1 0xE804
2585 #define B_AX_RXDMA_DBGOUT_EN BIT(31)
2586 #define B_AX_RXDMA_DBG_SEL_MASK GENMASK(30, 29)
2587 #define B_AX_RXDMA_FIFO_DBG_SEL_MASK GENMASK(28, 25)
2588 #define B_AX_RXDMA_DEFAULT_PAGE_MASK GENMASK(22, 21)
2589 #define B_AX_RXDMA_BUFF_REQ_PRI_MASK GENMASK(20, 19)
2590 #define B_AX_RXDMA_TGT_QUEID_MASK GENMASK(18, 13)
2591 #define B_AX_RXDMA_TGT_PRID_MASK GENMASK(12, 10)
2592 #define B_AX_RXDMA_DIS_CSI_RELEASE BIT(9)
2593 #define B_AX_RXDMA_DIS_RXSTS_WAIT_PTR_CLR BIT(7)
2594 #define B_AX_RXDMA_DIS_CSI_WAIT_PTR_CLR BIT(6)
2595 #define B_AX_RXSTS_PTR_FULL_MODE BIT(5)
2596 #define B_AX_CSI_PTR_FULL_MODE BIT(4)
2597 #define B_AX_RU3_PTR_FULL_MODE BIT(3)
2598 #define B_AX_RU2_PTR_FULL_MODE BIT(2)
2599 #define B_AX_RU1_PTR_FULL_MODE BIT(1)
2600 #define B_AX_RU0_PTR_FULL_MODE BIT(0)
2601 #define RX_FULL_MODE (B_AX_RU0_PTR_FULL_MODE | B_AX_RU1_PTR_FULL_MODE | \
2602 		      B_AX_RU2_PTR_FULL_MODE | B_AX_RU3_PTR_FULL_MODE | \
2603 		      B_AX_CSI_PTR_FULL_MODE | B_AX_RXSTS_PTR_FULL_MODE)
2604 
2605 #define R_AX_RX_CTRL0 0xC808
2606 #define R_AX_RX_CTRL0_C1 0xE808
2607 #define B_AX_DLE_CLOCK_FORCE_V1 BIT(31)
2608 #define B_AX_TXDMA_CLOCK_FORCE_V1 BIT(30)
2609 #define B_AX_RXDMA_CLOCK_FORCE_V1 BIT(29)
2610 #define B_AX_RXDMA_DEFAULT_PAGE_V1_MASK GENMASK(28, 24)
2611 #define B_AX_RXDMA_CSI_TGT_QUEID_MASK GENMASK(23, 18)
2612 #define B_AX_RXDMA_CSI_TGT_PRID_MASK GENMASK(17, 15)
2613 #define B_AX_RXDMA_DIS_CSI_RELEASE_V1 BIT(14)
2614 #define B_AX_CSI_PTR_FULL_MODE_V1 BIT(13)
2615 #define B_AX_RXDATA_PTR_FULL_MODE BIT(12)
2616 #define B_AX_RXSTS_PTR_FULL_MODE_V1 BIT(11)
2617 #define B_AX_TXRPT_FULL_RSV_DEPTH_V1_MASK GENMASK(10, 8)
2618 #define B_AX_RXDATA_FULL_RSV_DEPTH_MASK GENMASK(7, 5)
2619 #define B_AX_RXSTS_FULL_RSV_DEPTH_V1_MASK GENMASK(4, 2)
2620 #define B_AX_ORDER_FIFO_MASK GENMASK(1, 0)
2621 
2622 #define R_AX_RX_CTRL1 0xC80C
2623 #define R_AX_RX_CTRL1_C1 0xE80C
2624 #define B_AX_RXDMA_TXRPT_QUEUE_ID_SW_EN BIT(31)
2625 #define B_AX_RXDMA_TXRPT_QUEUE_ID_SW_V1_MASK GENMASK(30, 25)
2626 #define B_AX_RXDMA_F2PCMD_QUEUE_ID_SW_EN BIT(24)
2627 #define B_AX_RXDMA_F2PCMD_QUEUE_ID_SW_V1_MASK GENMASK(23, 18)
2628 #define B_AX_RXDMA_TXRPT_QUEUE_ID_TGT_SW_EN BIT(17)
2629 #define B_AX_RXDMA_TXRPT_QUEUE_ID_TGT_SW_1_MASK GENMASK(16, 11)
2630 #define B_AX_RXDMA_F2PCMD_QUEUE_ID_TGT_SW_EN BIT(10)
2631 #define B_AX_RXDMA_F2PCMD_QUEUE_ID_TGT_SW_1_MASK GENMASK(9, 4)
2632 #define B_AX_ORDER_FIFO_OUT BIT(3)
2633 #define B_AX_ORDER_FIFO_EMPTY BIT(2)
2634 #define B_AX_DBG_SEL_MASK GENMASK(1, 0)
2635 
2636 #define R_AX_RX_CTRL2 0xC810
2637 #define R_AX_RX_CTRL2_C1 0xE810
2638 #define B_AX_DLE_WDE_STATE_V1_MASK GENMASK(31, 30)
2639 #define B_AX_DLE_PLE_STATE_V1_MASK GENMASK(29, 28)
2640 #define B_AX_DLE_REQ_BUF_STATE_MASK GENMASK(27, 26)
2641 #define B_AX_DLE_ENQ_STATE_V1 BIT(25)
2642 #define B_AX_RX_DBG_SEL_MASK GENMASK(24, 19)
2643 #define B_AX_MACRX_CS_MASK GENMASK(18, 14)
2644 #define B_AX_RXSTS_CS_MASK GENMASK(13, 9)
2645 #define B_AX_ERR_INDICATOR BIT(5)
2646 #define B_AX_TXRPT_CS_MASK GENMASK(4, 0)
2647 
2648 #define R_AX_RXDMA_PKT_INFO_0 0xC814
2649 #define R_AX_RXDMA_PKT_INFO_1 0xC818
2650 #define R_AX_RXDMA_PKT_INFO_2 0xC81C
2651 
2652 #define R_AX_RX_ERR_FLAG_IMR 0xC804
2653 #define R_AX_RX_ERR_FLAG_IMR_C1 0xE804
2654 #define B_AX_RX_GET_NULL_PKT_ERR_MSK BIT(30)
2655 #define B_AX_RX_RU0_FSM_HANG_MSK_ERR_MSK BIT(29)
2656 #define B_AX_RX_RU1_FSM_HANG_MSK_ERR_MSK BIT(28)
2657 #define B_AX_RX_RU2_FSM_HANG_MSK_ERR_MSK BIT(27)
2658 #define B_AX_RX_RU3_FSM_HANG_MSK_ERR_MSK BIT(26)
2659 #define B_AX_RX_RU4_FSM_HANG_MSK_ERR_MSK BIT(25)
2660 #define B_AX_RX_RU5_FSM_HANG_MSK_ERR_MSK BIT(24)
2661 #define B_AX_RX_RU6_FSM_HANG_MSK_ERR_MSK BIT(23)
2662 #define B_AX_RX_RU7_FSM_HANG_MSK_ERR_MSK BIT(22)
2663 #define B_AX_RX_RXSTS_FSM_HANG_MSK_ERR_MSK BIT(21)
2664 #define B_AX_RX_CSI_FSM_HANG_MSK_ERR_MSK BIT(20)
2665 #define B_AX_RX_TXRPT_FSM_HANG_MSK_ERR_MSK BIT(19)
2666 #define B_AX_RX_F2PCMD_FSM_HANG_MSK_ERR_MSK BIT(18)
2667 #define B_AX_RX_RU0_ZERO_LEN_ERR_MSK BIT(17)
2668 #define B_AX_RX_RU1_ZERO_LEN_ERR_MSK BIT(16)
2669 #define B_AX_RX_RU2_ZERO_LEN_ERR_MSK BIT(15)
2670 #define B_AX_RX_RU3_ZERO_LEN_ERR_MSK BIT(14)
2671 #define B_AX_RX_RU4_ZERO_LEN_ERR_MSK BIT(13)
2672 #define B_AX_RX_RU5_ZERO_LEN_ERR_MSK BIT(12)
2673 #define B_AX_RX_RU6_ZERO_LEN_ERR_MSK BIT(11)
2674 #define B_AX_RX_RU7_ZERO_LEN_ERR_MSK BIT(10)
2675 #define B_AX_RX_RXSTS_ZERO_LEN_ERR_MSK BIT(9)
2676 #define B_AX_RX_CSI_ZERO_LEN_ERR_MSK BIT(8)
2677 #define B_AX_PLE_DATA_OPT_FSM_HANG_MSK BIT(7)
2678 #define B_AX_PLE_RXDATA_REQ_BUF_FSM_HANG_MSK BIT(6)
2679 #define B_AX_PLE_TXRPT_REQ_BUF_FSM_HANG_MSK BIT(5)
2680 #define B_AX_PLE_WD_OPT_FSM_HANG_MSK BIT(4)
2681 #define B_AX_PLE_ENQ_FSM_HANG_MSK BIT(3)
2682 #define B_AX_RXDATA_ENQUE_ORDER_ERR_MSK BIT(2)
2683 #define B_AX_RXSTS_ENQUE_ORDER_ERR_MSK BIT(1)
2684 #define B_AX_RX_CSI_PKT_NUM_ERR_MSK BIT(0)
2685 #define B_AX_RX_ERR_IMR_CLR_V1 (B_AX_RXSTS_ENQUE_ORDER_ERR_MSK | \
2686 				B_AX_RXDATA_ENQUE_ORDER_ERR_MSK | \
2687 				B_AX_RX_CSI_ZERO_LEN_ERR_MSK | \
2688 				B_AX_RX_RXSTS_ZERO_LEN_ERR_MSK | \
2689 				B_AX_RX_RU7_ZERO_LEN_ERR_MSK | \
2690 				B_AX_RX_RU6_ZERO_LEN_ERR_MSK | \
2691 				B_AX_RX_RU5_ZERO_LEN_ERR_MSK | \
2692 				B_AX_RX_RU4_ZERO_LEN_ERR_MSK | \
2693 				B_AX_RX_RU3_ZERO_LEN_ERR_MSK | \
2694 				B_AX_RX_RU2_ZERO_LEN_ERR_MSK | \
2695 				B_AX_RX_RU1_ZERO_LEN_ERR_MSK | \
2696 				B_AX_RX_RU0_ZERO_LEN_ERR_MSK | \
2697 				B_AX_RX_F2PCMD_FSM_HANG_MSK_ERR_MSK | \
2698 				B_AX_RX_TXRPT_FSM_HANG_MSK_ERR_MSK | \
2699 				B_AX_RX_CSI_FSM_HANG_MSK_ERR_MSK | \
2700 				B_AX_RX_RXSTS_FSM_HANG_MSK_ERR_MSK | \
2701 				B_AX_RX_RU7_FSM_HANG_MSK_ERR_MSK | \
2702 				B_AX_RX_RU6_FSM_HANG_MSK_ERR_MSK | \
2703 				B_AX_RX_RU5_FSM_HANG_MSK_ERR_MSK | \
2704 				B_AX_RX_RU4_FSM_HANG_MSK_ERR_MSK | \
2705 				B_AX_RX_RU3_FSM_HANG_MSK_ERR_MSK | \
2706 				B_AX_RX_RU2_FSM_HANG_MSK_ERR_MSK | \
2707 				B_AX_RX_RU1_FSM_HANG_MSK_ERR_MSK | \
2708 				B_AX_RX_RU0_FSM_HANG_MSK_ERR_MSK | \
2709 				B_AX_RX_GET_NULL_PKT_ERR_MSK)
2710 #define B_AX_RX_ERR_IMR_SET_V1 (B_AX_RXSTS_ENQUE_ORDER_ERR_MSK | \
2711 				B_AX_RXDATA_ENQUE_ORDER_ERR_MSK | \
2712 				B_AX_RX_CSI_ZERO_LEN_ERR_MSK | \
2713 				B_AX_RX_RXSTS_ZERO_LEN_ERR_MSK | \
2714 				B_AX_RX_RU7_ZERO_LEN_ERR_MSK | \
2715 				B_AX_RX_RU6_ZERO_LEN_ERR_MSK | \
2716 				B_AX_RX_RU5_ZERO_LEN_ERR_MSK | \
2717 				B_AX_RX_RU4_ZERO_LEN_ERR_MSK | \
2718 				B_AX_RX_RU3_ZERO_LEN_ERR_MSK | \
2719 				B_AX_RX_RU2_ZERO_LEN_ERR_MSK | \
2720 				B_AX_RX_RU1_ZERO_LEN_ERR_MSK | \
2721 				B_AX_RX_RU0_ZERO_LEN_ERR_MSK | \
2722 				B_AX_RX_F2PCMD_FSM_HANG_MSK_ERR_MSK | \
2723 				B_AX_RX_TXRPT_FSM_HANG_MSK_ERR_MSK | \
2724 				B_AX_RX_CSI_FSM_HANG_MSK_ERR_MSK | \
2725 				B_AX_RX_RXSTS_FSM_HANG_MSK_ERR_MSK | \
2726 				B_AX_RX_RU7_FSM_HANG_MSK_ERR_MSK | \
2727 				B_AX_RX_RU6_FSM_HANG_MSK_ERR_MSK | \
2728 				B_AX_RX_RU5_FSM_HANG_MSK_ERR_MSK | \
2729 				B_AX_RX_RU4_FSM_HANG_MSK_ERR_MSK | \
2730 				B_AX_RX_RU3_FSM_HANG_MSK_ERR_MSK | \
2731 				B_AX_RX_RU2_FSM_HANG_MSK_ERR_MSK | \
2732 				B_AX_RX_RU1_FSM_HANG_MSK_ERR_MSK | \
2733 				B_AX_RX_RU0_FSM_HANG_MSK_ERR_MSK | \
2734 				B_AX_RX_GET_NULL_PKT_ERR_MSK)
2735 
2736 #define R_AX_TX_ERR_FLAG_IMR 0xC870
2737 #define R_AX_TX_ERR_FLAG_IMR_C1 0xE870
2738 #define B_AX_TX_RU0_FSM_HANG_ERR_MSK BIT(31)
2739 #define B_AX_TX_RU1_FSM_HANG_ERR_MSK BIT(30)
2740 #define B_AX_TX_RU2_FSM_HANG_ERR_MSK BIT(29)
2741 #define B_AX_TX_RU3_FSM_HANG_ERR_MSK BIT(28)
2742 #define B_AX_TX_RU4_FSM_HANG_ERR_MSK BIT(27)
2743 #define B_AX_TX_RU5_FSM_HANG_ERR_MSK BIT(26)
2744 #define B_AX_TX_RU6_FSM_HANG_ERR_MSK BIT(25)
2745 #define B_AX_TX_RU7_FSM_HANG_ERR_MSK BIT(24)
2746 #define B_AX_TX_RU8_FSM_HANG_ERR_MSK BIT(23)
2747 #define B_AX_TX_RU9_FSM_HANG_ERR_MSK BIT(22)
2748 #define B_AX_TX_RU10_FSM_HANG_ERR_MSK BIT(21)
2749 #define B_AX_TX_RU11_FSM_HANG_ERR_MSK BIT(20)
2750 #define B_AX_TX_RU12_FSM_HANG_ERR_MSK BIT(19)
2751 #define B_AX_TX_RU13_FSM_HANG_ERR_MSK BIT(18)
2752 #define B_AX_TX_RU14_FSM_HANG_ERR_MSK BIT(17)
2753 #define B_AX_TX_RU15_FSM_HANG_ERR_MSK BIT(16)
2754 #define B_AX_TX_CSI_FSM_HANG_ERR_MSK BIT(15)
2755 #define B_AX_TX_WD_PLD_ID_FSM_HANG_ERR_MSK BIT(14)
2756 #define B_AX_TX_ERR_IMR_CLR_V1 (B_AX_TX_WD_PLD_ID_FSM_HANG_ERR_MSK | \
2757 				B_AX_TX_CSI_FSM_HANG_ERR_MSK | \
2758 				B_AX_TX_RU7_FSM_HANG_ERR_MSK | \
2759 				B_AX_TX_RU6_FSM_HANG_ERR_MSK | \
2760 				B_AX_TX_RU5_FSM_HANG_ERR_MSK | \
2761 				B_AX_TX_RU4_FSM_HANG_ERR_MSK | \
2762 				B_AX_TX_RU3_FSM_HANG_ERR_MSK | \
2763 				B_AX_TX_RU2_FSM_HANG_ERR_MSK | \
2764 				B_AX_TX_RU1_FSM_HANG_ERR_MSK | \
2765 				B_AX_TX_RU0_FSM_HANG_ERR_MSK)
2766 #define B_AX_TX_ERR_IMR_SET_V1 (B_AX_TX_WD_PLD_ID_FSM_HANG_ERR_MSK | \
2767 				B_AX_TX_CSI_FSM_HANG_ERR_MSK | \
2768 				B_AX_TX_RU7_FSM_HANG_ERR_MSK | \
2769 				B_AX_TX_RU6_FSM_HANG_ERR_MSK | \
2770 				B_AX_TX_RU5_FSM_HANG_ERR_MSK | \
2771 				B_AX_TX_RU4_FSM_HANG_ERR_MSK | \
2772 				B_AX_TX_RU3_FSM_HANG_ERR_MSK | \
2773 				B_AX_TX_RU2_FSM_HANG_ERR_MSK | \
2774 				B_AX_TX_RU1_FSM_HANG_ERR_MSK | \
2775 				B_AX_TX_RU0_FSM_HANG_ERR_MSK)
2776 
2777 #define R_AX_TCR0 0xCA00
2778 #define R_AX_TCR0_C1 0xEA00
2779 #define B_AX_TCR_ZLD_NUM_MASK GENMASK(31, 24)
2780 #define B_AX_TCR_UDF_EN BIT(23)
2781 #define B_AX_TCR_UDF_THSD_MASK GENMASK(22, 16)
2782 #define TCR_UDF_THSD 0x6
2783 #define B_AX_TCR_ERRSTEN_MASK GENMASK(15, 10)
2784 #define B_AX_TCR_VHTSIGA1_TXPS BIT(9)
2785 #define B_AX_TCR_PLCP_ERRHDL_EN BIT(8)
2786 #define B_AX_TCR_PADSEL BIT(7)
2787 #define B_AX_TCR_MASK_SIGBCRC BIT(6)
2788 #define B_AX_TCR_SR_VAL15_ALLOW BIT(5)
2789 #define B_AX_TCR_EN_EOF BIT(4)
2790 #define B_AX_TCR_EN_SCRAM_INC BIT(3)
2791 #define B_AX_TCR_EN_20MST BIT(2)
2792 #define B_AX_TCR_CRC BIT(1)
2793 #define B_AX_TCR_DISGCLK BIT(0)
2794 
2795 #define R_AX_TCR1 0xCA04
2796 #define R_AX_TCR1_C1 0xEA04
2797 #define B_AX_TXDFIFO_THRESHOLD GENMASK(31, 28)
2798 #define B_AX_TCR_CCK_LOCK_CLK BIT(27)
2799 #define B_AX_TCR_FORCE_READ_TXDFIFO BIT(26)
2800 #define B_AX_TCR_USTIME GENMASK(23, 16)
2801 #define B_AX_TCR_SMOOTH_VAL BIT(15)
2802 #define B_AX_TCR_SMOOTH_CTRL BIT(14)
2803 #define B_AX_CS_REQ_VAL BIT(13)
2804 #define B_AX_CS_REQ_SEL BIT(12)
2805 #define B_AX_TCR_ZLD_USTIME_AFTERPHYTXON GENMASK(11, 8)
2806 #define B_AX_TCR_TXTIMEOUT GENMASK(7, 0)
2807 
2808 #define R_AX_MD_TSFT_STMP_CTL 0xCA08
2809 #define R_AX_MD_TSFT_STMP_CTL_C1 0xEA08
2810 #define B_AX_TSFT_OFS_MASK GENMASK(31, 16)
2811 #define B_AX_STMP_THSD_MASK GENMASK(15, 8)
2812 #define B_AX_UPD_HGQMD BIT(1)
2813 #define B_AX_UPD_TIMIE BIT(0)
2814 
2815 #define R_AX_PPWRBIT_SETTING 0xCA0C
2816 #define R_AX_PPWRBIT_SETTING_C1 0xEA0C
2817 
2818 #define R_AX_TXD_FIFO_CTRL 0xCA1C
2819 #define R_AX_TXD_FIFO_CTRL_C1 0xEA1C
2820 #define B_AX_NON_LEGACY_PPDU_ZLD_USTIMER_MASK GENMASK(28, 24)
2821 #define B_AX_LEGACY_PPDU_ZLD_USTIMER_MASK GENMASK(20, 16)
2822 #define B_AX_TXDFIFO_HIGH_MCS_THRE_MASK GENMASK(15, 12)
2823 #define TXDFIFO_HIGH_MCS_THRE 0x7
2824 #define B_AX_TXDFIFO_LOW_MCS_THRE_MASK GENMASK(11, 8)
2825 #define TXDFIFO_LOW_MCS_THRE  0x7
2826 #define B_AX_HIGH_MCS_PHY_RATE_MASK GENMASK(7, 4)
2827 #define B_AX_BW_PHY_RATE_MASK GENMASK(1, 0)
2828 
2829 #define R_AX_MACTX_DBG_SEL_CNT 0xCA20
2830 #define R_AX_MACTX_DBG_SEL_CNT_C1 0xEA20
2831 #define B_AX_MACTX_MPDU_CNT GENMASK(31, 24)
2832 #define B_AX_MACTX_DMA_CNT GENMASK(23, 16)
2833 #define B_AX_LENGTH_ERR_FLAG_U3 BIT(11)
2834 #define B_AX_LENGTH_ERR_FLAG_U2 BIT(10)
2835 #define B_AX_LENGTH_ERR_FLAG_U1 BIT(9)
2836 #define B_AX_LENGTH_ERR_FLAG_U0 BIT(8)
2837 #define B_AX_DBGSEL_MACTX_MASK GENMASK(5, 0)
2838 
2839 #define R_AX_WMAC_TX_CTRL_DEBUG 0xCAE4
2840 #define R_AX_WMAC_TX_CTRL_DEBUG_C1 0xEAE4
2841 #define B_AX_TX_CTRL_DEBUG_SEL_MASK GENMASK(3, 0)
2842 
2843 #define R_AX_WMAC_TX_INFO0_DEBUG 0xCAE8
2844 #define R_AX_WMAC_TX_INFO0_DEBUG_C1 0xEAE8
2845 #define B_AX_TX_CTRL_INFO_P0_MASK GENMASK(31, 0)
2846 
2847 #define R_AX_WMAC_TX_INFO1_DEBUG 0xCAEC
2848 #define R_AX_WMAC_TX_INFO1_DEBUG_C1 0xEAEC
2849 #define B_AX_TX_CTRL_INFO_P1_MASK GENMASK(31, 0)
2850 
2851 #define R_AX_RSP_CHK_SIG 0xCC00
2852 #define R_AX_RSP_CHK_SIG_C1 0xEC00
2853 #define B_AX_RSP_STATIC_RTS_CHK_SERV_BW_EN BIT(30)
2854 #define B_AX_RSP_TBPPDU_CHK_PWR BIT(29)
2855 #define B_AX_RSP_CHK_BASIC_NAV BIT(21)
2856 #define B_AX_RSP_CHK_INTRA_NAV BIT(20)
2857 #define B_AX_RSP_CHK_TXNAV BIT(19)
2858 #define B_AX_TXDATA_END_PS_OPT BIT(18)
2859 #define B_AX_CHECK_SOUNDING_SEQ BIT(17)
2860 #define B_AX_RXBA_IGNOREA2 BIT(16)
2861 #define B_AX_ACKTO_CCK_MASK GENMASK(15, 8)
2862 #define B_AX_ACKTO_MASK GENMASK(7, 0)
2863 
2864 #define R_AX_TRXPTCL_RESP_0 0xCC04
2865 #define R_AX_TRXPTCL_RESP_0_C1 0xEC04
2866 #define B_AX_WMAC_RESP_STBC_EN BIT(31)
2867 #define B_AX_WMAC_RXFTM_TXACK_SC BIT(30)
2868 #define B_AX_WMAC_RXFTM_TXACKBWEQ BIT(29)
2869 #define B_AX_RSP_CHK_SEC_CCA_80 BIT(28)
2870 #define B_AX_RSP_CHK_SEC_CCA_40 BIT(27)
2871 #define B_AX_RSP_CHK_SEC_CCA_20 BIT(26)
2872 #define B_AX_RSP_CHK_BTCCA BIT(25)
2873 #define B_AX_RSP_CHK_EDCCA BIT(24)
2874 #define B_AX_RSP_CHK_CCA BIT(23)
2875 #define B_AX_WMAC_LDPC_EN BIT(22)
2876 #define B_AX_WMAC_SGIEN BIT(21)
2877 #define B_AX_WMAC_SPLCPEN BIT(20)
2878 #define B_AX_WMAC_BESP_EARLY_TXBA BIT(17)
2879 #define B_AX_WMAC_SPEC_SIFS_OFDM_MASK GENMASK(15, 8)
2880 #define B_AX_WMAC_SPEC_SIFS_CCK_MASK GENMASK(7, 0)
2881 #define WMAC_SPEC_SIFS_OFDM_52A 0x15
2882 #define WMAC_SPEC_SIFS_OFDM_52B 0x11
2883 #define WMAC_SPEC_SIFS_OFDM_52C 0x11
2884 #define WMAC_SPEC_SIFS_CCK	 0xA
2885 
2886 #define R_AX_TRXPTCL_RRSR_CTL_0 0xCC08
2887 #define R_AX_TRXPTCL_RRSR_CTL_0_C1 0xEC08
2888 #define B_AX_RESP_TX_MACID_CCA_TH_EN BIT(31)
2889 #define B_AX_RESP_TX_PWRMODE_MASK GENMASK(30, 28)
2890 #define B_AX_FTM_RRSR_RATE_EN_MASK GENMASK(27, 24)
2891 #define B_AX_NESS_MASK GENMASK(23, 22)
2892 #define B_AX_WMAC_RESP_DOPPLEB_AX_EN BIT(21)
2893 #define B_AX_WMAC_RESP_DCM_EN BIT(20)
2894 #define B_AX_WMAC_RRSB_AX_CCK_MASK GENMASK(19, 16)
2895 #define B_AX_WMAC_RESP_RATE_EN_MASK GENMASK(15, 12)
2896 #define B_AX_WMAC_RESP_RSC_MASK GENMASK(11, 10)
2897 #define B_AX_WMAC_RESP_REF_RATE_SEL BIT(9)
2898 #define B_AX_WMAC_RESP_REF_RATE_MASK GENMASK(8, 0)
2899 
2900 #define R_AX_MAC_LOOPBACK 0xCC20
2901 #define R_AX_MAC_LOOPBACK_C1 0xEC20
2902 #define B_AX_MACLBK_EN BIT(0)
2903 
2904 #define R_AX_WMAC_NAV_CTL 0xCC80
2905 #define R_AX_WMAC_NAV_CTL_C1 0xEC80
2906 #define B_AX_WMAC_NAV_UPPER_EN BIT(26)
2907 #define B_AX_WMAC_0P125US_TIMER_MASK GENMASK(25, 18)
2908 #define B_AX_WMAC_PLCP_UP_NAV_EN BIT(17)
2909 #define B_AX_WMAC_TF_UP_NAV_EN BIT(16)
2910 #define B_AX_WMAC_NAV_UPPER_MASK GENMASK(15, 8)
2911 #define NAV_12MS 0xBC
2912 #define NAV_25MS 0xC4
2913 #define B_AX_WMAC_RTS_RST_DUR_MASK GENMASK(7, 0)
2914 
2915 #define R_AX_RXTRIG_TEST_USER_2 0xCCB0
2916 #define R_AX_RXTRIG_TEST_USER_2_C1 0xECB0
2917 #define B_AX_RXTRIG_MACID_MASK GENMASK(31, 24)
2918 #define B_AX_RXTRIG_RU26_DIS BIT(21)
2919 #define B_AX_RXTRIG_FCSCHK_EN BIT(20)
2920 #define B_AX_RXTRIG_PORT_SEL_MASK GENMASK(19, 17)
2921 #define B_AX_RXTRIG_EN BIT(16)
2922 #define B_AX_RXTRIG_USERINFO_2_MASK GENMASK(15, 0)
2923 
2924 #define R_AX_TRXPTCL_ERROR_INDICA_MASK 0xCCBC
2925 #define R_AX_TRXPTCL_ERROR_INDICA_MASK_C1 0xECBC
2926 #define B_AX_WMAC_MODE BIT(22)
2927 #define B_AX_WMAC_TIMETOUT_THR_MASK GENMASK(21, 16)
2928 #define B_AX_RMAC_FTM BIT(8)
2929 #define B_AX_RMAC_CSI BIT(7)
2930 #define B_AX_TMAC_MIMO_CTRL BIT(6)
2931 #define B_AX_TMAC_RXTB BIT(5)
2932 #define B_AX_TMAC_HWSIGB_GEN BIT(4)
2933 #define B_AX_TMAC_TXPLCP BIT(3)
2934 #define B_AX_TMAC_RESP BIT(2)
2935 #define B_AX_TMAC_TXCTL BIT(1)
2936 #define B_AX_TMAC_MACTX BIT(0)
2937 #define B_AX_TMAC_IMR_CLR_V1 (B_AX_TMAC_MACTX | \
2938 			      B_AX_TMAC_TXCTL | \
2939 			      B_AX_TMAC_RESP | \
2940 			      B_AX_TMAC_TXPLCP | \
2941 			      B_AX_TMAC_HWSIGB_GEN | \
2942 			      B_AX_TMAC_RXTB | \
2943 			      B_AX_TMAC_MIMO_CTRL | \
2944 			      B_AX_RMAC_CSI | \
2945 			      B_AX_RMAC_FTM)
2946 #define B_AX_TMAC_IMR_SET_V1 (B_AX_TMAC_MACTX | \
2947 			      B_AX_TMAC_TXCTL | \
2948 			      B_AX_TMAC_RESP | \
2949 			      B_AX_TMAC_TXPLCP | \
2950 			      B_AX_TMAC_HWSIGB_GEN | \
2951 			      B_AX_TMAC_RXTB | \
2952 			      B_AX_TMAC_MIMO_CTRL | \
2953 			      B_AX_RMAC_FTM)
2954 
2955 #define R_AX_TRXPTCL_ERROR_INDICA 0xCCC0
2956 #define R_AX_TRXPTCL_ERROR_INDICA_C1 0xECC0
2957 #define B_AX_FTM_ERROR_FLAG_CLR BIT(8)
2958 #define B_AX_CSI_ERROR_FLAG_CLR BIT(7)
2959 #define B_AX_MIMOCTRL_ERROR_FLAG_CLR BIT(6)
2960 #define B_AX_RXTB_ERROR_FLAG_CLR BIT(5)
2961 #define B_AX_HWSIGB_GEN_ERROR_FLAG_CLR BIT(4)
2962 #define B_AX_TXPLCP_ERROR_FLAG_CLR BIT(3)
2963 #define B_AX_RESP_ERROR_FLAG_CLR BIT(2)
2964 #define B_AX_TXCTL_ERROR_FLAG_CLR BIT(1)
2965 #define B_AX_MACTX_ERROR_FLAG_CLR BIT(0)
2966 
2967 #define R_AX_WMAC_TX_TF_INFO_0 0xCCD0
2968 #define R_AX_WMAC_TX_TF_INFO_0_C1 0xECD0
2969 #define B_AX_WMAC_TX_TF_INFO_SEL_MASK GENMASK(2, 0)
2970 
2971 #define R_AX_WMAC_TX_TF_INFO_1 0xCCD4
2972 #define R_AX_WMAC_TX_TF_INFO_1_C1 0xECD4
2973 #define B_AX_WMAC_TX_TF_INFO_P0_MASK GENMASK(31, 0)
2974 
2975 #define R_AX_WMAC_TX_TF_INFO_2 0xCCD8
2976 #define R_AX_WMAC_TX_TF_INFO_2_C1 0xECD8
2977 #define B_AX_WMAC_TX_TF_INFO_P1_MASK GENMASK(31, 0)
2978 
2979 #define R_AX_TMAC_ERR_IMR_ISR 0xCCEC
2980 #define R_AX_TMAC_ERR_IMR_ISR_C1 0xECEC
2981 #define B_AX_TMAC_TXPLCP_ERR_CLR BIT(19)
2982 #define B_AX_TMAC_RESP_ERR_CLR BIT(18)
2983 #define B_AX_TMAC_TXCTL_ERR_CLR BIT(17)
2984 #define B_AX_TMAC_MACTX_ERR_CLR BIT(16)
2985 #define B_AX_TMAC_TXPLCP_ERR BIT(14)
2986 #define B_AX_TMAC_RESP_ERR BIT(13)
2987 #define B_AX_TMAC_TXCTL_ERR BIT(12)
2988 #define B_AX_TMAC_MACTX_ERR BIT(11)
2989 #define B_AX_TMAC_TXPLCP_INT_EN BIT(10)
2990 #define B_AX_TMAC_RESP_INT_EN BIT(9)
2991 #define B_AX_TMAC_TXCTL_INT_EN BIT(8)
2992 #define B_AX_TMAC_MACTX_INT_EN BIT(7)
2993 #define B_AX_WMAC_INT_MODE BIT(6)
2994 #define B_AX_TMAC_TIMETOUT_THR_MASK GENMASK(5, 0)
2995 #define B_AX_TMAC_IMR_CLR (B_AX_TMAC_MACTX_INT_EN | \
2996 			   B_AX_TMAC_TXCTL_INT_EN | \
2997 			   B_AX_TMAC_RESP_INT_EN | \
2998 			   B_AX_TMAC_TXPLCP_INT_EN)
2999 #define B_AX_TMAC_IMR_SET (B_AX_TMAC_MACTX_INT_EN | \
3000 			   B_AX_TMAC_TXCTL_INT_EN | \
3001 			   B_AX_TMAC_RESP_INT_EN | \
3002 			   B_AX_TMAC_TXPLCP_INT_EN)
3003 
3004 #define R_AX_DBGSEL_TRXPTCL 0xCCF4
3005 #define R_AX_DBGSEL_TRXPTCL_C1 0xECF4
3006 #define B_AX_DBGSEL_TRXPTCL_MASK GENMASK(7, 0)
3007 
3008 #define R_AX_PHYINFO_ERR_IMR_V1 0xCCF8
3009 #define R_AX_PHYINFO_ERR_IMR_V1_C1 0xECF8
3010 #define B_AX_PHYINTF_TIMEOUT_THR_MSAK_V1 GENMASK(21, 16)
3011 #define B_AX_CSI_ON_TIMEOUT_EN BIT(5)
3012 #define B_AX_STS_ON_TIMEOUT_EN BIT(4)
3013 #define B_AX_DATA_ON_TIMEOUT_EN BIT(3)
3014 #define B_AX_OFDM_CCA_TIMEOUT_EN BIT(2)
3015 #define B_AX_CCK_CCA_TIMEOUT_EN BIT(1)
3016 #define B_AX_PHY_TXON_TIMEOUT_EN BIT(0)
3017 #define B_AX_PHYINFO_IMR_CLR_V1 (B_AX_PHY_TXON_TIMEOUT_EN | \
3018 				 B_AX_CCK_CCA_TIMEOUT_EN | \
3019 				 B_AX_OFDM_CCA_TIMEOUT_EN | \
3020 				 B_AX_DATA_ON_TIMEOUT_EN | \
3021 				 B_AX_STS_ON_TIMEOUT_EN | \
3022 				 B_AX_CSI_ON_TIMEOUT_EN)
3023 #define B_AX_PHYINFO_IMR_SET_V1 (B_AX_PHY_TXON_TIMEOUT_EN | \
3024 				 B_AX_CCK_CCA_TIMEOUT_EN | \
3025 				 B_AX_OFDM_CCA_TIMEOUT_EN | \
3026 				 B_AX_DATA_ON_TIMEOUT_EN | \
3027 				 B_AX_STS_ON_TIMEOUT_EN | \
3028 				 B_AX_CSI_ON_TIMEOUT_EN)
3029 
3030 #define R_AX_PHYINFO_ERR_IMR 0xCCFC
3031 #define R_AX_PHYINFO_ERR_IMR_C1 0xECFC
3032 #define B_AX_CSI_ON_TIMEOUT BIT(29)
3033 #define B_AX_STS_ON_TIMEOUT BIT(28)
3034 #define B_AX_DATA_ON_TIMEOUT BIT(27)
3035 #define B_AX_OFDM_CCA_TIMEOUT BIT(26)
3036 #define B_AX_CCK_CCA_TIMEOUT BIT(25)
3037 #define B_AXC_PHY_TXON_TIMEOUT BIT(24)
3038 #define B_AX_CSI_ON_TIMEOUT_INT_EN BIT(21)
3039 #define B_AX_STS_ON_TIMEOUT_INT_EN BIT(20)
3040 #define B_AX_DATA_ON_TIMEOUT_INT_EN BIT(19)
3041 #define B_AX_OFDM_CCA_TIMEOUT_INT_EN BIT(18)
3042 #define B_AX_CCK_CCA_TIMEOUT_INT_EN BIT(17)
3043 #define B_AX_PHY_TXON_TIMEOUT_INT_EN BIT(16)
3044 #define B_AX_PHYINTF_TIMEOUT_THR_MSAK GENMASK(5, 0)
3045 #define B_AX_PHYINFO_IMR_EN_ALL (B_AX_PHY_TXON_TIMEOUT_INT_EN | \
3046 				 B_AX_CCK_CCA_TIMEOUT_INT_EN | \
3047 				 B_AX_OFDM_CCA_TIMEOUT_INT_EN | \
3048 				 B_AX_DATA_ON_TIMEOUT_INT_EN | \
3049 				 B_AX_STS_ON_TIMEOUT_INT_EN | \
3050 				 B_AX_CSI_ON_TIMEOUT_INT_EN)
3051 
3052 #define R_AX_PHYINFO_ERR_ISR 0xCCFC
3053 #define R_AX_PHYINFO_ERR_ISR_C1 0xECFC
3054 
3055 #define R_AX_BFMER_CTRL_0 0xCD78
3056 #define R_AX_BFMER_CTRL_0_C1 0xED78
3057 #define B_AX_BFMER_HE_CSI_OFFSET_MASK GENMASK(31, 24)
3058 #define B_AX_BFMER_VHT_CSI_OFFSET_MASK GENMASK(23, 16)
3059 #define B_AX_BFMER_HT_CSI_OFFSET_MASK GENMASK(15, 8)
3060 #define B_AX_BFMER_NDP_BFEN BIT(2)
3061 #define B_AX_BFMER_VHT_BFPRT_CHK BIT(0)
3062 
3063 #define R_AX_BFMEE_RESP_OPTION 0xCD80
3064 #define R_AX_BFMEE_RESP_OPTION_C1 0xED80
3065 #define B_AX_BFMEE_NDP_RX_STANDBY_TIMER_MASK GENMASK(31, 24)
3066 #define B_AX_BFMEE_BFRP_RX_STANDBY_TIMER_MASK GENMASK(23, 20)
3067 #define BFRP_RX_STANDBY_TIMER_KEEP 0x0
3068 #define BFRP_RX_STANDBY_TIMER_RELEASE 0x1
3069 #define B_AX_MU_BFRPTSEG_SEL_MASK GENMASK(18, 17)
3070 #define B_AX_BFMEE_NDP_RXSTDBY_SEL BIT(16)
3071 #define BFRP_RX_STANDBY_TIMER		0x0
3072 #define NDP_RX_STANDBY_TIMER		0xFF
3073 #define B_AX_BFMEE_HE_NDPA_EN BIT(2)
3074 #define B_AX_BFMEE_VHT_NDPA_EN BIT(1)
3075 #define B_AX_BFMEE_HT_NDPA_EN BIT(0)
3076 
3077 #define R_AX_TRXPTCL_RESP_CSI_CTRL_0 0xCD88
3078 #define R_AX_TRXPTCL_RESP_CSI_CTRL_0_C1 0xED88
3079 #define R_AX_TRXPTCL_RESP_CSI_CTRL_1 0xCD94
3080 #define R_AX_TRXPTCL_RESP_CSI_CTRL_1_C1 0xED94
3081 #define B_AX_BFMEE_CSISEQ_SEL BIT(29)
3082 #define B_AX_BFMEE_BFPARAM_SEL BIT(28)
3083 #define B_AX_BFMEE_OFDM_LEN_TH_MASK GENMASK(27, 24)
3084 #define B_AX_BFMEE_BF_PORT_SEL BIT(23)
3085 #define B_AX_BFMEE_USE_NSTS BIT(22)
3086 #define B_AX_BFMEE_CSI_RATE_FB_EN BIT(21)
3087 #define B_AX_BFMEE_CSI_GID_SEL BIT(20)
3088 #define B_AX_BFMEE_CSI_RSC_MASK GENMASK(19, 18)
3089 #define B_AX_BFMEE_CSI_FORCE_RETE_EN BIT(17)
3090 #define B_AX_BFMEE_CSI_USE_NDPARATE BIT(16)
3091 #define B_AX_BFMEE_CSI_WITHHTC_EN BIT(15)
3092 #define B_AX_BFMEE_CSIINFO0_BF_EN BIT(14)
3093 #define B_AX_BFMEE_CSIINFO0_STBC_EN BIT(13)
3094 #define B_AX_BFMEE_CSIINFO0_LDPC_EN BIT(12)
3095 #define B_AX_BFMEE_CSIINFO0_CS_MASK GENMASK(11, 10)
3096 #define B_AX_BFMEE_CSIINFO0_CB_MASK GENMASK(9, 8)
3097 #define B_AX_BFMEE_CSIINFO0_NG_MASK GENMASK(7, 6)
3098 #define B_AX_BFMEE_CSIINFO0_NR_MASK GENMASK(5, 3)
3099 #define B_AX_BFMEE_CSIINFO0_NC_MASK GENMASK(2, 0)
3100 
3101 #define R_AX_TRXPTCL_RESP_CSI_RRSC 0xCD8C
3102 #define R_AX_TRXPTCL_RESP_CSI_RRSC_C1 0xED8C
3103 #define CSI_RRSC_BMAP 0x29292911
3104 
3105 #define R_AX_TRXPTCL_RESP_CSI_RATE 0xCD90
3106 #define R_AX_TRXPTCL_RESP_CSI_RATE_C1 0xED90
3107 #define B_AX_BFMEE_HE_CSI_RATE_MASK GENMASK(22, 16)
3108 #define B_AX_BFMEE_VHT_CSI_RATE_MASK GENMASK(14, 8)
3109 #define B_AX_BFMEE_HT_CSI_RATE_MASK GENMASK(6, 0)
3110 #define CSI_INIT_RATE_HE		0x3
3111 #define CSI_INIT_RATE_VHT		0x3
3112 #define CSI_INIT_RATE_HT		0x3
3113 
3114 #define R_AX_RCR 0xCE00
3115 #define R_AX_RCR_C1 0xEE00
3116 #define B_AX_STOP_RX_IN BIT(11)
3117 #define B_AX_DRV_INFO_SIZE_MASK GENMASK(10, 8)
3118 #define B_AX_CH_EN_MASK GENMASK(3, 0)
3119 
3120 #define R_AX_DLK_PROTECT_CTL 0xCE02
3121 #define R_AX_DLK_PROTECT_CTL_C1 0xEE02
3122 #define B_AX_RX_DLK_CCA_TIME_MASK GENMASK(15, 8)
3123 #define B_AX_RX_DLK_DATA_TIME_MASK GENMASK(7, 4)
3124 
3125 #define R_AX_PLCP_HDR_FLTR 0xCE04
3126 #define R_AX_PLCP_HDR_FLTR_C1 0xEE04
3127 #define B_AX_DIS_CHK_MIN_LEN BIT(8)
3128 #define B_AX_HE_SIGB_CRC_CHK BIT(6)
3129 #define B_AX_VHT_MU_SIGB_CRC_CHK BIT(5)
3130 #define B_AX_VHT_SU_SIGB_CRC_CHK BIT(4)
3131 #define B_AX_SIGA_CRC_CHK BIT(3)
3132 #define B_AX_LSIG_PARITY_CHK_EN BIT(2)
3133 #define B_AX_CCK_SIG_CHK BIT(1)
3134 #define B_AX_CCK_CRC_CHK BIT(0)
3135 
3136 #define R_AX_RX_FLTR_OPT 0xCE20
3137 #define R_AX_RX_FLTR_OPT_C1 0xEE20
3138 #define B_AX_UID_FILTER_MASK GENMASK(31, 24)
3139 #define B_AX_UNSPT_FILTER_SH 22
3140 #define B_AX_UNSPT_FILTER_MASK GENMASK(23, 22)
3141 #define B_AX_RX_MPDU_MAX_LEN_MASK GENMASK(21, 16)
3142 #define B_AX_RX_MPDU_MAX_LEN_SIZE 0x3f
3143 #define B_AX_A_FTM_REQ BIT(14)
3144 #define B_AX_A_ERR_PKT BIT(13)
3145 #define B_AX_A_UNSUP_PKT BIT(12)
3146 #define B_AX_A_CRC32_ERR BIT(11)
3147 #define B_AX_A_PWR_MGNT BIT(10)
3148 #define B_AX_A_BCN_CHK_RULE_MASK GENMASK(9, 8)
3149 #define B_AX_A_BCN_CHK_EN BIT(7)
3150 #define B_AX_A_MC_LIST_CAM_MATCH BIT(6)
3151 #define B_AX_A_BC_CAM_MATCH BIT(5)
3152 #define B_AX_A_UC_CAM_MATCH BIT(4)
3153 #define B_AX_A_MC BIT(3)
3154 #define B_AX_A_BC BIT(2)
3155 #define B_AX_A_A1_MATCH BIT(1)
3156 #define B_AX_SNIFFER_MODE BIT(0)
3157 #define DEFAULT_AX_RX_FLTR (B_AX_A_A1_MATCH | B_AX_A_BC | B_AX_A_MC |	       \
3158 			    B_AX_A_UC_CAM_MATCH | B_AX_A_BC_CAM_MATCH |	       \
3159 			    B_AX_A_PWR_MGNT | B_AX_A_FTM_REQ |		       \
3160 			    u32_encode_bits(3, B_AX_UID_FILTER_MASK) |	       \
3161 			    B_AX_A_BCN_CHK_EN)
3162 #define B_AX_RX_FLTR_CFG_MASK ((u32)~B_AX_RX_MPDU_MAX_LEN_MASK)
3163 
3164 #define R_AX_CTRL_FLTR 0xCE24
3165 #define R_AX_CTRL_FLTR_C1 0xEE24
3166 #define R_AX_MGNT_FLTR 0xCE28
3167 #define R_AX_MGNT_FLTR_C1 0xEE28
3168 #define R_AX_DATA_FLTR 0xCE2C
3169 #define R_AX_DATA_FLTR_C1 0xEE2C
3170 #define RX_FLTR_FRAME_DROP	0x00000000
3171 #define RX_FLTR_FRAME_TO_HOST	0x55555555
3172 #define RX_FLTR_FRAME_TO_WLCPU	0xAAAAAAAA
3173 
3174 #define R_AX_ADDR_CAM_CTRL 0xCE34
3175 #define R_AX_ADDR_CAM_CTRL_C1 0xEE34
3176 #define B_AX_ADDR_CAM_RANGE_MASK GENMASK(23, 16)
3177 #define B_AX_ADDR_CAM_CMPLIMT_MASK GENMASK(15, 12)
3178 #define B_AX_ADDR_CAM_CLR BIT(8)
3179 #define B_AX_ADDR_CAM_A2_B0_CHK BIT(2)
3180 #define B_AX_ADDR_CAM_SRCH_PERPKT BIT(1)
3181 #define B_AX_ADDR_CAM_EN BIT(0)
3182 
3183 #define R_AX_RESPBA_CAM_CTRL 0xCE3C
3184 #define R_AX_RESPBA_CAM_CTRL_C1 0xEE3C
3185 #define B_AX_SSN_SEL BIT(2)
3186 #define B_AX_BACAM_RST_MASK GENMASK(1, 0)
3187 #define S_AX_BACAM_RST_ALL 2
3188 
3189 #define R_AX_PPDU_STAT 0xCE40
3190 #define R_AX_PPDU_STAT_C1 0xEE40
3191 #define B_AX_PPDU_STAT_RPT_TRIG BIT(8)
3192 #define B_AX_PPDU_STAT_RPT_CRC32 BIT(5)
3193 #define B_AX_PPDU_STAT_RPT_A1M BIT(4)
3194 #define B_AX_APP_PLCP_HDR_RPT BIT(3)
3195 #define B_AX_APP_RX_CNT_RPT BIT(2)
3196 #define B_AX_APP_MAC_INFO_RPT BIT(1)
3197 #define B_AX_PPDU_STAT_RPT_EN BIT(0)
3198 
3199 #define R_AX_RX_SR_CTRL 0xCE4A
3200 #define R_AX_RX_SR_CTRL_C1 0xEE4A
3201 #define B_AX_SR_EN BIT(0)
3202 
3203 #define R_AX_CSIRPT_OPTION 0xCE64
3204 #define R_AX_CSIRPT_OPTION_C1 0xEE64
3205 #define B_AX_CSIPRT_HESU_AID_EN BIT(25)
3206 #define B_AX_CSIPRT_VHTSU_AID_EN BIT(24)
3207 
3208 #define R_AX_RX_STATE_MONITOR 0xCEF0
3209 #define R_AX_RX_STATE_MONITOR_C1 0xEEF0
3210 #define B_AX_RX_STATE_MONITOR_MASK GENMASK(31, 0)
3211 #define B_AX_STATE_CUR_MASK GENMASK(31, 16)
3212 #define B_AX_STATE_NXT_MASK GENMASK(13, 8)
3213 #define B_AX_STATE_UPD BIT(7)
3214 #define B_AX_STATE_SEL_MASK GENMASK(4, 0)
3215 
3216 #define R_AX_RMAC_ERR_ISR 0xCEF4
3217 #define R_AX_RMAC_ERR_ISR_C1 0xEEF4
3218 #define B_AX_RXERR_INTPS_EN BIT(31)
3219 #define B_AX_RMAC_RX_CSI_TIMEOUT_INT_EN BIT(19)
3220 #define B_AX_RMAC_RX_TIMEOUT_INT_EN BIT(18)
3221 #define B_AX_RMAC_CSI_TIMEOUT_INT_EN BIT(17)
3222 #define B_AX_RMAC_DATA_ON_TIMEOUT_INT_EN BIT(16)
3223 #define B_AX_RMAC_CCA_TIMEOUT_INT_EN BIT(15)
3224 #define B_AX_RMAC_DMA_TIMEOUT_INT_EN BIT(14)
3225 #define B_AX_RMAC_DATA_ON_TO_IDLE_TIMEOUT_INT_EN BIT(13)
3226 #define B_AX_RMAC_CCA_TO_IDLE_TIMEOUT_INT_EN BIT(12)
3227 #define B_AX_RMAC_RX_CSI_TIMEOUT_FLAG BIT(7)
3228 #define B_AX_RMAC_RX_TIMEOUT_FLAG BIT(6)
3229 #define B_AX_BMAC_CSI_TIMEOUT_FLAG BIT(5)
3230 #define B_AX_BMAC_DATA_ON_TIMEOUT_FLAG BIT(4)
3231 #define B_AX_BMAC_CCA_TIMEOUT_FLAG BIT(3)
3232 #define B_AX_BMAC_DMA_TIMEOUT_FLAG BIT(2)
3233 #define B_AX_BMAC_DATA_ON_TO_IDLE_TIMEOUT_FLAG BIT(1)
3234 #define B_AX_BMAC_CCA_TO_IDLE_TIMEOUT_FLAG BIT(0)
3235 #define B_AX_RMAC_IMR_CLR (B_AX_RMAC_CCA_TO_IDLE_TIMEOUT_INT_EN | \
3236 			   B_AX_RMAC_DATA_ON_TO_IDLE_TIMEOUT_INT_EN | \
3237 			   B_AX_RMAC_DMA_TIMEOUT_INT_EN | \
3238 			   B_AX_RMAC_CCA_TIMEOUT_INT_EN | \
3239 			   B_AX_RMAC_DATA_ON_TIMEOUT_INT_EN | \
3240 			   B_AX_RMAC_CSI_TIMEOUT_INT_EN | \
3241 			   B_AX_RMAC_RX_TIMEOUT_INT_EN | \
3242 			   B_AX_RMAC_RX_CSI_TIMEOUT_INT_EN)
3243 #define B_AX_RMAC_IMR_SET (B_AX_RMAC_DMA_TIMEOUT_INT_EN | \
3244 			   B_AX_RMAC_CSI_TIMEOUT_INT_EN | \
3245 			   B_AX_RMAC_RX_TIMEOUT_INT_EN | \
3246 			   B_AX_RMAC_RX_CSI_TIMEOUT_INT_EN)
3247 
3248 #define R_AX_RX_ERR_IMR 0xCEF8
3249 #define R_AX_RX_ERR_IMR_C1 0xEEF8
3250 #define B_AX_RX_ERR_TRIG_ACT_TO_MSK BIT(9)
3251 #define B_AX_RX_ERR_STS_ACT_TO_MSK BIT(8)
3252 #define B_AX_RX_ERR_CSI_ACT_TO_MSK BIT(7)
3253 #define B_AX_RX_ERR_ACT_TO_MSK BIT(6)
3254 #define B_AX_CSI_DATAON_ASSERT_TO_MSK BIT(5)
3255 #define B_AX_DATAON_ASSERT_TO_MSK BIT(4)
3256 #define B_AX_CCA_ASSERT_TO_MSK BIT(3)
3257 #define B_AX_RX_ERR_DMA_TO_MSK BIT(2)
3258 #define B_AX_RX_ERR_DATA_TO_MSK BIT(1)
3259 #define B_AX_RX_ERR_CCA_TO_MSK BIT(0)
3260 #define B_AX_RMAC_IMR_CLR_V1 (B_AX_RX_ERR_CCA_TO_MSK | \
3261 			      B_AX_RX_ERR_DATA_TO_MSK | \
3262 			      B_AX_RX_ERR_DMA_TO_MSK | \
3263 			      B_AX_CCA_ASSERT_TO_MSK | \
3264 			      B_AX_DATAON_ASSERT_TO_MSK | \
3265 			      B_AX_CSI_DATAON_ASSERT_TO_MSK | \
3266 			      B_AX_RX_ERR_ACT_TO_MSK | \
3267 			      B_AX_RX_ERR_CSI_ACT_TO_MSK | \
3268 			      B_AX_RX_ERR_STS_ACT_TO_MSK | \
3269 			      B_AX_RX_ERR_TRIG_ACT_TO_MSK)
3270 #define B_AX_RMAC_IMR_SET_V1 (B_AX_RX_ERR_CCA_TO_MSK | \
3271 			      B_AX_RX_ERR_DATA_TO_MSK | \
3272 			      B_AX_RX_ERR_DMA_TO_MSK | \
3273 			      B_AX_CCA_ASSERT_TO_MSK | \
3274 			      B_AX_DATAON_ASSERT_TO_MSK | \
3275 			      B_AX_CSI_DATAON_ASSERT_TO_MSK | \
3276 			      B_AX_RX_ERR_ACT_TO_MSK | \
3277 			      B_AX_RX_ERR_CSI_ACT_TO_MSK | \
3278 			      B_AX_RX_ERR_STS_ACT_TO_MSK | \
3279 			      B_AX_RX_ERR_TRIG_ACT_TO_MSK)
3280 
3281 #define R_AX_RMAC_PLCP_MON 0xCEF8
3282 #define R_AX_RMAC_PLCP_MON_C1 0xEEF8
3283 #define B_AX_RMAC_PLCP_MON_MASK GENMASK(31, 0)
3284 #define B_AX_PCLP_MON_SEL_MASK GENMASK(31, 28)
3285 #define B_AX_PCLP_MON_CONT_MASK GENMASK(27, 0)
3286 
3287 #define R_AX_RX_DEBUG_SELECT 0xCEFC
3288 #define R_AX_RX_DEBUG_SELECT_C1 0xEEFC
3289 #define B_AX_DEBUG_SEL_MASK GENMASK(7, 0)
3290 
3291 #define R_AX_PWR_RATE_CTRL 0xD200
3292 #define R_AX_PWR_RATE_CTRL_C1 0xF200
3293 #define B_AX_PWR_REF GENMASK(27, 10)
3294 #define B_AX_FORCE_PWR_BY_RATE_EN BIT(9)
3295 #define B_AX_FORCE_PWR_BY_RATE_VALUE_MASK GENMASK(8, 0)
3296 
3297 #define R_AX_PWR_RATE_OFST_CTRL 0xD204
3298 #define R_AX_PWR_COEXT_CTRL 0xD220
3299 #define B_AX_TXAGC_BT_EN BIT(1)
3300 #define B_AX_TXAGC_BT_MASK GENMASK(11, 3)
3301 
3302 #define R_AX_PWR_UL_CTRL0 0xD240
3303 #define R_AX_PWR_UL_CTRL2 0xD248
3304 #define B_AX_PWR_UL_CFO_MASK GENMASK(2, 0)
3305 #define B_AX_PWR_UL_CTRL2_MASK 0x07700007
3306 #define R_AX_PWR_UL_TB_CTRL 0xD288
3307 #define B_AX_PWR_UL_TB_CTRL_EN BIT(31)
3308 #define R_AX_PWR_UL_TB_1T 0xD28C
3309 #define B_AX_PWR_UL_TB_1T_MASK GENMASK(4, 0)
3310 #define B_AX_PWR_UL_TB_1T_V1_MASK GENMASK(7, 0)
3311 #define R_AX_PWR_UL_TB_2T 0xD290
3312 #define B_AX_PWR_UL_TB_2T_MASK GENMASK(4, 0)
3313 #define B_AX_PWR_UL_TB_2T_V1_MASK GENMASK(7, 0)
3314 #define R_AX_PWR_BY_RATE_TABLE0 0xD2C0
3315 #define R_AX_PWR_BY_RATE_TABLE10 0xD2E8
3316 #define R_AX_PWR_BY_RATE R_AX_PWR_BY_RATE_TABLE0
3317 #define R_AX_PWR_BY_RATE_MAX R_AX_PWR_BY_RATE_TABLE10
3318 #define R_AX_PWR_LMT_TABLE0 0xD2EC
3319 #define R_AX_PWR_LMT_TABLE19 0xD338
3320 #define R_AX_PWR_LMT R_AX_PWR_LMT_TABLE0
3321 #define R_AX_PWR_LMT_MAX R_AX_PWR_LMT_TABLE19
3322 #define R_AX_PWR_RU_LMT_TABLE0 0xD33C
3323 #define R_AX_PWR_RU_LMT_TABLE11 0xD368
3324 #define R_AX_PWR_RU_LMT R_AX_PWR_RU_LMT_TABLE0
3325 #define R_AX_PWR_RU_LMT_MAX R_AX_PWR_RU_LMT_TABLE11
3326 #define R_AX_PWR_MACID_LMT_TABLE0 0xD36C
3327 #define R_AX_PWR_MACID_LMT_TABLE127 0xD568
3328 
3329 #define R_AX_PATH_COM0 0xD800
3330 #define AX_PATH_COM0_DFVAL 0x00000000
3331 #define AX_PATH_COM0_PATHA 0x08889880
3332 #define AX_PATH_COM0_PATHB 0x11111900
3333 #define AX_PATH_COM0_PATHAB 0x19999980
3334 #define R_AX_PATH_COM1 0xD804
3335 #define AX_PATH_COM1_DFVAL 0x00000000
3336 #define AX_PATH_COM1_PATHA 0x13111111
3337 #define AX_PATH_COM1_PATHB 0x23222222
3338 #define AX_PATH_COM1_PATHAB 0x33333333
3339 #define R_AX_PATH_COM2 0xD808
3340 #define AX_PATH_COM2_DFVAL 0x00000000
3341 #define AX_PATH_COM2_PATHA 0x01209313
3342 #define AX_PATH_COM2_PATHB 0x01209323
3343 #define AX_PATH_COM2_PATHAB 0x01209333
3344 #define R_AX_PATH_COM3 0xD80C
3345 #define AX_PATH_COM3_DFVAL 0x49249249
3346 #define R_AX_PATH_COM4 0xD810
3347 #define AX_PATH_COM4_DFVAL 0x1C9C9C49
3348 #define R_AX_PATH_COM5 0xD814
3349 #define AX_PATH_COM5_DFVAL 0x39393939
3350 #define R_AX_PATH_COM6 0xD818
3351 #define AX_PATH_COM6_DFVAL 0x39393939
3352 #define R_AX_PATH_COM7 0xD81C
3353 #define AX_PATH_COM7_DFVAL 0x39393939
3354 #define AX_PATH_COM7_PATHA 0x39393939
3355 #define AX_PATH_COM7_PATHB 0x39383939
3356 #define AX_PATH_COM7_PATHAB 0x39393939
3357 #define R_AX_PATH_COM8 0xD820
3358 #define AX_PATH_COM8_DFVAL 0x00000000
3359 #define AX_PATH_COM8_PATHA 0x00003939
3360 #define AX_PATH_COM8_PATHB 0x00003938
3361 #define AX_PATH_COM8_PATHAB 0x00003939
3362 #define R_AX_PATH_COM9 0xD824
3363 #define AX_PATH_COM9_DFVAL 0x000007C0
3364 #define R_AX_PATH_COM10 0xD828
3365 #define AX_PATH_COM10_DFVAL 0xE0000000
3366 #define R_AX_PATH_COM11 0xD82C
3367 #define AX_PATH_COM11_DFVAL 0x00000000
3368 #define R_P80_AT_HIGH_FREQ_BB_WRP 0xD848
3369 #define B_P80_AT_HIGH_FREQ_BB_WRP BIT(28)
3370 #define R_AX_TSSI_CTRL_HEAD 0xD908
3371 #define R_AX_BANDEDGE_CFG 0xD94C
3372 #define B_AX_BANDEDGE_CFG_IDX_MASK GENMASK(31, 30)
3373 #define R_AX_TSSI_CTRL_TAIL 0xD95C
3374 
3375 #define R_AX_TXPWR_IMR 0xD9E0
3376 #define R_AX_TXPWR_IMR_C1 0xF9E0
3377 #define R_AX_TXPWR_ISR 0xD9E4
3378 #define R_AX_TXPWR_ISR_C1 0xF9E4
3379 
3380 #define R_AX_BTC_CFG 0xDA00
3381 #define B_AX_BTC_EN BIT(31)
3382 #define B_AX_EN_EXT_BT_PINMUX BIT(29)
3383 #define B_AX_BTC_RST BIT(28)
3384 #define B_AX_BTC_DBG_SRC_SEL BIT(27)
3385 #define B_AX_BTC_MODE_MASK GENMASK(25, 24)
3386 #define B_AX_INV_WL_ACT2 BIT(17)
3387 #define B_AX_BTG_LNA1_GAIN_SEL BIT(16)
3388 #define B_AX_COEX_DLY_CLK_MASK GENMASK(15, 8)
3389 #define B_AX_IGN_GNT_BT2_RX BIT(7)
3390 #define B_AX_IGN_GNT_BT2_TX BIT(6)
3391 #define B_AX_IGN_GNT_BT2 BIT(5)
3392 #define B_AX_BTC_DBG_SEL_MASK GENMASK(4, 3)
3393 #define B_AX_DIS_BTC_CLK_G BIT(2)
3394 #define B_AX_GNT_WL_RX_CTRL BIT(1)
3395 #define B_AX_WL_SRC BIT(0)
3396 
3397 #define R_AX_RTK_MODE_CFG_V1 0xDA04
3398 #define R_AX_RTK_MODE_CFG_V1_C1 0xFA04
3399 #define B_AX_BT_BLE_EN_V1 BIT(24)
3400 #define B_AX_BT_ULTRA_EN BIT(16)
3401 #define B_AX_BT_L_RX_ULTRA_MASK GENMASK(15, 14)
3402 #define B_AX_BT_L_TX_ULTRA_MASK GENMASK(13, 12)
3403 #define B_AX_BT_H_RX_ULTRA_MASK GENMASK(11, 10)
3404 #define B_AX_BT_H_TX_ULTRA_MASK GENMASK(9, 8)
3405 #define B_AX_SAMPLE_CLK_MASK GENMASK(7, 0)
3406 
3407 #define R_AX_WL_PRI_MSK 0xDA10
3408 #define B_AX_PTA_WL_PRI_MASK_BCNQ BIT(8)
3409 
3410 #define R_AX_BT_CNT_CFG 0xDA10
3411 #define R_AX_BT_CNT_CFG_C1 0xFA10
3412 #define B_AX_BT_CNT_RST_V1 BIT(1)
3413 #define B_AX_BT_CNT_EN BIT(0)
3414 
3415 #define R_BTC_BT_CNT_HIGH 0xDA14
3416 #define R_BTC_BT_CNT_LOW 0xDA18
3417 
3418 #define R_AX_BTC_FUNC_EN 0xDA20
3419 #define R_AX_BTC_FUNC_EN_C1 0xFA20
3420 #define B_AX_PTA_WL_TX_EN BIT(1)
3421 #define B_AX_PTA_EDCCA_EN BIT(0)
3422 
3423 #define R_BTC_COEX_WL_REQ 0xDA24
3424 #define B_BTC_TX_BCN_HI BIT(22)
3425 #define B_BTC_RSP_ACK_HI BIT(10)
3426 
3427 #define R_BTC_BREAK_TABLE 0xDA2C
3428 #define BTC_BREAK_PARAM 0xf0ffffff
3429 
3430 #define R_BTC_BT_COEX_MSK_TABLE 0xDA30
3431 #define B_BTC_PRI_MASK_RXCCK_V1 BIT(28)
3432 #define B_BTC_PRI_MASK_TX_RESP_V1 BIT(3)
3433 
3434 #define R_AX_BT_COEX_CFG_2 0xDA34
3435 #define R_AX_BT_COEX_CFG_2_C1 0xFA34
3436 #define B_AX_GNT_BT_BYPASS_PRIORITY BIT(12)
3437 #define B_AX_GNT_BT_POLARITY BIT(8)
3438 #define B_AX_TIMER_MASK GENMASK(7, 0)
3439 #define MAC_AX_CSR_RATE 80
3440 
3441 #define R_AX_CSR_MODE 0xDA40
3442 #define R_AX_CSR_MODE_C1 0xFA40
3443 #define B_AX_BT_CNT_RST BIT(16)
3444 #define B_AX_BT_STAT_DELAY_MASK GENMASK(15, 12)
3445 #define MAC_AX_CSR_DELAY 0
3446 #define B_AX_BT_TRX_INIT_DETECT_MASK GENMASK(11, 8)
3447 #define MAC_AX_CSR_TRX_TO 4
3448 #define B_AX_BT_PRI_DETECT_TO_MASK GENMASK(7, 4)
3449 #define MAC_AX_CSR_PRI_TO 5
3450 #define B_AX_WL_ACT_MSK BIT(3)
3451 #define B_AX_STATIS_BT_EN BIT(2)
3452 #define B_AX_WL_ACT_MASK_ENABLE BIT(1)
3453 #define B_AX_ENHANCED_BT BIT(0)
3454 
3455 #define R_AX_BT_BREAK_TABLE 0xDA44
3456 
3457 #define R_AX_BT_STAST_HIGH 0xDA44
3458 #define B_AX_STATIS_BT_HI_RX_MASK GENMASK(31, 16)
3459 #define B_AX_STATIS_BT_HI_TX_MASK GENMASK(15, 0)
3460 #define R_AX_BT_STAST_LOW 0xDA48
3461 #define B_AX_STATIS_BT_LO_TX_1_MASK GENMASK(15, 0)
3462 #define B_AX_STATIS_BT_LO_RX_1_MASK GENMASK(31, 16)
3463 
3464 #define R_AX_GNT_SW_CTRL 0xDA48
3465 #define R_AX_GNT_SW_CTRL_C1 0xFA48
3466 #define B_AX_WL_ACT2_VAL BIT(21)
3467 #define B_AX_WL_ACT2_SWCTRL BIT(20)
3468 #define B_AX_WL_ACT_VAL BIT(19)
3469 #define B_AX_WL_ACT_SWCTRL BIT(18)
3470 #define B_AX_GNT_BT_RX_VAL BIT(17)
3471 #define B_AX_GNT_BT_RX_SWCTRL BIT(16)
3472 #define B_AX_GNT_BT_TX_VAL BIT(15)
3473 #define B_AX_GNT_BT_TX_SWCTRL BIT(14)
3474 #define B_AX_GNT_WL_RX_VAL BIT(13)
3475 #define B_AX_GNT_WL_RX_SWCTRL BIT(12)
3476 #define B_AX_GNT_WL_TX_VAL BIT(11)
3477 #define B_AX_GNT_WL_TX_SWCTRL BIT(10)
3478 #define B_AX_GNT_BT_RFC_S1_VAL BIT(9)
3479 #define B_AX_GNT_BT_RFC_S1_SWCTRL BIT(8)
3480 #define B_AX_GNT_WL_RFC_S1_VAL BIT(7)
3481 #define B_AX_GNT_WL_RFC_S1_SWCTRL BIT(6)
3482 #define B_AX_GNT_BT_RFC_S0_VAL BIT(5)
3483 #define B_AX_GNT_BT_RFC_S0_SWCTRL BIT(4)
3484 #define B_AX_GNT_WL_RFC_S0_VAL BIT(3)
3485 #define B_AX_GNT_WL_RFC_S0_SWCTRL BIT(2)
3486 #define B_AX_GNT_WL_BB_VAL BIT(1)
3487 #define B_AX_GNT_WL_BB_SWCTRL BIT(0)
3488 
3489 #define R_AX_GNT_VAL 0x0054
3490 #define B_AX_GNT_BT_RFC_S1_STA BIT(5)
3491 #define B_AX_GNT_WL_RFC_S1_STA BIT(4)
3492 #define B_AX_GNT_BT_RFC_S0_STA BIT(3)
3493 #define B_AX_GNT_WL_RFC_S0_STA BIT(2)
3494 
3495 #define R_AX_GNT_VAL_V1 0xDA4C
3496 #define B_AX_GNT_BT_RFC_S1 BIT(4)
3497 #define B_AX_GNT_BT_RFC_S0 BIT(3)
3498 #define B_AX_GNT_WL_RFC_S1 BIT(2)
3499 #define B_AX_GNT_WL_RFC_S0 BIT(1)
3500 
3501 #define R_AX_TDMA_MODE 0xDA4C
3502 #define R_AX_TDMA_MODE_C1 0xFA4C
3503 #define B_AX_R_BT_CMD_RPT_MASK GENMASK(31, 16)
3504 #define B_AX_R_RPT_FROM_BT_MASK GENMASK(15, 8)
3505 #define B_AX_BT_HID_ISR_SET_MASK GENMASK(7, 6)
3506 #define B_AX_TDMA_BT_START_NOTIFY BIT(5)
3507 #define B_AX_ENABLE_TDMA_FW_MODE BIT(4)
3508 #define B_AX_ENABLE_PTA_TDMA_MODE BIT(3)
3509 #define B_AX_ENABLE_COEXIST_TAB_IN_TDMA BIT(2)
3510 #define B_AX_GPIO2_GPIO3_EXANGE_OR_NO_BT_CCA BIT(1)
3511 #define B_AX_RTK_BT_ENABLE BIT(0)
3512 
3513 #define R_AX_BT_COEX_CFG_5 0xDA6C
3514 #define R_AX_BT_COEX_CFG_5_C1 0xFA6C
3515 #define B_AX_BT_TIME_MASK GENMASK(31, 6)
3516 #define B_AX_BT_RPT_SAMPLE_RATE_MASK GENMASK(5, 0)
3517 #define MAC_AX_RTK_RATE 5
3518 
3519 #define R_AX_LTE_CTRL 0xDAF0
3520 #define R_AX_LTE_WDATA 0xDAF4
3521 #define R_AX_LTE_RDATA 0xDAF8
3522 
3523 #define R_AX_MACID_ANT_TABLE 0xDC00
3524 #define R_AX_MACID_ANT_TABLE_LAST 0xDDFC
3525 
3526 #define CMAC1_START_ADDR 0xE000
3527 #define CMAC1_END_ADDR 0xFFFF
3528 #define R_AX_CMAC_REG_END 0xFFFF
3529 
3530 #define R_AX_LTE_SW_CFG_1 0x0038
3531 #define R_AX_LTE_SW_CFG_1_C1 0x2038
3532 #define B_AX_GNT_BT_RFC_S1_SW_VAL BIT(31)
3533 #define B_AX_GNT_BT_RFC_S1_SW_CTRL BIT(30)
3534 #define B_AX_GNT_WL_RFC_S1_SW_VAL BIT(29)
3535 #define B_AX_GNT_WL_RFC_S1_SW_CTRL BIT(28)
3536 #define B_AX_GNT_BT_BB_S1_SW_VAL BIT(27)
3537 #define B_AX_GNT_BT_BB_S1_SW_CTRL BIT(26)
3538 #define B_AX_GNT_WL_BB_S1_SW_VAL BIT(25)
3539 #define B_AX_GNT_WL_BB_S1_SW_CTRL BIT(24)
3540 #define B_AX_BT_SW_CTRL_WL_PRIORITY BIT(19)
3541 #define B_AX_WL_SW_CTRL_WL_PRIORITY BIT(18)
3542 #define B_AX_LTE_PATTERN_2_EN BIT(17)
3543 #define B_AX_LTE_PATTERN_1_EN BIT(16)
3544 #define B_AX_GNT_BT_RFC_S0_SW_VAL BIT(15)
3545 #define B_AX_GNT_BT_RFC_S0_SW_CTRL BIT(14)
3546 #define B_AX_GNT_WL_RFC_S0_SW_VAL BIT(13)
3547 #define B_AX_GNT_WL_RFC_S0_SW_CTRL BIT(12)
3548 #define B_AX_GNT_BT_BB_S0_SW_VAL BIT(11)
3549 #define B_AX_GNT_BT_BB_S0_SW_CTRL BIT(10)
3550 #define B_AX_GNT_WL_BB_S0_SW_VAL BIT(9)
3551 #define B_AX_GNT_WL_BB_S0_SW_CTRL BIT(8)
3552 #define B_AX_LTECOEX_FUN_EN BIT(7)
3553 #define B_AX_LTECOEX_3WIRE_CTRL_MUX BIT(6)
3554 #define B_AX_LTECOEX_OP_MODE_SEL_MASK GENMASK(5, 4)
3555 #define B_AX_LTECOEX_UART_MUX BIT(3)
3556 #define B_AX_LTECOEX_UART_MODE_SEL_MASK GENMASK(2, 0)
3557 
3558 #define R_AX_LTE_SW_CFG_2 0x003C
3559 #define R_AX_LTE_SW_CFG_2_C1 0x203C
3560 #define B_AX_WL_RX_CTRL BIT(8)
3561 #define B_AX_GNT_WL_RX_SW_VAL BIT(7)
3562 #define B_AX_GNT_WL_RX_SW_CTRL BIT(6)
3563 #define B_AX_GNT_WL_TX_SW_VAL BIT(5)
3564 #define B_AX_GNT_WL_TX_SW_CTRL BIT(4)
3565 #define B_AX_GNT_BT_RX_SW_VAL BIT(3)
3566 #define B_AX_GNT_BT_RX_SW_CTRL BIT(2)
3567 #define B_AX_GNT_BT_TX_SW_VAL BIT(1)
3568 #define B_AX_GNT_BT_TX_SW_CTRL BIT(0)
3569 
3570 #define RR_MOD 0x00
3571 #define RR_MOD_V1 0x10000
3572 #define RR_MOD_IQK GENMASK(19, 4)
3573 #define RR_MOD_DPK GENMASK(19, 5)
3574 #define RR_MOD_MASK GENMASK(19, 16)
3575 #define RR_MOD_DCK GENMASK(14, 10)
3576 #define RR_MOD_RGM GENMASK(13, 4)
3577 #define RR_MOD_V_DOWN 0x0
3578 #define RR_MOD_V_STANDBY 0x1
3579 #define RR_TXAGC 0x10001
3580 #define RR_MOD_V_TX 0x2
3581 #define RR_MOD_V_RX 0x3
3582 #define RR_MOD_V_TXIQK 0x4
3583 #define RR_MOD_V_DPK 0x5
3584 #define RR_MOD_V_RXK1 0x6
3585 #define RR_MOD_V_RXK2 0x7
3586 #define RR_MOD_NBW GENMASK(15, 14)
3587 #define RR_MOD_M_RXG GENMASK(13, 4)
3588 #define RR_MOD_M_RXBB GENMASK(9, 5)
3589 #define RR_MOD_LO_SEL BIT(1)
3590 #define RR_MODOPT 0x01
3591 #define RR_MODOPT_M_TXPWR GENMASK(5, 0)
3592 #define RR_WLSEL 0x02
3593 #define RR_WLSEL_AG GENMASK(18, 16)
3594 #define RR_RSV1 0x05
3595 #define RR_RSV1_RST BIT(0)
3596 #define RR_BBDC 0x10005
3597 #define RR_BBDC_SEL BIT(0)
3598 #define RR_DTXLOK 0x08
3599 #define RR_RSV2 0x09
3600 #define RR_LOKVB 0x0a
3601 #define RR_LOKVB_COI GENMASK(19, 14)
3602 #define RR_LOKVB_COQ GENMASK(9, 4)
3603 #define RR_TXIG 0x11
3604 #define RR_TXIG_TG GENMASK(16, 12)
3605 #define RR_TXIG_GR1 GENMASK(6, 4)
3606 #define RR_TXIG_GR0 GENMASK(1, 0)
3607 #define RR_CHTR 0x17
3608 #define RR_CHTR_MOD GENMASK(11, 10)
3609 #define RR_CHTR_TXRX GENMASK(9, 0)
3610 #define RR_CFGCH 0x18
3611 #define RR_CFGCH_V1 0x10018
3612 #define RR_CFGCH_BAND1 GENMASK(17, 16)
3613 #define CFGCH_BAND1_2G 0
3614 #define CFGCH_BAND1_5G 1
3615 #define CFGCH_BAND1_6G 3
3616 #define RR_CFGCH_POW_LCK BIT(15)
3617 #define RR_CFGCH_TRX_AH BIT(14)
3618 #define RR_CFGCH_BCN BIT(13)
3619 #define RR_CFGCH_BW2 BIT(12)
3620 #define RR_CFGCH_BAND0 GENMASK(9, 8)
3621 #define CFGCH_BAND0_2G 0
3622 #define CFGCH_BAND0_5G 1
3623 #define CFGCH_BAND0_6G 0
3624 #define RR_CFGCH_BW GENMASK(11, 10)
3625 #define RR_CFGCH_CH GENMASK(7, 0)
3626 #define CFGCH_BW_20M 3
3627 #define CFGCH_BW_40M 2
3628 #define CFGCH_BW_80M 1
3629 #define CFGCH_BW_160M 0
3630 #define RR_APK 0x19
3631 #define RR_APK_MOD GENMASK(5, 4)
3632 #define RR_BTC 0x1a
3633 #define RR_BTC_TXBB GENMASK(14, 12)
3634 #define RR_BTC_RXBB GENMASK(11, 10)
3635 #define RR_RCKC 0x1b
3636 #define RR_RCKC_CA GENMASK(14, 10)
3637 #define RR_RCKS 0x1c
3638 #define RR_RCKO 0x1d
3639 #define RR_RCKO_OFF GENMASK(13, 9)
3640 #define RR_RXKPLL 0x1e
3641 #define RR_RXKPLL_OFF GENMASK(5, 0)
3642 #define RR_RXKPLL_POW BIT(19)
3643 #define RR_RSV4 0x1f
3644 #define RR_RSV4_AGH GENMASK(17, 16)
3645 #define RR_RSV4_PLLCH GENMASK(9, 0)
3646 #define RR_RXK 0x20
3647 #define RR_RXK_SEL2G BIT(8)
3648 #define RR_RXK_SEL5G BIT(7)
3649 #define RR_RXK_PLLEN BIT(5)
3650 #define RR_LUTWA 0x33
3651 #define RR_LUTWA_MASK GENMASK(9, 0)
3652 #define RR_LUTWA_M1 GENMASK(7, 0)
3653 #define RR_LUTWA_M2 GENMASK(4, 0)
3654 #define RR_LUTWD1 0x3e
3655 #define RR_LUTWD0 0x3f
3656 #define RR_LUTWD0_MB GENMASK(11, 6)
3657 #define RR_LUTWD0_LB GENMASK(5, 0)
3658 #define RR_TM 0x42
3659 #define RR_TM_TRI BIT(19)
3660 #define RR_TM_VAL GENMASK(6, 1)
3661 #define RR_TM2 0x43
3662 #define RR_TM2_OFF GENMASK(19, 16)
3663 #define RR_TXG1 0x51
3664 #define RR_TXG1_ATT2 BIT(19)
3665 #define RR_TXG1_ATT1 BIT(11)
3666 #define RR_TXG2 0x52
3667 #define RR_TXG2_ATT0 BIT(11)
3668 #define RR_BSPAD 0x54
3669 #define RR_TXGA 0x55
3670 #define RR_TXGA_TRK_EN BIT(7)
3671 #define RR_TXGA_LOK_EXT GENMASK(4, 0)
3672 #define RR_TXGA_LOK_EN BIT(0)
3673 #define RR_TXGA_V1 0x10055
3674 #define RR_TXGA_V1_TRK_EN BIT(7)
3675 #define RR_GAINTX 0x56
3676 #define RR_GAINTX_ALL GENMASK(15, 0)
3677 #define RR_GAINTX_PAD GENMASK(9, 5)
3678 #define RR_GAINTX_BB GENMASK(4, 0)
3679 #define RR_TXMO 0x58
3680 #define RR_TXMO_COI GENMASK(19, 15)
3681 #define RR_TXMO_COQ GENMASK(14, 10)
3682 #define RR_TXMO_FII GENMASK(9, 6)
3683 #define RR_TXMO_FIQ GENMASK(5, 2)
3684 #define RR_TXA 0x5d
3685 #define RR_TXA_TRK GENMASK(19, 14)
3686 #define RR_TXRSV 0x5c
3687 #define RR_TXRSV_GAPK BIT(19)
3688 #define RR_BIAS 0x5e
3689 #define RR_BIAS_GAPK BIT(19)
3690 #define RR_TXAC 0x5f
3691 #define RR_TXAC_IQG GENMASK(3, 0)
3692 #define RR_BIASA 0x60
3693 #define RR_BIASA_TXG GENMASK(15, 12)
3694 #define RR_BIASA_TXA GENMASK(19, 16)
3695 #define RR_BIASA_A GENMASK(2, 0)
3696 #define RR_BIASA2 0x63
3697 #define RR_BIASA2_LB GENMASK(4, 2)
3698 #define RR_TXATANK 0x64
3699 #define RR_TXATANK_LBSW2 GENMASK(17, 15)
3700 #define RR_TXATANK_LBSW GENMASK(16, 15)
3701 #define RR_TXA2 0x65
3702 #define RR_TXA2_LDO GENMASK(19, 16)
3703 #define RR_TRXIQ 0x66
3704 #define RR_RSV6 0x6d
3705 #define RR_TXVBUF 0x7c
3706 #define RR_TXVBUF_DACEN BIT(5)
3707 #define RR_TXPOW 0x7f
3708 #define RR_TXPOW_TXA BIT(8)
3709 #define RR_TXPOW_TXAS BIT(7)
3710 #define RR_TXPOW_TXG BIT(1)
3711 #define RR_RXPOW 0x80
3712 #define RR_RXPOW_IQK GENMASK(17, 16)
3713 #define RR_RXBB 0x83
3714 #define RR_RXBB_VOBUF GENMASK(15, 12)
3715 #define RR_RXBB_C2G GENMASK(16, 10)
3716 #define RR_RXBB_C1G GENMASK(9, 8)
3717 #define RR_RXBB_FATT GENMASK(7, 0)
3718 #define RR_RXBB_ATTR GENMASK(7, 4)
3719 #define RR_RXBB_ATTC GENMASK(2, 0)
3720 #define RR_RXG 0x84
3721 #define RR_RXG_IQKMOD GENMASK(19, 16)
3722 #define RR_XGLNA2 0x85
3723 #define RR_XGLNA2_SW GENMASK(1, 0)
3724 #define RR_RXAE 0x89
3725 #define RR_RXAE_IQKMOD GENMASK(3, 0)
3726 #define RR_RXA 0x8a
3727 #define RR_RXA_DPK GENMASK(9, 8)
3728 #define RR_RXA_LNA 0x8b
3729 #define RR_RXA2 0x8c
3730 #define RR_RAA2_SWATT GENMASK(15, 9)
3731 #define RR_RXA2_C1 GENMASK(12, 10)
3732 #define RR_RXA2_C2 GENMASK(9, 3)
3733 #define RR_RXA2_CC2 GENMASK(8, 7)
3734 #define RR_RXA2_IATT GENMASK(7, 4)
3735 #define RR_RXA2_HATT GENMASK(6, 0)
3736 #define RR_RXA2_ATT GENMASK(3, 0)
3737 #define RR_RXIQGEN 0x8d
3738 #define RR_RXIQGEN_ATTL GENMASK(12, 8)
3739 #define RR_RXIQGEN_ATTH GENMASK(14, 13)
3740 #define RR_RXBB2 0x8f
3741 #define RR_RXBB2_DAC_EN BIT(13)
3742 #define RR_RXBB2_CKT BIT(12)
3743 #define RR_EN_TIA_IDA GENMASK(11, 10)
3744 #define RR_RXBB2_IDAC GENMASK(11, 9)
3745 #define RR_RXBB2_EBW GENMASK(6, 5)
3746 #define RR_XALNA2 0x90
3747 #define RR_XALNA2_SW2 GENMASK(9, 8)
3748 #define RR_XALNA2_SW GENMASK(1, 0)
3749 #define RR_DCK 0x92
3750 #define RR_DCK_S1 GENMASK(19, 16)
3751 #define RR_DCK_TIA GENMASK(15, 9)
3752 #define RR_DCK_DONE GENMASK(7, 5)
3753 #define RR_DCK_FINE BIT(1)
3754 #define RR_DCK_LV BIT(0)
3755 #define RR_DCK1 0x93
3756 #define RR_DCK1_S1 GENMASK(19, 16)
3757 #define RR_DCK1_TIA GENMASK(15, 9)
3758 #define RR_DCK1_DONE BIT(5)
3759 #define RR_DCK1_CLR GENMASK(3, 0)
3760 #define RR_DCK1_SEL BIT(3)
3761 #define RR_DCK2 0x94
3762 #define RR_DCK2_CYCLE GENMASK(7, 2)
3763 #define RR_DCKC 0x95
3764 #define RR_DCKC_CHK BIT(3)
3765 #define RR_IQGEN 0x97
3766 #define RR_IQGEN_BIAS GENMASK(11, 8)
3767 #define RR_TXIQK 0x98
3768 #define RR_TXIQK_ATT2 GENMASK(15, 12)
3769 #define RR_TXIQK_ATT1 GENMASK(6, 0)
3770 #define RR_TIA 0x9e
3771 #define RR_TIA_N6 BIT(8)
3772 #define RR_MIXER 0x9f
3773 #define RR_MIXER_GN GENMASK(4, 3)
3774 #define RR_POW 0xa0
3775 #define RR_POW_SYN GENMASK(3, 2)
3776 #define RR_LOGEN 0xa3
3777 #define RR_LOGEN_RPT GENMASK(19, 16)
3778 #define RR_SX 0xaf
3779 #define RR_LDO 0xb1
3780 #define RR_LDO_SEL GENMASK(8, 6)
3781 #define RR_VCO 0xb2
3782 #define RR_LPF 0xb7
3783 #define RR_LPF_BUSY BIT(8)
3784 #define RR_XTALX2 0xb8
3785 #define RR_MALSEL 0xbe
3786 #define RR_SYNFB 0xc5
3787 #define RR_SYNFB_LK BIT(15)
3788 #define RR_LCKST 0xcf
3789 #define RR_LCKST_BIN BIT(0)
3790 #define RR_LCK_TRG 0xd3
3791 #define RR_LCK_TRGSEL BIT(8)
3792 #define RR_MMD 0xd5
3793 #define RR_MMD_RST_EN BIT(8)
3794 #define RR_MMD_RST_SYN BIT(6)
3795 #define RR_IQKPLL 0xdc
3796 #define RR_IQKPLL_MOD GENMASK(9, 8)
3797 #define RR_SYNLUT 0xdd
3798 #define RR_SYNLUT_MOD BIT(4)
3799 #define RR_RCKD 0xde
3800 #define RR_RCKD_POW GENMASK(19, 13)
3801 #define RR_RCKD_BW BIT(2)
3802 #define RR_TXADBG 0xde
3803 #define RR_LUTDBG 0xdf
3804 #define RR_LUTDBG_TIA BIT(12)
3805 #define RR_LUTDBG_LOK BIT(2)
3806 #define RR_LUTPLL 0xec
3807 #define RR_CAL_RW BIT(19)
3808 #define RR_LUTWE2 0xee
3809 #define RR_LUTWE2_RTXBW BIT(2)
3810 #define RR_LUTWE 0xef
3811 #define RR_LUTWE_LOK BIT(2)
3812 #define RR_RFC 0xf0
3813 #define RR_WCAL BIT(16)
3814 #define RR_RFC_CKEN BIT(1)
3815 
3816 #define R_UPD_P0 0x0000
3817 #define R_RSTB_WATCH_DOG 0x000C
3818 #define B_P0_RSTB_WATCH_DOG BIT(0)
3819 #define B_P1_RSTB_WATCH_DOG BIT(1)
3820 #define B_UPD_P0_EN BIT(31)
3821 #define R_ANAPAR_PW15 0x030C
3822 #define B_ANAPAR_PW15 GENMASK(31, 24)
3823 #define B_ANAPAR_PW15_H GENMASK(27, 24)
3824 #define B_ANAPAR_PW15_H2 GENMASK(27, 26)
3825 #define R_ANAPAR 0x032C
3826 #define B_ANAPAR_15 GENMASK(31, 16)
3827 #define B_ANAPAR_ADCCLK BIT(30)
3828 #define B_ANAPAR_FLTRST BIT(22)
3829 #define B_ANAPAR_CRXBB GENMASK(18, 16)
3830 #define B_ANAPAR_EN BIT(16)
3831 #define B_ANAPAR_14 GENMASK(15, 0)
3832 #define R_RFE_E_A2 0x0334
3833 #define R_RFE_O_SEL_A2 0x0338
3834 #define R_RFE_SEL0_A2 0x033C
3835 #define R_RFE_SEL32_A2 0x0340
3836 #define R_CIRST 0x035c
3837 #define B_CIRST_SYN GENMASK(11, 10)
3838 #define R_SWSI_DATA_V1 0x0370
3839 #define B_SWSI_DATA_VAL_V1 GENMASK(19, 0)
3840 #define B_SWSI_DATA_ADDR_V1 GENMASK(27, 20)
3841 #define B_SWSI_DATA_PATH_V1 GENMASK(30, 28)
3842 #define B_SWSI_DATA_BIT_MASK_EN_V1 BIT(31)
3843 #define R_SWSI_BIT_MASK_V1 0x0374
3844 #define B_SWSI_BIT_MASK_V1 GENMASK(19, 0)
3845 #define R_SWSI_READ_ADDR_V1 0x0378
3846 #define B_SWSI_READ_ADDR_ADDR_V1 GENMASK(7, 0)
3847 #define B_SWSI_READ_ADDR_PATH_V1 GENMASK(10, 8)
3848 #define B_SWSI_READ_ADDR_V1 GENMASK(10, 0)
3849 #define R_UPD_CLK_ADC 0x0700
3850 #define B_UPD_CLK_ADC_VAL GENMASK(26, 25)
3851 #define B_UPD_CLK_ADC_ON BIT(24)
3852 #define B_ENABLE_CCK BIT(5)
3853 #define R_RSTB_ASYNC 0x0704
3854 #define B_RSTB_ASYNC_ALL BIT(1)
3855 #define R_MAC_PIN_SEL 0x0734
3856 #define B_CH_IDX_SEG0 GENMASK(23, 16)
3857 #define R_PLCP_HISTOGRAM 0x0738
3858 #define B_STS_PARSING_TIME GENMASK(19, 16)
3859 #define B_STS_DIS_TRIG_BY_FAIL BIT(3)
3860 #define B_STS_DIS_TRIG_BY_BRK BIT(2)
3861 #define R_PHY_STS_BITMAP_ADDR_START R_PHY_STS_BITMAP_SEARCH_FAIL
3862 #define B_PHY_STS_BITMAP_ADDR_MASK GENMASK(6, 2)
3863 #define R_PHY_STS_BITMAP_SEARCH_FAIL 0x073C
3864 #define B_PHY_STS_BITMAP_MSK_52A 0x337cff3f
3865 #define R_PHY_STS_BITMAP_R2T 0x0740
3866 #define R_PHY_STS_BITMAP_CCA_SPOOF 0x0744
3867 #define R_PHY_STS_BITMAP_OFDM_BRK 0x0748
3868 #define R_PHY_STS_BITMAP_CCK_BRK 0x074C
3869 #define R_PHY_STS_BITMAP_DL_MU_SPOOF 0x0750
3870 #define R_PHY_STS_BITMAP_HE_MU 0x0754
3871 #define R_PHY_STS_BITMAP_VHT_MU 0x0758
3872 #define R_PHY_STS_BITMAP_UL_TB_SPOOF 0x075C
3873 #define R_PHY_STS_BITMAP_TRIGBASE 0x0760
3874 #define R_PHY_STS_BITMAP_CCK 0x0764
3875 #define R_PHY_STS_BITMAP_LEGACY 0x0768
3876 #define R_PHY_STS_BITMAP_HT 0x076C
3877 #define R_PHY_STS_BITMAP_VHT 0x0770
3878 #define R_PHY_STS_BITMAP_HE 0x0774
3879 #define R_PMAC_GNT 0x0980
3880 #define B_PMAC_GNT_TXEN BIT(0)
3881 #define B_PMAC_GNT_RXEN BIT(16)
3882 #define B_PMAC_GNT_P1 GENMASK(20, 17)
3883 #define B_PMAC_GNT_P2 GENMASK(29, 26)
3884 #define R_PMAC_RX_CFG1 0x0988
3885 #define B_PMAC_OPT1_MSK GENMASK(11, 0)
3886 #define R_PMAC_RXMOD 0x0994
3887 #define B_PMAC_RXMOD_MSK GENMASK(7, 4)
3888 #define R_MAC_SEL 0x09A4
3889 #define B_MAC_SEL_OFDM_TRI_FILTER BIT(31)
3890 #define B_MAC_SEL_PWR_EN BIT(16)
3891 #define B_MAC_SEL_DPD_EN BIT(10)
3892 #define B_MAC_SEL_MOD GENMASK(4, 2)
3893 #define R_PMAC_TX_CTRL 0x09C0
3894 #define B_PMAC_TXEN_DIS BIT(0)
3895 #define R_PMAC_TX_PRD 0x09C4
3896 #define B_PMAC_TX_PRD_MSK GENMASK(31, 8)
3897 #define B_PMAC_CTX_EN BIT(0)
3898 #define B_PMAC_PTX_EN BIT(4)
3899 #define R_PMAC_TX_CNT 0x09C8
3900 #define B_PMAC_TX_CNT_MSK GENMASK(31, 0)
3901 #define R_P80_AT_HIGH_FREQ 0x09D8
3902 #define B_P80_AT_HIGH_FREQ BIT(26)
3903 #define R_DBCC_80P80_SEL_EVM_RPT 0x0A10
3904 #define B_DBCC_80P80_SEL_EVM_RPT_EN BIT(0)
3905 #define R_CCX 0x0C00
3906 #define B_CCX_EDCCA_OPT_MSK GENMASK(6, 4)
3907 #define B_MEASUREMENT_TRIG_MSK BIT(2)
3908 #define B_CCX_TRIG_OPT_MSK BIT(1)
3909 #define B_CCX_EN_MSK BIT(0)
3910 #define R_IFS_COUNTER 0x0C28
3911 #define B_IFS_CLM_PERIOD_MSK GENMASK(31, 16)
3912 #define B_IFS_CLM_COUNTER_UNIT_MSK GENMASK(15, 14)
3913 #define B_IFS_COUNTER_CLR_MSK BIT(13)
3914 #define B_IFS_COLLECT_EN BIT(12)
3915 #define R_IFS_T1 0x0C2C
3916 #define B_IFS_T1_TH_HIGH_MSK GENMASK(31, 16)
3917 #define B_IFS_T1_EN_MSK BIT(15)
3918 #define B_IFS_T1_TH_LOW_MSK GENMASK(14, 0)
3919 #define R_IFS_T2 0x0C30
3920 #define B_IFS_T2_TH_HIGH_MSK GENMASK(31, 16)
3921 #define B_IFS_T2_EN_MSK BIT(15)
3922 #define B_IFS_T2_TH_LOW_MSK GENMASK(14, 0)
3923 #define R_IFS_T3 0x0C34
3924 #define B_IFS_T3_TH_HIGH_MSK GENMASK(31, 16)
3925 #define B_IFS_T3_EN_MSK BIT(15)
3926 #define B_IFS_T3_TH_LOW_MSK GENMASK(14, 0)
3927 #define R_IFS_T4 0x0C38
3928 #define B_IFS_T4_TH_HIGH_MSK GENMASK(31, 16)
3929 #define B_IFS_T4_EN_MSK BIT(15)
3930 #define B_IFS_T4_TH_LOW_MSK GENMASK(14, 0)
3931 #define R_PD_CTRL 0x0C3C
3932 #define B_PD_HIT_DIS BIT(9)
3933 #define R_IOQ_IQK_DPK 0x0C60
3934 #define B_IOQ_IQK_DPK_EN BIT(1)
3935 #define R_GNT_BT_WGT_EN 0x0C6C
3936 #define B_GNT_BT_WGT_EN BIT(21)
3937 #define R_PD_ARBITER_OFF 0x0C80
3938 #define B_PD_ARBITER_OFF BIT(31)
3939 #define R_SNDCCA_A1 0x0C9C
3940 #define B_SNDCCA_A1_EN GENMASK(19, 12)
3941 #define R_SNDCCA_A2 0x0CA0
3942 #define B_SNDCCA_A2_VAL GENMASK(19, 12)
3943 #define R_RXHT_MCS_LIMIT 0x0D18
3944 #define B_RXHT_MCS_LIMIT GENMASK(9, 8)
3945 #define R_RXVHT_MCS_LIMIT 0x0D18
3946 #define B_RXVHT_MCS_LIMIT GENMASK(22, 21)
3947 #define R_P0_EN_SOUND_WO_NDP 0x0D7C
3948 #define B_P0_EN_SOUND_WO_NDP BIT(1)
3949 #define R_RXHE 0x0D80
3950 #define B_RXHETB_MAX_NSS GENMASK(25, 23)
3951 #define B_RXHE_MAX_NSS GENMASK(16, 14)
3952 #define B_RXHE_USER_MAX GENMASK(13, 6)
3953 #define R_SPOOF_ASYNC_RST 0x0D84
3954 #define B_SPOOF_ASYNC_RST BIT(15)
3955 #define R_NDP_BRK0 0xDA0
3956 #define R_NDP_BRK1 0xDA4
3957 #define B_NDP_RU_BRK BIT(0)
3958 #define R_BRK_ASYNC_RST_EN_1 0x0DC0
3959 #define R_BRK_ASYNC_RST_EN_2 0x0DC4
3960 #define R_BRK_ASYNC_RST_EN_3 0x0DC8
3961 #define R_S0_HW_SI_DIS 0x1200
3962 #define B_S0_HW_SI_DIS_W_R_TRIG GENMASK(30, 28)
3963 #define R_P0_RXCK 0x12A0
3964 #define B_P0_RXCK_BW3 BIT(30)
3965 #define B_P0_TXCK_ALL GENMASK(19, 12)
3966 #define B_P0_RXCK_ON BIT(19)
3967 #define B_P0_RXCK_VAL GENMASK(18, 16)
3968 #define B_P0_TXCK_ON BIT(15)
3969 #define B_P0_TXCK_VAL GENMASK(14, 12)
3970 #define R_P0_RFMODE 0x12AC
3971 #define B_P0_RFMODE_ORI_TXRX_FTM_TX GENMASK(31, 4)
3972 #define B_P0_RFMODE_MUX GENMASK(11, 4)
3973 #define R_P0_RFMODE_ORI_RX 0x12AC
3974 #define B_P0_RFMODE_ORI_RX_ALL GENMASK(23, 12)
3975 #define R_P0_RFMODE_FTM_RX 0x12B0
3976 #define B_P0_RFMODE_FTM_RX GENMASK(11, 0)
3977 #define R_P0_NRBW 0x12B8
3978 #define B_P0_NRBW_DBG BIT(30)
3979 #define R_S0_RXDC 0x12D4
3980 #define B_S0_RXDC_I GENMASK(25, 16)
3981 #define B_S0_RXDC_Q GENMASK(31, 26)
3982 #define R_S0_RXDC2 0x12D8
3983 #define B_S0_RXDC2_SEL GENMASK(9, 8)
3984 #define B_S0_RXDC2_AVG GENMASK(7, 6)
3985 #define B_S0_RXDC2_MEN GENMASK(5, 4)
3986 #define B_S0_RXDC2_Q2 GENMASK(3, 0)
3987 #define R_CFO_COMP_SEG0_L 0x1384
3988 #define R_CFO_COMP_SEG0_H 0x1388
3989 #define R_CFO_COMP_SEG0_CTRL 0x138C
3990 #define R_DBG32_D 0x1730
3991 #define R_SWSI_V1 0x174C
3992 #define B_SWSI_W_BUSY_V1 BIT(24)
3993 #define B_SWSI_R_BUSY_V1 BIT(25)
3994 #define B_SWSI_R_DATA_DONE_V1 BIT(26)
3995 #define R_TX_COUNTER 0x1A40
3996 #define R_IFS_CLM_TX_CNT 0x1ACC
3997 #define B_IFS_CLM_EDCCA_EXCLUDE_CCA_FA_MSK GENMASK(31, 16)
3998 #define B_IFS_CLM_TX_CNT_MSK GENMASK(15, 0)
3999 #define R_IFS_CLM_CCA 0x1AD0
4000 #define B_IFS_CLM_OFDMCCA_EXCLUDE_FA_MSK GENMASK(31, 16)
4001 #define B_IFS_CLM_CCKCCA_EXCLUDE_FA_MSK GENMASK(15, 0)
4002 #define R_IFS_CLM_FA 0x1AD4
4003 #define B_IFS_CLM_OFDM_FA_MSK GENMASK(31, 16)
4004 #define B_IFS_CLM_CCK_FA_MSK GENMASK(15, 0)
4005 #define R_IFS_HIS 0x1AD8
4006 #define B_IFS_T4_HIS_MSK GENMASK(31, 24)
4007 #define B_IFS_T3_HIS_MSK GENMASK(23, 16)
4008 #define B_IFS_T2_HIS_MSK GENMASK(15, 8)
4009 #define B_IFS_T1_HIS_MSK GENMASK(7, 0)
4010 #define R_IFS_AVG_L 0x1ADC
4011 #define B_IFS_T2_AVG_MSK GENMASK(31, 16)
4012 #define B_IFS_T1_AVG_MSK GENMASK(15, 0)
4013 #define R_IFS_AVG_H 0x1AE0
4014 #define B_IFS_T4_AVG_MSK GENMASK(31, 16)
4015 #define B_IFS_T3_AVG_MSK GENMASK(15, 0)
4016 #define R_IFS_CCA_L 0x1AE4
4017 #define B_IFS_T2_CCA_MSK GENMASK(31, 16)
4018 #define B_IFS_T1_CCA_MSK GENMASK(15, 0)
4019 #define R_IFS_CCA_H 0x1AE8
4020 #define B_IFS_T4_CCA_MSK GENMASK(31, 16)
4021 #define B_IFS_T3_CCA_MSK GENMASK(15, 0)
4022 #define R_IFSCNT 0x1AEC
4023 #define B_IFSCNT_DONE_MSK BIT(16)
4024 #define B_IFSCNT_TOTAL_CNT_MSK GENMASK(15, 0)
4025 #define R_TXAGC_TP 0x1C04
4026 #define B_TXAGC_TP GENMASK(2, 0)
4027 #define R_TSSI_THER 0x1C10
4028 #define B_TSSI_THER GENMASK(29, 24)
4029 #define R_TSSI_CWRPT 0x1C18
4030 #define B_TSSI_CWRPT_RDY BIT(16)
4031 #define B_TSSI_CWRPT GENMASK(8, 0)
4032 #define R_TXAGC_BTP 0x1CA0
4033 #define B_TXAGC_BTP GENMASK(31, 24)
4034 #define R_TXAGC_BB 0x1C60
4035 #define B_TXAGC_BB_OFT GENMASK(31, 16)
4036 #define B_TXAGC_BB GENMASK(31, 24)
4037 #define R_S0_ADDCK 0x1E00
4038 #define B_S0_ADDCK_I GENMASK(9, 0)
4039 #define B_S0_ADDCK_Q GENMASK(19, 10)
4040 #define R_ADC_FIFO 0x20fc
4041 #define B_ADC_FIFO_RST GENMASK(31, 24)
4042 #define B_ADC_FIFO_RXK GENMASK(31, 16)
4043 #define B_ADC_FIFO_A3 BIT(28)
4044 #define B_ADC_FIFO_A2 BIT(24)
4045 #define B_ADC_FIFO_A1 BIT(20)
4046 #define B_ADC_FIFO_A0 BIT(16)
4047 #define R_TXFIR0 0x2300
4048 #define B_TXFIR_C01 GENMASK(23, 0)
4049 #define R_TXFIR2 0x2304
4050 #define B_TXFIR_C23 GENMASK(23, 0)
4051 #define R_TXFIR4 0x2308
4052 #define B_TXFIR_C45 GENMASK(23, 0)
4053 #define R_TXFIR6 0x230c
4054 #define B_TXFIR_C67 GENMASK(23, 0)
4055 #define R_TXFIR8 0x2310
4056 #define B_TXFIR_C89 GENMASK(23, 0)
4057 #define R_TXFIRA 0x2314
4058 #define B_TXFIR_CAB GENMASK(23, 0)
4059 #define R_TXFIRC 0x2318
4060 #define B_TXFIR_CCD GENMASK(23, 0)
4061 #define R_TXFIRE 0x231c
4062 #define B_TXFIR_CEF GENMASK(23, 0)
4063 #define R_11B_RX_V1 0x2320
4064 #define B_11B_RXCCA_DIS_V1 BIT(0)
4065 #define R_RPL_OFST 0x2340
4066 #define B_RPL_OFST_MASK GENMASK(14, 8)
4067 #define R_RXCCA 0x2344
4068 #define B_RXCCA_DIS BIT(31)
4069 #define R_RXCCA_V1 0x2320
4070 #define B_RXCCA_DIS_V1 BIT(0)
4071 #define R_RXSC 0x237C
4072 #define B_RXSC_EN BIT(0)
4073 #define R_RX_RPL_OFST 0x23AC
4074 #define B_RX_RPL_OFST_CCK_MASK GENMASK(6, 0)
4075 #define R_RXSCOBC 0x23B0
4076 #define B_RXSCOBC_TH GENMASK(18, 0)
4077 #define R_RXSCOCCK 0x23B4
4078 #define B_RXSCOCCK_TH GENMASK(18, 0)
4079 #define R_P80_AT_HIGH_FREQ_RU_ALLOC 0x2410
4080 #define B_P80_AT_HIGH_FREQ_RU_ALLOC_PHY1 BIT(14)
4081 #define B_P80_AT_HIGH_FREQ_RU_ALLOC_PHY0 BIT(13)
4082 #define R_DBCC_80P80_SEL_EVM_RPT2 0x2A10
4083 #define B_DBCC_80P80_SEL_EVM_RPT2_EN BIT(0)
4084 #define R_P1_EN_SOUND_WO_NDP 0x2D7C
4085 #define B_P1_EN_SOUND_WO_NDP BIT(1)
4086 #define R_S1_HW_SI_DIS 0x3200
4087 #define B_S1_HW_SI_DIS_W_R_TRIG GENMASK(30, 28)
4088 #define R_P1_RXCK 0x32A0
4089 #define B_P1_RXCK_BW3 BIT(30)
4090 #define B_P1_TXCK_ALL GENMASK(19, 12)
4091 #define B_P1_RXCK_ON BIT(19)
4092 #define B_P1_RXCK_VAL GENMASK(18, 16)
4093 #define R_P1_RFMODE 0x32AC
4094 #define B_P1_RFMODE_ORI_TXRX_FTM_TX GENMASK(31, 4)
4095 #define B_P1_RFMODE_MUX GENMASK(11, 4)
4096 #define R_P1_RFMODE_ORI_RX 0x32AC
4097 #define B_P1_RFMODE_ORI_RX_ALL GENMASK(23, 12)
4098 #define R_P1_RFMODE_FTM_RX 0x32B0
4099 #define B_P1_RFMODE_FTM_RX GENMASK(11, 0)
4100 #define R_P1_DBGMOD 0x32B8
4101 #define B_P1_DBGMOD_ON BIT(30)
4102 #define R_S1_RXDC 0x32D4
4103 #define B_S1_RXDC_I GENMASK(25, 16)
4104 #define B_S1_RXDC_Q GENMASK(31, 26)
4105 #define R_S1_RXDC2 0x32D8
4106 #define B_S1_RXDC2_EN GENMASK(5, 4)
4107 #define B_S1_RXDC2_SEL GENMASK(9, 8)
4108 #define B_S1_RXDC2_Q2 GENMASK(3, 0)
4109 #define R_TXAGC_BB_S1 0x3C60
4110 #define B_TXAGC_BB_S1_OFT GENMASK(31, 16)
4111 #define B_TXAGC_BB_S1 GENMASK(31, 24)
4112 #define R_S1_ADDCK 0x3E00
4113 #define B_S1_ADDCK_I GENMASK(9, 0)
4114 #define B_S1_ADDCK_Q GENMASK(19, 10)
4115 #define R_MUIC 0x40F8
4116 #define B_MUIC_EN BIT(0)
4117 #define R_DCFO 0x4264
4118 #define B_DCFO GENMASK(7, 0)
4119 #define R_SEG0CSI 0x42AC
4120 #define B_SEG0CSI_IDX GENMASK(10, 0)
4121 #define R_SEG0CSI_EN 0x42C4
4122 #define B_SEG0CSI_EN BIT(23)
4123 #define R_BSS_CLR_MAP 0x43ac
4124 #define R_BSS_CLR_MAP_V1 0x43B0
4125 #define B_BSS_CLR_MAP_VLD0 BIT(28)
4126 #define B_BSS_CLR_MAP_TGT GENMASK(27, 22)
4127 #define B_BSS_CLR_MAP_STAID GENMASK(21, 11)
4128 #define R_CFO_TRK0 0x4404
4129 #define R_CFO_TRK1 0x440C
4130 #define B_CFO_TRK_MSK GENMASK(14, 10)
4131 #define R_T2F_GI_COMB 0x4424
4132 #define B_T2F_GI_COMB_EN BIT(2)
4133 #define R_BT_DYN_DC_EST_EN 0x441C
4134 #define R_BT_DYN_DC_EST_EN_V1 0x4420
4135 #define B_BT_DYN_DC_EST_EN_MSK BIT(31)
4136 #define R_ASSIGN_SBD_OPT_V1 0x4440
4137 #define B_ASSIGN_SBD_OPT_EN_V1 BIT(31)
4138 #define R_ASSIGN_SBD_OPT 0x4450
4139 #define B_ASSIGN_SBD_OPT_EN BIT(24)
4140 #define R_DCFO_COMP_S0 0x448C
4141 #define B_DCFO_COMP_S0_MSK GENMASK(11, 0)
4142 #define R_DCFO_WEIGHT 0x4490
4143 #define B_DCFO_WEIGHT_MSK GENMASK(27, 24)
4144 #define R_DCFO_OPT 0x4494
4145 #define B_DCFO_OPT_EN BIT(29)
4146 #define B_TXSHAPE_TRIANGULAR_CFG GENMASK(25, 24)
4147 #define R_BANDEDGE 0x4498
4148 #define B_BANDEDGE_EN BIT(30)
4149 #define R_DPD_BF 0x44a0
4150 #define B_DPD_BF_OFDM GENMASK(16, 12)
4151 #define B_DPD_BF_SCA GENMASK(6, 0)
4152 #define R_TXPATH_SEL 0x458C
4153 #define B_TXPATH_SEL_MSK GENMASK(31, 28)
4154 #define R_TXPWR 0x4594
4155 #define B_TXPWR_MSK GENMASK(30, 22)
4156 #define R_TXNSS_MAP 0x45B4
4157 #define B_TXNSS_MAP_MSK GENMASK(20, 17)
4158 #define R_PCOEFF0_V1 0x45BC
4159 #define B_PCOEFF01_MSK_V1 GENMASK(23, 0)
4160 #define R_PCOEFF2_V1 0x45CC
4161 #define B_PCOEFF23_MSK_V1 GENMASK(23, 0)
4162 #define R_PCOEFF4_V1 0x45D0
4163 #define B_PCOEFF45_MSK_V1 GENMASK(23, 0)
4164 #define R_PCOEFF6_V1 0x45D4
4165 #define B_PCOEFF67_MSK_V1 GENMASK(23, 0)
4166 #define R_PCOEFF8_V1 0x45D8
4167 #define B_PCOEFF89_MSK_V1 GENMASK(23, 0)
4168 #define R_PCOEFFA_V1 0x45C0
4169 #define B_PCOEFFAB_MSK_V1 GENMASK(23, 0)
4170 #define R_PCOEFFC_V1 0x45C4
4171 #define B_PCOEFFCD_MSK_V1 GENMASK(23, 0)
4172 #define R_PCOEFFE_V1 0x45C8
4173 #define B_PCOEFFEF_MSK_V1 GENMASK(23, 0)
4174 #define R_PATH0_IB_PKPW 0x4628
4175 #define B_PATH0_IB_PKPW_MSK GENMASK(11, 6)
4176 #define R_PATH0_LNA_ERR1 0x462C
4177 #define B_PATH0_LNA_ERR_G1_A_MSK GENMASK(29, 24)
4178 #define B_PATH0_LNA_ERR_G0_G_MSK GENMASK(17, 12)
4179 #define B_PATH0_LNA_ERR_G0_A_MSK GENMASK(11, 6)
4180 #define R_PATH0_LNA_ERR2 0x4630
4181 #define B_PATH0_LNA_ERR_G2_G_MSK GENMASK(23, 18)
4182 #define B_PATH0_LNA_ERR_G2_A_MSK GENMASK(17, 12)
4183 #define B_PATH0_LNA_ERR_G1_G_MSK GENMASK(5, 0)
4184 #define R_PATH0_LNA_ERR3 0x4634
4185 #define B_PATH0_LNA_ERR_G4_G_MSK GENMASK(29, 24)
4186 #define B_PATH0_LNA_ERR_G4_A_MSK GENMASK(23, 18)
4187 #define B_PATH0_LNA_ERR_G3_G_MSK GENMASK(11, 6)
4188 #define B_PATH0_LNA_ERR_G3_A_MSK GENMASK(5, 0)
4189 #define R_PATH0_LNA_ERR4 0x4638
4190 #define B_PATH0_LNA_ERR_G6_A_MSK GENMASK(29, 24)
4191 #define B_PATH0_LNA_ERR_G5_G_MSK GENMASK(17, 12)
4192 #define B_PATH0_LNA_ERR_G5_A_MSK GENMASK(11, 6)
4193 #define R_PATH0_LNA_ERR5 0x463C
4194 #define B_PATH0_LNA_ERR_G6_G_MSK GENMASK(5, 0)
4195 #define R_PATH0_TIA_ERR_G0 0x4640
4196 #define B_PATH0_TIA_ERR_G0_G_MSK GENMASK(23, 18)
4197 #define B_PATH0_TIA_ERR_G0_A_MSK GENMASK(17, 12)
4198 #define R_PATH0_TIA_ERR_G1 0x4644
4199 #define B_PATH0_TIA_ERR_G1_SEL GENMASK(31, 30)
4200 #define B_PATH0_TIA_ERR_G1_G_MSK GENMASK(11, 6)
4201 #define B_PATH0_TIA_ERR_G1_A_MSK GENMASK(5, 0)
4202 #define R_PATH0_IB_PBK 0x4650
4203 #define B_PATH0_IB_PBK_MSK GENMASK(14, 10)
4204 #define R_PATH0_RXB_INIT 0x4658
4205 #define B_PATH0_RXB_INIT_IDX_MSK GENMASK(9, 5)
4206 #define R_PATH0_LNA_INIT 0x4668
4207 #define R_PATH0_LNA_INIT_V1 0x472C
4208 #define B_PATH0_LNA_INIT_IDX_MSK GENMASK(26, 24)
4209 #define R_PATH0_BTG 0x466C
4210 #define B_PATH0_BTG_SHEN GENMASK(18, 17)
4211 #define R_PATH0_TIA_INIT 0x4674
4212 #define B_PATH0_TIA_INIT_IDX_MSK BIT(17)
4213 #define R_PATH0_P20_FOLLOW_BY_PAGCUGC 0x46A0
4214 #define R_PATH0_P20_FOLLOW_BY_PAGCUGC_V1 0x4C24
4215 #define R_PATH0_P20_FOLLOW_BY_PAGCUGC_V2 0x46E8
4216 #define B_PATH0_P20_FOLLOW_BY_PAGCUGC_EN_MSK BIT(5)
4217 #define R_PATH0_S20_FOLLOW_BY_PAGCUGC 0x46A4
4218 #define R_PATH0_S20_FOLLOW_BY_PAGCUGC_V1 0x4C28
4219 #define R_PATH0_S20_FOLLOW_BY_PAGCUGC_V2 0x46EC
4220 #define B_PATH0_S20_FOLLOW_BY_PAGCUGC_EN_MSK BIT(5)
4221 #define R_PATH0_RXB_INIT_V1 0x46A8
4222 #define B_PATH0_RXB_INIT_IDX_MSK_V1 GENMASK(14, 10)
4223 #define R_PATH0_G_LNA6_OP1DB_V1 0x4688
4224 #define B_PATH0_G_LNA6_OP1DB_V1 GENMASK(31, 24)
4225 #define R_PATH0_G_TIA0_LNA6_OP1DB_V1 0x4694
4226 #define B_PATH0_G_TIA0_LNA6_OP1DB_V1 GENMASK(7, 0)
4227 #define R_PATH0_G_TIA1_LNA6_OP1DB_V1 0x4694
4228 #define B_PATH0_R_G_OFST_MASK GENMASK(23, 16)
4229 #define B_PATH0_G_TIA1_LNA6_OP1DB_V1 GENMASK(15, 8)
4230 #define R_CDD_EVM_CHK_EN 0x46C0
4231 #define B_CDD_EVM_CHK_EN BIT(0)
4232 #define R_PATH0_BAND_SEL_V1 0x4738
4233 #define B_PATH0_BAND_SEL_MSK_V1 BIT(17)
4234 #define R_PATH0_BT_SHARE_V1 0x4738
4235 #define B_PATH0_BT_SHARE_V1 BIT(19)
4236 #define R_PATH0_BTG_PATH_V1 0x4738
4237 #define B_PATH0_BTG_PATH_V1 BIT(22)
4238 #define R_P0_NBIIDX 0x469C
4239 #define B_P0_NBIIDX_VAL GENMASK(11, 0)
4240 #define B_P0_NBIIDX_NOTCH_EN BIT(12)
4241 #define R_P0_BACKOFF_IBADC_V1 0x469C
4242 #define B_P0_BACKOFF_IBADC_V1 GENMASK(31, 26)
4243 #define B_P0_NBIIDX_NOTCH_EN_V1 BIT(12)
4244 #define R_P1_MODE 0x4718
4245 #define B_P1_MODE_SEL GENMASK(31, 30)
4246 #define R_P0_AGC_CTL 0x4730
4247 #define B_P0_AGC_EN BIT(31)
4248 #define R_PATH1_LNA_INIT 0x473C
4249 #define R_PATH1_LNA_INIT_V1 0x4A80
4250 #define B_PATH1_LNA_INIT_IDX_MSK GENMASK(26, 24)
4251 #define R_PATH0_TIA_INIT_V1 0x473C
4252 #define B_PATH0_TIA_INIT_IDX_MSK_V1 BIT(9)
4253 #define R_PATH1_TIA_INIT 0x4748
4254 #define B_PATH1_TIA_INIT_IDX_MSK BIT(17)
4255 #define R_PATH1_BTG 0x4740
4256 #define B_PATH1_BTG_SHEN GENMASK(18, 17)
4257 #define R_PATH1_RXB_INIT 0x472C
4258 #define B_PATH1_RXB_INIT_IDX_MSK GENMASK(9, 5)
4259 #define R_PATH1_G_LNA6_OP1DB_V1 0x476C
4260 #define B_PATH1_G_LNA6_OP1DB_V1 GENMASK(31, 24)
4261 #define R_PATH1_P20_FOLLOW_BY_PAGCUGC 0x4774
4262 #define R_PATH1_P20_FOLLOW_BY_PAGCUGC_V1 0x4CE8
4263 #define R_PATH1_P20_FOLLOW_BY_PAGCUGC_V2 0x47A8
4264 #define B_PATH1_P20_FOLLOW_BY_PAGCUGC_EN_MSK BIT(5)
4265 #define R_PATH1_S20_FOLLOW_BY_PAGCUGC 0x4778
4266 #define R_PATH1_S20_FOLLOW_BY_PAGCUGC_V1 0x4CEC
4267 #define R_PATH1_S20_FOLLOW_BY_PAGCUGC_V2 0x47AC
4268 #define B_PATH1_S20_FOLLOW_BY_PAGCUGC_EN_MSK BIT(5)
4269 #define R_PATH1_G_TIA0_LNA6_OP1DB_V1 0x4778
4270 #define B_PATH1_G_TIA0_LNA6_OP1DB_V1 GENMASK(7, 0)
4271 #define R_PATH1_G_TIA1_LNA6_OP1DB_V1 0x4778
4272 #define B_PATH1_G_TIA1_LNA6_OP1DB_V1 GENMASK(15, 8)
4273 #define R_PATH1_BAND_SEL_V1 0x4AA4
4274 #define B_PATH1_BAND_SEL_MSK_V1 BIT(17)
4275 #define R_PATH1_BT_SHARE_V1 0x4AA4
4276 #define B_PATH1_BT_SHARE_V1 BIT(19)
4277 #define R_PATH1_BTG_PATH_V1 0x4AA4
4278 #define B_PATH1_BTG_PATH_V1 BIT(22)
4279 #define R_P1_NBIIDX 0x4770
4280 #define B_P1_NBIIDX_VAL GENMASK(11, 0)
4281 #define B_P1_NBIIDX_NOTCH_EN BIT(12)
4282 #define R_PKT_CTRL 0x47D4
4283 #define B_PKT_POP_EN BIT(8)
4284 #define R_SEG0R_PD 0x481C
4285 #define R_SEG0R_PD_V1 0x4860
4286 #define R_SEG0R_EDCCA_LVL 0x4840
4287 #define R_SEG0R_EDCCA_LVL_V1 0x4884
4288 #define B_SEG0R_PPDU_LVL_MSK GENMASK(31, 24)
4289 #define B_SEG0R_EDCCA_LVL_P_MSK GENMASK(15, 8)
4290 #define B_SEG0R_EDCCA_LVL_A_MSK GENMASK(7, 0)
4291 #define B_SEG0R_PD_SPATIAL_REUSE_EN_MSK_V1 BIT(30)
4292 #define B_SEG0R_PD_SPATIAL_REUSE_EN_MSK BIT(29)
4293 #define B_SEG0R_PD_LOWER_BOUND_MSK GENMASK(10, 6)
4294 #define R_2P4G_BAND 0x4970
4295 #define B_2P4G_BAND_SEL BIT(1)
4296 #define R_FC0_BW 0x4974
4297 #define R_FC0_BW_V1 0x49C0
4298 #define B_FC0_BW_SET GENMASK(31, 30)
4299 #define B_ANT_RX_BT_SEG0 GENMASK(25, 22)
4300 #define B_ANT_RX_1RCCA_SEG1 GENMASK(21, 18)
4301 #define B_ANT_RX_1RCCA_SEG0 GENMASK(17, 14)
4302 #define B_FC0_BW_INV GENMASK(6, 0)
4303 #define R_CHBW_MOD 0x4978
4304 #define R_CHBW_MOD_V1 0x49C4
4305 #define B_BT_SHARE BIT(14)
4306 #define B_CHBW_MOD_SBW GENMASK(13, 12)
4307 #define B_CHBW_MOD_PRICH GENMASK(11, 8)
4308 #define B_ANT_RX_SEG0 GENMASK(3, 0)
4309 #define R_P0_RPL1 0x49B0
4310 #define B_P0_RPL1_41_MASK GENMASK(31, 24)
4311 #define B_P0_RPL1_40_MASK GENMASK(23, 16)
4312 #define B_P0_RPL1_20_MASK GENMASK(15, 8)
4313 #define B_P0_RPL1_MASK (B_P0_RPL1_41_MASK | B_P0_RPL1_40_MASK | B_P0_RPL1_20_MASK)
4314 #define B_P0_RPL1_SHIFT 8
4315 #define B_P0_RPL1_BIAS_MASK GENMASK(7, 0)
4316 #define R_P0_RPL2 0x49B4
4317 #define B_P0_RTL2_8A_MASK GENMASK(31, 24)
4318 #define B_P0_RTL2_81_MASK GENMASK(23, 16)
4319 #define B_P0_RTL2_80_MASK GENMASK(15, 8)
4320 #define B_P0_RTL2_42_MASK GENMASK(7, 0)
4321 #define R_P0_RPL3 0x49B8
4322 #define B_P0_RTL3_89_MASK GENMASK(31, 24)
4323 #define B_P0_RTL3_84_MASK GENMASK(23, 16)
4324 #define B_P0_RTL3_83_MASK GENMASK(15, 8)
4325 #define B_P0_RTL3_82_MASK GENMASK(7, 0)
4326 #define R_PD_BOOST_EN 0x49E8
4327 #define B_PD_BOOST_EN BIT(7)
4328 #define R_P1_BACKOFF_IBADC_V1 0x49F0
4329 #define B_P1_BACKOFF_IBADC_V1 GENMASK(31, 26)
4330 #define R_P1_RPL1 0x4A00
4331 #define R_P1_RPL2 0x4A04
4332 #define R_P1_RPL3 0x4A08
4333 #define R_BK_FC0_INV_V1 0x4A1C
4334 #define B_BK_FC0_INV_MSK_V1 GENMASK(18, 0)
4335 #define R_CCK_FC0_INV_V1 0x4A20
4336 #define B_CCK_FC0_INV_MSK_V1 GENMASK(18, 0)
4337 #define R_PATH1_RXB_INIT_V1 0x4A5C
4338 #define B_PATH1_RXB_INIT_IDX_MSK_V1 GENMASK(14, 10)
4339 #define R_P1_AGC_CTL 0x4A9C
4340 #define B_P1_AGC_EN BIT(31)
4341 #define R_PATH1_TIA_INIT_V1 0x4AA8
4342 #define B_PATH1_TIA_INIT_IDX_MSK_V1 BIT(9)
4343 #define R_P0_AGC_RSVD 0x4ACC
4344 #define R_PATH0_RXBB_V1 0x4AD4
4345 #define B_PATH0_RXBB_MSK_V1 GENMASK(31, 0)
4346 #define R_P1_AGC_RSVD 0x4AD8
4347 #define R_PATH1_RXBB_V1 0x4AE0
4348 #define B_PATH1_RXBB_MSK_V1 GENMASK(31, 0)
4349 #define R_PATH0_BT_BACKOFF_V1 0x4AE4
4350 #define B_PATH0_BT_BACKOFF_V1 GENMASK(23, 0)
4351 #define R_PATH1_BT_BACKOFF_V1 0x4AEC
4352 #define B_PATH1_BT_BACKOFF_V1 GENMASK(23, 0)
4353 #define R_PATH0_FRC_FIR_TYPE_V1 0x4C00
4354 #define B_PATH0_FRC_FIR_TYPE_MSK_V1 GENMASK(1, 0)
4355 #define R_PATH0_NOTCH 0x4C14
4356 #define B_PATH0_NOTCH_EN BIT(12)
4357 #define B_PATH0_NOTCH_VAL GENMASK(11, 0)
4358 #define R_PATH0_NOTCH2 0x4C20
4359 #define B_PATH0_NOTCH2_EN BIT(12)
4360 #define B_PATH0_NOTCH2_VAL GENMASK(11, 0)
4361 #define R_PATH0_5MDET 0x4C4C
4362 #define R_PATH0_5MDET_V1 0x46F8
4363 #define B_PATH0_5MDET_EN BIT(12)
4364 #define B_PATH0_5MDET_SB2 BIT(8)
4365 #define B_PATH0_5MDET_SB0 BIT(6)
4366 #define B_PATH0_5MDET_TH GENMASK(5, 0)
4367 #define R_PATH1_FRC_FIR_TYPE_V1 0x4CC4
4368 #define B_PATH1_FRC_FIR_TYPE_MSK_V1 GENMASK(1, 0)
4369 #define R_PATH1_NOTCH 0x4CD8
4370 #define B_PATH1_NOTCH_EN BIT(12)
4371 #define B_PATH1_NOTCH_VAL GENMASK(11, 0)
4372 #define R_PATH1_NOTCH2 0x4CE4
4373 #define B_PATH1_NOTCH2_EN BIT(12)
4374 #define B_PATH1_NOTCH2_VAL GENMASK(11, 0)
4375 #define R_PATH1_5MDET 0x4D10
4376 #define R_PATH1_5MDET_V1 0x47B8
4377 #define B_PATH1_5MDET_EN BIT(12)
4378 #define B_PATH1_5MDET_SB2 BIT(8)
4379 #define B_PATH1_5MDET_SB0 BIT(6)
4380 #define B_PATH1_5MDET_TH GENMASK(5, 0)
4381 #define R_RPL_BIAS_COMP 0x4DF0
4382 #define B_RPL_BIAS_COMP_MASK GENMASK(7, 0)
4383 #define R_RPL_PATHAB 0x4E0C
4384 #define B_RPL_PATHB_MASK GENMASK(23, 16)
4385 #define B_RPL_PATHA_MASK GENMASK(15, 8)
4386 #define R_RSSI_M_PATHAB 0x4E2C
4387 #define B_RSSI_M_PATHB_MASK GENMASK(15, 8)
4388 #define B_RSSI_M_PATHA_MASK GENMASK(7, 0)
4389 #define R_FC0_V1 0x4E30
4390 #define B_FC0_MSK_V1 GENMASK(12, 0)
4391 #define R_RX_BW40_2XFFT_EN_V1 0x4E30
4392 #define B_RX_BW40_2XFFT_EN_MSK_V1 BIT(26)
4393 #define R_DCFO_COMP_S0_V1 0x4A40
4394 #define B_DCFO_COMP_S0_V1_MSK GENMASK(13, 0)
4395 #define R_BMODE_PDTH_V1 0x4B64
4396 #define B_BMODE_PDTH_LOWER_BOUND_MSK_V1 GENMASK(31, 24)
4397 #define R_BMODE_PDTH_EN_V1 0x4B74
4398 #define B_BMODE_PDTH_LIMIT_EN_MSK_V1 BIT(30)
4399 #define R_CFO_COMP_SEG1_L 0x5384
4400 #define R_CFO_COMP_SEG1_H 0x5388
4401 #define R_CFO_COMP_SEG1_CTRL 0x538C
4402 #define B_CFO_COMP_VALID_BIT BIT(29)
4403 #define B_CFO_COMP_WEIGHT_MSK GENMASK(27, 24)
4404 #define B_CFO_COMP_VAL_MSK GENMASK(11, 0)
4405 #define R_TSSI_PA_K1 0x5600
4406 #define R_TSSI_PA_K2 0x5604
4407 #define R_P0_TSSI_ALIM1 0x5630
4408 #define B_P0_TSSI_ALIM1 GENMASK(29, 0)
4409 #define B_P0_TSSI_ALIM11 GENMASK(29, 20)
4410 #define B_P0_TSSI_ALIM12 GENMASK(19, 10)
4411 #define B_P0_TSSI_ALIM13 GENMASK(9, 0)
4412 #define R_P0_TSSI_ALIM3 0x5634
4413 #define B_P0_TSSI_ALIM31 GENMASK(9, 0)
4414 #define R_TSSI_PA_K5 0x5638
4415 #define R_P0_TSSI_ALIM2 0x563c
4416 #define B_P0_TSSI_ALIM2 GENMASK(29, 0)
4417 #define R_P0_TSSI_ALIM4 0x5640
4418 #define R_TSSI_PA_K8 0x5644
4419 #define R_UPD_CLK 0x5670
4420 #define B_DAC_VAL BIT(31)
4421 #define B_ACK_VAL GENMASK(30, 29)
4422 #define B_DPD_DIS BIT(14)
4423 #define B_DPD_GDIS BIT(13)
4424 #define B_IQK_RFC_ON BIT(1)
4425 #define R_TXPWRB 0x56CC
4426 #define B_TXPWRB_ON BIT(28)
4427 #define B_TXPWRB_VAL GENMASK(27, 19)
4428 #define R_DPD_OFT_EN 0x5800
4429 #define B_DPD_OFT_EN BIT(28)
4430 #define B_DPD_TSSI_CW GENMASK(26, 18)
4431 #define B_DPD_PWR_CW GENMASK(17, 9)
4432 #define B_DPD_REF GENMASK(8, 0)
4433 #define R_P0_TSSIC 0x5814
4434 #define B_P0_TSSIC_BYPASS BIT(11)
4435 #define R_DPD_OFT_ADDR 0x5804
4436 #define B_DPD_OFT_ADDR GENMASK(31, 27)
4437 #define R_TXPWRB_H 0x580c
4438 #define B_TXPWRB_RDY BIT(15)
4439 #define R_P0_TMETER 0x5810
4440 #define B_P0_TMETER GENMASK(15, 10)
4441 #define B_P0_TMETER_DIS BIT(16)
4442 #define B_P0_TMETER_TRK BIT(24)
4443 #define R_P1_TSSIC 0x7814
4444 #define B_P1_TSSIC_BYPASS BIT(11)
4445 #define R_P0_TSSI_TRK 0x5818
4446 #define B_P0_TSSI_TRK_EN BIT(30)
4447 #define B_P0_TSSI_RFC GENMASK(28, 27)
4448 #define B_P0_TSSI_OFT_EN BIT(28)
4449 #define B_P0_TSSI_OFT GENMASK(7, 0)
4450 #define R_P0_TSSI_AVG 0x5820
4451 #define B_P0_TSSI_EN BIT(31)
4452 #define B_P0_TSSI_AVG GENMASK(15, 12)
4453 #define R_P0_RFCTM 0x5864
4454 #define B_P0_RFCTM_EN BIT(29)
4455 #define B_P0_RFCTM_VAL GENMASK(25, 20)
4456 #define R_P0_RFCTM_RDY BIT(26)
4457 #define R_P0_TRSW 0x5868
4458 #define B_P0_TRSW_B BIT(0)
4459 #define B_P0_TRSW_A BIT(1)
4460 #define B_P0_TRSW_X BIT(2)
4461 #define B_P0_TRSW_SO_A2 GENMASK(7, 5)
4462 #define R_P0_RFM 0x5894
4463 #define B_P0_RFM_DIS_WL BIT(7)
4464 #define B_P0_RFM_TX_OPT BIT(6)
4465 #define B_P0_RFM_BT_EN BIT(5)
4466 #define B_P0_RFM_OUT GENMASK(4, 0)
4467 #define R_P0_PATH_RST 0x58AC
4468 #define R_P0_TXDPD 0x58D4
4469 #define B_P0_TXDPD GENMASK(31, 28)
4470 #define R_P0_TXPW_RSTB 0x58DC
4471 #define B_P0_TXPW_RSTB_MANON BIT(30)
4472 #define B_P0_TXPW_RSTB_TSSI BIT(31)
4473 #define R_P0_TSSI_MV_AVG 0x58E4
4474 #define B_P0_TSSI_MV_MIX GENMASK(19, 11)
4475 #define B_P0_TSSI_MV_AVG GENMASK(13, 11)
4476 #define B_P0_TSSI_MV_CLR BIT(14)
4477 #define R_TXGAIN_SCALE 0x58F0
4478 #define B_TXGAIN_SCALE_EN BIT(19)
4479 #define B_TXGAIN_SCALE_OFT GENMASK(31, 24)
4480 #define R_P0_TSSI_BASE 0x5C00
4481 #define R_S0_DACKI 0x5E00
4482 #define B_S0_DACKI_AR GENMASK(31, 28)
4483 #define B_S0_DACKI_EN BIT(3)
4484 #define R_S0_DACKI2 0x5E30
4485 #define B_S0_DACKI2_K GENMASK(21, 12)
4486 #define R_S0_DACKI7 0x5E44
4487 #define B_S0_DACKI7_K GENMASK(15, 8)
4488 #define R_S0_DACKI8 0x5E48
4489 #define B_S0_DACKI8_K GENMASK(15, 8)
4490 #define R_S0_DACKQ 0x5E50
4491 #define B_S0_DACKQ_AR GENMASK(31, 28)
4492 #define B_S0_DACKQ_EN BIT(3)
4493 #define R_S0_DACKQ2 0x5E80
4494 #define B_S0_DACKQ2_K GENMASK(21, 12)
4495 #define R_S0_DACKQ7 0x5E94
4496 #define B_S0_DACKQ7_K GENMASK(15, 8)
4497 #define R_S0_DACKQ8 0x5E98
4498 #define B_S0_DACKQ8_K GENMASK(15, 8)
4499 #define R_RPL_BIAS_COMP1 0x6DF0
4500 #define B_RPL_BIAS_COMP1_MASK GENMASK(7, 0)
4501 #define R_P1_TSSI_ALIM1 0x7630
4502 #define B_P1_TSSI_ALIM1 GENMASK(29, 0)
4503 #define B_P1_TSSI_ALIM11 GENMASK(29, 20)
4504 #define B_P1_TSSI_ALIM12 GENMASK(19, 10)
4505 #define B_P1_TSSI_ALIM13 GENMASK(9, 0)
4506 #define R_P1_TSSI_ALIM3 0x7634
4507 #define B_P1_TSSI_ALIM31 GENMASK(9, 0)
4508 #define R_P1_TSSI_ALIM2 0x763c
4509 #define B_P1_TSSI_ALIM2 GENMASK(29, 0)
4510 #define R_P1_TSSIC 0x7814
4511 #define B_P1_TSSIC_BYPASS BIT(11)
4512 #define R_P1_TMETER 0x7810
4513 #define B_P1_TMETER GENMASK(15, 10)
4514 #define B_P1_TMETER_DIS BIT(16)
4515 #define B_P1_TMETER_TRK BIT(24)
4516 #define R_P1_TSSI_TRK 0x7818
4517 #define B_P1_TSSI_TRK_EN BIT(30)
4518 #define B_P1_TSSI_RFC GENMASK(28, 27)
4519 #define B_P1_TSSI_OFT_EN BIT(28)
4520 #define B_P1_TSSI_OFT GENMASK(7, 0)
4521 #define R_P1_TSSI_AVG 0x7820
4522 #define B_P1_TSSI_EN BIT(31)
4523 #define B_P1_TSSI_AVG GENMASK(15, 12)
4524 #define R_P1_RFCTM 0x7864
4525 #define R_P1_RFCTM_RDY BIT(26)
4526 #define B_P1_RFCTM_VAL GENMASK(25, 20)
4527 #define B_P1_RFCTM_DEL GENMASK(19, 11)
4528 #define R_P1_PATH_RST 0x78AC
4529 #define R_P1_TXPW_RSTB 0x78DC
4530 #define B_P1_TXPW_RSTB_MANON BIT(30)
4531 #define B_P1_TXPW_RSTB_TSSI BIT(31)
4532 #define R_P1_TSSI_MV_AVG 0x78E4
4533 #define B_P1_TSSI_MV_MIX GENMASK(19, 11)
4534 #define B_P1_TSSI_MV_AVG GENMASK(13, 11)
4535 #define B_P1_TSSI_MV_CLR BIT(14)
4536 #define R_TSSI_THOF 0x7C00
4537 #define R_S1_DACKI 0x7E00
4538 #define B_S1_DACKI_AR GENMASK(31, 28)
4539 #define B_S1_DACKI_EN BIT(3)
4540 #define R_S1_DACKI2 0x7E30
4541 #define B_S1_DACKI2_K GENMASK(21, 12)
4542 #define R_S1_DACKI7 0x7E44
4543 #define B_S1_DACKI_K GENMASK(15, 8)
4544 #define R_S1_DACKI8 0x7E48
4545 #define B_S1_DACKI8_K GENMASK(15, 8)
4546 #define R_S1_DACKQ 0x7E50
4547 #define B_S1_DACKQ_AR GENMASK(31, 28)
4548 #define B_S1_DACKQ_EN BIT(3)
4549 #define R_S1_DACKQ2 0x7E80
4550 #define B_S1_DACKQ2_K GENMASK(21, 12)
4551 #define R_S1_DACKQ7 0x7E94
4552 #define B_S1_DACKQ7_K GENMASK(15, 8)
4553 #define R_S1_DACKQ8 0x7E98
4554 #define B_S1_DACKQ8_K GENMASK(15, 8)
4555 #define R_NCTL_CFG 0x8000
4556 #define B_NCTL_CFG_SPAGE GENMASK(2, 1)
4557 #define R_NCTL_RPT 0x8008
4558 #define B_NCTL_RPT_FLG BIT(26)
4559 #define R_NCTL_N1 0x8010
4560 #define B_NCTL_N1_CIP GENMASK(7, 0)
4561 #define R_NCTL_N2 0x8014
4562 #define R_IQK_COM 0x8018
4563 #define R_IQK_DIF 0x801C
4564 #define B_IQK_DIF_TRX GENMASK(1, 0)
4565 #define R_IQK_DIF1 0x8020
4566 #define B_IQK_DIF1_TXPI GENMASK(19, 0)
4567 #define R_IQK_DIF2 0x8024
4568 #define B_IQK_DIF2_RXPI GENMASK(19, 0)
4569 #define R_IQK_DIF4 0x802C
4570 #define B_IQK_DIF4_RXT GENMASK(27, 16)
4571 #define B_IQK_DIF4_TXT GENMASK(11, 0)
4572 #define IQK_DF4_TXT_8_25MHZ 0x021
4573 #define R_IQK_CFG 0x8034
4574 #define B_IQK_CFG_SET GENMASK(5, 4)
4575 #define R_TPG_SEL 0x8068
4576 #define R_TPG_MOD 0x806C
4577 #define B_TPG_MOD_F GENMASK(2, 1)
4578 #define R_MDPK_SYNC 0x8070
4579 #define B_MDPK_SYNC_SEL BIT(31)
4580 #define B_MDPK_SYNC_MAN GENMASK(31, 28)
4581 #define R_MDPK_RX_DCK 0x8074
4582 #define B_MDPK_RX_DCK_EN BIT(31)
4583 #define R_KIP_MOD 0x8078
4584 #define B_KIP_MOD GENMASK(19, 0)
4585 #define R_NCTL_RW 0x8080
4586 #define R_KIP_SYSCFG 0x8088
4587 #define R_KIP_CLK 0x808C
4588 #define R_DPK_IDL 0x809C
4589 #define B_DPK_IDL BIT(8)
4590 #define R_LDL_NORM 0x80A0
4591 #define B_LDL_NORM_MA BIT(16)
4592 #define B_LDL_NORM_PN GENMASK(12, 8)
4593 #define B_LDL_NORM_OP GENMASK(1, 0)
4594 #define R_DPK_CTL 0x80B0
4595 #define B_DPK_CTL_EN BIT(28)
4596 #define R_DPK_CFG 0x80B8
4597 #define B_DPK_CFG_IDX GENMASK(14, 12)
4598 #define R_DPK_CFG2 0x80BC
4599 #define B_DPK_CFG2_ST BIT(14)
4600 #define R_DPK_CFG3 0x80C0
4601 #define R_KPATH_CFG 0x80D0
4602 #define B_KPATH_CFG_ED GENMASK(21, 20)
4603 #define R_KIP_RPT1 0x80D4
4604 #define B_KIP_RPT1_SEL GENMASK(21, 16)
4605 #define B_KIP_RPT1_SEL_V1 GENMASK(19, 16)
4606 #define R_SRAM_IQRX 0x80D8
4607 #define R_GAPK 0x80E0
4608 #define B_GAPK_ADR BIT(0)
4609 #define R_SRAM_IQRX2 0x80E8
4610 #define R_DPK_MPA 0x80EC
4611 #define B_DPK_MPA_T0 BIT(10)
4612 #define B_DPK_MPA_T1 BIT(9)
4613 #define B_DPK_MPA_T2 BIT(8)
4614 #define R_DPK_WR 0x80F4
4615 #define B_DPK_WR_ST BIT(29)
4616 #define R_DPK_TRK 0x80f0
4617 #define B_DPK_TRK_DIS BIT(31)
4618 #define R_RPT_COM 0x80FC
4619 #define B_PRT_COM_SYNERR BIT(30)
4620 #define B_PRT_COM_DCI GENMASK(27, 16)
4621 #define B_PRT_COM_CORV GENMASK(15, 8)
4622 #define B_PRT_COM_DCQ GENMASK(11, 0)
4623 #define B_PRT_COM_RXOV BIT(8)
4624 #define B_PRT_COM_GL GENMASK(7, 4)
4625 #define B_PRT_COM_CORI GENMASK(7, 0)
4626 #define B_PRT_COM_RXBB GENMASK(5, 0)
4627 #define B_PRT_COM_RXBB_V1 GENMASK(4, 0)
4628 #define B_PRT_COM_DONE BIT(0)
4629 #define R_COEF_SEL 0x8104
4630 #define B_COEF_SEL_IQC BIT(0)
4631 #define B_COEF_SEL_MDPD BIT(8)
4632 #define R_CFIR_SYS 0x8120
4633 #define R_IQK_RES 0x8124
4634 #define B_IQK_RES_K BIT(28)
4635 #define B_IQK_RES_TXCFIR GENMASK(11, 8)
4636 #define B_IQK_RES_RXCFIR GENMASK(3, 0)
4637 #define R_TXIQC 0x8138
4638 #define R_RXIQC 0x813c
4639 #define B_RXIQC_BYPASS BIT(0)
4640 #define B_RXIQC_BYPASS2 BIT(2)
4641 #define B_RXIQC_NEWP GENMASK(19, 8)
4642 #define B_RXIQC_NEWX GENMASK(31, 20)
4643 #define R_KIP 0x8140
4644 #define B_KIP_DBCC BIT(0)
4645 #define B_KIP_RFGAIN BIT(8)
4646 #define R_RFGAIN 0x8144
4647 #define B_RFGAIN_PAD GENMASK(4, 0)
4648 #define B_RFGAIN_TXBB GENMASK(12, 8)
4649 #define R_RFGAIN_BND 0x8148
4650 #define B_RFGAIN_BND GENMASK(4, 0)
4651 #define R_CFIR_MAP 0x8150
4652 #define R_CFIR_LUT 0x8154
4653 #define B_CFIR_LUT_SEL BIT(8)
4654 #define B_CFIR_LUT_SET BIT(4)
4655 #define B_CFIR_LUT_G3 BIT(3)
4656 #define B_CFIR_LUT_G2 BIT(2)
4657 #define B_CFIR_LUT_GP_V1 GENMASK(2, 0)
4658 #define B_CFIR_LUT_GP GENMASK(1, 0)
4659 #define R_DPK_GN 0x819C
4660 #define B_DPK_GN_EN GENMASK(17, 16)
4661 #define B_DPK_GN_AG GENMASK(9, 0)
4662 #define R_DPD_V1 0x81a0
4663 #define B_DPD_LBK BIT(7)
4664 #define R_DPD_CH0 0x81AC
4665 #define R_DPD_BND 0x81B4
4666 #define B_DPD_BND_1 GENMASK(24, 16)
4667 #define B_DPD_BND_0 GENMASK(8, 0)
4668 #define R_DPD_CH0A 0x81BC
4669 #define B_DPD_MEN GENMASK(31, 28)
4670 #define B_DPD_ORDER GENMASK(26, 24)
4671 #define B_DPD_ORDER_V1 GENMASK(26, 25)
4672 #define B_DPD_CFG GENMASK(22, 0)
4673 #define B_DPD_SEL GENMASK(13, 8)
4674 #define R_TXAGC_RFK 0x81C4
4675 #define B_TXAGC_RFK_CH0 GENMASK(5, 0)
4676 #define R_DPD_COM 0x81C8
4677 #define B_DPD_COM_OF BIT(15)
4678 #define R_KIP_IQP 0x81CC
4679 #define B_KIP_IQP_SW GENMASK(13, 12)
4680 #define B_KIP_IQP_IQSW GENMASK(5, 0)
4681 #define R_KIP_RPT 0x81D4
4682 #define B_KIP_RPT_SEL GENMASK(21, 16)
4683 #define R_W_COEF 0x81D8
4684 #define R_LOAD_COEF 0x81DC
4685 #define B_LOAD_COEF_MDPD BIT(16)
4686 #define B_LOAD_COEF_CFIR GENMASK(1, 0)
4687 #define B_LOAD_COEF_DI BIT(1)
4688 #define B_LOAD_COEF_AUTO BIT(0)
4689 #define R_DPK_GL 0x81F0
4690 #define B_DPK_GL_A0 GENMASK(31, 28)
4691 #define B_DPK_GL_A1 GENMASK(17, 0)
4692 #define R_RPT_PER 0x81FC
4693 #define B_RPT_PER_TSSI GENMASK(28, 16)
4694 #define B_RPT_PER_OF GENMASK(15, 8)
4695 #define B_RPT_PER_TH GENMASK(5, 0)
4696 #define R_IQRSN 0x8220
4697 #define B_IQRSN_K1 BIT(28)
4698 #define B_IQRSN_K2 BIT(16)
4699 #define R_RXCFIR_P0C0 0x8D40
4700 #define R_RXCFIR_P0C1 0x8D84
4701 #define R_RXCFIR_P0C2 0x8DC8
4702 #define R_RXCFIR_P0C3 0x8E0C
4703 #define R_TXCFIR_P0C0 0x8F50
4704 #define R_TXCFIR_P0C1 0x8F84
4705 #define R_TXCFIR_P0C2 0x8FB8
4706 #define R_TXCFIR_P0C3 0x8FEC
4707 #define R_RXCFIR_P1C0 0x9140
4708 #define R_RXCFIR_P1C1 0x9184
4709 #define R_RXCFIR_P1C2 0x91C8
4710 #define R_RXCFIR_P1C3 0x920C
4711 #define R_TXCFIR_P1C0 0x9350
4712 #define R_TXCFIR_P1C1 0x9384
4713 #define R_TXCFIR_P1C2 0x93B8
4714 #define R_TXCFIR_P1C3 0x93EC
4715 #define R_IQKINF 0x9FE0
4716 #define B_IQKINF_VER GENMASK(31, 24)
4717 #define B_IQKINF_FAIL_RXGRP GENMASK(23, 16)
4718 #define B_IQKINF_FAIL_TXGRP GENMASK(15, 8)
4719 #define B_IQKINF_FAIL GENMASK(3, 0)
4720 #define B_IQKINF_F_RX BIT(3)
4721 #define B_IQKINF_FTX BIT(2)
4722 #define B_IQKINF_FFIN BIT(1)
4723 #define B_IQKINF_FCOR BIT(0)
4724 #define R_IQKCH 0x9FE4
4725 #define B_IQKCH_CH GENMASK(15, 8)
4726 #define B_IQKCH_BW GENMASK(7, 4)
4727 #define B_IQKCH_BAND GENMASK(3, 0)
4728 #define R_IQKINF2 0x9FE8
4729 #define B_IQKINF2_FCNT GENMASK(23, 16)
4730 #define B_IQKINF2_KCNT GENMASK(15, 8)
4731 #define B_IQKINF2_NCTLV GENMASK(7, 0)
4732 #define R_DCOF0 0xC000
4733 #define B_DCOF0_V GENMASK(4, 1)
4734 #define R_DCOF1 0xC004
4735 #define B_DCOF1_S BIT(0)
4736 #define R_DCOF8 0xC020
4737 #define B_DCOF8_V GENMASK(4, 1)
4738 #define R_DACK_S0P0 0xC040
4739 #define B_DACK_S0P0_OK BIT(31)
4740 #define R_DACK_BIAS00 0xc048
4741 #define B_DACK_BIAS00 GENMASK(11, 2)
4742 #define R_DACK_S0P2 0xC05C
4743 #define B_DACK_S0M0 GENMASK(31, 24)
4744 #define B_DACK_S0P2_OK BIT(2)
4745 #define R_DACK_DADCK00 0xC060
4746 #define B_DACK_DADCK00 GENMASK(31, 24)
4747 #define R_DACK_S0P1 0xC064
4748 #define B_DACK_S0P1_OK BIT(31)
4749 #define R_DACK_BIAS01 0xC06C
4750 #define B_DACK_BIAS01 GENMASK(11, 2)
4751 #define R_DACK_S0P3 0xC080
4752 #define B_DACK_S0M1 GENMASK(31, 24)
4753 #define B_DACK_S0P3_OK BIT(2)
4754 #define R_DACK_DADCK01 0xC084
4755 #define B_DACK_DADCK01 GENMASK(31, 24)
4756 #define R_DRCK_FH 0xC094
4757 #define B_DRCK_LAT BIT(9)
4758 #define R_DRCK 0xC0C4
4759 #define B_DRCK_MUL GENMASK(21, 17)
4760 #define B_DRCK_IDLE BIT(9)
4761 #define B_DRCK_EN BIT(6)
4762 #define B_DRCK_VAL GENMASK(4, 0)
4763 #define R_DRCK_RES 0xC0C8
4764 #define B_DRCK_RES GENMASK(19, 15)
4765 #define B_DRCK_POL BIT(3)
4766 #define R_DRCK_V1 0xC0CC
4767 #define B_DRCK_V1_SEL BIT(9)
4768 #define B_DRCK_V1_KICK BIT(6)
4769 #define B_DRCK_V1_CV GENMASK(4, 0)
4770 #define R_DRCK_RS 0xC0D0
4771 #define B_DRCK_RS_LPS GENMASK(19, 15)
4772 #define B_DRCK_RS_DONE BIT(3)
4773 #define R_PATH0_SAMPL_DLY_T_V1 0xC0D4
4774 #define B_PATH0_SAMPL_DLY_T_MSK_V1 GENMASK(27, 26)
4775 #define R_P0_CFCH_BW0 0xC0D4
4776 #define B_P0_CFCH_BW0 GENMASK(27, 26)
4777 #define B_P0_CFCH_EN GENMASK(14, 11)
4778 #define B_P0_CFCH_CTL GENMASK(10, 7)
4779 #define R_P0_CFCH_BW1 0xC0D8
4780 #define B_P0_CFCH_EX BIT(13)
4781 #define B_P0_CFCH_BW1 GENMASK(8, 5)
4782 #define R_ADCMOD 0xC0E8
4783 #define B_ADCMOD_LP GENMASK(31, 16)
4784 #define R_ADDCK0D 0xC0F0
4785 #define B_ADDCK0D_VAL2 GENMASK(31, 26)
4786 #define B_ADDCK0D_VAL GENMASK(25, 16)
4787 #define R_ADDCK0 0xC0F4
4788 #define B_ADDCK0_TRG BIT(11)
4789 #define B_ADDCK0 GENMASK(9, 8)
4790 #define B_ADDCK0_MAN GENMASK(5, 4)
4791 #define B_ADDCK0_EN BIT(4)
4792 #define B_ADDCK0_VAL GENMASK(3, 0)
4793 #define B_ADDCK0_RST BIT(2)
4794 #define R_ADDCK0_RL 0xC0F8
4795 #define B_ADDCK0_RLS GENMASK(29, 28)
4796 #define B_ADDCK0_RL1 GENMASK(27, 18)
4797 #define B_ADDCK0_RL0 GENMASK(17, 8)
4798 #define R_ADDCKR0 0xC0FC
4799 #define B_ADDCKR0_A0 GENMASK(19, 10)
4800 #define B_ADDCKR0_A1 GENMASK(9, 0)
4801 #define R_DACK10 0xC100
4802 #define B_DACK10 GENMASK(4, 1)
4803 #define R_DACK1_K 0xc104
4804 #define B_DACK1_EN BIT(0)
4805 #define R_DACK11 0xC120
4806 #define B_DACK11 GENMASK(4, 1)
4807 #define R_DACK_S1P0 0xC140
4808 #define B_DACK_S1P0_OK BIT(31)
4809 #define R_DACK_BIAS10 0xC148
4810 #define B_DACK_BIAS10 GENMASK(11, 2)
4811 #define R_DACK10S 0xC15C
4812 #define B_DACK10S GENMASK(31, 24)
4813 #define R_DACK_S1P2 0xC15C
4814 #define B_DACK_S1P2_OK BIT(2)
4815 #define R_DACK_DADCK10 0xC160
4816 #define B_DACK_DADCK10 GENMASK(31, 24)
4817 #define R_DACK_S1P1 0xC164
4818 #define B_DACK_S1P1_OK BIT(31)
4819 #define R_DACK_BIAS11 0xC16C
4820 #define B_DACK_BIAS11 GENMASK(11, 2)
4821 #define R_DACK11S 0xC180
4822 #define B_DACK11S GENMASK(31, 24)
4823 #define R_DACK_S1P3 0xC180
4824 #define B_DACK_S1P3_OK BIT(2)
4825 #define R_DACK_DADCK11 0xC184
4826 #define B_DACK_DADCK11 GENMASK(31, 24)
4827 #define R_PATH1_SAMPL_DLY_T_V1 0xC1D4
4828 #define B_PATH1_SAMPL_DLY_T_MSK_V1 GENMASK(27, 26)
4829 #define R_PATH0_BW_SEL_V1 0xC0D8
4830 #define B_PATH0_BW_SEL_MSK_V1 GENMASK(8, 5)
4831 #define R_PATH1_BW_SEL_V1 0xC1D8
4832 #define B_PATH1_BW_SEL_EX BIT(13)
4833 #define B_PATH1_BW_SEL_MSK_V1 GENMASK(8, 5)
4834 #define R_ADDCK1D 0xC1F0
4835 #define B_ADDCK1D_VAL2 GENMASK(31, 26)
4836 #define B_ADDCK1D_VAL GENMASK(25, 16)
4837 #define R_ADDCK1 0xC1F4
4838 #define B_ADDCK1_TRG BIT(11)
4839 #define B_ADDCK1 GENMASK(9, 8)
4840 #define B_ADDCK1_MAN GENMASK(5, 4)
4841 #define B_ADDCK1_EN BIT(4)
4842 #define B_ADDCK1_RST BIT(2)
4843 #define R_ADDCK1_RL 0xC1F8
4844 #define B_ADDCK1_RLS GENMASK(29, 28)
4845 #define B_ADDCK1_RL1 GENMASK(27, 18)
4846 #define B_ADDCK1_RL0 GENMASK(17, 8)
4847 #define R_ADDCKR1 0xC1fC
4848 #define B_ADDCKR1_A0 GENMASK(19, 10)
4849 #define B_ADDCKR1_A1 GENMASK(9, 0)
4850 
4851 /* WiFi CPU local domain */
4852 #define R_AX_WDT_CTRL 0x0040
4853 #define B_AX_WDT_EN BIT(31)
4854 #define B_AX_WDT_OPT_RESET_PLATFORM_EN BIT(29)
4855 #define B_AX_IO_HANG_IMR BIT(27)
4856 #define B_AX_IO_HANG_CMAC_RDATA_EN BIT(26)
4857 #define B_AX_IO_HANG_DMAC_EN BIT(25)
4858 #define B_AX_WDT_CLR BIT(16)
4859 #define B_AX_WDT_COUNT_MASK GENMASK(15, 0)
4860 #define WDT_CTRL_ALL_DIS 0
4861 
4862 #define R_AX_WDT_STATUS 0x0044
4863 #define B_AX_FS_WDT_INT BIT(8)
4864 #define B_AX_FS_WDT_INT_MSK BIT(0)
4865 
4866 #endif
4867