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