1// SPDX-License-Identifier: GPL-2.0-only
2/* Copyright (C) 2020 Felix Fietkau <nbd@nbd.name> */
3
4#ifndef __MTK_WED_REGS_H
5#define __MTK_WED_REGS_H
6
7#define MTK_WFDMA_DESC_CTRL_TO_HOST BIT(8)
8#define MTK_WDMA_DESC_CTRL_LEN1 GENMASK(14, 0)
9#define MTK_WDMA_DESC_CTRL_LEN1_V2 GENMASK(13, 0)
10#define MTK_WDMA_DESC_CTRL_LAST_SEG1 BIT(15)
11#define MTK_WDMA_DESC_CTRL_BURST BIT(16)
12#define MTK_WDMA_DESC_CTRL_LEN0 GENMASK(29, 16)
13#define MTK_WDMA_DESC_CTRL_LAST_SEG0 BIT(30)
14#define MTK_WDMA_DESC_CTRL_DMA_DONE BIT(31)
15
16#define MTK_WDMA_TXD0_DESC_INFO_DMA_DONE BIT(29)
17#define MTK_WDMA_TXD1_DESC_INFO_DMA_DONE BIT(31)
18
19struct mtk_wdma_desc {
20 __le32 buf0;
21 __le32 ctrl;
22 __le32 buf1;
23 __le32 info;
24} __packed __aligned(4);
25
26#define MTK_WED_REV_ID 0x004
27
28#define MTK_WED_RESET 0x008
29#define MTK_WED_RESET_TX_BM BIT(0)
30#define MTK_WED_RESET_RX_BM BIT(1)
31#define MTK_WED_RESET_RX_PG_BM BIT(2)
32#define MTK_WED_RESET_RRO_RX_TO_PG BIT(3)
33#define MTK_WED_RESET_TX_FREE_AGENT BIT(4)
34#define MTK_WED_RESET_WPDMA_TX_DRV BIT(8)
35#define MTK_WED_RESET_WPDMA_RX_DRV BIT(9)
36#define MTK_WED_RESET_WPDMA_RX_D_DRV BIT(10)
37#define MTK_WED_RESET_WPDMA_INT_AGENT BIT(11)
38#define MTK_WED_RESET_WED_TX_DMA BIT(12)
39#define MTK_WED_RESET_WED_RX_DMA BIT(13)
40#define MTK_WED_RESET_WDMA_TX_DRV BIT(16)
41#define MTK_WED_RESET_WDMA_RX_DRV BIT(17)
42#define MTK_WED_RESET_WDMA_INT_AGENT BIT(19)
43#define MTK_WED_RESET_RX_RRO_QM BIT(20)
44#define MTK_WED_RESET_RX_ROUTE_QM BIT(21)
45#define MTK_WED_RESET_TX_AMSDU BIT(22)
46#define MTK_WED_RESET_WED BIT(31)
47
48#define MTK_WED_CTRL 0x00c
49#define MTK_WED_CTRL_WPDMA_INT_AGENT_EN BIT(0)
50#define MTK_WED_CTRL_WPDMA_INT_AGENT_BUSY BIT(1)
51#define MTK_WED_CTRL_WDMA_INT_AGENT_EN BIT(2)
52#define MTK_WED_CTRL_WDMA_INT_AGENT_BUSY BIT(3)
53#define MTK_WED_CTRL_WED_RX_IND_CMD_EN BIT(5)
54#define MTK_WED_CTRL_WED_RX_PG_BM_EN BIT(6)
55#define MTK_WED_CTRL_WED_RX_PG_BM_BUSY BIT(7)
56#define MTK_WED_CTRL_WED_TX_BM_EN BIT(8)
57#define MTK_WED_CTRL_WED_TX_BM_BUSY BIT(9)
58#define MTK_WED_CTRL_WED_TX_FREE_AGENT_EN BIT(10)
59#define MTK_WED_CTRL_WED_TX_FREE_AGENT_BUSY BIT(11)
60#define MTK_WED_CTRL_WED_RX_BM_EN BIT(12)
61#define MTK_WED_CTRL_WED_RX_BM_BUSY BIT(13)
62#define MTK_WED_CTRL_RX_RRO_QM_EN BIT(14)
63#define MTK_WED_CTRL_RX_RRO_QM_BUSY BIT(15)
64#define MTK_WED_CTRL_RX_ROUTE_QM_EN BIT(16)
65#define MTK_WED_CTRL_RX_ROUTE_QM_BUSY BIT(17)
66#define MTK_WED_CTRL_TX_TKID_ALI_EN BIT(20)
67#define MTK_WED_CTRL_TX_TKID_ALI_BUSY BIT(21)
68#define MTK_WED_CTRL_TX_AMSDU_EN BIT(22)
69#define MTK_WED_CTRL_TX_AMSDU_BUSY BIT(23)
70#define MTK_WED_CTRL_FINAL_DIDX_READ BIT(24)
71#define MTK_WED_CTRL_ETH_DMAD_FMT BIT(25)
72#define MTK_WED_CTRL_MIB_READ_CLEAR BIT(28)
73#define MTK_WED_CTRL_FLD_MIB_RD_CLR BIT(28)
74
75#define MTK_WED_EXT_INT_STATUS 0x020
76#define MTK_WED_EXT_INT_STATUS_TF_LEN_ERR BIT(0)
77#define MTK_WED_EXT_INT_STATUS_TKID_WO_PYLD BIT(1)
78#define MTK_WED_EXT_INT_STATUS_TKID_TITO_INVALID BIT(4)
79#define MTK_WED_EXT_INT_STATUS_TX_FBUF_LO_TH BIT(8)
80#define MTK_WED_EXT_INT_STATUS_TX_FBUF_HI_TH BIT(9)
81#define MTK_WED_EXT_INT_STATUS_RX_FBUF_LO_TH BIT(10) /* wed v2 */
82#define MTK_WED_EXT_INT_STATUS_RX_FBUF_HI_TH BIT(11) /* wed v2 */
83#define MTK_WED_EXT_INT_STATUS_RX_DRV_R_RESP_ERR BIT(16)
84#define MTK_WED_EXT_INT_STATUS_RX_DRV_W_RESP_ERR BIT(17)
85#define MTK_WED_EXT_INT_STATUS_RX_DRV_COHERENT BIT(18)
86#define MTK_WED_EXT_INT_STATUS_RX_DRV_INIT_WDMA_EN BIT(19)
87#define MTK_WED_EXT_INT_STATUS_RX_DRV_BM_DMAD_COHERENT BIT(20)
88#define MTK_WED_EXT_INT_STATUS_TX_DRV_R_RESP_ERR BIT(21)
89#define MTK_WED_EXT_INT_STATUS_TX_DMA_R_RESP_ERR BIT(22)
90#define MTK_WED_EXT_INT_STATUS_TX_DMA_W_RESP_ERR BIT(23)
91#define MTK_WED_EXT_INT_STATUS_RX_DRV_DMA_RECYCLE BIT(24)
92#define MTK_WED_EXT_INT_STATUS_RX_DRV_GET_BM_DMAD_SKIP BIT(25)
93#define MTK_WED_EXT_INT_STATUS_WPDMA_RX_D_DRV_ERR BIT(26)
94#define MTK_WED_EXT_INT_STATUS_WPDMA_MID_RDY BIT(27)
95#define MTK_WED_EXT_INT_STATUS_ERROR_MASK (MTK_WED_EXT_INT_STATUS_TF_LEN_ERR | \
96 MTK_WED_EXT_INT_STATUS_TKID_WO_PYLD | \
97 MTK_WED_EXT_INT_STATUS_TKID_TITO_INVALID | \
98 MTK_WED_EXT_INT_STATUS_RX_DRV_R_RESP_ERR | \
99 MTK_WED_EXT_INT_STATUS_RX_DRV_W_RESP_ERR | \
100 MTK_WED_EXT_INT_STATUS_RX_DRV_INIT_WDMA_EN | \
101 MTK_WED_EXT_INT_STATUS_TX_DMA_R_RESP_ERR)
102
103#define MTK_WED_EXT_INT_MASK 0x028
104#define MTK_WED_EXT_INT_MASK1 0x02c
105#define MTK_WED_EXT_INT_MASK2 0x030
106#define MTK_WED_EXT_INT_MASK3 0x034
107
108#define MTK_WED_STATUS 0x060
109#define MTK_WED_STATUS_TX GENMASK(15, 8)
110
111#define MTK_WED_WPDMA_STATUS 0x068
112#define MTK_WED_WPDMA_STATUS_TX_DRV GENMASK(15, 8)
113
114#define MTK_WED_TX_BM_CTRL 0x080
115#define MTK_WED_TX_BM_CTRL_VLD_GRP_NUM GENMASK(6, 0)
116#define MTK_WED_TX_BM_CTRL_RSV_GRP_NUM GENMASK(22, 16)
117#define MTK_WED_TX_BM_CTRL_LEGACY_EN BIT(26)
118#define MTK_WED_TX_TKID_CTRL_FREE_FORMAT BIT(27)
119#define MTK_WED_TX_BM_CTRL_PAUSE BIT(28)
120
121#define MTK_WED_TX_BM_BASE 0x084
122#define MTK_WED_TX_BM_INIT_PTR 0x088
123#define MTK_WED_TX_BM_SW_TAIL_IDX GENMASK(16, 0)
124#define MTK_WED_TX_BM_INIT_SW_TAIL_IDX BIT(16)
125
126#define MTK_WED_TX_BM_TKID_START GENMASK(15, 0)
127#define MTK_WED_TX_BM_TKID_END GENMASK(31, 16)
128
129#define MTK_WED_TX_BM_BUF_LEN 0x08c
130
131#define MTK_WED_TX_BM_INTF 0x09c
132#define MTK_WED_TX_BM_INTF_TKID GENMASK(15, 0)
133#define MTK_WED_TX_BM_INTF_TKFIFO_FDEP GENMASK(23, 16)
134#define MTK_WED_TX_BM_INTF_TKID_VALID BIT(28)
135#define MTK_WED_TX_BM_INTF_TKID_READ BIT(29)
136
137#define MTK_WED_TX_BM_DYN_THR 0x0a0
138#define MTK_WED_TX_BM_DYN_THR_LO GENMASK(6, 0)
139#define MTK_WED_TX_BM_DYN_THR_LO_V2 GENMASK(8, 0)
140#define MTK_WED_TX_BM_DYN_THR_HI GENMASK(22, 16)
141#define MTK_WED_TX_BM_DYN_THR_HI_V2 GENMASK(24, 16)
142
143#define MTK_WED_TX_TKID_CTRL 0x0c0
144#define MTK_WED_TX_TKID_CTRL_VLD_GRP_NUM GENMASK(6, 0)
145#define MTK_WED_TX_TKID_CTRL_RSV_GRP_NUM GENMASK(22, 16)
146#define MTK_WED_TX_TKID_CTRL_PAUSE BIT(28)
147
148#define MTK_WED_TX_TKID_INTF 0x0dc
149#define MTK_WED_TX_TKID_INTF_TKFIFO_FDEP GENMASK(25, 16)
150
151#define MTK_WED_TX_TKID_CTRL_VLD_GRP_NUM_V3 GENMASK(7, 0)
152#define MTK_WED_TX_TKID_CTRL_RSV_GRP_NUM_V3 GENMASK(23, 16)
153
154#define MTK_WED_TX_TKID_DYN_THR 0x0e0
155#define MTK_WED_TX_TKID_DYN_THR_LO GENMASK(6, 0)
156#define MTK_WED_TX_TKID_DYN_THR_HI GENMASK(22, 16)
157
158#define MTK_WED_TXP_DW0 0x120
159#define MTK_WED_TXP_DW1 0x124
160#define MTK_WED_WPDMA_WRITE_TXP GENMASK(31, 16)
161#define MTK_WED_TXDP_CTRL 0x130
162#define MTK_WED_TXDP_DW9_OVERWR BIT(9)
163#define MTK_WED_RX_BM_TKID_MIB 0x1cc
164
165#define MTK_WED_INT_STATUS 0x200
166#define MTK_WED_INT_MASK 0x204
167
168#define MTK_WED_GLO_CFG 0x208
169#define MTK_WED_GLO_CFG_TX_DMA_EN BIT(0)
170#define MTK_WED_GLO_CFG_TX_DMA_BUSY BIT(1)
171#define MTK_WED_GLO_CFG_RX_DMA_EN BIT(2)
172#define MTK_WED_GLO_CFG_RX_DMA_BUSY BIT(3)
173#define MTK_WED_GLO_CFG_RX_BT_SIZE GENMASK(5, 4)
174#define MTK_WED_GLO_CFG_TX_WB_DDONE BIT(6)
175#define MTK_WED_GLO_CFG_BIG_ENDIAN BIT(7)
176#define MTK_WED_GLO_CFG_DIS_BT_SIZE_ALIGN BIT(8)
177#define MTK_WED_GLO_CFG_TX_BT_SIZE_LO BIT(9)
178#define MTK_WED_GLO_CFG_MULTI_DMA_EN GENMASK(11, 10)
179#define MTK_WED_GLO_CFG_FIFO_LITTLE_ENDIAN BIT(12)
180#define MTK_WED_GLO_CFG_MI_DEPTH_RD GENMASK(21, 13)
181#define MTK_WED_GLO_CFG_TX_BT_SIZE_HI GENMASK(23, 22)
182#define MTK_WED_GLO_CFG_SW_RESET BIT(24)
183#define MTK_WED_GLO_CFG_FIRST_TOKEN_ONLY BIT(26)
184#define MTK_WED_GLO_CFG_OMIT_RX_INFO BIT(27)
185#define MTK_WED_GLO_CFG_OMIT_TX_INFO BIT(28)
186#define MTK_WED_GLO_CFG_BYTE_SWAP BIT(29)
187#define MTK_WED_GLO_CFG_RX_2B_OFFSET BIT(31)
188
189#define MTK_WED_RESET_IDX 0x20c
190#define MTK_WED_RESET_WPDMA_IDX_RX GENMASK(31, 30)
191
192#define MTK_WED_TX_MIB(_n) (0x2a0 + (_n) * 4)
193#define MTK_WED_RX_MIB(_n) (0x2e0 + (_n) * 4)
194
195#define MTK_WED_RING_TX(_n) (0x300 + (_n) * 0x10)
196
197#define MTK_WED_RING_RX(_n) (0x400 + (_n) * 0x10)
198#define MTK_WED_RING_RX_DATA(_n) (0x420 + (_n) * 0x10)
199
200#define MTK_WED_SCR0 0x3c0
201#define MTK_WED_RX1_CTRL2 0x418
202#define MTK_WED_WPDMA_INT_TRIGGER 0x504
203#define MTK_WED_WPDMA_INT_TRIGGER_RX_DONE BIT(1)
204#define MTK_WED_WPDMA_INT_TRIGGER_TX_DONE GENMASK(5, 4)
205
206#define MTK_WED_WPDMA_GLO_CFG 0x508
207#define MTK_WED_WPDMA_GLO_CFG_TX_DRV_EN BIT(0)
208#define MTK_WED_WPDMA_GLO_CFG_TX_DRV_BUSY BIT(1)
209#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_EN BIT(2)
210#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_BUSY BIT(3)
211#define MTK_WED_WPDMA_GLO_CFG_RX_BT_SIZE GENMASK(5, 4)
212#define MTK_WED_WPDMA_GLO_CFG_TX_WB_DDONE BIT(6)
213#define MTK_WED_WPDMA_GLO_CFG_BIG_ENDIAN BIT(7)
214#define MTK_WED_WPDMA_GLO_CFG_DIS_BT_SIZE_ALIGN BIT(8)
215#define MTK_WED_WPDMA_GLO_CFG_TX_BT_SIZE_LO BIT(9)
216#define MTK_WED_WPDMA_GLO_CFG_MULTI_DMA_EN GENMASK(11, 10)
217#define MTK_WED_WPDMA_GLO_CFG_FIFO_LITTLE_ENDIAN BIT(12)
218#define MTK_WED_WPDMA_GLO_CFG_MI_DEPTH_RD GENMASK(21, 13)
219#define MTK_WED_WPDMA_GLO_CFG_TX_BT_SIZE_HI GENMASK(23, 22)
220#define MTK_WED_WPDMA_GLO_CFG_SW_RESET BIT(24)
221#define MTK_WED_WPDMA_GLO_CFG_FIRST_TOKEN_ONLY BIT(26)
222#define MTK_WED_WPDMA_GLO_CFG_OMIT_RX_INFO BIT(27)
223#define MTK_WED_WPDMA_GLO_CFG_OMIT_TX_INFO BIT(28)
224#define MTK_WED_WPDMA_GLO_CFG_BYTE_SWAP BIT(29)
225#define MTK_WED_WPDMA_GLO_CFG_RX_2B_OFFSET BIT(31)
226
227/* CONFIG_MEDIATEK_NETSYS_V2 */
228#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_R0_PKT_PROC BIT(4)
229#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_R1_PKT_PROC BIT(5)
230#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_R0_CRX_SYNC BIT(6)
231#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_R1_CRX_SYNC BIT(7)
232#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_EVENT_PKT_FMT_VER GENMASK(15, 12)
233#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_UNS_VER_FORCE_4 BIT(18)
234#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_UNSUPPORT_FMT BIT(19)
235#define MTK_WED_WPDMA_GLO_CFG_RX_DRV_EVENT_PKT_FMT_CHK BIT(20)
236#define MTK_WED_WPDMA_GLO_CFG_RX_DDONE2_WR BIT(21)
237#define MTK_WED_WPDMA_GLO_CFG_TX_TKID_KEEP BIT(24)
238#define MTK_WED_WPDMA_GLO_CFG_TX_DDONE_CHK_LAST BIT(25)
239#define MTK_WED_WPDMA_GLO_CFG_TX_DMAD_DW3_PREV BIT(28)
240#define MTK_WED_WPDMA_GLO_CFG_TX_DDONE_CHK BIT(30)
241
242#define MTK_WED_WPDMA_RESET_IDX 0x50c
243#define MTK_WED_WPDMA_RESET_IDX_TX GENMASK(3, 0)
244#define MTK_WED_WPDMA_RESET_IDX_RX GENMASK(17, 16)
245
246#define MTK_WED_WPDMA_CTRL 0x518
247#define MTK_WED_WPDMA_CTRL_SDL1_FIXED BIT(31)
248
249#define MTK_WED_WPDMA_INT_CTRL 0x520
250#define MTK_WED_WPDMA_INT_CTRL_SUBRT_ADV BIT(21)
251#define MTK_WED_WPDMA_INT_CTRL_SIG_SRC BIT(22)
252#define MTK_WED_WPDMA_INT_CTRL_SRC_SEL GENMASK(17, 16)
253
254#define MTK_WED_WPDMA_INT_MASK 0x524
255
256#define MTK_WED_WPDMA_INT_CTRL_TX 0x530
257#define MTK_WED_WPDMA_INT_CTRL_TX0_DONE_EN BIT(0)
258#define MTK_WED_WPDMA_INT_CTRL_TX0_DONE_CLR BIT(1)
259#define MTK_WED_WPDMA_INT_CTRL_TX0_DONE_TRIG GENMASK(6, 2)
260#define MTK_WED_WPDMA_INT_CTRL_TX1_DONE_EN BIT(8)
261#define MTK_WED_WPDMA_INT_CTRL_TX1_DONE_CLR BIT(9)
262#define MTK_WED_WPDMA_INT_CTRL_TX1_DONE_TRIG GENMASK(14, 10)
263
264#define MTK_WED_WPDMA_INT_CTRL_RX 0x534
265#define MTK_WED_WPDMA_INT_CTRL_RX0_EN BIT(0)
266#define MTK_WED_WPDMA_INT_CTRL_RX0_CLR BIT(1)
267#define MTK_WED_WPDMA_INT_CTRL_RX0_DONE_TRIG GENMASK(6, 2)
268#define MTK_WED_WPDMA_INT_CTRL_RX1_EN BIT(8)
269#define MTK_WED_WPDMA_INT_CTRL_RX1_CLR BIT(9)
270#define MTK_WED_WPDMA_INT_CTRL_RX1_DONE_TRIG GENMASK(14, 10)
271
272#define MTK_WED_WPDMA_INT_CTRL_TX_FREE 0x538
273#define MTK_WED_WPDMA_INT_CTRL_TX_FREE_DONE_EN BIT(0)
274#define MTK_WED_WPDMA_INT_CTRL_TX_FREE_DONE_CLR BIT(1)
275#define MTK_WED_WPDMA_INT_CTRL_TX_FREE_DONE_TRIG GENMASK(6, 2)
276
277#define MTK_WED_PCIE_CFG_BASE 0x560
278
279#define MTK_WED_PCIE_CFG_BASE 0x560
280#define MTK_WED_PCIE_CFG_INTM 0x564
281#define MTK_WED_PCIE_CFG_MSIS 0x568
282#define MTK_WED_PCIE_INT_TRIGGER 0x570
283#define MTK_WED_PCIE_INT_TRIGGER_STATUS BIT(16)
284
285#define MTK_WED_PCIE_INT_CTRL 0x57c
286#define MTK_WED_PCIE_INT_CTRL_POLL_EN GENMASK(13, 12)
287#define MTK_WED_PCIE_INT_CTRL_SRC_SEL GENMASK(17, 16)
288#define MTK_WED_PCIE_INT_CTRL_MSK_EN_POLA BIT(20)
289#define MTK_WED_PCIE_INT_CTRL_MSK_IRQ_FILTER BIT(21)
290
291#define MTK_WED_WPDMA_CFG_BASE 0x580
292#define MTK_WED_WPDMA_CFG_INT_MASK 0x584
293#define MTK_WED_WPDMA_CFG_TX 0x588
294#define MTK_WED_WPDMA_CFG_TX_FREE 0x58c
295
296#define MTK_WED_WPDMA_TX_MIB(_n) (0x5a0 + (_n) * 4)
297#define MTK_WED_WPDMA_TX_COHERENT_MIB(_n) (0x5d0 + (_n) * 4)
298#define MTK_WED_WPDMA_RX_MIB(_n) (0x5e0 + (_n) * 4)
299#define MTK_WED_WPDMA_RX_COHERENT_MIB(_n) (0x5f0 + (_n) * 4)
300
301#define MTK_WED_WPDMA_RING_TX(_n) (0x600 + (_n) * 0x10)
302#define MTK_WED_WPDMA_RING_RX(_n) (0x700 + (_n) * 0x10)
303#define MTK_WED_WPDMA_RING_RX_DATA(_n) (0x730 + (_n) * 0x10)
304
305#define MTK_WED_WPDMA_RX_D_GLO_CFG 0x75c
306#define MTK_WED_WPDMA_RX_D_RX_DRV_EN BIT(0)
307#define MTK_WED_WPDMA_RX_D_RX_DRV_BUSY BIT(1)
308#define MTK_WED_WPDMA_RX_D_FSM_RETURN_IDLE BIT(3)
309#define MTK_WED_WPDMA_RX_D_RST_INIT_COMPLETE BIT(4)
310#define MTK_WED_WPDMA_RX_D_INIT_PHASE_RXEN_SEL GENMASK(11, 7)
311#define MTK_WED_WPDMA_RX_D_RXD_READ_LEN GENMASK(31, 24)
312
313#define MTK_WED_WPDMA_RX_D_RST_IDX 0x760
314#define MTK_WED_WPDMA_RX_D_RST_CRX_IDX GENMASK(17, 16)
315#define MTK_WED_WPDMA_RX_D_RST_DRV_IDX_ALL BIT(20)
316#define MTK_WED_WPDMA_RX_D_RST_DRV_IDX GENMASK(25, 24)
317
318#define MTK_WED_WPDMA_RX_GLO_CFG 0x76c
319
320#define MTK_WED_WPDMA_RX_D_MIB(_n) (0x774 + (_n) * 4)
321#define MTK_WED_WPDMA_RX_D_PROCESSED_MIB(_n) (0x784 + (_n) * 4)
322#define MTK_WED_WPDMA_RX_D_COHERENT_MIB 0x78c
323
324#define MTK_WED_WPDMA_RX_D_PREF_CFG 0x7b4
325#define MTK_WED_WPDMA_RX_D_PREF_EN BIT(0)
326#define MTK_WED_WPDMA_RX_D_PREF_BUSY BIT(1)
327#define MTK_WED_WPDMA_RX_D_PREF_BURST_SIZE GENMASK(12, 8)
328#define MTK_WED_WPDMA_RX_D_PREF_LOW_THRES GENMASK(21, 16)
329
330#define MTK_WED_WPDMA_RX_D_PREF_RX0_SIDX 0x7b8
331#define MTK_WED_WPDMA_RX_D_PREF_SIDX_IDX_CLR BIT(15)
332
333#define MTK_WED_WPDMA_RX_D_PREF_RX1_SIDX 0x7bc
334
335#define MTK_WED_WPDMA_RX_D_PREF_FIFO_CFG 0x7c0
336#define MTK_WED_WPDMA_RX_D_PREF_FIFO_CFG_R0_CLR BIT(0)
337#define MTK_WED_WPDMA_RX_D_PREF_FIFO_CFG_R1_CLR BIT(16)
338
339#define MTK_WED_WDMA_RING_TX 0x800
340
341#define MTK_WED_WDMA_TX_MIB 0x810
342
343#define MTK_WED_WDMA_RING_RX(_n) (0x900 + (_n) * 0x10)
344#define MTK_WED_WDMA_RX_THRES(_n) (0x940 + (_n) * 0x4)
345
346#define MTK_WED_WDMA_RX_PREF_CFG 0x950
347#define MTK_WED_WDMA_RX_PREF_EN BIT(0)
348#define MTK_WED_WDMA_RX_PREF_BUSY BIT(1)
349#define MTK_WED_WDMA_RX_PREF_BURST_SIZE GENMASK(12, 8)
350#define MTK_WED_WDMA_RX_PREF_LOW_THRES GENMASK(21, 16)
351#define MTK_WED_WDMA_RX_PREF_RX0_SIDX_CLR BIT(24)
352#define MTK_WED_WDMA_RX_PREF_RX1_SIDX_CLR BIT(25)
353#define MTK_WED_WDMA_RX_PREF_DDONE2_EN BIT(26)
354#define MTK_WED_WDMA_RX_PREF_DDONE2_BUSY BIT(27)
355
356#define MTK_WED_WDMA_RX_PREF_FIFO_CFG 0x95C
357#define MTK_WED_WDMA_RX_PREF_FIFO_RX0_CLR BIT(0)
358#define MTK_WED_WDMA_RX_PREF_FIFO_RX1_CLR BIT(16)
359
360#define MTK_WED_WDMA_GLO_CFG 0xa04
361#define MTK_WED_WDMA_GLO_CFG_TX_DRV_EN BIT(0)
362#define MTK_WED_WDMA_GLO_CFG_TX_DDONE_CHK BIT(1)
363#define MTK_WED_WDMA_GLO_CFG_RX_DRV_EN BIT(2)
364#define MTK_WED_WDMA_GLO_CFG_RX_DRV_BUSY BIT(3)
365#define MTK_WED_WDMA_GLO_CFG_BT_SIZE GENMASK(5, 4)
366#define MTK_WED_WDMA_GLO_CFG_TX_WB_DDONE BIT(6)
367#define MTK_WED_WDMA_GLO_CFG_RX_DIS_FSM_AUTO_IDLE BIT(13)
368#define MTK_WED_WDMA_GLO_CFG_WCOMPLETE_SEL BIT(16)
369#define MTK_WED_WDMA_GLO_CFG_INIT_PHASE_RXDMA_BYPASS BIT(17)
370#define MTK_WED_WDMA_GLO_CFG_INIT_PHASE_BYPASS BIT(18)
371#define MTK_WED_WDMA_GLO_CFG_FSM_RETURN_IDLE BIT(19)
372#define MTK_WED_WDMA_GLO_CFG_WAIT_COHERENT BIT(20)
373#define MTK_WED_WDMA_GLO_CFG_AXI_W_AFTER_AW BIT(21)
374#define MTK_WED_WDMA_GLO_CFG_IDLE_DMAD_SUPPLY_SINGLE_W BIT(22)
375#define MTK_WED_WDMA_GLO_CFG_IDLE_DMAD_SUPPLY BIT(23)
376#define MTK_WED_WDMA_GLO_CFG_DYNAMIC_SKIP_DMAD_PREP BIT(24)
377#define MTK_WED_WDMA_GLO_CFG_DYNAMIC_DMAD_RECYCLE BIT(25)
378#define MTK_WED_WDMA_GLO_CFG_RST_INIT_COMPLETE BIT(26)
379#define MTK_WED_WDMA_GLO_CFG_RXDRV_CLKGATE_BYPASS BIT(30)
380
381#define MTK_WED_WDMA_RESET_IDX 0xa08
382#define MTK_WED_WDMA_RESET_IDX_RX GENMASK(17, 16)
383#define MTK_WED_WDMA_RESET_IDX_RX_ALL BIT(20)
384#define MTK_WED_WDMA_RESET_IDX_DRV GENMASK(25, 24)
385
386#define MTK_WED_WDMA_INT_CLR 0xa24
387#define MTK_WED_WDMA_INT_CLR_RX_DONE GENMASK(17, 16)
388
389#define MTK_WED_WDMA_INT_TRIGGER 0xa28
390#define MTK_WED_WDMA_INT_TRIGGER_RX_DONE GENMASK(17, 16)
391
392#define MTK_WED_WDMA_INT_CTRL 0xa2c
393#define MTK_WED_WDMA_INT_POLL_PRD GENMASK(7, 0)
394#define MTK_WED_WDMA_INT_CTRL_POLL_SRC_SEL GENMASK(17, 16)
395
396#define MTK_WED_WDMA_CFG_BASE 0xaa0
397#define MTK_WED_WDMA_OFFSET0 0xaa4
398#define MTK_WED_WDMA_OFFSET1 0xaa8
399
400#define MTK_WED_WDMA_OFST0_GLO_INTS GENMASK(15, 0)
401#define MTK_WED_WDMA_OFST0_GLO_CFG GENMASK(31, 16)
402#define MTK_WED_WDMA_OFST1_TX_CTRL GENMASK(15, 0)
403#define MTK_WED_WDMA_OFST1_RX_CTRL GENMASK(31, 16)
404
405#define MTK_WED_WDMA_RX_MIB(_n) (0xae0 + (_n) * 4)
406#define MTK_WED_WDMA_RX_RECYCLE_MIB(_n) (0xae8 + (_n) * 4)
407#define MTK_WED_WDMA_RX_PROCESSED_MIB(_n) (0xaf0 + (_n) * 4)
408
409#define MTK_WED_RX_BM_RX_DMAD 0xd80
410#define MTK_WED_RX_BM_RX_DMAD_SDL0 GENMASK(13, 0)
411
412#define MTK_WED_RX_BM_BASE 0xd84
413#define MTK_WED_RX_BM_INIT_PTR 0xd88
414#define MTK_WED_RX_BM_SW_TAIL GENMASK(15, 0)
415#define MTK_WED_RX_BM_INIT_SW_TAIL BIT(16)
416
417#define MTK_WED_RX_PTR 0xd8c
418
419#define MTK_WED_RX_BM_DYN_ALLOC_TH 0xdb4
420#define MTK_WED_RX_BM_DYN_ALLOC_TH_H GENMASK(31, 16)
421#define MTK_WED_RX_BM_DYN_ALLOC_TH_L GENMASK(15, 0)
422
423#define MTK_WED_RING_OFS_BASE 0x00
424#define MTK_WED_RING_OFS_COUNT 0x04
425#define MTK_WED_RING_OFS_CPU_IDX 0x08
426#define MTK_WED_RING_OFS_DMA_IDX 0x0c
427
428#define MTK_WDMA_RING_TX(_n) (0x000 + (_n) * 0x10)
429#define MTK_WDMA_RING_RX(_n) (0x100 + (_n) * 0x10)
430
431#define MTK_WDMA_GLO_CFG 0x204
432#define MTK_WDMA_GLO_CFG_TX_DMA_EN BIT(0)
433#define MTK_WDMA_GLO_CFG_TX_DMA_BUSY BIT(1)
434#define MTK_WDMA_GLO_CFG_RX_DMA_EN BIT(2)
435#define MTK_WDMA_GLO_CFG_RX_DMA_BUSY BIT(3)
436#define MTK_WDMA_GLO_CFG_RX_INFO3_PRERES BIT(26)
437#define MTK_WDMA_GLO_CFG_RX_INFO2_PRERES BIT(27)
438#define MTK_WDMA_GLO_CFG_RX_INFO1_PRERES BIT(28)
439
440#define MTK_WDMA_RESET_IDX 0x208
441#define MTK_WDMA_RESET_IDX_TX GENMASK(3, 0)
442#define MTK_WDMA_RESET_IDX_RX GENMASK(17, 16)
443
444#define MTK_WDMA_INT_STATUS 0x220
445
446#define MTK_WDMA_INT_MASK 0x228
447#define MTK_WDMA_INT_MASK_TX_DONE GENMASK(3, 0)
448#define MTK_WDMA_INT_MASK_RX_DONE GENMASK(17, 16)
449#define MTK_WDMA_INT_MASK_TX_DELAY BIT(28)
450#define MTK_WDMA_INT_MASK_TX_COHERENT BIT(29)
451#define MTK_WDMA_INT_MASK_RX_DELAY BIT(30)
452#define MTK_WDMA_INT_MASK_RX_COHERENT BIT(31)
453
454#define MTK_WDMA_XDMA_TX_FIFO_CFG 0x238
455#define MTK_WDMA_XDMA_TX_FIFO_CFG_TX_PAR_FIFO_CLEAR BIT(0)
456#define MTK_WDMA_XDMA_TX_FIFO_CFG_TX_CMD_FIFO_CLEAR BIT(4)
457#define MTK_WDMA_XDMA_TX_FIFO_CFG_TX_DMAD_FIFO_CLEAR BIT(8)
458#define MTK_WDMA_XDMA_TX_FIFO_CFG_TX_ARR_FIFO_CLEAR BIT(12)
459
460#define MTK_WDMA_XDMA_RX_FIFO_CFG 0x23c
461#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_PAR_FIFO_CLEAR BIT(0)
462#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_CMD_FIFO_CLEAR BIT(4)
463#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_DMAD_FIFO_CLEAR BIT(8)
464#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_ARR_FIFO_CLEAR BIT(12)
465#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_LEN_FIFO_CLEAR BIT(15)
466#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_WID_FIFO_CLEAR BIT(18)
467#define MTK_WDMA_XDMA_RX_FIFO_CFG_RX_BID_FIFO_CLEAR BIT(21)
468
469#define MTK_WDMA_INT_GRP1 0x250
470#define MTK_WDMA_INT_GRP2 0x254
471
472#define MTK_WDMA_PREF_TX_CFG 0x2d0
473#define MTK_WDMA_PREF_TX_CFG_PREF_EN BIT(0)
474#define MTK_WDMA_PREF_TX_CFG_PREF_BUSY BIT(1)
475
476#define MTK_WDMA_PREF_RX_CFG 0x2dc
477#define MTK_WDMA_PREF_RX_CFG_PREF_EN BIT(0)
478#define MTK_WDMA_PREF_RX_CFG_PREF_BUSY BIT(1)
479
480#define MTK_WDMA_PREF_RX_FIFO_CFG 0x2e0
481#define MTK_WDMA_PREF_RX_FIFO_CFG_RING0_CLEAR BIT(0)
482#define MTK_WDMA_PREF_RX_FIFO_CFG_RING1_CLEAR BIT(16)
483
484#define MTK_WDMA_PREF_TX_FIFO_CFG 0x2d4
485#define MTK_WDMA_PREF_TX_FIFO_CFG_RING0_CLEAR BIT(0)
486#define MTK_WDMA_PREF_TX_FIFO_CFG_RING1_CLEAR BIT(16)
487
488#define MTK_WDMA_PREF_SIDX_CFG 0x2e4
489#define MTK_WDMA_PREF_SIDX_CFG_TX_RING_CLEAR GENMASK(3, 0)
490#define MTK_WDMA_PREF_SIDX_CFG_RX_RING_CLEAR GENMASK(5, 4)
491
492#define MTK_WDMA_WRBK_TX_CFG 0x300
493#define MTK_WDMA_WRBK_TX_CFG_WRBK_BUSY BIT(0)
494#define MTK_WDMA_WRBK_TX_CFG_WRBK_EN BIT(30)
495
496#define MTK_WDMA_WRBK_TX_FIFO_CFG(_n) (0x304 + (_n) * 0x4)
497#define MTK_WDMA_WRBK_TX_FIFO_CFG_RING_CLEAR BIT(0)
498
499#define MTK_WDMA_WRBK_RX_CFG 0x344
500#define MTK_WDMA_WRBK_RX_CFG_WRBK_BUSY BIT(0)
501#define MTK_WDMA_WRBK_RX_CFG_WRBK_EN BIT(30)
502
503#define MTK_WDMA_WRBK_RX_FIFO_CFG(_n) (0x348 + (_n) * 0x4)
504#define MTK_WDMA_WRBK_RX_FIFO_CFG_RING_CLEAR BIT(0)
505
506#define MTK_WDMA_WRBK_SIDX_CFG 0x388
507#define MTK_WDMA_WRBK_SIDX_CFG_TX_RING_CLEAR GENMASK(3, 0)
508#define MTK_WDMA_WRBK_SIDX_CFG_RX_RING_CLEAR GENMASK(5, 4)
509
510#define MTK_PCIE_MIRROR_MAP(n) ((n) ? 0x4 : 0x0)
511#define MTK_PCIE_MIRROR_MAP_EN BIT(0)
512#define MTK_PCIE_MIRROR_MAP_WED_ID BIT(1)
513
514/* DMA channel mapping */
515#define HIFSYS_DMA_AG_MAP 0x008
516
517#define MTK_WED_RTQM_GLO_CFG 0xb00
518#define MTK_WED_RTQM_BUSY BIT(1)
519#define MTK_WED_RTQM_Q_RST BIT(2)
520#define MTK_WED_RTQM_Q_DBG_BYPASS BIT(5)
521#define MTK_WED_RTQM_TXDMAD_FPORT GENMASK(23, 20)
522
523#define MTK_WED_RTQM_RST 0xb04
524
525#define MTK_WED_RTQM_IGRS0_I2HW_DMAD_CNT 0xb1c
526#define MTK_WED_RTQM_IGRS0_I2H_DMAD_CNT(_n) (0xb20 + (_n) * 0x4)
527#define MTK_WED_RTQM_IGRS0_I2HW_PKT_CNT 0xb28
528#define MTK_WED_RTQM_IGRS0_I2H_PKT_CNT(_n) (0xb2c + (_n) * 0x4)
529#define MTK_WED_RTQM_IGRS0_FDROP_CNT 0xb34
530
531#define MTK_WED_RTQM_IGRS1_I2HW_DMAD_CNT 0xb44
532#define MTK_WED_RTQM_IGRS1_I2H_DMAD_CNT(_n) (0xb48 + (_n) * 0x4)
533#define MTK_WED_RTQM_IGRS1_I2HW_PKT_CNT 0xb50
534#define MTK_WED_RTQM_IGRS1_I2H_PKT_CNT(_n) (0xb54 + (_n) * 0x4)
535#define MTK_WED_RTQM_IGRS1_FDROP_CNT 0xb5c
536
537#define MTK_WED_RTQM_IGRS2_I2HW_DMAD_CNT 0xb6c
538#define MTK_WED_RTQM_IGRS2_I2H_DMAD_CNT(_n) (0xb70 + (_n) * 0x4)
539#define MTK_WED_RTQM_IGRS2_I2HW_PKT_CNT 0xb78
540#define MTK_WED_RTQM_IGRS2_I2H_PKT_CNT(_n) (0xb7c + (_n) * 0x4)
541#define MTK_WED_RTQM_IGRS2_FDROP_CNT 0xb84
542
543#define MTK_WED_RTQM_IGRS3_I2HW_DMAD_CNT 0xb94
544#define MTK_WED_RTQM_IGRS3_I2H_DMAD_CNT(_n) (0xb98 + (_n) * 0x4)
545#define MTK_WED_RTQM_IGRS3_I2HW_PKT_CNT 0xba0
546#define MTK_WED_RTQM_IGRS3_I2H_PKT_CNT(_n) (0xba4 + (_n) * 0x4)
547#define MTK_WED_RTQM_IGRS3_FDROP_CNT 0xbac
548
549#define MTK_WED_RTQM_R2H_MIB(_n) (0xb70 + (_n) * 0x4)
550#define MTK_WED_RTQM_R2Q_MIB(_n) (0xb78 + (_n) * 0x4)
551#define MTK_WED_RTQM_Q2N_MIB 0xb80
552#define MTK_WED_RTQM_Q2H_MIB(_n) (0xb84 + (_n) * 0x4)
553
554#define MTK_WED_RTQM_Q2B_MIB 0xb8c
555#define MTK_WED_RTQM_PFDBK_MIB 0xb90
556
557#define MTK_WED_RTQM_ENQ_CFG0 0xbb8
558#define MTK_WED_RTQM_ENQ_CFG_TXDMAD_FPORT GENMASK(15, 12)
559
560#define MTK_WED_RTQM_FDROP_MIB 0xb84
561#define MTK_WED_RTQM_ENQ_I2Q_DMAD_CNT 0xbbc
562#define MTK_WED_RTQM_ENQ_I2N_DMAD_CNT 0xbc0
563#define MTK_WED_RTQM_ENQ_I2Q_PKT_CNT 0xbc4
564#define MTK_WED_RTQM_ENQ_I2N_PKT_CNT 0xbc8
565#define MTK_WED_RTQM_ENQ_USED_ENTRY_CNT 0xbcc
566#define MTK_WED_RTQM_ENQ_ERR_CNT 0xbd0
567
568#define MTK_WED_RTQM_DEQ_DMAD_CNT 0xbd8
569#define MTK_WED_RTQM_DEQ_Q2I_DMAD_CNT 0xbdc
570#define MTK_WED_RTQM_DEQ_PKT_CNT 0xbe0
571#define MTK_WED_RTQM_DEQ_Q2I_PKT_CNT 0xbe4
572#define MTK_WED_RTQM_DEQ_USED_PFDBK_CNT 0xbe8
573#define MTK_WED_RTQM_DEQ_ERR_CNT 0xbec
574
575#define MTK_WED_RROQM_GLO_CFG 0xc04
576#define MTK_WED_RROQM_RST_IDX 0xc08
577#define MTK_WED_RROQM_RST_IDX_MIOD BIT(0)
578#define MTK_WED_RROQM_RST_IDX_FDBK BIT(4)
579
580#define MTK_WED_RROQM_MIOD_CTRL0 0xc40
581#define MTK_WED_RROQM_MIOD_CTRL1 0xc44
582#define MTK_WED_RROQM_MIOD_CNT GENMASK(11, 0)
583
584#define MTK_WED_RROQM_MIOD_CTRL2 0xc48
585#define MTK_WED_RROQM_MIOD_CTRL3 0xc4c
586
587#define MTK_WED_RROQM_FDBK_CTRL0 0xc50
588#define MTK_WED_RROQM_FDBK_CTRL1 0xc54
589#define MTK_WED_RROQM_FDBK_CNT GENMASK(11, 0)
590
591#define MTK_WED_RROQM_FDBK_CTRL2 0xc58
592
593#define MTK_WED_RROQ_BASE_L 0xc80
594#define MTK_WED_RROQ_BASE_H 0xc84
595
596#define MTK_WED_RROQM_MIOD_CFG 0xc8c
597#define MTK_WED_RROQM_MIOD_MID_DW GENMASK(5, 0)
598#define MTK_WED_RROQM_MIOD_MOD_DW GENMASK(13, 8)
599#define MTK_WED_RROQM_MIOD_ENTRY_DW GENMASK(22, 16)
600
601#define MTK_WED_RROQM_MID_MIB 0xcc0
602#define MTK_WED_RROQM_MOD_MIB 0xcc4
603#define MTK_WED_RROQM_MOD_COHERENT_MIB 0xcc8
604#define MTK_WED_RROQM_FDBK_MIB 0xcd0
605#define MTK_WED_RROQM_FDBK_COHERENT_MIB 0xcd4
606#define MTK_WED_RROQM_FDBK_IND_MIB 0xce0
607#define MTK_WED_RROQM_FDBK_ENQ_MIB 0xce4
608#define MTK_WED_RROQM_FDBK_ANC_MIB 0xce8
609#define MTK_WED_RROQM_FDBK_ANC2H_MIB 0xcec
610
611#define MTK_WED_RX_BM_RX_DMAD 0xd80
612#define MTK_WED_RX_BM_BASE 0xd84
613#define MTK_WED_RX_BM_INIT_PTR 0xd88
614#define MTK_WED_RX_BM_PTR 0xd8c
615#define MTK_WED_RX_BM_PTR_HEAD GENMASK(32, 16)
616#define MTK_WED_RX_BM_PTR_TAIL GENMASK(15, 0)
617
618#define MTK_WED_RX_BM_BLEN 0xd90
619#define MTK_WED_RX_BM_STS 0xd94
620#define MTK_WED_RX_BM_INTF2 0xd98
621#define MTK_WED_RX_BM_INTF 0xd9c
622#define MTK_WED_RX_BM_ERR_STS 0xda8
623
624#define MTK_RRO_IND_CMD_SIGNATURE 0xe00
625#define MTK_RRO_IND_CMD_DMA_IDX GENMASK(11, 0)
626#define MTK_RRO_IND_CMD_MAGIC_CNT GENMASK(30, 28)
627
628#define MTK_WED_IND_CMD_RX_CTRL0 0xe04
629#define MTK_WED_IND_CMD_PROC_IDX GENMASK(11, 0)
630#define MTK_WED_IND_CMD_PREFETCH_FREE_CNT GENMASK(19, 16)
631#define MTK_WED_IND_CMD_MAGIC_CNT GENMASK(30, 28)
632
633#define MTK_WED_IND_CMD_RX_CTRL1 0xe08
634#define MTK_WED_IND_CMD_RX_CTRL2 0xe0c
635#define MTK_WED_IND_CMD_MAX_CNT GENMASK(11, 0)
636#define MTK_WED_IND_CMD_BASE_M GENMASK(19, 16)
637
638#define MTK_WED_RRO_CFG0 0xe10
639#define MTK_WED_RRO_CFG1 0xe14
640#define MTK_WED_RRO_CFG1_MAX_WIN_SZ GENMASK(31, 29)
641#define MTK_WED_RRO_CFG1_ACK_SN_BASE_M GENMASK(19, 16)
642#define MTK_WED_RRO_CFG1_PARTICL_SE_ID GENMASK(11, 0)
643
644#define MTK_WED_ADDR_ELEM_CFG0 0xe18
645#define MTK_WED_ADDR_ELEM_CFG1 0xe1c
646#define MTK_WED_ADDR_ELEM_PREFETCH_FREE_CNT GENMASK(19, 16)
647
648#define MTK_WED_ADDR_ELEM_TBL_CFG 0xe20
649#define MTK_WED_ADDR_ELEM_TBL_OFFSET GENMASK(6, 0)
650#define MTK_WED_ADDR_ELEM_TBL_RD_RDY BIT(28)
651#define MTK_WED_ADDR_ELEM_TBL_WR_RDY BIT(29)
652#define MTK_WED_ADDR_ELEM_TBL_RD BIT(30)
653#define MTK_WED_ADDR_ELEM_TBL_WR BIT(31)
654
655#define MTK_WED_RADDR_ELEM_TBL_WDATA 0xe24
656#define MTK_WED_RADDR_ELEM_TBL_RDATA 0xe28
657
658#define MTK_WED_PN_CHECK_CFG 0xe30
659#define MTK_WED_PN_CHECK_SE_ID GENMASK(11, 0)
660#define MTK_WED_PN_CHECK_RD_RDY BIT(28)
661#define MTK_WED_PN_CHECK_WR_RDY BIT(29)
662#define MTK_WED_PN_CHECK_RD BIT(30)
663#define MTK_WED_PN_CHECK_WR BIT(31)
664
665#define MTK_WED_PN_CHECK_WDATA_M 0xe38
666#define MTK_WED_PN_CHECK_IS_FIRST BIT(17)
667
668#define MTK_WED_RRO_MSDU_PG_RING_CFG(_n) (0xe44 + (_n) * 0x8)
669
670#define MTK_WED_RRO_MSDU_PG_RING2_CFG 0xe58
671#define MTK_WED_RRO_MSDU_PG_DRV_CLR BIT(26)
672#define MTK_WED_RRO_MSDU_PG_DRV_EN BIT(31)
673
674#define MTK_WED_RRO_MSDU_PG_CTRL0(_n) (0xe5c + (_n) * 0xc)
675#define MTK_WED_RRO_MSDU_PG_CTRL1(_n) (0xe60 + (_n) * 0xc)
676#define MTK_WED_RRO_MSDU_PG_CTRL2(_n) (0xe64 + (_n) * 0xc)
677
678#define MTK_WED_RRO_RX_D_RX(_n) (0xe80 + (_n) * 0x10)
679
680#define MTK_WED_RRO_RX_MAGIC_CNT BIT(13)
681
682#define MTK_WED_RRO_RX_D_CFG(_n) (0xea0 + (_n) * 0x4)
683#define MTK_WED_RRO_RX_D_DRV_CLR BIT(26)
684#define MTK_WED_RRO_RX_D_DRV_EN BIT(31)
685
686#define MTK_WED_RRO_PG_BM_RX_DMAM 0xeb0
687#define MTK_WED_RRO_PG_BM_RX_SDL0 GENMASK(13, 0)
688
689#define MTK_WED_RRO_PG_BM_BASE 0xeb4
690#define MTK_WED_RRO_PG_BM_INIT_PTR 0xeb8
691#define MTK_WED_RRO_PG_BM_SW_TAIL_IDX GENMASK(15, 0)
692#define MTK_WED_RRO_PG_BM_INIT_SW_TAIL_IDX BIT(16)
693
694#define MTK_WED_WPDMA_INT_CTRL_RRO_RX 0xeec
695#define MTK_WED_WPDMA_INT_CTRL_RRO_RX0_EN BIT(0)
696#define MTK_WED_WPDMA_INT_CTRL_RRO_RX0_CLR BIT(1)
697#define MTK_WED_WPDMA_INT_CTRL_RRO_RX0_DONE_TRIG GENMASK(6, 2)
698#define MTK_WED_WPDMA_INT_CTRL_RRO_RX1_EN BIT(8)
699#define MTK_WED_WPDMA_INT_CTRL_RRO_RX1_CLR BIT(9)
700#define MTK_WED_WPDMA_INT_CTRL_RRO_RX1_DONE_TRIG GENMASK(14, 10)
701
702#define MTK_WED_WPDMA_INT_CTRL_RRO_MSDU_PG 0xef4
703#define MTK_WED_WPDMA_INT_CTRL_RRO_PG0_EN BIT(0)
704#define MTK_WED_WPDMA_INT_CTRL_RRO_PG0_CLR BIT(1)
705#define MTK_WED_WPDMA_INT_CTRL_RRO_PG0_DONE_TRIG GENMASK(6, 2)
706#define MTK_WED_WPDMA_INT_CTRL_RRO_PG1_EN BIT(8)
707#define MTK_WED_WPDMA_INT_CTRL_RRO_PG1_CLR BIT(9)
708#define MTK_WED_WPDMA_INT_CTRL_RRO_PG1_DONE_TRIG GENMASK(14, 10)
709#define MTK_WED_WPDMA_INT_CTRL_RRO_PG2_EN BIT(16)
710#define MTK_WED_WPDMA_INT_CTRL_RRO_PG2_CLR BIT(17)
711#define MTK_WED_WPDMA_INT_CTRL_RRO_PG2_DONE_TRIG GENMASK(22, 18)
712
713#define MTK_WED_RRO_RX_HW_STS 0xf00
714#define MTK_WED_RX_IND_CMD_BUSY GENMASK(31, 0)
715
716#define MTK_WED_RX_IND_CMD_CNT0 0xf20
717#define MTK_WED_RX_IND_CMD_DBG_CNT_EN BIT(31)
718
719#define MTK_WED_RX_IND_CMD_CNT(_n) (0xf20 + (_n) * 0x4)
720#define MTK_WED_IND_CMD_MAGIC_CNT_FAIL_CNT GENMASK(15, 0)
721
722#define MTK_WED_RX_ADDR_ELEM_CNT(_n) (0xf48 + (_n) * 0x4)
723#define MTK_WED_ADDR_ELEM_SIG_FAIL_CNT GENMASK(15, 0)
724#define MTK_WED_ADDR_ELEM_FIRST_SIG_FAIL_CNT GENMASK(31, 16)
725#define MTK_WED_ADDR_ELEM_ACKSN_CNT GENMASK(27, 0)
726
727#define MTK_WED_RX_MSDU_PG_CNT(_n) (0xf5c + (_n) * 0x4)
728
729#define MTK_WED_RX_PN_CHK_CNT 0xf70
730#define MTK_WED_PN_CHK_FAIL_CNT GENMASK(15, 0)
731
732#define MTK_WED_WOCPU_VIEW_MIOD_BASE 0x8000
733#define MTK_WED_PCIE_INT_MASK 0x0
734
735#define MTK_WED_AMSDU_FIFO 0x1800
736#define MTK_WED_AMSDU_IS_PRIOR0_RING BIT(10)
737
738#define MTK_WED_AMSDU_STA_INFO 0x01810
739#define MTK_WED_AMSDU_STA_INFO_DO_INIT BIT(0)
740#define MTK_WED_AMSDU_STA_INFO_SET_INIT BIT(1)
741
742#define MTK_WED_AMSDU_STA_INFO_INIT 0x01814
743#define MTK_WED_AMSDU_STA_WTBL_HDRT_MODE BIT(0)
744#define MTK_WED_AMSDU_STA_RMVL BIT(1)
745#define MTK_WED_AMSDU_STA_MAX_AMSDU_LEN GENMASK(7, 2)
746#define MTK_WED_AMSDU_STA_MAX_AMSDU_NUM GENMASK(11, 8)
747
748#define MTK_WED_AMSDU_HIFTXD_BASE_L(_n) (0x1980 + (_n) * 0x4)
749
750#define MTK_WED_AMSDU_PSE 0x1910
751#define MTK_WED_AMSDU_PSE_RESET BIT(16)
752
753#define MTK_WED_AMSDU_HIFTXD_CFG 0x1968
754#define MTK_WED_AMSDU_HIFTXD_SRC GENMASK(16, 15)
755
756#define MTK_WED_MON_AMSDU_FIFO_DMAD 0x1a34
757
758#define MTK_WED_MON_AMSDU_ENG_DMAD(_n) (0x1a80 + (_n) * 0x50)
759#define MTK_WED_MON_AMSDU_ENG_QFPL(_n) (0x1a84 + (_n) * 0x50)
760#define MTK_WED_MON_AMSDU_ENG_QENI(_n) (0x1a88 + (_n) * 0x50)
761#define MTK_WED_MON_AMSDU_ENG_QENO(_n) (0x1a8c + (_n) * 0x50)
762#define MTK_WED_MON_AMSDU_ENG_MERG(_n) (0x1a90 + (_n) * 0x50)
763
764#define MTK_WED_MON_AMSDU_ENG_CNT8(_n) (0x1a94 + (_n) * 0x50)
765#define MTK_WED_AMSDU_ENG_MAX_QGPP_CNT GENMASK(10, 0)
766#define MTK_WED_AMSDU_ENG_MAX_PL_CNT GENMASK(27, 16)
767
768#define MTK_WED_MON_AMSDU_ENG_CNT9(_n) (0x1a98 + (_n) * 0x50)
769#define MTK_WED_AMSDU_ENG_CUR_ENTRY GENMASK(10, 0)
770#define MTK_WED_AMSDU_ENG_MAX_BUF_MERGED GENMASK(20, 16)
771#define MTK_WED_AMSDU_ENG_MAX_MSDU_MERGED GENMASK(28, 24)
772
773#define MTK_WED_MON_AMSDU_QMEM_STS1 0x1e04
774
775#define MTK_WED_MON_AMSDU_QMEM_CNT(_n) (0x1e0c + (_n) * 0x4)
776#define MTK_WED_AMSDU_QMEM_FQ_CNT GENMASK(27, 16)
777#define MTK_WED_AMSDU_QMEM_SP_QCNT GENMASK(11, 0)
778#define MTK_WED_AMSDU_QMEM_TID0_QCNT GENMASK(27, 16)
779#define MTK_WED_AMSDU_QMEM_TID1_QCNT GENMASK(11, 0)
780#define MTK_WED_AMSDU_QMEM_TID2_QCNT GENMASK(27, 16)
781#define MTK_WED_AMSDU_QMEM_TID3_QCNT GENMASK(11, 0)
782#define MTK_WED_AMSDU_QMEM_TID4_QCNT GENMASK(27, 16)
783#define MTK_WED_AMSDU_QMEM_TID5_QCNT GENMASK(11, 0)
784#define MTK_WED_AMSDU_QMEM_TID6_QCNT GENMASK(27, 16)
785#define MTK_WED_AMSDU_QMEM_TID7_QCNT GENMASK(11, 0)
786
787#define MTK_WED_MON_AMSDU_QMEM_PTR(_n) (0x1e20 + (_n) * 0x4)
788#define MTK_WED_AMSDU_QMEM_FQ_HEAD GENMASK(27, 16)
789#define MTK_WED_AMSDU_QMEM_SP_QHEAD GENMASK(11, 0)
790#define MTK_WED_AMSDU_QMEM_TID0_QHEAD GENMASK(27, 16)
791#define MTK_WED_AMSDU_QMEM_TID1_QHEAD GENMASK(11, 0)
792#define MTK_WED_AMSDU_QMEM_TID2_QHEAD GENMASK(27, 16)
793#define MTK_WED_AMSDU_QMEM_TID3_QHEAD GENMASK(11, 0)
794#define MTK_WED_AMSDU_QMEM_TID4_QHEAD GENMASK(27, 16)
795#define MTK_WED_AMSDU_QMEM_TID5_QHEAD GENMASK(11, 0)
796#define MTK_WED_AMSDU_QMEM_TID6_QHEAD GENMASK(27, 16)
797#define MTK_WED_AMSDU_QMEM_TID7_QHEAD GENMASK(11, 0)
798#define MTK_WED_AMSDU_QMEM_FQ_TAIL GENMASK(27, 16)
799#define MTK_WED_AMSDU_QMEM_SP_QTAIL GENMASK(11, 0)
800#define MTK_WED_AMSDU_QMEM_TID0_QTAIL GENMASK(27, 16)
801#define MTK_WED_AMSDU_QMEM_TID1_QTAIL GENMASK(11, 0)
802#define MTK_WED_AMSDU_QMEM_TID2_QTAIL GENMASK(27, 16)
803#define MTK_WED_AMSDU_QMEM_TID3_QTAIL GENMASK(11, 0)
804#define MTK_WED_AMSDU_QMEM_TID4_QTAIL GENMASK(27, 16)
805#define MTK_WED_AMSDU_QMEM_TID5_QTAIL GENMASK(11, 0)
806#define MTK_WED_AMSDU_QMEM_TID6_QTAIL GENMASK(27, 16)
807#define MTK_WED_AMSDU_QMEM_TID7_QTAIL GENMASK(11, 0)
808
809#define MTK_WED_MON_AMSDU_HIFTXD_FETCH_MSDU(_n) (0x1ec4 + (_n) * 0x4)
810
811#define MTK_WED_PCIE_BASE 0x11280000
812#define MTK_WED_PCIE_BASE0 0x11300000
813#define MTK_WED_PCIE_BASE1 0x11310000
814#define MTK_WED_PCIE_BASE2 0x11290000
815#endif
816

source code of linux/drivers/net/ethernet/mediatek/mtk_wed_regs.h