usb: dwc3: dwc3-qcom: Fix typo in the dwc3 vbus override API
[linux-2.6-microblaze.git] / drivers / net / ethernet / marvell / octeontx2 / af / rvu_reg.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*  Marvell OcteonTx2 RVU Admin Function driver
3  *
4  * Copyright (C) 2018 Marvell International Ltd.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  */
10
11 #ifndef RVU_REG_H
12 #define RVU_REG_H
13
14 /* Admin function registers */
15 #define RVU_AF_MSIXTR_BASE                  (0x10)
16 #define RVU_AF_ECO                          (0x20)
17 #define RVU_AF_BLK_RST                      (0x30)
18 #define RVU_AF_PF_BAR4_ADDR                 (0x40)
19 #define RVU_AF_RAS                          (0x100)
20 #define RVU_AF_RAS_W1S                      (0x108)
21 #define RVU_AF_RAS_ENA_W1S                  (0x110)
22 #define RVU_AF_RAS_ENA_W1C                  (0x118)
23 #define RVU_AF_GEN_INT                      (0x120)
24 #define RVU_AF_GEN_INT_W1S                  (0x128)
25 #define RVU_AF_GEN_INT_ENA_W1S              (0x130)
26 #define RVU_AF_GEN_INT_ENA_W1C              (0x138)
27 #define RVU_AF_AFPF_MBOX0                   (0x02000)
28 #define RVU_AF_AFPF_MBOX1                   (0x02008)
29 #define RVU_AF_AFPFX_MBOXX(a, b)            (0x2000 | (a) << 4 | (b) << 3)
30 #define RVU_AF_PFME_STATUS                  (0x2800)
31 #define RVU_AF_PFTRPEND                     (0x2810)
32 #define RVU_AF_PFTRPEND_W1S                 (0x2820)
33 #define RVU_AF_PF_RST                       (0x2840)
34 #define RVU_AF_HWVF_RST                     (0x2850)
35 #define RVU_AF_PFAF_MBOX_INT                (0x2880)
36 #define RVU_AF_PFAF_MBOX_INT_W1S            (0x2888)
37 #define RVU_AF_PFAF_MBOX_INT_ENA_W1S        (0x2890)
38 #define RVU_AF_PFAF_MBOX_INT_ENA_W1C        (0x2898)
39 #define RVU_AF_PFFLR_INT                    (0x28a0)
40 #define RVU_AF_PFFLR_INT_W1S                (0x28a8)
41 #define RVU_AF_PFFLR_INT_ENA_W1S            (0x28b0)
42 #define RVU_AF_PFFLR_INT_ENA_W1C            (0x28b8)
43 #define RVU_AF_PFME_INT                     (0x28c0)
44 #define RVU_AF_PFME_INT_W1S                 (0x28c8)
45 #define RVU_AF_PFME_INT_ENA_W1S             (0x28d0)
46 #define RVU_AF_PFME_INT_ENA_W1C             (0x28d8)
47 #define RVU_AF_PFX_BAR4_ADDR(a)             (0x5000 | (a) << 4)
48 #define RVU_AF_PFX_BAR4_CFG                 (0x5200 | (a) << 4)
49 #define RVU_AF_PFX_VF_BAR4_ADDR             (0x5400 | (a) << 4)
50 #define RVU_AF_PFX_VF_BAR4_CFG              (0x5600 | (a) << 4)
51 #define RVU_AF_PFX_LMTLINE_ADDR             (0x5800 | (a) << 4)
52
53 /* Admin function's privileged PF/VF registers */
54 #define RVU_PRIV_CONST                      (0x8000000)
55 #define RVU_PRIV_GEN_CFG                    (0x8000010)
56 #define RVU_PRIV_CLK_CFG                    (0x8000020)
57 #define RVU_PRIV_ACTIVE_PC                  (0x8000030)
58 #define RVU_PRIV_PFX_CFG(a)                 (0x8000100 | (a) << 16)
59 #define RVU_PRIV_PFX_MSIX_CFG(a)            (0x8000110 | (a) << 16)
60 #define RVU_PRIV_PFX_ID_CFG(a)              (0x8000120 | (a) << 16)
61 #define RVU_PRIV_PFX_INT_CFG(a)             (0x8000200 | (a) << 16)
62 #define RVU_PRIV_PFX_NIXX_CFG(a)            (0x8000300 | (a) << 3)
63 #define RVU_PRIV_PFX_NPA_CFG                (0x8000310)
64 #define RVU_PRIV_PFX_SSO_CFG                (0x8000320)
65 #define RVU_PRIV_PFX_SSOW_CFG               (0x8000330)
66 #define RVU_PRIV_PFX_TIM_CFG                (0x8000340)
67 #define RVU_PRIV_PFX_CPTX_CFG(a)            (0x8000350 | (a) << 3)
68 #define RVU_PRIV_BLOCK_TYPEX_REV(a)         (0x8000400 | (a) << 3)
69 #define RVU_PRIV_HWVFX_INT_CFG(a)           (0x8001280 | (a) << 16)
70 #define RVU_PRIV_HWVFX_NIXX_CFG(a)          (0x8001300 | (a) << 3)
71 #define RVU_PRIV_HWVFX_NPA_CFG              (0x8001310)
72 #define RVU_PRIV_HWVFX_SSO_CFG              (0x8001320)
73 #define RVU_PRIV_HWVFX_SSOW_CFG             (0x8001330)
74 #define RVU_PRIV_HWVFX_TIM_CFG              (0x8001340)
75 #define RVU_PRIV_HWVFX_CPTX_CFG(a)          (0x8001350 | (a) << 3)
76
77 /* RVU PF registers */
78 #define RVU_PF_VFX_PFVF_MBOX0               (0x00000)
79 #define RVU_PF_VFX_PFVF_MBOX1               (0x00008)
80 #define RVU_PF_VFX_PFVF_MBOXX(a, b)         (0x0 | (a) << 12 | (b) << 3)
81 #define RVU_PF_VF_BAR4_ADDR                 (0x10)
82 #define RVU_PF_BLOCK_ADDRX_DISC(a)          (0x200 | (a) << 3)
83 #define RVU_PF_VFME_STATUSX(a)              (0x800 | (a) << 3)
84 #define RVU_PF_VFTRPENDX(a)                 (0x820 | (a) << 3)
85 #define RVU_PF_VFTRPEND_W1SX(a)             (0x840 | (a) << 3)
86 #define RVU_PF_VFPF_MBOX_INTX(a)            (0x880 | (a) << 3)
87 #define RVU_PF_VFPF_MBOX_INT_W1SX(a)        (0x8A0 | (a) << 3)
88 #define RVU_PF_VFPF_MBOX_INT_ENA_W1SX(a)    (0x8C0 | (a) << 3)
89 #define RVU_PF_VFPF_MBOX_INT_ENA_W1CX(a)    (0x8E0 | (a) << 3)
90 #define RVU_PF_VFFLR_INTX(a)                (0x900 | (a) << 3)
91 #define RVU_PF_VFFLR_INT_W1SX(a)            (0x920 | (a) << 3)
92 #define RVU_PF_VFFLR_INT_ENA_W1SX(a)        (0x940 | (a) << 3)
93 #define RVU_PF_VFFLR_INT_ENA_W1CX(a)        (0x960 | (a) << 3)
94 #define RVU_PF_VFME_INTX(a)                 (0x980 | (a) << 3)
95 #define RVU_PF_VFME_INT_W1SX(a)             (0x9A0 | (a) << 3)
96 #define RVU_PF_VFME_INT_ENA_W1SX(a)         (0x9C0 | (a) << 3)
97 #define RVU_PF_VFME_INT_ENA_W1CX(a)         (0x9E0 | (a) << 3)
98 #define RVU_PF_PFAF_MBOX0                   (0xC00)
99 #define RVU_PF_PFAF_MBOX1                   (0xC08)
100 #define RVU_PF_PFAF_MBOXX(a)                (0xC00 | (a) << 3)
101 #define RVU_PF_INT                          (0xc20)
102 #define RVU_PF_INT_W1S                      (0xc28)
103 #define RVU_PF_INT_ENA_W1S                  (0xc30)
104 #define RVU_PF_INT_ENA_W1C                  (0xc38)
105 #define RVU_PF_MSIX_VECX_ADDR(a)            (0x000 | (a) << 4)
106 #define RVU_PF_MSIX_VECX_CTL(a)             (0x008 | (a) << 4)
107 #define RVU_PF_MSIX_PBAX(a)                 (0xF0000 | (a) << 3)
108 #define RVU_PF_VF_MBOX_ADDR                 (0xC40)
109 #define RVU_PF_LMTLINE_ADDR                 (0xC48)
110
111 /* RVU VF registers */
112 #define RVU_VF_VFPF_MBOX0                   (0x00000)
113 #define RVU_VF_VFPF_MBOX1                   (0x00008)
114
115 /* NPA block's admin function registers */
116 #define NPA_AF_BLK_RST                  (0x0000)
117 #define NPA_AF_CONST                    (0x0010)
118 #define NPA_AF_CONST1                   (0x0018)
119 #define NPA_AF_LF_RST                   (0x0020)
120 #define NPA_AF_GEN_CFG                  (0x0030)
121 #define NPA_AF_NDC_CFG                  (0x0040)
122 #define NPA_AF_INP_CTL                  (0x00D0)
123 #define NPA_AF_ACTIVE_CYCLES_PC         (0x00F0)
124 #define NPA_AF_AVG_DELAY                (0x0100)
125 #define NPA_AF_GEN_INT                  (0x0140)
126 #define NPA_AF_GEN_INT_W1S              (0x0148)
127 #define NPA_AF_GEN_INT_ENA_W1S          (0x0150)
128 #define NPA_AF_GEN_INT_ENA_W1C          (0x0158)
129 #define NPA_AF_RVU_INT                  (0x0160)
130 #define NPA_AF_RVU_INT_W1S              (0x0168)
131 #define NPA_AF_RVU_INT_ENA_W1S          (0x0170)
132 #define NPA_AF_RVU_INT_ENA_W1C          (0x0178)
133 #define NPA_AF_ERR_INT                  (0x0180)
134 #define NPA_AF_ERR_INT_W1S              (0x0188)
135 #define NPA_AF_ERR_INT_ENA_W1S          (0x0190)
136 #define NPA_AF_ERR_INT_ENA_W1C          (0x0198)
137 #define NPA_AF_RAS                      (0x01A0)
138 #define NPA_AF_RAS_W1S                  (0x01A8)
139 #define NPA_AF_RAS_ENA_W1S              (0x01B0)
140 #define NPA_AF_RAS_ENA_W1C              (0x01B8)
141 #define NPA_AF_BP_TEST                  (0x0200)
142 #define NPA_AF_ECO                      (0x0300)
143 #define NPA_AF_AQ_CFG                   (0x0600)
144 #define NPA_AF_AQ_BASE                  (0x0610)
145 #define NPA_AF_AQ_STATUS                (0x0620)
146 #define NPA_AF_AQ_DOOR                  (0x0630)
147 #define NPA_AF_AQ_DONE_WAIT             (0x0640)
148 #define NPA_AF_AQ_DONE                  (0x0650)
149 #define NPA_AF_AQ_DONE_ACK              (0x0660)
150 #define NPA_AF_AQ_DONE_INT              (0x0680)
151 #define NPA_AF_AQ_DONE_INT_W1S          (0x0688)
152 #define NPA_AF_AQ_DONE_ENA_W1S          (0x0690)
153 #define NPA_AF_AQ_DONE_ENA_W1C          (0x0698)
154 #define NPA_AF_LFX_AURAS_CFG(a)         (0x4000 | (a) << 18)
155 #define NPA_AF_LFX_LOC_AURAS_BASE(a)    (0x4010 | (a) << 18)
156 #define NPA_AF_LFX_QINTS_CFG(a)         (0x4100 | (a) << 18)
157 #define NPA_AF_LFX_QINTS_BASE(a)        (0x4110 | (a) << 18)
158 #define NPA_PRIV_AF_INT_CFG             (0x10000)
159 #define NPA_PRIV_LFX_CFG                (0x10010)
160 #define NPA_PRIV_LFX_INT_CFG            (0x10020)
161 #define NPA_AF_RVU_LF_CFG_DEBUG         (0x10030)
162
163 /* NIX block's admin function registers */
164 #define NIX_AF_CFG                      (0x0000)
165 #define NIX_AF_STATUS                   (0x0010)
166 #define NIX_AF_NDC_CFG                  (0x0018)
167 #define NIX_AF_CONST                    (0x0020)
168 #define NIX_AF_CONST1                   (0x0028)
169 #define NIX_AF_CONST2                   (0x0030)
170 #define NIX_AF_CONST3                   (0x0038)
171 #define NIX_AF_SQ_CONST                 (0x0040)
172 #define NIX_AF_CQ_CONST                 (0x0048)
173 #define NIX_AF_RQ_CONST                 (0x0050)
174 #define NIX_AF_PL_CONST                 (0x0058)
175 #define NIX_AF_PSE_CONST                (0x0060)
176 #define NIX_AF_TL1_CONST                (0x0070)
177 #define NIX_AF_TL2_CONST                (0x0078)
178 #define NIX_AF_TL3_CONST                (0x0080)
179 #define NIX_AF_TL4_CONST                (0x0088)
180 #define NIX_AF_MDQ_CONST                (0x0090)
181 #define NIX_AF_MC_MIRROR_CONST          (0x0098)
182 #define NIX_AF_LSO_CFG                  (0x00A8)
183 #define NIX_AF_BLK_RST                  (0x00B0)
184 #define NIX_AF_TX_TSTMP_CFG             (0x00C0)
185 #define NIX_AF_PL_TS                    (0x00C8)
186 #define NIX_AF_RX_CFG                   (0x00D0)
187 #define NIX_AF_AVG_DELAY                (0x00E0)
188 #define NIX_AF_CINT_DELAY               (0x00F0)
189 #define NIX_AF_RX_MCAST_BASE            (0x0100)
190 #define NIX_AF_RX_MCAST_CFG             (0x0110)
191 #define NIX_AF_RX_MCAST_BUF_BASE        (0x0120)
192 #define NIX_AF_RX_MCAST_BUF_CFG         (0x0130)
193 #define NIX_AF_RX_MIRROR_BUF_BASE       (0x0140)
194 #define NIX_AF_RX_MIRROR_BUF_CFG        (0x0148)
195 #define NIX_AF_LF_RST                   (0x0150)
196 #define NIX_AF_GEN_INT                  (0x0160)
197 #define NIX_AF_GEN_INT_W1S              (0x0168)
198 #define NIX_AF_GEN_INT_ENA_W1S          (0x0170)
199 #define NIX_AF_GEN_INT_ENA_W1C          (0x0178)
200 #define NIX_AF_ERR_INT                  (0x0180)
201 #define NIX_AF_ERR_INT_W1S              (0x0188)
202 #define NIX_AF_ERR_INT_ENA_W1S          (0x0190)
203 #define NIX_AF_ERR_INT_ENA_W1C          (0x0198)
204 #define NIX_AF_RAS                      (0x01A0)
205 #define NIX_AF_RAS_W1S                  (0x01A8)
206 #define NIX_AF_RAS_ENA_W1S              (0x01B0)
207 #define NIX_AF_RAS_ENA_W1C              (0x01B8)
208 #define NIX_AF_RVU_INT                  (0x01C0)
209 #define NIX_AF_RVU_INT_W1S              (0x01C8)
210 #define NIX_AF_RVU_INT_ENA_W1S          (0x01D0)
211 #define NIX_AF_RVU_INT_ENA_W1C          (0x01D8)
212 #define NIX_AF_TCP_TIMER                (0x01E0)
213 #define NIX_AF_RX_DEF_ET(a)             (0x01F0ull | (uint64_t)(a) << 3)
214 #define NIX_AF_RX_DEF_OL2               (0x0200)
215 #define NIX_AF_RX_DEF_OIP4              (0x0210)
216 #define NIX_AF_RX_DEF_IIP4              (0x0220)
217 #define NIX_AF_RX_DEF_VLAN0_PCP_DEI     (0x0228)
218 #define NIX_AF_RX_DEF_OIP6              (0x0230)
219 #define NIX_AF_RX_DEF_VLAN1_PCP_DEI     (0x0238)
220 #define NIX_AF_RX_DEF_IIP6              (0x0240)
221 #define NIX_AF_RX_DEF_OTCP              (0x0250)
222 #define NIX_AF_RX_DEF_ITCP              (0x0260)
223 #define NIX_AF_RX_DEF_OUDP              (0x0270)
224 #define NIX_AF_RX_DEF_IUDP              (0x0280)
225 #define NIX_AF_RX_DEF_OSCTP             (0x0290)
226 #define NIX_AF_RX_DEF_CST_APAD0         (0x0298)
227 #define NIX_AF_RX_DEF_ISCTP             (0x02A0)
228 #define NIX_AF_RX_DEF_IPSECX            (0x02B0)
229 #define NIX_AF_RX_DEF_CST_APAD1         (0x02A8)
230 #define NIX_AF_RX_DEF_IIP4_DSCP         (0x02E0)
231 #define NIX_AF_RX_DEF_OIP4_DSCP         (0x02E8)
232 #define NIX_AF_RX_DEF_IIP6_DSCP         (0x02F0)
233 #define NIX_AF_RX_DEF_OIP6_DSCP         (0x02F8)
234 #define NIX_AF_RX_IPSEC_GEN_CFG         (0x0300)
235 #define NIX_AF_RX_CPTX_INST_ADDR        (0x0310)
236 #define NIX_AF_NDC_TX_SYNC              (0x03F0)
237 #define NIX_AF_AQ_CFG                   (0x0400)
238 #define NIX_AF_AQ_BASE                  (0x0410)
239 #define NIX_AF_AQ_STATUS                (0x0420)
240 #define NIX_AF_AQ_DOOR                  (0x0430)
241 #define NIX_AF_AQ_DONE_WAIT             (0x0440)
242 #define NIX_AF_AQ_DONE                  (0x0450)
243 #define NIX_AF_AQ_DONE_ACK              (0x0460)
244 #define NIX_AF_AQ_DONE_TIMER            (0x0470)
245 #define NIX_AF_AQ_DONE_INT              (0x0480)
246 #define NIX_AF_AQ_DONE_INT_W1S          (0x0488)
247 #define NIX_AF_AQ_DONE_ENA_W1S          (0x0490)
248 #define NIX_AF_AQ_DONE_ENA_W1C          (0x0498)
249 #define NIX_AF_RX_LINKX_SLX_SPKT_CNT    (0x0500)
250 #define NIX_AF_RX_LINKX_SLX_SXQE_CNT    (0x0510)
251 #define NIX_AF_RX_MCAST_JOBSX_SW_CNT    (0x0520)
252 #define NIX_AF_RX_MIRROR_JOBSX_SW_CNT   (0x0530)
253 #define NIX_AF_RX_LINKX_CFG(a)          (0x0540 | (a) << 16)
254 #define NIX_AF_RX_SW_SYNC               (0x0550)
255 #define NIX_AF_RX_SW_SYNC_DONE          (0x0560)
256 #define NIX_AF_SEB_ECO                  (0x0600)
257 #define NIX_AF_SEB_TEST_BP              (0x0610)
258 #define NIX_AF_NORM_TX_FIFO_STATUS      (0x0620)
259 #define NIX_AF_EXPR_TX_FIFO_STATUS      (0x0630)
260 #define NIX_AF_SDP_TX_FIFO_STATUS       (0x0640)
261 #define NIX_AF_TX_NPC_CAPTURE_CONFIG    (0x0660)
262 #define NIX_AF_TX_NPC_CAPTURE_INFO      (0x0670)
263
264 #define NIX_AF_DEBUG_NPC_RESP_DATAX(a)          (0x680 | (a) << 3)
265 #define NIX_AF_SMQX_CFG(a)                      (0x700 | (a) << 16)
266 #define NIX_AF_SQM_DBG_CTL_STATUS               (0x750)
267 #define NIX_AF_PSE_CHANNEL_LEVEL                (0x800)
268 #define NIX_AF_PSE_SHAPER_CFG                   (0x810)
269 #define NIX_AF_TX_EXPR_CREDIT                   (0x830)
270 #define NIX_AF_MARK_FORMATX_CTL(a)              (0x900 | (a) << 18)
271 #define NIX_AF_TX_LINKX_NORM_CREDIT(a)          (0xA00 | (a) << 16)
272 #define NIX_AF_TX_LINKX_EXPR_CREDIT(a)          (0xA10 | (a) << 16)
273 #define NIX_AF_TX_LINKX_SW_XOFF(a)              (0xA20 | (a) << 16)
274 #define NIX_AF_TX_LINKX_HW_XOFF(a)              (0xA30 | (a) << 16)
275 #define NIX_AF_SDP_LINK_CREDIT                  (0xa40)
276 #define NIX_AF_SDP_SW_XOFFX(a)                  (0xA60 | (a) << 3)
277 #define NIX_AF_SDP_HW_XOFFX(a)                  (0xAC0 | (a) << 3)
278 #define NIX_AF_TL4X_BP_STATUS(a)                (0xB00 | (a) << 16)
279 #define NIX_AF_TL4X_SDP_LINK_CFG(a)             (0xB10 | (a) << 16)
280 #define NIX_AF_TL1X_SCHEDULE(a)                 (0xC00 | (a) << 16)
281 #define NIX_AF_TL1X_SHAPE(a)                    (0xC10 | (a) << 16)
282 #define NIX_AF_TL1X_CIR(a)                      (0xC20 | (a) << 16)
283 #define NIX_AF_TL1X_SHAPE_STATE(a)              (0xC50 | (a) << 16)
284 #define NIX_AF_TL1X_SW_XOFF(a)                  (0xC70 | (a) << 16)
285 #define NIX_AF_TL1X_TOPOLOGY(a)                 (0xC80 | (a) << 16)
286 #define NIX_AF_TL1X_GREEN(a)                    (0xC90 | (a) << 16)
287 #define NIX_AF_TL1X_YELLOW(a)                   (0xCA0 | (a) << 16)
288 #define NIX_AF_TL1X_RED(a)                      (0xCB0 | (a) << 16)
289 #define NIX_AF_TL1X_MD_DEBUG0(a)                (0xCC0 | (a) << 16)
290 #define NIX_AF_TL1X_MD_DEBUG1(a)                (0xCC8 | (a) << 16)
291 #define NIX_AF_TL1X_MD_DEBUG2(a)                (0xCD0 | (a) << 16)
292 #define NIX_AF_TL1X_MD_DEBUG3(a)                (0xCD8 | (a) << 16)
293 #define NIX_AF_TL1A_DEBUG                       (0xce0)
294 #define NIX_AF_TL1B_DEBUG                       (0xcf0)
295 #define NIX_AF_TL1_DEBUG_GREEN                  (0xd00)
296 #define NIX_AF_TL1_DEBUG_NODE                   (0xd10)
297 #define NIX_AF_TL1X_DROPPED_PACKETS(a)          (0xD20 | (a) << 16)
298 #define NIX_AF_TL1X_DROPPED_BYTES(a)            (0xD30 | (a) << 16)
299 #define NIX_AF_TL1X_RED_PACKETS(a)              (0xD40 | (a) << 16)
300 #define NIX_AF_TL1X_RED_BYTES(a)                (0xD50 | (a) << 16)
301 #define NIX_AF_TL1X_YELLOW_PACKETS(a)           (0xD60 | (a) << 16)
302 #define NIX_AF_TL1X_YELLOW_BYTES(a)             (0xD70 | (a) << 16)
303 #define NIX_AF_TL1X_GREEN_PACKETS(a)            (0xD80 | (a) << 16)
304 #define NIX_AF_TL1X_GREEN_BYTES(a)              (0xD90 | (a) << 16)
305 #define NIX_AF_TL2X_SCHEDULE(a)                 (0xE00 | (a) << 16)
306 #define NIX_AF_TL2X_SHAPE(a)                    (0xE10 | (a) << 16)
307 #define NIX_AF_TL2X_CIR(a)                      (0xE20 | (a) << 16)
308 #define NIX_AF_TL2X_PIR(a)                      (0xE30 | (a) << 16)
309 #define NIX_AF_TL2X_SCHED_STATE(a)              (0xE40 | (a) << 16)
310 #define NIX_AF_TL2X_SHAPE_STATE(a)              (0xE50 | (a) << 16)
311 #define NIX_AF_TL2X_POINTERS(a)                 (0xE60 | (a) << 16)
312 #define NIX_AF_TL2X_SW_XOFF(a)                  (0xE70 | (a) << 16)
313 #define NIX_AF_TL2X_TOPOLOGY(a)                 (0xE80 | (a) << 16)
314 #define NIX_AF_TL2X_PARENT(a)                   (0xE88 | (a) << 16)
315 #define NIX_AF_TL2X_GREEN(a)                    (0xE90 | (a) << 16)
316 #define NIX_AF_TL2X_YELLOW(a)                   (0xEA0 | (a) << 16)
317 #define NIX_AF_TL2X_RED(a)                      (0xEB0 | (a) << 16)
318 #define NIX_AF_TL2X_MD_DEBUG0(a)                (0xEC0 | (a) << 16)
319 #define NIX_AF_TL2X_MD_DEBUG1(a)                (0xEC8 | (a) << 16)
320 #define NIX_AF_TL2X_MD_DEBUG2(a)                (0xED0 | (a) << 16)
321 #define NIX_AF_TL2X_MD_DEBUG3(a)                (0xED8 | (a) << 16)
322 #define NIX_AF_TL2A_DEBUG                       (0xee0)
323 #define NIX_AF_TL2B_DEBUG                       (0xef0)
324 #define NIX_AF_TL3X_SCHEDULE(a)                 (0x1000 | (a) << 16)
325 #define NIX_AF_TL3X_SHAPE(a)                    (0x1010 | (a) << 16)
326 #define NIX_AF_TL3X_CIR(a)                      (0x1020 | (a) << 16)
327 #define NIX_AF_TL3X_PIR(a)                      (0x1030 | (a) << 16)
328 #define NIX_AF_TL3X_SCHED_STATE(a)              (0x1040 | (a) << 16)
329 #define NIX_AF_TL3X_SHAPE_STATE(a)              (0x1050 | (a) << 16)
330 #define NIX_AF_TL3X_POINTERS(a)                 (0x1060 | (a) << 16)
331 #define NIX_AF_TL3X_SW_XOFF(a)                  (0x1070 | (a) << 16)
332 #define NIX_AF_TL3X_TOPOLOGY(a)                 (0x1080 | (a) << 16)
333 #define NIX_AF_TL3X_PARENT(a)                   (0x1088 | (a) << 16)
334 #define NIX_AF_TL3X_GREEN(a)                    (0x1090 | (a) << 16)
335 #define NIX_AF_TL3X_YELLOW(a)                   (0x10A0 | (a) << 16)
336 #define NIX_AF_TL3X_RED(a)                      (0x10B0 | (a) << 16)
337 #define NIX_AF_TL3X_MD_DEBUG0(a)                (0x10C0 | (a) << 16)
338 #define NIX_AF_TL3X_MD_DEBUG1(a)                (0x10C8 | (a) << 16)
339 #define NIX_AF_TL3X_MD_DEBUG2(a)                (0x10D0 | (a) << 16)
340 #define NIX_AF_TL3X_MD_DEBUG3(a)                (0x10D8 | (a) << 16)
341 #define NIX_AF_TL3A_DEBUG                       (0x10e0)
342 #define NIX_AF_TL3B_DEBUG                       (0x10f0)
343 #define NIX_AF_TL4X_SCHEDULE(a)                 (0x1200 | (a) << 16)
344 #define NIX_AF_TL4X_SHAPE(a)                    (0x1210 | (a) << 16)
345 #define NIX_AF_TL4X_CIR(a)                      (0x1220 | (a) << 16)
346 #define NIX_AF_TL4X_PIR(a)                      (0x1230 | (a) << 16)
347 #define NIX_AF_TL4X_SCHED_STATE(a)              (0x1240 | (a) << 16)
348 #define NIX_AF_TL4X_SHAPE_STATE(a)              (0x1250 | (a) << 16)
349 #define NIX_AF_TL4X_POINTERS(a)                 (0x1260 | (a) << 16)
350 #define NIX_AF_TL4X_SW_XOFF(a)                  (0x1270 | (a) << 16)
351 #define NIX_AF_TL4X_TOPOLOGY(a)                 (0x1280 | (a) << 16)
352 #define NIX_AF_TL4X_PARENT(a)                   (0x1288 | (a) << 16)
353 #define NIX_AF_TL4X_GREEN(a)                    (0x1290 | (a) << 16)
354 #define NIX_AF_TL4X_YELLOW(a)                   (0x12A0 | (a) << 16)
355 #define NIX_AF_TL4X_RED(a)                      (0x12B0 | (a) << 16)
356 #define NIX_AF_TL4X_MD_DEBUG0(a)                (0x12C0 | (a) << 16)
357 #define NIX_AF_TL4X_MD_DEBUG1(a)                (0x12C8 | (a) << 16)
358 #define NIX_AF_TL4X_MD_DEBUG2(a)                (0x12D0 | (a) << 16)
359 #define NIX_AF_TL4X_MD_DEBUG3(a)                (0x12D8 | (a) << 16)
360 #define NIX_AF_TL4A_DEBUG                       (0x12e0)
361 #define NIX_AF_TL4B_DEBUG                       (0x12f0)
362 #define NIX_AF_MDQX_SCHEDULE(a)                 (0x1400 | (a) << 16)
363 #define NIX_AF_MDQX_SHAPE(a)                    (0x1410 | (a) << 16)
364 #define NIX_AF_MDQX_CIR(a)                      (0x1420 | (a) << 16)
365 #define NIX_AF_MDQX_PIR(a)                      (0x1430 | (a) << 16)
366 #define NIX_AF_MDQX_SCHED_STATE(a)              (0x1440 | (a) << 16)
367 #define NIX_AF_MDQX_SHAPE_STATE(a)              (0x1450 | (a) << 16)
368 #define NIX_AF_MDQX_POINTERS(a)                 (0x1460 | (a) << 16)
369 #define NIX_AF_MDQX_SW_XOFF(a)                  (0x1470 | (a) << 16)
370 #define NIX_AF_MDQX_PARENT(a)                   (0x1480 | (a) << 16)
371 #define NIX_AF_MDQX_MD_DEBUG(a)                 (0x14C0 | (a) << 16)
372 #define NIX_AF_MDQX_PTR_FIFO(a)                 (0x14D0 | (a) << 16)
373 #define NIX_AF_MDQA_DEBUG                       (0x14e0)
374 #define NIX_AF_MDQB_DEBUG                       (0x14f0)
375 #define NIX_AF_TL3_TL2X_CFG(a)                  (0x1600 | (a) << 18)
376 #define NIX_AF_TL3_TL2X_BP_STATUS(a)            (0x1610 | (a) << 16)
377 #define NIX_AF_TL3_TL2X_LINKX_CFG(a, b)         (0x1700 | (a) << 16 | (b) << 3)
378 #define NIX_AF_RX_FLOW_KEY_ALGX_FIELDX(a, b)    (0x1800 | (a) << 18 | (b) << 3)
379 #define NIX_AF_TX_MCASTX(a)                     (0x1900 | (a) << 15)
380 #define NIX_AF_TX_VTAG_DEFX_CTL(a)              (0x1A00 | (a) << 16)
381 #define NIX_AF_TX_VTAG_DEFX_DATA(a)             (0x1A10 | (a) << 16)
382 #define NIX_AF_RX_BPIDX_STATUS(a)               (0x1A20 | (a) << 17)
383 #define NIX_AF_RX_CHANX_CFG(a)                  (0x1A30 | (a) << 15)
384 #define NIX_AF_CINT_TIMERX(a)                   (0x1A40 | (a) << 18)
385 #define NIX_AF_LSO_FORMATX_FIELDX(a, b)         (0x1B00 | (a) << 16 | (b) << 3)
386 #define NIX_AF_LFX_CFG(a)               (0x4000 | (a) << 17)
387 #define NIX_AF_LFX_SQS_CFG(a)           (0x4020 | (a) << 17)
388 #define NIX_AF_LFX_TX_CFG2(a)           (0x4028 | (a) << 17)
389 #define NIX_AF_LFX_SQS_BASE(a)          (0x4030 | (a) << 17)
390 #define NIX_AF_LFX_RQS_CFG(a)           (0x4040 | (a) << 17)
391 #define NIX_AF_LFX_RQS_BASE(a)          (0x4050 | (a) << 17)
392 #define NIX_AF_LFX_CQS_CFG(a)           (0x4060 | (a) << 17)
393 #define NIX_AF_LFX_CQS_BASE(a)          (0x4070 | (a) << 17)
394 #define NIX_AF_LFX_TX_CFG(a)            (0x4080 | (a) << 17)
395 #define NIX_AF_LFX_TX_PARSE_CFG(a)      (0x4090 | (a) << 17)
396 #define NIX_AF_LFX_RX_CFG(a)            (0x40A0 | (a) << 17)
397 #define NIX_AF_LFX_RSS_CFG(a)           (0x40C0 | (a) << 17)
398 #define NIX_AF_LFX_RSS_BASE(a)          (0x40D0 | (a) << 17)
399 #define NIX_AF_LFX_QINTS_CFG(a)         (0x4100 | (a) << 17)
400 #define NIX_AF_LFX_QINTS_BASE(a)        (0x4110 | (a) << 17)
401 #define NIX_AF_LFX_CINTS_CFG(a)         (0x4120 | (a) << 17)
402 #define NIX_AF_LFX_CINTS_BASE(a)        (0x4130 | (a) << 17)
403 #define NIX_AF_LFX_RX_IPSEC_CFG0(a)     (0x4140 | (a) << 17)
404 #define NIX_AF_LFX_RX_IPSEC_CFG1(a)     (0x4148 | (a) << 17)
405 #define NIX_AF_LFX_RX_IPSEC_DYNO_CFG(a) (0x4150 | (a) << 17)
406 #define NIX_AF_LFX_RX_IPSEC_DYNO_BASE(a)        (0x4158 | (a) << 17)
407 #define NIX_AF_LFX_RX_IPSEC_SA_BASE(a)  (0x4170 | (a) << 17)
408 #define NIX_AF_LFX_TX_STATUS(a)         (0x4180 | (a) << 17)
409 #define NIX_AF_LFX_RX_VTAG_TYPEX(a, b)  (0x4200 | (a) << 17 | (b) << 3)
410 #define NIX_AF_LFX_LOCKX(a, b)          (0x4300 | (a) << 17 | (b) << 3)
411 #define NIX_AF_LFX_TX_STATX(a, b)       (0x4400 | (a) << 17 | (b) << 3)
412 #define NIX_AF_LFX_RX_STATX(a, b)       (0x4500 | (a) << 17 | (b) << 3)
413 #define NIX_AF_LFX_RSS_GRPX(a, b)       (0x4600 | (a) << 17 | (b) << 3)
414 #define NIX_AF_RX_NPC_MC_RCV            (0x4700)
415 #define NIX_AF_RX_NPC_MC_DROP           (0x4710)
416 #define NIX_AF_RX_NPC_MIRROR_RCV        (0x4720)
417 #define NIX_AF_RX_NPC_MIRROR_DROP       (0x4730)
418 #define NIX_AF_RX_ACTIVE_CYCLES_PCX(a)  (0x4800 | (a) << 16)
419 #define NIX_AF_LINKX_CFG(a)             (0x4010 | (a) << 17)
420
421 #define NIX_PRIV_AF_INT_CFG             (0x8000000)
422 #define NIX_PRIV_LFX_CFG                (0x8000010)
423 #define NIX_PRIV_LFX_INT_CFG            (0x8000020)
424 #define NIX_AF_RVU_LF_CFG_DEBUG         (0x8000030)
425
426 #define NIX_AF_LINKX_BASE_MASK          GENMASK_ULL(11, 0)
427 #define NIX_AF_LINKX_RANGE_MASK         GENMASK_ULL(19, 16)
428
429 /* SSO */
430 #define SSO_AF_CONST                    (0x1000)
431 #define SSO_AF_CONST1                   (0x1008)
432 #define SSO_AF_BLK_RST                  (0x10f8)
433 #define SSO_AF_LF_HWGRP_RST             (0x10e0)
434 #define SSO_AF_RVU_LF_CFG_DEBUG         (0x3800)
435 #define SSO_PRIV_LFX_HWGRP_CFG          (0x10000)
436 #define SSO_PRIV_LFX_HWGRP_INT_CFG      (0x20000)
437
438 /* SSOW */
439 #define SSOW_AF_RVU_LF_HWS_CFG_DEBUG    (0x0010)
440 #define SSOW_AF_LF_HWS_RST              (0x0030)
441 #define SSOW_PRIV_LFX_HWS_CFG           (0x1000)
442 #define SSOW_PRIV_LFX_HWS_INT_CFG       (0x2000)
443
444 /* TIM */
445 #define TIM_AF_CONST                    (0x90)
446 #define TIM_PRIV_LFX_CFG                (0x20000)
447 #define TIM_PRIV_LFX_INT_CFG            (0x24000)
448 #define TIM_AF_RVU_LF_CFG_DEBUG         (0x30000)
449 #define TIM_AF_BLK_RST                  (0x10)
450 #define TIM_AF_LF_RST                   (0x20)
451
452 /* CPT */
453 #define CPT_AF_CONSTANTS0               (0x0000)
454 #define CPT_AF_CONSTANTS1               (0x1000)
455 #define CPT_AF_DIAG                     (0x3000)
456 #define CPT_AF_ECO                      (0x4000)
457 #define CPT_AF_FLTX_INT(a)              (0xa000ull | (u64)(a) << 3)
458 #define CPT_AF_FLTX_INT_W1S(a)          (0xb000ull | (u64)(a) << 3)
459 #define CPT_AF_FLTX_INT_ENA_W1C(a)      (0xc000ull | (u64)(a) << 3)
460 #define CPT_AF_FLTX_INT_ENA_W1S(a)      (0xd000ull | (u64)(a) << 3)
461 #define CPT_AF_PSNX_EXE(a)              (0xe000ull | (u64)(a) << 3)
462 #define CPT_AF_PSNX_EXE_W1S(a)          (0xf000ull | (u64)(a) << 3)
463 #define CPT_AF_PSNX_LF(a)               (0x10000ull | (u64)(a) << 3)
464 #define CPT_AF_PSNX_LF_W1S(a)           (0x11000ull | (u64)(a) << 3)
465 #define CPT_AF_EXEX_CTL2(a)             (0x12000ull | (u64)(a) << 3)
466 #define CPT_AF_EXEX_STS(a)              (0x13000ull | (u64)(a) << 3)
467 #define CPT_AF_EXE_ERR_INFO             (0x14000)
468 #define CPT_AF_EXEX_ACTIVE(a)           (0x16000ull | (u64)(a) << 3)
469 #define CPT_AF_INST_REQ_PC              (0x17000)
470 #define CPT_AF_INST_LATENCY_PC          (0x18000)
471 #define CPT_AF_RD_REQ_PC                (0x19000)
472 #define CPT_AF_RD_LATENCY_PC            (0x1a000)
473 #define CPT_AF_RD_UC_PC                 (0x1b000)
474 #define CPT_AF_ACTIVE_CYCLES_PC         (0x1c000)
475 #define CPT_AF_EXE_DBG_CTL              (0x1d000)
476 #define CPT_AF_EXE_DBG_DATA             (0x1e000)
477 #define CPT_AF_EXE_REQ_TIMER            (0x1f000)
478 #define CPT_AF_EXEX_CTL(a)              (0x20000ull | (u64)(a) << 3)
479 #define CPT_AF_EXE_PERF_CTL             (0x21000)
480 #define CPT_AF_EXE_DBG_CNTX(a)          (0x22000ull | (u64)(a) << 3)
481 #define CPT_AF_EXE_PERF_EVENT_CNT       (0x23000)
482 #define CPT_AF_EXE_EPCI_INBX_CNT(a)     (0x24000ull | (u64)(a) << 3)
483 #define CPT_AF_EXE_EPCI_OUTBX_CNT(a)    (0x25000ull | (u64)(a) << 3)
484 #define CPT_AF_EXEX_UCODE_BASE(a)       (0x26000ull | (u64)(a) << 3)
485 #define CPT_AF_LFX_CTL(a)               (0x27000ull | (u64)(a) << 3)
486 #define CPT_AF_LFX_CTL2(a)              (0x29000ull | (u64)(a) << 3)
487 #define CPT_AF_CPTCLK_CNT               (0x2a000)
488 #define CPT_AF_PF_FUNC                  (0x2b000)
489 #define CPT_AF_LFX_PTR_CTL(a)           (0x2c000ull | (u64)(a) << 3)
490 #define CPT_AF_GRPX_THR(a)              (0x2d000ull | (u64)(a) << 3)
491 #define CPT_AF_CTL                      (0x2e000ull)
492 #define CPT_AF_XEX_THR(a)               (0x2f000ull | (u64)(a) << 3)
493 #define CPT_PRIV_LFX_CFG                (0x41000)
494 #define CPT_PRIV_AF_INT_CFG             (0x42000)
495 #define CPT_PRIV_LFX_INT_CFG            (0x43000)
496 #define CPT_AF_LF_RST                   (0x44000)
497 #define CPT_AF_RVU_LF_CFG_DEBUG         (0x45000)
498 #define CPT_AF_BLK_RST                  (0x46000)
499 #define CPT_AF_RVU_INT                  (0x47000)
500 #define CPT_AF_RVU_INT_W1S              (0x47008)
501 #define CPT_AF_RVU_INT_ENA_W1S          (0x47010)
502 #define CPT_AF_RVU_INT_ENA_W1C          (0x47018)
503 #define CPT_AF_RAS_INT                  (0x47020)
504 #define CPT_AF_RAS_INT_W1S              (0x47028)
505 #define CPT_AF_RAS_INT_ENA_W1S          (0x47030)
506 #define CPT_AF_RAS_INT_ENA_W1C          (0x47038)
507 #define CPT_AF_CTX_FLUSH_TIMER          (0x48000ull)
508 #define CPT_AF_CTX_ERR                  (0x48008ull)
509 #define CPT_AF_CTX_ENC_ID               (0x48010ull)
510 #define CPT_AF_CTX_MIS_PC               (0x49400ull)
511 #define CPT_AF_CTX_HIT_PC               (0x49408ull)
512 #define CPT_AF_CTX_AOP_PC               (0x49410ull)
513 #define CPT_AF_CTX_AOP_LATENCY_PC       (0x49418ull)
514 #define CPT_AF_CTX_IFETCH_PC            (0x49420ull)
515 #define CPT_AF_CTX_IFETCH_LATENCY_PC    (0x49428ull)
516 #define CPT_AF_CTX_FFETCH_PC            (0x49430ull)
517 #define CPT_AF_CTX_FFETCH_LATENCY_PC    (0x49438ull)
518 #define CPT_AF_CTX_WBACK_PC             (0x49440ull)
519 #define CPT_AF_CTX_WBACK_LATENCY_PC     (0x49448ull)
520 #define CPT_AF_CTX_PSH_PC               (0x49450ull)
521 #define CPT_AF_CTX_PSH_LATENCY_PC       (0x49458ull)
522 #define CPT_AF_RXC_TIME                 (0x50010ull)
523 #define CPT_AF_RXC_TIME_CFG             (0x50018ull)
524 #define CPT_AF_RXC_DFRG                 (0x50020ull)
525 #define CPT_AF_RXC_ACTIVE_STS           (0x50028ull)
526 #define CPT_AF_RXC_ZOMBIE_STS           (0x50030ull)
527 #define CPT_AF_X2PX_LINK_CFG(a)         (0x51000ull | (u64)(a) << 3)
528
529 #define AF_BAR2_ALIASX(a, b)            (0x9100000ull | (a) << 12 | (b))
530 #define CPT_AF_BAR2_SEL                 0x9000000
531 #define CPT_AF_BAR2_ALIASX(a, b)        AF_BAR2_ALIASX(a, b)
532
533 #define CPT_AF_LF_CTL2_SHIFT 3
534 #define CPT_AF_LF_SSO_PF_FUNC_SHIFT 32
535
536 #define CPT_LF_CTL                      0x10
537 #define CPT_LF_INPROG                   0x40
538 #define CPT_LF_Q_GRP_PTR                0x120
539
540 #define NPC_AF_BLK_RST                  (0x00040)
541
542 /* NPC */
543 #define NPC_AF_CFG                      (0x00000)
544 #define NPC_AF_ACTIVE_PC                (0x00010)
545 #define NPC_AF_CONST                    (0x00020)
546 #define NPC_AF_CONST1                   (0x00030)
547 #define NPC_AF_BLK_RST                  (0x00040)
548 #define NPC_AF_MCAM_SCRUB_CTL           (0x000a0)
549 #define NPC_AF_KCAM_SCRUB_CTL           (0x000b0)
550 #define NPC_AF_CONST2                   (0x00100)
551 #define NPC_AF_CONST3                   (0x00110)
552 #define NPC_AF_KPUX_CFG(a)              (0x00500 | (a) << 3)
553 #define NPC_AF_PCK_CFG                  (0x00600)
554 #define NPC_AF_PCK_DEF_OL2              (0x00610)
555 #define NPC_AF_PCK_DEF_OIP4             (0x00620)
556 #define NPC_AF_PCK_DEF_OIP6             (0x00630)
557 #define NPC_AF_PCK_DEF_IIP4             (0x00640)
558 #define NPC_AF_KEX_LDATAX_FLAGS_CFG(a)  (0x00800 | (a) << 3)
559 #define NPC_AF_INTFX_KEX_CFG(a)         (0x01010 | (a) << 8)
560 #define NPC_AF_PKINDX_ACTION0(a)        (0x80000ull | (a) << 6)
561 #define NPC_AF_PKINDX_ACTION1(a)        (0x80008ull | (a) << 6)
562 #define NPC_AF_PKINDX_CPI_DEFX(a, b)    (0x80020ull | (a) << 6 | (b) << 3)
563 #define NPC_AF_KPUX_ENTRYX_CAMX(a, b, c) \
564                 (0x100000 | (a) << 14 | (b) << 6 | (c) << 3)
565 #define NPC_AF_KPUX_ENTRYX_ACTION0(a, b) \
566                 (0x100020 | (a) << 14 | (b) << 6)
567 #define NPC_AF_KPUX_ENTRYX_ACTION1(a, b) \
568                 (0x100028 | (a) << 14 | (b) << 6)
569 #define NPC_AF_KPUX_ENTRY_DISX(a, b)    (0x180000 | (a) << 6 | (b) << 3)
570 #define NPC_AF_CPIX_CFG(a)              (0x200000 | (a) << 3)
571 #define NPC_AF_INTFX_LIDX_LTX_LDX_CFG(a, b, c, d) \
572                 (0x900000 | (a) << 16 | (b) << 12 | (c) << 5 | (d) << 3)
573 #define NPC_AF_INTFX_LDATAX_FLAGSX_CFG(a, b, c) \
574                 (0x980000 | (a) << 16 | (b) << 12 | (c) << 3)
575 #define NPC_AF_INTFX_MISS_STAT_ACT(a)   (0x1880040 + (a) * 0x8)
576 #define NPC_AF_INTFX_MISS_ACT(a)        (0x1a00000 | (a) << 4)
577 #define NPC_AF_INTFX_MISS_TAG_ACT(a)    (0x1b00008 | (a) << 4)
578 #define NPC_AF_MCAM_BANKX_HITX(a, b)    (0x1c80000 | (a) << 8 | (b) << 4)
579 #define NPC_AF_LKUP_CTL                 (0x2000000)
580 #define NPC_AF_LKUP_DATAX(a)            (0x2000200 | (a) << 4)
581 #define NPC_AF_LKUP_RESULTX(a)          (0x2000400 | (a) << 4)
582 #define NPC_AF_INTFX_STAT(a)            (0x2000800 | (a) << 4)
583 #define NPC_AF_DBG_CTL                  (0x3000000)
584 #define NPC_AF_DBG_STATUS               (0x3000010)
585 #define NPC_AF_KPUX_DBG(a)              (0x3000020 | (a) << 8)
586 #define NPC_AF_IKPU_ERR_CTL             (0x3000080)
587 #define NPC_AF_KPUX_ERR_CTL(a)          (0x30000a0 | (a) << 8)
588 #define NPC_AF_MCAM_DBG                 (0x3001000)
589 #define NPC_AF_DBG_DATAX(a)             (0x3001400 | (a) << 4)
590 #define NPC_AF_DBG_RESULTX(a)           (0x3001800 | (a) << 4)
591
592 #define NPC_AF_MCAMEX_BANKX_CAMX_INTF(a, b, c) ({                          \
593         u64 offset;                                                        \
594                                                                            \
595         offset = (0x1000000ull | (a) << 10 | (b) << 6 | (c) << 3);         \
596         if (rvu->hw->npc_ext_set)                                          \
597                 offset = (0x8000000ull | (a) << 8 | (b) << 22 | (c) << 3); \
598         offset; })
599
600 #define NPC_AF_MCAMEX_BANKX_CAMX_W0(a, b, c) ({                            \
601         u64 offset;                                                        \
602                                                                            \
603         offset = (0x1000010ull | (a) << 10 | (b) << 6 | (c) << 3);         \
604         if (rvu->hw->npc_ext_set)                                          \
605                 offset = (0x8000010ull | (a) << 8 | (b) << 22 | (c) << 3); \
606         offset; })
607
608 #define NPC_AF_MCAMEX_BANKX_CAMX_W1(a, b, c) ({                            \
609         u64 offset;                                                        \
610                                                                            \
611         offset = (0x1000020ull | (a) << 10 | (b) << 6 | (c) << 3);         \
612         if (rvu->hw->npc_ext_set)                                          \
613                 offset = (0x8000020ull | (a) << 8 | (b) << 22 | (c) << 3); \
614         offset; })
615
616 #define NPC_AF_MCAMEX_BANKX_CFG(a, b) ({                                   \
617         u64 offset;                                                        \
618                                                                            \
619         offset = (0x1800000ull | (a) << 8 | (b) << 4);                     \
620         if (rvu->hw->npc_ext_set)                                          \
621                 offset = (0x8000038ull | (a) << 8 | (b) << 22);            \
622         offset; })
623
624 #define NPC_AF_MCAMEX_BANKX_ACTION(a, b) ({                                \
625         u64 offset;                                                        \
626                                                                            \
627         offset = (0x1900000ull | (a) << 8 | (b) << 4);                     \
628         if (rvu->hw->npc_ext_set)                                          \
629                 offset = (0x8000040ull | (a) << 8 | (b) << 22);            \
630         offset; })                                                         \
631
632 #define NPC_AF_MCAMEX_BANKX_TAG_ACT(a, b) ({                               \
633         u64 offset;                                                        \
634                                                                            \
635         offset = (0x1900008ull | (a) << 8 | (b) << 4);                     \
636         if (rvu->hw->npc_ext_set)                                          \
637                 offset = (0x8000048ull | (a) << 8 | (b) << 22);            \
638         offset; })                                                         \
639
640 #define NPC_AF_MCAMEX_BANKX_STAT_ACT(a, b) ({                              \
641         u64 offset;                                                        \
642                                                                            \
643         offset = (0x1880000ull | (a) << 8 | (b) << 4);                     \
644         if (rvu->hw->npc_ext_set)                                          \
645                 offset = (0x8000050ull | (a) << 8 | (b) << 22);            \
646         offset; })                                                         \
647
648 #define NPC_AF_MATCH_STATX(a) ({                                           \
649         u64 offset;                                                        \
650                                                                            \
651         offset = (0x1880008ull | (a) << 8);                                \
652         if (rvu->hw->npc_ext_set)                                          \
653                 offset = (0x8000078ull | (a) << 8);                        \
654         offset; })                                                         \
655
656 /* NDC */
657 #define NDC_AF_CONST                    (0x00000)
658 #define NDC_AF_CLK_EN                   (0x00020)
659 #define NDC_AF_CTL                      (0x00030)
660 #define NDC_AF_BANK_CTL                 (0x00040)
661 #define NDC_AF_BANK_CTL_DONE            (0x00048)
662 #define NDC_AF_INTR                     (0x00058)
663 #define NDC_AF_INTR_W1S                 (0x00060)
664 #define NDC_AF_INTR_ENA_W1S             (0x00068)
665 #define NDC_AF_INTR_ENA_W1C             (0x00070)
666 #define NDC_AF_ACTIVE_PC                (0x00078)
667 #define NDC_AF_BP_TEST_ENABLE           (0x001F8)
668 #define NDC_AF_BP_TEST(a)               (0x00200 | (a) << 3)
669 #define NDC_AF_BLK_RST                  (0x002F0)
670 #define NDC_PRIV_AF_INT_CFG             (0x002F8)
671 #define NDC_AF_HASHX(a)                 (0x00300 | (a) << 3)
672 #define NDC_AF_PORTX_RTX_RWX_REQ_PC(a, b, c) \
673                 (0x00C00 | (a) << 5 | (b) << 4 | (c) << 3)
674 #define NDC_AF_PORTX_RTX_RWX_OSTDN_PC(a, b, c) \
675                 (0x00D00 | (a) << 5 | (b) << 4 | (c) << 3)
676 #define NDC_AF_PORTX_RTX_RWX_LAT_PC(a, b, c) \
677                 (0x00E00 | (a) << 5 | (b) << 4 | (c) << 3)
678 #define NDC_AF_PORTX_RTX_CANT_ALLOC_PC(a, b) \
679                 (0x00F00 | (a) << 5 | (b) << 4)
680 #define NDC_AF_BANKX_HIT_PC(a)          (0x01000 | (a) << 3)
681 #define NDC_AF_BANKX_MISS_PC(a)         (0x01100 | (a) << 3)
682
683 /* LBK */
684 #define LBK_CONST                       (0x10ull)
685 #define LBK_LINK_CFG_P2X                (0x400ull)
686 #define LBK_LINK_CFG_X2P                (0x408ull)
687 #define LBK_CONST_CHANS                 GENMASK_ULL(47, 32)
688 #define LBK_CONST_DST                   GENMASK_ULL(31, 28)
689 #define LBK_CONST_SRC                   GENMASK_ULL(27, 24)
690 #define LBK_CONST_BUF_SIZE              GENMASK_ULL(23, 0)
691 #define LBK_LINK_CFG_RANGE_MASK         GENMASK_ULL(19, 16)
692 #define LBK_LINK_CFG_ID_MASK            GENMASK_ULL(11, 6)
693 #define LBK_LINK_CFG_BASE_MASK          GENMASK_ULL(5, 0)
694
695 #endif /* RVU_REG_H */