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 | |
19 | struct 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 | |