GNU Linux-libre 6.8.9-gnu
[releases.git] / drivers / net / ethernet / mediatek / mtk_wed_regs.h
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