1/* SPDX-License-Identifier: (GPL-2.0 OR MIT) */
2
3/* This file is autogenerated by cml-utils 2021-10-10 13:25:08 +0200.
4 * Commit ID: 26db2002924973d36a30b369c94f025a678fe9ea (dirty)
5 */
6
7#ifndef _LAN966X_REGS_H_
8#define _LAN966X_REGS_H_
9
10#include <linux/bitfield.h>
11#include <linux/types.h>
12#include <linux/bug.h>
13
14enum lan966x_target {
15 TARGET_AFI = 2,
16 TARGET_ANA = 3,
17 TARGET_CHIP_TOP = 5,
18 TARGET_CPU = 6,
19 TARGET_DEV = 13,
20 TARGET_FDMA = 21,
21 TARGET_GCB = 27,
22 TARGET_ORG = 36,
23 TARGET_PTP = 41,
24 TARGET_QS = 42,
25 TARGET_QSYS = 46,
26 TARGET_REW = 47,
27 TARGET_SYS = 52,
28 TARGET_VCAP = 61,
29 NUM_TARGETS = 66
30};
31
32#define __REG(...) __VA_ARGS__
33
34/* AFI:PORT_TBL:PORT_FRM_OUT */
35#define AFI_PORT_FRM_OUT(g) __REG(TARGET_AFI, 0, 1, 98816, g, 10, 8, 0, 0, 1, 4)
36
37#define AFI_PORT_FRM_OUT_FRM_OUT_CNT GENMASK(26, 16)
38#define AFI_PORT_FRM_OUT_FRM_OUT_CNT_SET(x)\
39 FIELD_PREP(AFI_PORT_FRM_OUT_FRM_OUT_CNT, x)
40#define AFI_PORT_FRM_OUT_FRM_OUT_CNT_GET(x)\
41 FIELD_GET(AFI_PORT_FRM_OUT_FRM_OUT_CNT, x)
42
43/* AFI:PORT_TBL:PORT_CFG */
44#define AFI_PORT_CFG(g) __REG(TARGET_AFI, 0, 1, 98816, g, 10, 8, 4, 0, 1, 4)
45
46#define AFI_PORT_CFG_FC_SKIP_TTI_INJ BIT(16)
47#define AFI_PORT_CFG_FC_SKIP_TTI_INJ_SET(x)\
48 FIELD_PREP(AFI_PORT_CFG_FC_SKIP_TTI_INJ, x)
49#define AFI_PORT_CFG_FC_SKIP_TTI_INJ_GET(x)\
50 FIELD_GET(AFI_PORT_CFG_FC_SKIP_TTI_INJ, x)
51
52#define AFI_PORT_CFG_FRM_OUT_MAX GENMASK(9, 0)
53#define AFI_PORT_CFG_FRM_OUT_MAX_SET(x)\
54 FIELD_PREP(AFI_PORT_CFG_FRM_OUT_MAX, x)
55#define AFI_PORT_CFG_FRM_OUT_MAX_GET(x)\
56 FIELD_GET(AFI_PORT_CFG_FRM_OUT_MAX, x)
57
58/* ANA:ANA:ADVLEARN */
59#define ANA_ADVLEARN __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 0, 0, 1, 4)
60
61#define ANA_ADVLEARN_VLAN_CHK BIT(0)
62#define ANA_ADVLEARN_VLAN_CHK_SET(x)\
63 FIELD_PREP(ANA_ADVLEARN_VLAN_CHK, x)
64#define ANA_ADVLEARN_VLAN_CHK_GET(x)\
65 FIELD_GET(ANA_ADVLEARN_VLAN_CHK, x)
66
67/* ANA:ANA:VLANMASK */
68#define ANA_VLANMASK __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 8, 0, 1, 4)
69
70/* ANA:ANA:ANAINTR */
71#define ANA_ANAINTR __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 16, 0, 1, 4)
72
73#define ANA_ANAINTR_INTR BIT(1)
74#define ANA_ANAINTR_INTR_SET(x)\
75 FIELD_PREP(ANA_ANAINTR_INTR, x)
76#define ANA_ANAINTR_INTR_GET(x)\
77 FIELD_GET(ANA_ANAINTR_INTR, x)
78
79#define ANA_ANAINTR_INTR_ENA BIT(0)
80#define ANA_ANAINTR_INTR_ENA_SET(x)\
81 FIELD_PREP(ANA_ANAINTR_INTR_ENA, x)
82#define ANA_ANAINTR_INTR_ENA_GET(x)\
83 FIELD_GET(ANA_ANAINTR_INTR_ENA, x)
84
85/* ANA:ANA:AUTOAGE */
86#define ANA_AUTOAGE __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 44, 0, 1, 4)
87
88#define ANA_AUTOAGE_AGE_PERIOD GENMASK(20, 1)
89#define ANA_AUTOAGE_AGE_PERIOD_SET(x)\
90 FIELD_PREP(ANA_AUTOAGE_AGE_PERIOD, x)
91#define ANA_AUTOAGE_AGE_PERIOD_GET(x)\
92 FIELD_GET(ANA_AUTOAGE_AGE_PERIOD, x)
93
94/* ANA:ANA:MIRRORPORTS */
95#define ANA_MIRRORPORTS __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 60, 0, 1, 4)
96
97#define ANA_MIRRORPORTS_MIRRORPORTS GENMASK(8, 0)
98#define ANA_MIRRORPORTS_MIRRORPORTS_SET(x)\
99 FIELD_PREP(ANA_MIRRORPORTS_MIRRORPORTS, x)
100#define ANA_MIRRORPORTS_MIRRORPORTS_GET(x)\
101 FIELD_GET(ANA_MIRRORPORTS_MIRRORPORTS, x)
102
103/* ANA:ANA:EMIRRORPORTS */
104#define ANA_EMIRRORPORTS __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 64, 0, 1, 4)
105
106#define ANA_EMIRRORPORTS_EMIRRORPORTS GENMASK(8, 0)
107#define ANA_EMIRRORPORTS_EMIRRORPORTS_SET(x)\
108 FIELD_PREP(ANA_EMIRRORPORTS_EMIRRORPORTS, x)
109#define ANA_EMIRRORPORTS_EMIRRORPORTS_GET(x)\
110 FIELD_GET(ANA_EMIRRORPORTS_EMIRRORPORTS, x)
111
112/* ANA:ANA:FLOODING */
113#define ANA_FLOODING(r) __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 68, r, 8, 4)
114
115#define ANA_FLOODING_FLD_UNICAST GENMASK(17, 12)
116#define ANA_FLOODING_FLD_UNICAST_SET(x)\
117 FIELD_PREP(ANA_FLOODING_FLD_UNICAST, x)
118#define ANA_FLOODING_FLD_UNICAST_GET(x)\
119 FIELD_GET(ANA_FLOODING_FLD_UNICAST, x)
120
121#define ANA_FLOODING_FLD_BROADCAST GENMASK(11, 6)
122#define ANA_FLOODING_FLD_BROADCAST_SET(x)\
123 FIELD_PREP(ANA_FLOODING_FLD_BROADCAST, x)
124#define ANA_FLOODING_FLD_BROADCAST_GET(x)\
125 FIELD_GET(ANA_FLOODING_FLD_BROADCAST, x)
126
127#define ANA_FLOODING_FLD_MULTICAST GENMASK(5, 0)
128#define ANA_FLOODING_FLD_MULTICAST_SET(x)\
129 FIELD_PREP(ANA_FLOODING_FLD_MULTICAST, x)
130#define ANA_FLOODING_FLD_MULTICAST_GET(x)\
131 FIELD_GET(ANA_FLOODING_FLD_MULTICAST, x)
132
133/* ANA:ANA:FLOODING_IPMC */
134#define ANA_FLOODING_IPMC __REG(TARGET_ANA, 0, 1, 29824, 0, 1, 244, 100, 0, 1, 4)
135
136#define ANA_FLOODING_IPMC_FLD_MC4_CTRL GENMASK(23, 18)
137#define ANA_FLOODING_IPMC_FLD_MC4_CTRL_SET(x)\
138 FIELD_PREP(ANA_FLOODING_IPMC_FLD_MC4_CTRL, x)
139#define ANA_FLOODING_IPMC_FLD_MC4_CTRL_GET(x)\
140 FIELD_GET(ANA_FLOODING_IPMC_FLD_MC4_CTRL, x)
141
142#define ANA_FLOODING_IPMC_FLD_MC4_DATA GENMASK(17, 12)
143#define ANA_FLOODING_IPMC_FLD_MC4_DATA_SET(x)\
144 FIELD_PREP(ANA_FLOODING_IPMC_FLD_MC4_DATA, x)
145#define ANA_FLOODING_IPMC_FLD_MC4_DATA_GET(x)\
146 FIELD_GET(ANA_FLOODING_IPMC_FLD_MC4_DATA, x)
147
148#define ANA_FLOODING_IPMC_FLD_MC6_CTRL GENMASK(11, 6)
149#define ANA_FLOODING_IPMC_FLD_MC6_CTRL_SET(x)\
150 FIELD_PREP(ANA_FLOODING_IPMC_FLD_MC6_CTRL, x)
151#define ANA_FLOODING_IPMC_FLD_MC6_CTRL_GET(x)\
152 FIELD_GET(ANA_FLOODING_IPMC_FLD_MC6_CTRL, x)
153
154#define ANA_FLOODING_IPMC_FLD_MC6_DATA GENMASK(5, 0)
155#define ANA_FLOODING_IPMC_FLD_MC6_DATA_SET(x)\
156 FIELD_PREP(ANA_FLOODING_IPMC_FLD_MC6_DATA, x)
157#define ANA_FLOODING_IPMC_FLD_MC6_DATA_GET(x)\
158 FIELD_GET(ANA_FLOODING_IPMC_FLD_MC6_DATA, x)
159
160/* ANA:PGID:PGID */
161#define ANA_PGID(g) __REG(TARGET_ANA, 0, 1, 27648, g, 89, 8, 0, 0, 1, 4)
162
163#define ANA_PGID_PGID GENMASK(8, 0)
164#define ANA_PGID_PGID_SET(x)\
165 FIELD_PREP(ANA_PGID_PGID, x)
166#define ANA_PGID_PGID_GET(x)\
167 FIELD_GET(ANA_PGID_PGID, x)
168
169/* ANA:PGID:PGID_CFG */
170#define ANA_PGID_CFG(g) __REG(TARGET_ANA, 0, 1, 27648, g, 89, 8, 4, 0, 1, 4)
171
172#define ANA_PGID_CFG_OBEY_VLAN BIT(0)
173#define ANA_PGID_CFG_OBEY_VLAN_SET(x)\
174 FIELD_PREP(ANA_PGID_CFG_OBEY_VLAN, x)
175#define ANA_PGID_CFG_OBEY_VLAN_GET(x)\
176 FIELD_GET(ANA_PGID_CFG_OBEY_VLAN, x)
177
178/* ANA:ANA_TABLES:MACHDATA */
179#define ANA_MACHDATA __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 40, 0, 1, 4)
180
181/* ANA:ANA_TABLES:MACLDATA */
182#define ANA_MACLDATA __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 44, 0, 1, 4)
183
184/* ANA:ANA_TABLES:MACACCESS */
185#define ANA_MACACCESS __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 48, 0, 1, 4)
186
187#define ANA_MACACCESS_CHANGE2SW BIT(17)
188#define ANA_MACACCESS_CHANGE2SW_SET(x)\
189 FIELD_PREP(ANA_MACACCESS_CHANGE2SW, x)
190#define ANA_MACACCESS_CHANGE2SW_GET(x)\
191 FIELD_GET(ANA_MACACCESS_CHANGE2SW, x)
192
193#define ANA_MACACCESS_MAC_CPU_COPY BIT(16)
194#define ANA_MACACCESS_MAC_CPU_COPY_SET(x)\
195 FIELD_PREP(ANA_MACACCESS_MAC_CPU_COPY, x)
196#define ANA_MACACCESS_MAC_CPU_COPY_GET(x)\
197 FIELD_GET(ANA_MACACCESS_MAC_CPU_COPY, x)
198
199#define ANA_MACACCESS_VALID BIT(12)
200#define ANA_MACACCESS_VALID_SET(x)\
201 FIELD_PREP(ANA_MACACCESS_VALID, x)
202#define ANA_MACACCESS_VALID_GET(x)\
203 FIELD_GET(ANA_MACACCESS_VALID, x)
204
205#define ANA_MACACCESS_ENTRYTYPE GENMASK(11, 10)
206#define ANA_MACACCESS_ENTRYTYPE_SET(x)\
207 FIELD_PREP(ANA_MACACCESS_ENTRYTYPE, x)
208#define ANA_MACACCESS_ENTRYTYPE_GET(x)\
209 FIELD_GET(ANA_MACACCESS_ENTRYTYPE, x)
210
211#define ANA_MACACCESS_DEST_IDX GENMASK(9, 4)
212#define ANA_MACACCESS_DEST_IDX_SET(x)\
213 FIELD_PREP(ANA_MACACCESS_DEST_IDX, x)
214#define ANA_MACACCESS_DEST_IDX_GET(x)\
215 FIELD_GET(ANA_MACACCESS_DEST_IDX, x)
216
217#define ANA_MACACCESS_MAC_TABLE_CMD GENMASK(3, 0)
218#define ANA_MACACCESS_MAC_TABLE_CMD_SET(x)\
219 FIELD_PREP(ANA_MACACCESS_MAC_TABLE_CMD, x)
220#define ANA_MACACCESS_MAC_TABLE_CMD_GET(x)\
221 FIELD_GET(ANA_MACACCESS_MAC_TABLE_CMD, x)
222
223/* ANA:ANA_TABLES:MACTINDX */
224#define ANA_MACTINDX __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 52, 0, 1, 4)
225
226#define ANA_MACTINDX_BUCKET GENMASK(12, 11)
227#define ANA_MACTINDX_BUCKET_SET(x)\
228 FIELD_PREP(ANA_MACTINDX_BUCKET, x)
229#define ANA_MACTINDX_BUCKET_GET(x)\
230 FIELD_GET(ANA_MACTINDX_BUCKET, x)
231
232#define ANA_MACTINDX_M_INDEX GENMASK(10, 0)
233#define ANA_MACTINDX_M_INDEX_SET(x)\
234 FIELD_PREP(ANA_MACTINDX_M_INDEX, x)
235#define ANA_MACTINDX_M_INDEX_GET(x)\
236 FIELD_GET(ANA_MACTINDX_M_INDEX, x)
237
238/* ANA:ANA_TABLES:VLAN_PORT_MASK */
239#define ANA_VLAN_PORT_MASK __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 56, 0, 1, 4)
240
241#define ANA_VLAN_PORT_MASK_VLAN_PORT_MASK GENMASK(8, 0)
242#define ANA_VLAN_PORT_MASK_VLAN_PORT_MASK_SET(x)\
243 FIELD_PREP(ANA_VLAN_PORT_MASK_VLAN_PORT_MASK, x)
244#define ANA_VLAN_PORT_MASK_VLAN_PORT_MASK_GET(x)\
245 FIELD_GET(ANA_VLAN_PORT_MASK_VLAN_PORT_MASK, x)
246
247/* ANA:ANA_TABLES:VLANACCESS */
248#define ANA_VLANACCESS __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 60, 0, 1, 4)
249
250#define ANA_VLANACCESS_VLAN_TBL_CMD GENMASK(1, 0)
251#define ANA_VLANACCESS_VLAN_TBL_CMD_SET(x)\
252 FIELD_PREP(ANA_VLANACCESS_VLAN_TBL_CMD, x)
253#define ANA_VLANACCESS_VLAN_TBL_CMD_GET(x)\
254 FIELD_GET(ANA_VLANACCESS_VLAN_TBL_CMD, x)
255
256/* ANA:ANA_TABLES:VLANTIDX */
257#define ANA_VLANTIDX __REG(TARGET_ANA, 0, 1, 27520, 0, 1, 128, 64, 0, 1, 4)
258
259#define ANA_VLANTIDX_VLAN_PGID_CPU_DIS BIT(18)
260#define ANA_VLANTIDX_VLAN_PGID_CPU_DIS_SET(x)\
261 FIELD_PREP(ANA_VLANTIDX_VLAN_PGID_CPU_DIS, x)
262#define ANA_VLANTIDX_VLAN_PGID_CPU_DIS_GET(x)\
263 FIELD_GET(ANA_VLANTIDX_VLAN_PGID_CPU_DIS, x)
264
265#define ANA_VLANTIDX_V_INDEX GENMASK(11, 0)
266#define ANA_VLANTIDX_V_INDEX_SET(x)\
267 FIELD_PREP(ANA_VLANTIDX_V_INDEX, x)
268#define ANA_VLANTIDX_V_INDEX_GET(x)\
269 FIELD_GET(ANA_VLANTIDX_V_INDEX, x)
270
271/* ANA:PORT:VLAN_CFG */
272#define ANA_VLAN_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 0, 0, 1, 4)
273
274#define ANA_VLAN_CFG_VLAN_AWARE_ENA BIT(20)
275#define ANA_VLAN_CFG_VLAN_AWARE_ENA_SET(x)\
276 FIELD_PREP(ANA_VLAN_CFG_VLAN_AWARE_ENA, x)
277#define ANA_VLAN_CFG_VLAN_AWARE_ENA_GET(x)\
278 FIELD_GET(ANA_VLAN_CFG_VLAN_AWARE_ENA, x)
279
280#define ANA_VLAN_CFG_VLAN_POP_CNT GENMASK(19, 18)
281#define ANA_VLAN_CFG_VLAN_POP_CNT_SET(x)\
282 FIELD_PREP(ANA_VLAN_CFG_VLAN_POP_CNT, x)
283#define ANA_VLAN_CFG_VLAN_POP_CNT_GET(x)\
284 FIELD_GET(ANA_VLAN_CFG_VLAN_POP_CNT, x)
285
286#define ANA_VLAN_CFG_VLAN_PCP GENMASK(15, 13)
287#define ANA_VLAN_CFG_VLAN_PCP_SET(x)\
288 FIELD_PREP(ANA_VLAN_CFG_VLAN_PCP, x)
289#define ANA_VLAN_CFG_VLAN_PCP_GET(x)\
290 FIELD_GET(ANA_VLAN_CFG_VLAN_PCP, x)
291
292#define ANA_VLAN_CFG_VLAN_DEI BIT(12)
293#define ANA_VLAN_CFG_VLAN_DEI_SET(x)\
294 FIELD_PREP(ANA_VLAN_CFG_VLAN_DEI, x)
295#define ANA_VLAN_CFG_VLAN_DEI_GET(x)\
296 FIELD_GET(ANA_VLAN_CFG_VLAN_DEI, x)
297
298#define ANA_VLAN_CFG_VLAN_VID GENMASK(11, 0)
299#define ANA_VLAN_CFG_VLAN_VID_SET(x)\
300 FIELD_PREP(ANA_VLAN_CFG_VLAN_VID, x)
301#define ANA_VLAN_CFG_VLAN_VID_GET(x)\
302 FIELD_GET(ANA_VLAN_CFG_VLAN_VID, x)
303
304/* ANA:PORT:DROP_CFG */
305#define ANA_DROP_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 4, 0, 1, 4)
306
307#define ANA_DROP_CFG_DROP_UNTAGGED_ENA BIT(6)
308#define ANA_DROP_CFG_DROP_UNTAGGED_ENA_SET(x)\
309 FIELD_PREP(ANA_DROP_CFG_DROP_UNTAGGED_ENA, x)
310#define ANA_DROP_CFG_DROP_UNTAGGED_ENA_GET(x)\
311 FIELD_GET(ANA_DROP_CFG_DROP_UNTAGGED_ENA, x)
312
313#define ANA_DROP_CFG_DROP_PRIO_S_TAGGED_ENA BIT(3)
314#define ANA_DROP_CFG_DROP_PRIO_S_TAGGED_ENA_SET(x)\
315 FIELD_PREP(ANA_DROP_CFG_DROP_PRIO_S_TAGGED_ENA, x)
316#define ANA_DROP_CFG_DROP_PRIO_S_TAGGED_ENA_GET(x)\
317 FIELD_GET(ANA_DROP_CFG_DROP_PRIO_S_TAGGED_ENA, x)
318
319#define ANA_DROP_CFG_DROP_PRIO_C_TAGGED_ENA BIT(2)
320#define ANA_DROP_CFG_DROP_PRIO_C_TAGGED_ENA_SET(x)\
321 FIELD_PREP(ANA_DROP_CFG_DROP_PRIO_C_TAGGED_ENA, x)
322#define ANA_DROP_CFG_DROP_PRIO_C_TAGGED_ENA_GET(x)\
323 FIELD_GET(ANA_DROP_CFG_DROP_PRIO_C_TAGGED_ENA, x)
324
325#define ANA_DROP_CFG_DROP_MC_SMAC_ENA BIT(0)
326#define ANA_DROP_CFG_DROP_MC_SMAC_ENA_SET(x)\
327 FIELD_PREP(ANA_DROP_CFG_DROP_MC_SMAC_ENA, x)
328#define ANA_DROP_CFG_DROP_MC_SMAC_ENA_GET(x)\
329 FIELD_GET(ANA_DROP_CFG_DROP_MC_SMAC_ENA, x)
330
331/* ANA:PORT:QOS_CFG */
332#define ANA_QOS_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 8, 0, 1, 4)
333
334#define ANA_QOS_CFG_DP_DEFAULT_VAL BIT(8)
335#define ANA_QOS_CFG_DP_DEFAULT_VAL_SET(x)\
336 FIELD_PREP(ANA_QOS_CFG_DP_DEFAULT_VAL, x)
337#define ANA_QOS_CFG_DP_DEFAULT_VAL_GET(x)\
338 FIELD_GET(ANA_QOS_CFG_DP_DEFAULT_VAL, x)
339
340#define ANA_QOS_CFG_QOS_DEFAULT_VAL GENMASK(7, 5)
341#define ANA_QOS_CFG_QOS_DEFAULT_VAL_SET(x)\
342 FIELD_PREP(ANA_QOS_CFG_QOS_DEFAULT_VAL, x)
343#define ANA_QOS_CFG_QOS_DEFAULT_VAL_GET(x)\
344 FIELD_GET(ANA_QOS_CFG_QOS_DEFAULT_VAL, x)
345
346#define ANA_QOS_CFG_QOS_DSCP_ENA BIT(4)
347#define ANA_QOS_CFG_QOS_DSCP_ENA_SET(x)\
348 FIELD_PREP(ANA_QOS_CFG_QOS_DSCP_ENA, x)
349#define ANA_QOS_CFG_QOS_DSCP_ENA_GET(x)\
350 FIELD_GET(ANA_QOS_CFG_QOS_DSCP_ENA, x)
351
352#define ANA_QOS_CFG_QOS_PCP_ENA BIT(3)
353#define ANA_QOS_CFG_QOS_PCP_ENA_SET(x)\
354 FIELD_PREP(ANA_QOS_CFG_QOS_PCP_ENA, x)
355#define ANA_QOS_CFG_QOS_PCP_ENA_GET(x)\
356 FIELD_GET(ANA_QOS_CFG_QOS_PCP_ENA, x)
357
358#define ANA_QOS_CFG_DSCP_REWR_CFG GENMASK(1, 0)
359#define ANA_QOS_CFG_DSCP_REWR_CFG_SET(x)\
360 FIELD_PREP(ANA_QOS_CFG_DSCP_REWR_CFG, x)
361#define ANA_QOS_CFG_DSCP_REWR_CFG_GET(x)\
362 FIELD_GET(ANA_QOS_CFG_DSCP_REWR_CFG, x)
363
364/* ANA:PORT:VCAP_CFG */
365#define ANA_VCAP_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 12, 0, 1, 4)
366
367#define ANA_VCAP_CFG_S1_ENA BIT(14)
368#define ANA_VCAP_CFG_S1_ENA_SET(x)\
369 FIELD_PREP(ANA_VCAP_CFG_S1_ENA, x)
370#define ANA_VCAP_CFG_S1_ENA_GET(x)\
371 FIELD_GET(ANA_VCAP_CFG_S1_ENA, x)
372
373/* ANA:PORT:VCAP_S1_KEY_CFG */
374#define ANA_VCAP_S1_CFG(g, r) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 16, r, 3, 4)
375
376#define ANA_VCAP_S1_CFG_KEY_RT_CFG GENMASK(11, 9)
377#define ANA_VCAP_S1_CFG_KEY_RT_CFG_SET(x)\
378 FIELD_PREP(ANA_VCAP_S1_CFG_KEY_RT_CFG, x)
379#define ANA_VCAP_S1_CFG_KEY_RT_CFG_GET(x)\
380 FIELD_GET(ANA_VCAP_S1_CFG_KEY_RT_CFG, x)
381
382#define ANA_VCAP_S1_CFG_KEY_IP6_CFG GENMASK(8, 6)
383#define ANA_VCAP_S1_CFG_KEY_IP6_CFG_SET(x)\
384 FIELD_PREP(ANA_VCAP_S1_CFG_KEY_IP6_CFG, x)
385#define ANA_VCAP_S1_CFG_KEY_IP6_CFG_GET(x)\
386 FIELD_GET(ANA_VCAP_S1_CFG_KEY_IP6_CFG, x)
387
388#define ANA_VCAP_S1_CFG_KEY_IP4_CFG GENMASK(5, 3)
389#define ANA_VCAP_S1_CFG_KEY_IP4_CFG_SET(x)\
390 FIELD_PREP(ANA_VCAP_S1_CFG_KEY_IP4_CFG, x)
391#define ANA_VCAP_S1_CFG_KEY_IP4_CFG_GET(x)\
392 FIELD_GET(ANA_VCAP_S1_CFG_KEY_IP4_CFG, x)
393
394#define ANA_VCAP_S1_CFG_KEY_OTHER_CFG GENMASK(2, 0)
395#define ANA_VCAP_S1_CFG_KEY_OTHER_CFG_SET(x)\
396 FIELD_PREP(ANA_VCAP_S1_CFG_KEY_OTHER_CFG, x)
397#define ANA_VCAP_S1_CFG_KEY_OTHER_CFG_GET(x)\
398 FIELD_GET(ANA_VCAP_S1_CFG_KEY_OTHER_CFG, x)
399
400/* ANA:PORT:VCAP_S2_CFG */
401#define ANA_VCAP_S2_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 28, 0, 1, 4)
402
403#define ANA_VCAP_S2_CFG_ISDX_ENA GENMASK(20, 19)
404#define ANA_VCAP_S2_CFG_ISDX_ENA_SET(x)\
405 FIELD_PREP(ANA_VCAP_S2_CFG_ISDX_ENA, x)
406#define ANA_VCAP_S2_CFG_ISDX_ENA_GET(x)\
407 FIELD_GET(ANA_VCAP_S2_CFG_ISDX_ENA, x)
408
409#define ANA_VCAP_S2_CFG_UDP_PAYLOAD_ENA GENMASK(18, 17)
410#define ANA_VCAP_S2_CFG_UDP_PAYLOAD_ENA_SET(x)\
411 FIELD_PREP(ANA_VCAP_S2_CFG_UDP_PAYLOAD_ENA, x)
412#define ANA_VCAP_S2_CFG_UDP_PAYLOAD_ENA_GET(x)\
413 FIELD_GET(ANA_VCAP_S2_CFG_UDP_PAYLOAD_ENA, x)
414
415#define ANA_VCAP_S2_CFG_ETYPE_PAYLOAD_ENA GENMASK(16, 15)
416#define ANA_VCAP_S2_CFG_ETYPE_PAYLOAD_ENA_SET(x)\
417 FIELD_PREP(ANA_VCAP_S2_CFG_ETYPE_PAYLOAD_ENA, x)
418#define ANA_VCAP_S2_CFG_ETYPE_PAYLOAD_ENA_GET(x)\
419 FIELD_GET(ANA_VCAP_S2_CFG_ETYPE_PAYLOAD_ENA, x)
420
421#define ANA_VCAP_S2_CFG_ENA BIT(14)
422#define ANA_VCAP_S2_CFG_ENA_SET(x)\
423 FIELD_PREP(ANA_VCAP_S2_CFG_ENA, x)
424#define ANA_VCAP_S2_CFG_ENA_GET(x)\
425 FIELD_GET(ANA_VCAP_S2_CFG_ENA, x)
426
427#define ANA_VCAP_S2_CFG_SNAP_DIS GENMASK(13, 12)
428#define ANA_VCAP_S2_CFG_SNAP_DIS_SET(x)\
429 FIELD_PREP(ANA_VCAP_S2_CFG_SNAP_DIS, x)
430#define ANA_VCAP_S2_CFG_SNAP_DIS_GET(x)\
431 FIELD_GET(ANA_VCAP_S2_CFG_SNAP_DIS, x)
432
433#define ANA_VCAP_S2_CFG_ARP_DIS GENMASK(11, 10)
434#define ANA_VCAP_S2_CFG_ARP_DIS_SET(x)\
435 FIELD_PREP(ANA_VCAP_S2_CFG_ARP_DIS, x)
436#define ANA_VCAP_S2_CFG_ARP_DIS_GET(x)\
437 FIELD_GET(ANA_VCAP_S2_CFG_ARP_DIS, x)
438
439#define ANA_VCAP_S2_CFG_IP_TCPUDP_DIS GENMASK(9, 8)
440#define ANA_VCAP_S2_CFG_IP_TCPUDP_DIS_SET(x)\
441 FIELD_PREP(ANA_VCAP_S2_CFG_IP_TCPUDP_DIS, x)
442#define ANA_VCAP_S2_CFG_IP_TCPUDP_DIS_GET(x)\
443 FIELD_GET(ANA_VCAP_S2_CFG_IP_TCPUDP_DIS, x)
444
445#define ANA_VCAP_S2_CFG_IP_OTHER_DIS GENMASK(7, 6)
446#define ANA_VCAP_S2_CFG_IP_OTHER_DIS_SET(x)\
447 FIELD_PREP(ANA_VCAP_S2_CFG_IP_OTHER_DIS, x)
448#define ANA_VCAP_S2_CFG_IP_OTHER_DIS_GET(x)\
449 FIELD_GET(ANA_VCAP_S2_CFG_IP_OTHER_DIS, x)
450
451#define ANA_VCAP_S2_CFG_IP6_CFG GENMASK(5, 2)
452#define ANA_VCAP_S2_CFG_IP6_CFG_SET(x)\
453 FIELD_PREP(ANA_VCAP_S2_CFG_IP6_CFG, x)
454#define ANA_VCAP_S2_CFG_IP6_CFG_GET(x)\
455 FIELD_GET(ANA_VCAP_S2_CFG_IP6_CFG, x)
456
457#define ANA_VCAP_S2_CFG_OAM_DIS GENMASK(1, 0)
458#define ANA_VCAP_S2_CFG_OAM_DIS_SET(x)\
459 FIELD_PREP(ANA_VCAP_S2_CFG_OAM_DIS, x)
460#define ANA_VCAP_S2_CFG_OAM_DIS_GET(x)\
461 FIELD_GET(ANA_VCAP_S2_CFG_OAM_DIS, x)
462
463/* ANA:PORT:QOS_PCP_DEI_MAP_CFG */
464#define ANA_PCP_DEI_CFG(g, r) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 32, r, 16, 4)
465
466#define ANA_PCP_DEI_CFG_DP_PCP_DEI_VAL BIT(3)
467#define ANA_PCP_DEI_CFG_DP_PCP_DEI_VAL_SET(x)\
468 FIELD_PREP(ANA_PCP_DEI_CFG_DP_PCP_DEI_VAL, x)
469#define ANA_PCP_DEI_CFG_DP_PCP_DEI_VAL_GET(x)\
470 FIELD_GET(ANA_PCP_DEI_CFG_DP_PCP_DEI_VAL, x)
471
472#define ANA_PCP_DEI_CFG_QOS_PCP_DEI_VAL GENMASK(2, 0)
473#define ANA_PCP_DEI_CFG_QOS_PCP_DEI_VAL_SET(x)\
474 FIELD_PREP(ANA_PCP_DEI_CFG_QOS_PCP_DEI_VAL, x)
475#define ANA_PCP_DEI_CFG_QOS_PCP_DEI_VAL_GET(x)\
476 FIELD_GET(ANA_PCP_DEI_CFG_QOS_PCP_DEI_VAL, x)
477
478/* ANA:PORT:CPU_FWD_CFG */
479#define ANA_CPU_FWD_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 96, 0, 1, 4)
480
481#define ANA_CPU_FWD_CFG_MLD_REDIR_ENA BIT(6)
482#define ANA_CPU_FWD_CFG_MLD_REDIR_ENA_SET(x)\
483 FIELD_PREP(ANA_CPU_FWD_CFG_MLD_REDIR_ENA, x)
484#define ANA_CPU_FWD_CFG_MLD_REDIR_ENA_GET(x)\
485 FIELD_GET(ANA_CPU_FWD_CFG_MLD_REDIR_ENA, x)
486
487#define ANA_CPU_FWD_CFG_IGMP_REDIR_ENA BIT(5)
488#define ANA_CPU_FWD_CFG_IGMP_REDIR_ENA_SET(x)\
489 FIELD_PREP(ANA_CPU_FWD_CFG_IGMP_REDIR_ENA, x)
490#define ANA_CPU_FWD_CFG_IGMP_REDIR_ENA_GET(x)\
491 FIELD_GET(ANA_CPU_FWD_CFG_IGMP_REDIR_ENA, x)
492
493#define ANA_CPU_FWD_CFG_IPMC_CTRL_COPY_ENA BIT(4)
494#define ANA_CPU_FWD_CFG_IPMC_CTRL_COPY_ENA_SET(x)\
495 FIELD_PREP(ANA_CPU_FWD_CFG_IPMC_CTRL_COPY_ENA, x)
496#define ANA_CPU_FWD_CFG_IPMC_CTRL_COPY_ENA_GET(x)\
497 FIELD_GET(ANA_CPU_FWD_CFG_IPMC_CTRL_COPY_ENA, x)
498
499#define ANA_CPU_FWD_CFG_SRC_COPY_ENA BIT(3)
500#define ANA_CPU_FWD_CFG_SRC_COPY_ENA_SET(x)\
501 FIELD_PREP(ANA_CPU_FWD_CFG_SRC_COPY_ENA, x)
502#define ANA_CPU_FWD_CFG_SRC_COPY_ENA_GET(x)\
503 FIELD_GET(ANA_CPU_FWD_CFG_SRC_COPY_ENA, x)
504
505/* ANA:PORT:CPU_FWD_BPDU_CFG */
506#define ANA_CPU_FWD_BPDU_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 100, 0, 1, 4)
507
508/* ANA:PORT:PORT_CFG */
509#define ANA_PORT_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 112, 0, 1, 4)
510
511#define ANA_PORT_CFG_SRC_MIRROR_ENA BIT(13)
512#define ANA_PORT_CFG_SRC_MIRROR_ENA_SET(x)\
513 FIELD_PREP(ANA_PORT_CFG_SRC_MIRROR_ENA, x)
514#define ANA_PORT_CFG_SRC_MIRROR_ENA_GET(x)\
515 FIELD_GET(ANA_PORT_CFG_SRC_MIRROR_ENA, x)
516
517#define ANA_PORT_CFG_LEARNAUTO BIT(6)
518#define ANA_PORT_CFG_LEARNAUTO_SET(x)\
519 FIELD_PREP(ANA_PORT_CFG_LEARNAUTO, x)
520#define ANA_PORT_CFG_LEARNAUTO_GET(x)\
521 FIELD_GET(ANA_PORT_CFG_LEARNAUTO, x)
522
523#define ANA_PORT_CFG_LEARN_ENA BIT(5)
524#define ANA_PORT_CFG_LEARN_ENA_SET(x)\
525 FIELD_PREP(ANA_PORT_CFG_LEARN_ENA, x)
526#define ANA_PORT_CFG_LEARN_ENA_GET(x)\
527 FIELD_GET(ANA_PORT_CFG_LEARN_ENA, x)
528
529#define ANA_PORT_CFG_RECV_ENA BIT(4)
530#define ANA_PORT_CFG_RECV_ENA_SET(x)\
531 FIELD_PREP(ANA_PORT_CFG_RECV_ENA, x)
532#define ANA_PORT_CFG_RECV_ENA_GET(x)\
533 FIELD_GET(ANA_PORT_CFG_RECV_ENA, x)
534
535#define ANA_PORT_CFG_PORTID_VAL GENMASK(3, 0)
536#define ANA_PORT_CFG_PORTID_VAL_SET(x)\
537 FIELD_PREP(ANA_PORT_CFG_PORTID_VAL, x)
538#define ANA_PORT_CFG_PORTID_VAL_GET(x)\
539 FIELD_GET(ANA_PORT_CFG_PORTID_VAL, x)
540
541/* ANA:COMMON:DSCP_REWR_CFG */
542#define ANA_DSCP_REWR_CFG(r) __REG(TARGET_ANA, 0, 1, 31232, 0, 1, 552, 332, r, 16, 4)
543
544#define ANA_DSCP_REWR_CFG_DSCP_QOS_REWR_VAL GENMASK(5, 0)
545#define ANA_DSCP_REWR_CFG_DSCP_QOS_REWR_VAL_SET(x)\
546 FIELD_PREP(ANA_DSCP_REWR_CFG_DSCP_QOS_REWR_VAL, x)
547#define ANA_DSCP_REWR_CFG_DSCP_QOS_REWR_VAL_GET(x)\
548 FIELD_GET(ANA_DSCP_REWR_CFG_DSCP_QOS_REWR_VAL, x)
549
550/* ANA:PORT:POL_CFG */
551#define ANA_POL_CFG(g) __REG(TARGET_ANA, 0, 1, 28672, g, 9, 128, 116, 0, 1, 4)
552
553#define ANA_POL_CFG_PORT_POL_ENA BIT(17)
554#define ANA_POL_CFG_PORT_POL_ENA_SET(x)\
555 FIELD_PREP(ANA_POL_CFG_PORT_POL_ENA, x)
556#define ANA_POL_CFG_PORT_POL_ENA_GET(x)\
557 FIELD_GET(ANA_POL_CFG_PORT_POL_ENA, x)
558
559#define ANA_POL_CFG_POL_ORDER GENMASK(8, 0)
560#define ANA_POL_CFG_POL_ORDER_SET(x)\
561 FIELD_PREP(ANA_POL_CFG_POL_ORDER, x)
562#define ANA_POL_CFG_POL_ORDER_GET(x)\
563 FIELD_GET(ANA_POL_CFG_POL_ORDER, x)
564
565/* ANA:PFC:PFC_CFG */
566#define ANA_PFC_CFG(g) __REG(TARGET_ANA, 0, 1, 30720, g, 8, 64, 0, 0, 1, 4)
567
568#define ANA_PFC_CFG_FC_LINK_SPEED GENMASK(1, 0)
569#define ANA_PFC_CFG_FC_LINK_SPEED_SET(x)\
570 FIELD_PREP(ANA_PFC_CFG_FC_LINK_SPEED, x)
571#define ANA_PFC_CFG_FC_LINK_SPEED_GET(x)\
572 FIELD_GET(ANA_PFC_CFG_FC_LINK_SPEED, x)
573
574/* ANA:COMMON:AGGR_CFG */
575#define ANA_AGGR_CFG __REG(TARGET_ANA, 0, 1, 31232, 0, 1, 552, 0, 0, 1, 4)
576
577#define ANA_AGGR_CFG_AC_RND_ENA BIT(6)
578#define ANA_AGGR_CFG_AC_RND_ENA_SET(x)\
579 FIELD_PREP(ANA_AGGR_CFG_AC_RND_ENA, x)
580#define ANA_AGGR_CFG_AC_RND_ENA_GET(x)\
581 FIELD_GET(ANA_AGGR_CFG_AC_RND_ENA, x)
582
583#define ANA_AGGR_CFG_AC_DMAC_ENA BIT(5)
584#define ANA_AGGR_CFG_AC_DMAC_ENA_SET(x)\
585 FIELD_PREP(ANA_AGGR_CFG_AC_DMAC_ENA, x)
586#define ANA_AGGR_CFG_AC_DMAC_ENA_GET(x)\
587 FIELD_GET(ANA_AGGR_CFG_AC_DMAC_ENA, x)
588
589#define ANA_AGGR_CFG_AC_SMAC_ENA BIT(4)
590#define ANA_AGGR_CFG_AC_SMAC_ENA_SET(x)\
591 FIELD_PREP(ANA_AGGR_CFG_AC_SMAC_ENA, x)
592#define ANA_AGGR_CFG_AC_SMAC_ENA_GET(x)\
593 FIELD_GET(ANA_AGGR_CFG_AC_SMAC_ENA, x)
594
595#define ANA_AGGR_CFG_AC_IP6_FLOW_LBL_ENA BIT(3)
596#define ANA_AGGR_CFG_AC_IP6_FLOW_LBL_ENA_SET(x)\
597 FIELD_PREP(ANA_AGGR_CFG_AC_IP6_FLOW_LBL_ENA, x)
598#define ANA_AGGR_CFG_AC_IP6_FLOW_LBL_ENA_GET(x)\
599 FIELD_GET(ANA_AGGR_CFG_AC_IP6_FLOW_LBL_ENA, x)
600
601#define ANA_AGGR_CFG_AC_IP6_TCPUDP_ENA BIT(2)
602#define ANA_AGGR_CFG_AC_IP6_TCPUDP_ENA_SET(x)\
603 FIELD_PREP(ANA_AGGR_CFG_AC_IP6_TCPUDP_ENA, x)
604#define ANA_AGGR_CFG_AC_IP6_TCPUDP_ENA_GET(x)\
605 FIELD_GET(ANA_AGGR_CFG_AC_IP6_TCPUDP_ENA, x)
606
607#define ANA_AGGR_CFG_AC_IP4_SIPDIP_ENA BIT(1)
608#define ANA_AGGR_CFG_AC_IP4_SIPDIP_ENA_SET(x)\
609 FIELD_PREP(ANA_AGGR_CFG_AC_IP4_SIPDIP_ENA, x)
610#define ANA_AGGR_CFG_AC_IP4_SIPDIP_ENA_GET(x)\
611 FIELD_GET(ANA_AGGR_CFG_AC_IP4_SIPDIP_ENA, x)
612
613#define ANA_AGGR_CFG_AC_IP4_TCPUDP_ENA BIT(0)
614#define ANA_AGGR_CFG_AC_IP4_TCPUDP_ENA_SET(x)\
615 FIELD_PREP(ANA_AGGR_CFG_AC_IP4_TCPUDP_ENA, x)
616#define ANA_AGGR_CFG_AC_IP4_TCPUDP_ENA_GET(x)\
617 FIELD_GET(ANA_AGGR_CFG_AC_IP4_TCPUDP_ENA, x)
618
619/* ANA:COMMON:DSCP_CFG */
620#define ANA_DSCP_CFG(r) __REG(TARGET_ANA, 0, 1, 31232, 0, 1, 552, 76, r, 64, 4)
621
622#define ANA_DSCP_CFG_DP_DSCP_VAL BIT(11)
623#define ANA_DSCP_CFG_DP_DSCP_VAL_SET(x)\
624 FIELD_PREP(ANA_DSCP_CFG_DP_DSCP_VAL, x)
625#define ANA_DSCP_CFG_DP_DSCP_VAL_GET(x)\
626 FIELD_GET(ANA_DSCP_CFG_DP_DSCP_VAL, x)
627
628#define ANA_DSCP_CFG_QOS_DSCP_VAL GENMASK(10, 8)
629#define ANA_DSCP_CFG_QOS_DSCP_VAL_SET(x)\
630 FIELD_PREP(ANA_DSCP_CFG_QOS_DSCP_VAL, x)
631#define ANA_DSCP_CFG_QOS_DSCP_VAL_GET(x)\
632 FIELD_GET(ANA_DSCP_CFG_QOS_DSCP_VAL, x)
633
634#define ANA_DSCP_CFG_DSCP_TRUST_ENA BIT(1)
635#define ANA_DSCP_CFG_DSCP_TRUST_ENA_SET(x)\
636 FIELD_PREP(ANA_DSCP_CFG_DSCP_TRUST_ENA, x)
637#define ANA_DSCP_CFG_DSCP_TRUST_ENA_GET(x)\
638 FIELD_GET(ANA_DSCP_CFG_DSCP_TRUST_ENA, x)
639
640#define ANA_DSCP_CFG_DSCP_REWR_ENA BIT(0)
641#define ANA_DSCP_CFG_DSCP_REWR_ENA_SET(x)\
642 FIELD_PREP(ANA_DSCP_CFG_DSCP_REWR_ENA, x)
643#define ANA_DSCP_CFG_DSCP_REWR_ENA_GET(x)\
644 FIELD_GET(ANA_DSCP_CFG_DSCP_REWR_ENA, x)
645
646/* ANA:POL:POL_PIR_CFG */
647#define ANA_POL_PIR_CFG(g) __REG(TARGET_ANA, 0, 1, 16384, g, 345, 32, 0, 0, 1, 4)
648
649#define ANA_POL_PIR_CFG_PIR_RATE GENMASK(20, 6)
650#define ANA_POL_PIR_CFG_PIR_RATE_SET(x)\
651 FIELD_PREP(ANA_POL_PIR_CFG_PIR_RATE, x)
652#define ANA_POL_PIR_CFG_PIR_RATE_GET(x)\
653 FIELD_GET(ANA_POL_PIR_CFG_PIR_RATE, x)
654
655#define ANA_POL_PIR_CFG_PIR_BURST GENMASK(5, 0)
656#define ANA_POL_PIR_CFG_PIR_BURST_SET(x)\
657 FIELD_PREP(ANA_POL_PIR_CFG_PIR_BURST, x)
658#define ANA_POL_PIR_CFG_PIR_BURST_GET(x)\
659 FIELD_GET(ANA_POL_PIR_CFG_PIR_BURST, x)
660
661/* ANA:POL:POL_MODE_CFG */
662#define ANA_POL_MODE(g) __REG(TARGET_ANA, 0, 1, 16384, g, 345, 32, 8, 0, 1, 4)
663
664#define ANA_POL_MODE_DROP_ON_YELLOW_ENA BIT(11)
665#define ANA_POL_MODE_DROP_ON_YELLOW_ENA_SET(x)\
666 FIELD_PREP(ANA_POL_MODE_DROP_ON_YELLOW_ENA, x)
667#define ANA_POL_MODE_DROP_ON_YELLOW_ENA_GET(x)\
668 FIELD_GET(ANA_POL_MODE_DROP_ON_YELLOW_ENA, x)
669
670#define ANA_POL_MODE_MARK_ALL_FRMS_RED_ENA BIT(10)
671#define ANA_POL_MODE_MARK_ALL_FRMS_RED_ENA_SET(x)\
672 FIELD_PREP(ANA_POL_MODE_MARK_ALL_FRMS_RED_ENA, x)
673#define ANA_POL_MODE_MARK_ALL_FRMS_RED_ENA_GET(x)\
674 FIELD_GET(ANA_POL_MODE_MARK_ALL_FRMS_RED_ENA, x)
675
676#define ANA_POL_MODE_IPG_SIZE GENMASK(9, 5)
677#define ANA_POL_MODE_IPG_SIZE_SET(x)\
678 FIELD_PREP(ANA_POL_MODE_IPG_SIZE, x)
679#define ANA_POL_MODE_IPG_SIZE_GET(x)\
680 FIELD_GET(ANA_POL_MODE_IPG_SIZE, x)
681
682#define ANA_POL_MODE_FRM_MODE GENMASK(4, 3)
683#define ANA_POL_MODE_FRM_MODE_SET(x)\
684 FIELD_PREP(ANA_POL_MODE_FRM_MODE, x)
685#define ANA_POL_MODE_FRM_MODE_GET(x)\
686 FIELD_GET(ANA_POL_MODE_FRM_MODE, x)
687
688#define ANA_POL_MODE_OVERSHOOT_ENA BIT(0)
689#define ANA_POL_MODE_OVERSHOOT_ENA_SET(x)\
690 FIELD_PREP(ANA_POL_MODE_OVERSHOOT_ENA, x)
691#define ANA_POL_MODE_OVERSHOOT_ENA_GET(x)\
692 FIELD_GET(ANA_POL_MODE_OVERSHOOT_ENA, x)
693
694/* ANA:POL:POL_PIR_STATE */
695#define ANA_POL_PIR_STATE(g) __REG(TARGET_ANA, 0, 1, 16384, g, 345, 32, 12, 0, 1, 4)
696
697#define ANA_POL_PIR_STATE_PIR_LVL GENMASK(21, 0)
698#define ANA_POL_PIR_STATE_PIR_LVL_SET(x)\
699 FIELD_PREP(ANA_POL_PIR_STATE_PIR_LVL, x)
700#define ANA_POL_PIR_STATE_PIR_LVL_GET(x)\
701 FIELD_GET(ANA_POL_PIR_STATE_PIR_LVL, x)
702
703/* CHIP_TOP:CUPHY_CFG:CUPHY_PORT_CFG */
704#define CHIP_TOP_CUPHY_PORT_CFG(r) __REG(TARGET_CHIP_TOP, 0, 1, 16, 0, 1, 20, 8, r, 2, 4)
705
706#define CHIP_TOP_CUPHY_PORT_CFG_GTX_CLK_ENA BIT(0)
707#define CHIP_TOP_CUPHY_PORT_CFG_GTX_CLK_ENA_SET(x)\
708 FIELD_PREP(CHIP_TOP_CUPHY_PORT_CFG_GTX_CLK_ENA, x)
709#define CHIP_TOP_CUPHY_PORT_CFG_GTX_CLK_ENA_GET(x)\
710 FIELD_GET(CHIP_TOP_CUPHY_PORT_CFG_GTX_CLK_ENA, x)
711
712/* DEV:PORT_MODE:CLOCK_CFG */
713#define DEV_CLOCK_CFG(t) __REG(TARGET_DEV, t, 8, 0, 0, 1, 28, 0, 0, 1, 4)
714
715#define DEV_CLOCK_CFG_MAC_TX_RST BIT(7)
716#define DEV_CLOCK_CFG_MAC_TX_RST_SET(x)\
717 FIELD_PREP(DEV_CLOCK_CFG_MAC_TX_RST, x)
718#define DEV_CLOCK_CFG_MAC_TX_RST_GET(x)\
719 FIELD_GET(DEV_CLOCK_CFG_MAC_TX_RST, x)
720
721#define DEV_CLOCK_CFG_MAC_RX_RST BIT(6)
722#define DEV_CLOCK_CFG_MAC_RX_RST_SET(x)\
723 FIELD_PREP(DEV_CLOCK_CFG_MAC_RX_RST, x)
724#define DEV_CLOCK_CFG_MAC_RX_RST_GET(x)\
725 FIELD_GET(DEV_CLOCK_CFG_MAC_RX_RST, x)
726
727#define DEV_CLOCK_CFG_PCS_TX_RST BIT(5)
728#define DEV_CLOCK_CFG_PCS_TX_RST_SET(x)\
729 FIELD_PREP(DEV_CLOCK_CFG_PCS_TX_RST, x)
730#define DEV_CLOCK_CFG_PCS_TX_RST_GET(x)\
731 FIELD_GET(DEV_CLOCK_CFG_PCS_TX_RST, x)
732
733#define DEV_CLOCK_CFG_PCS_RX_RST BIT(4)
734#define DEV_CLOCK_CFG_PCS_RX_RST_SET(x)\
735 FIELD_PREP(DEV_CLOCK_CFG_PCS_RX_RST, x)
736#define DEV_CLOCK_CFG_PCS_RX_RST_GET(x)\
737 FIELD_GET(DEV_CLOCK_CFG_PCS_RX_RST, x)
738
739#define DEV_CLOCK_CFG_PORT_RST BIT(3)
740#define DEV_CLOCK_CFG_PORT_RST_SET(x)\
741 FIELD_PREP(DEV_CLOCK_CFG_PORT_RST, x)
742#define DEV_CLOCK_CFG_PORT_RST_GET(x)\
743 FIELD_GET(DEV_CLOCK_CFG_PORT_RST, x)
744
745#define DEV_CLOCK_CFG_LINK_SPEED GENMASK(1, 0)
746#define DEV_CLOCK_CFG_LINK_SPEED_SET(x)\
747 FIELD_PREP(DEV_CLOCK_CFG_LINK_SPEED, x)
748#define DEV_CLOCK_CFG_LINK_SPEED_GET(x)\
749 FIELD_GET(DEV_CLOCK_CFG_LINK_SPEED, x)
750
751/* DEV:MAC_CFG_STATUS:MAC_ENA_CFG */
752#define DEV_MAC_ENA_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 0, 0, 1, 4)
753
754#define DEV_MAC_ENA_CFG_RX_ENA BIT(4)
755#define DEV_MAC_ENA_CFG_RX_ENA_SET(x)\
756 FIELD_PREP(DEV_MAC_ENA_CFG_RX_ENA, x)
757#define DEV_MAC_ENA_CFG_RX_ENA_GET(x)\
758 FIELD_GET(DEV_MAC_ENA_CFG_RX_ENA, x)
759
760#define DEV_MAC_ENA_CFG_TX_ENA BIT(0)
761#define DEV_MAC_ENA_CFG_TX_ENA_SET(x)\
762 FIELD_PREP(DEV_MAC_ENA_CFG_TX_ENA, x)
763#define DEV_MAC_ENA_CFG_TX_ENA_GET(x)\
764 FIELD_GET(DEV_MAC_ENA_CFG_TX_ENA, x)
765
766/* DEV:MAC_CFG_STATUS:MAC_MODE_CFG */
767#define DEV_MAC_MODE_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 4, 0, 1, 4)
768
769#define DEV_MAC_MODE_CFG_GIGA_MODE_ENA BIT(4)
770#define DEV_MAC_MODE_CFG_GIGA_MODE_ENA_SET(x)\
771 FIELD_PREP(DEV_MAC_MODE_CFG_GIGA_MODE_ENA, x)
772#define DEV_MAC_MODE_CFG_GIGA_MODE_ENA_GET(x)\
773 FIELD_GET(DEV_MAC_MODE_CFG_GIGA_MODE_ENA, x)
774
775/* DEV:MAC_CFG_STATUS:MAC_MAXLEN_CFG */
776#define DEV_MAC_MAXLEN_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 8, 0, 1, 4)
777
778#define DEV_MAC_MAXLEN_CFG_MAX_LEN GENMASK(15, 0)
779#define DEV_MAC_MAXLEN_CFG_MAX_LEN_SET(x)\
780 FIELD_PREP(DEV_MAC_MAXLEN_CFG_MAX_LEN, x)
781#define DEV_MAC_MAXLEN_CFG_MAX_LEN_GET(x)\
782 FIELD_GET(DEV_MAC_MAXLEN_CFG_MAX_LEN, x)
783
784/* DEV:MAC_CFG_STATUS:MAC_TAGS_CFG */
785#define DEV_MAC_TAGS_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 12, 0, 1, 4)
786
787#define DEV_MAC_TAGS_CFG_VLAN_DBL_AWR_ENA BIT(1)
788#define DEV_MAC_TAGS_CFG_VLAN_DBL_AWR_ENA_SET(x)\
789 FIELD_PREP(DEV_MAC_TAGS_CFG_VLAN_DBL_AWR_ENA, x)
790#define DEV_MAC_TAGS_CFG_VLAN_DBL_AWR_ENA_GET(x)\
791 FIELD_GET(DEV_MAC_TAGS_CFG_VLAN_DBL_AWR_ENA, x)
792
793#define DEV_MAC_TAGS_CFG_VLAN_AWR_ENA BIT(0)
794#define DEV_MAC_TAGS_CFG_VLAN_AWR_ENA_SET(x)\
795 FIELD_PREP(DEV_MAC_TAGS_CFG_VLAN_AWR_ENA, x)
796#define DEV_MAC_TAGS_CFG_VLAN_AWR_ENA_GET(x)\
797 FIELD_GET(DEV_MAC_TAGS_CFG_VLAN_AWR_ENA, x)
798
799/* DEV:MAC_CFG_STATUS:MAC_IFG_CFG */
800#define DEV_MAC_IFG_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 20, 0, 1, 4)
801
802#define DEV_MAC_IFG_CFG_TX_IFG GENMASK(12, 8)
803#define DEV_MAC_IFG_CFG_TX_IFG_SET(x)\
804 FIELD_PREP(DEV_MAC_IFG_CFG_TX_IFG, x)
805#define DEV_MAC_IFG_CFG_TX_IFG_GET(x)\
806 FIELD_GET(DEV_MAC_IFG_CFG_TX_IFG, x)
807
808#define DEV_MAC_IFG_CFG_RX_IFG2 GENMASK(7, 4)
809#define DEV_MAC_IFG_CFG_RX_IFG2_SET(x)\
810 FIELD_PREP(DEV_MAC_IFG_CFG_RX_IFG2, x)
811#define DEV_MAC_IFG_CFG_RX_IFG2_GET(x)\
812 FIELD_GET(DEV_MAC_IFG_CFG_RX_IFG2, x)
813
814#define DEV_MAC_IFG_CFG_RX_IFG1 GENMASK(3, 0)
815#define DEV_MAC_IFG_CFG_RX_IFG1_SET(x)\
816 FIELD_PREP(DEV_MAC_IFG_CFG_RX_IFG1, x)
817#define DEV_MAC_IFG_CFG_RX_IFG1_GET(x)\
818 FIELD_GET(DEV_MAC_IFG_CFG_RX_IFG1, x)
819
820/* DEV:MAC_CFG_STATUS:MAC_HDX_CFG */
821#define DEV_MAC_HDX_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 24, 0, 1, 4)
822
823#define DEV_MAC_HDX_CFG_SEED GENMASK(23, 16)
824#define DEV_MAC_HDX_CFG_SEED_SET(x)\
825 FIELD_PREP(DEV_MAC_HDX_CFG_SEED, x)
826#define DEV_MAC_HDX_CFG_SEED_GET(x)\
827 FIELD_GET(DEV_MAC_HDX_CFG_SEED, x)
828
829#define DEV_MAC_HDX_CFG_SEED_LOAD BIT(12)
830#define DEV_MAC_HDX_CFG_SEED_LOAD_SET(x)\
831 FIELD_PREP(DEV_MAC_HDX_CFG_SEED_LOAD, x)
832#define DEV_MAC_HDX_CFG_SEED_LOAD_GET(x)\
833 FIELD_GET(DEV_MAC_HDX_CFG_SEED_LOAD, x)
834
835/* DEV:MAC_CFG_STATUS:MAC_FC_MAC_LOW_CFG */
836#define DEV_FC_MAC_LOW_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 32, 0, 1, 4)
837
838/* DEV:MAC_CFG_STATUS:MAC_FC_MAC_HIGH_CFG */
839#define DEV_FC_MAC_HIGH_CFG(t) __REG(TARGET_DEV, t, 8, 28, 0, 1, 44, 36, 0, 1, 4)
840
841/* DEV:PCS1G_CFG_STATUS:PCS1G_CFG */
842#define DEV_PCS1G_CFG(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 0, 0, 1, 4)
843
844#define DEV_PCS1G_CFG_PCS_ENA BIT(0)
845#define DEV_PCS1G_CFG_PCS_ENA_SET(x)\
846 FIELD_PREP(DEV_PCS1G_CFG_PCS_ENA, x)
847#define DEV_PCS1G_CFG_PCS_ENA_GET(x)\
848 FIELD_GET(DEV_PCS1G_CFG_PCS_ENA, x)
849
850/* DEV:PCS1G_CFG_STATUS:PCS1G_MODE_CFG */
851#define DEV_PCS1G_MODE_CFG(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 4, 0, 1, 4)
852
853#define DEV_PCS1G_MODE_CFG_SGMII_MODE_ENA BIT(0)
854#define DEV_PCS1G_MODE_CFG_SGMII_MODE_ENA_SET(x)\
855 FIELD_PREP(DEV_PCS1G_MODE_CFG_SGMII_MODE_ENA, x)
856#define DEV_PCS1G_MODE_CFG_SGMII_MODE_ENA_GET(x)\
857 FIELD_GET(DEV_PCS1G_MODE_CFG_SGMII_MODE_ENA, x)
858
859#define DEV_PCS1G_MODE_CFG_SAVE_PREAMBLE_ENA BIT(1)
860#define DEV_PCS1G_MODE_CFG_SAVE_PREAMBLE_ENA_SET(x)\
861 FIELD_PREP(DEV_PCS1G_MODE_CFG_SAVE_PREAMBLE_ENA, x)
862#define DEV_PCS1G_MODE_CFG_SAVE_PREAMBLE_ENA_GET(x)\
863 FIELD_GET(DEV_PCS1G_MODE_CFG_SAVE_PREAMBLE_ENA, x)
864
865/* DEV:PCS1G_CFG_STATUS:PCS1G_SD_CFG */
866#define DEV_PCS1G_SD_CFG(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 8, 0, 1, 4)
867
868#define DEV_PCS1G_SD_CFG_SD_ENA BIT(0)
869#define DEV_PCS1G_SD_CFG_SD_ENA_SET(x)\
870 FIELD_PREP(DEV_PCS1G_SD_CFG_SD_ENA, x)
871#define DEV_PCS1G_SD_CFG_SD_ENA_GET(x)\
872 FIELD_GET(DEV_PCS1G_SD_CFG_SD_ENA, x)
873
874/* DEV:PCS1G_CFG_STATUS:PCS1G_ANEG_CFG */
875#define DEV_PCS1G_ANEG_CFG(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 12, 0, 1, 4)
876
877#define DEV_PCS1G_ANEG_CFG_ADV_ABILITY GENMASK(31, 16)
878#define DEV_PCS1G_ANEG_CFG_ADV_ABILITY_SET(x)\
879 FIELD_PREP(DEV_PCS1G_ANEG_CFG_ADV_ABILITY, x)
880#define DEV_PCS1G_ANEG_CFG_ADV_ABILITY_GET(x)\
881 FIELD_GET(DEV_PCS1G_ANEG_CFG_ADV_ABILITY, x)
882
883#define DEV_PCS1G_ANEG_CFG_SW_RESOLVE_ENA BIT(8)
884#define DEV_PCS1G_ANEG_CFG_SW_RESOLVE_ENA_SET(x)\
885 FIELD_PREP(DEV_PCS1G_ANEG_CFG_SW_RESOLVE_ENA, x)
886#define DEV_PCS1G_ANEG_CFG_SW_RESOLVE_ENA_GET(x)\
887 FIELD_GET(DEV_PCS1G_ANEG_CFG_SW_RESOLVE_ENA, x)
888
889#define DEV_PCS1G_ANEG_CFG_RESTART_ONE_SHOT BIT(1)
890#define DEV_PCS1G_ANEG_CFG_RESTART_ONE_SHOT_SET(x)\
891 FIELD_PREP(DEV_PCS1G_ANEG_CFG_RESTART_ONE_SHOT, x)
892#define DEV_PCS1G_ANEG_CFG_RESTART_ONE_SHOT_GET(x)\
893 FIELD_GET(DEV_PCS1G_ANEG_CFG_RESTART_ONE_SHOT, x)
894
895#define DEV_PCS1G_ANEG_CFG_ENA BIT(0)
896#define DEV_PCS1G_ANEG_CFG_ENA_SET(x)\
897 FIELD_PREP(DEV_PCS1G_ANEG_CFG_ENA, x)
898#define DEV_PCS1G_ANEG_CFG_ENA_GET(x)\
899 FIELD_GET(DEV_PCS1G_ANEG_CFG_ENA, x)
900
901/* DEV:PCS1G_CFG_STATUS:PCS1G_ANEG_STATUS */
902#define DEV_PCS1G_ANEG_STATUS(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 32, 0, 1, 4)
903
904#define DEV_PCS1G_ANEG_STATUS_LP_ADV GENMASK(31, 16)
905#define DEV_PCS1G_ANEG_STATUS_LP_ADV_SET(x)\
906 FIELD_PREP(DEV_PCS1G_ANEG_STATUS_LP_ADV, x)
907#define DEV_PCS1G_ANEG_STATUS_LP_ADV_GET(x)\
908 FIELD_GET(DEV_PCS1G_ANEG_STATUS_LP_ADV, x)
909
910#define DEV_PCS1G_ANEG_STATUS_ANEG_COMPLETE BIT(0)
911#define DEV_PCS1G_ANEG_STATUS_ANEG_COMPLETE_SET(x)\
912 FIELD_PREP(DEV_PCS1G_ANEG_STATUS_ANEG_COMPLETE, x)
913#define DEV_PCS1G_ANEG_STATUS_ANEG_COMPLETE_GET(x)\
914 FIELD_GET(DEV_PCS1G_ANEG_STATUS_ANEG_COMPLETE, x)
915
916/* DEV:PCS1G_CFG_STATUS:PCS1G_LINK_STATUS */
917#define DEV_PCS1G_LINK_STATUS(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 40, 0, 1, 4)
918
919#define DEV_PCS1G_LINK_STATUS_LINK_STATUS BIT(4)
920#define DEV_PCS1G_LINK_STATUS_LINK_STATUS_SET(x)\
921 FIELD_PREP(DEV_PCS1G_LINK_STATUS_LINK_STATUS, x)
922#define DEV_PCS1G_LINK_STATUS_LINK_STATUS_GET(x)\
923 FIELD_GET(DEV_PCS1G_LINK_STATUS_LINK_STATUS, x)
924
925#define DEV_PCS1G_LINK_STATUS_SYNC_STATUS BIT(0)
926#define DEV_PCS1G_LINK_STATUS_SYNC_STATUS_SET(x)\
927 FIELD_PREP(DEV_PCS1G_LINK_STATUS_SYNC_STATUS, x)
928#define DEV_PCS1G_LINK_STATUS_SYNC_STATUS_GET(x)\
929 FIELD_GET(DEV_PCS1G_LINK_STATUS_SYNC_STATUS, x)
930
931/* DEV:PCS1G_CFG_STATUS:PCS1G_STICKY */
932#define DEV_PCS1G_STICKY(t) __REG(TARGET_DEV, t, 8, 72, 0, 1, 68, 48, 0, 1, 4)
933
934#define DEV_PCS1G_STICKY_LINK_DOWN_STICKY BIT(4)
935#define DEV_PCS1G_STICKY_LINK_DOWN_STICKY_SET(x)\
936 FIELD_PREP(DEV_PCS1G_STICKY_LINK_DOWN_STICKY, x)
937#define DEV_PCS1G_STICKY_LINK_DOWN_STICKY_GET(x)\
938 FIELD_GET(DEV_PCS1G_STICKY_LINK_DOWN_STICKY, x)
939
940/* FDMA:FDMA:FDMA_CH_ACTIVATE */
941#define FDMA_CH_ACTIVATE __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 0, 0, 1, 4)
942
943#define FDMA_CH_ACTIVATE_CH_ACTIVATE GENMASK(7, 0)
944#define FDMA_CH_ACTIVATE_CH_ACTIVATE_SET(x)\
945 FIELD_PREP(FDMA_CH_ACTIVATE_CH_ACTIVATE, x)
946#define FDMA_CH_ACTIVATE_CH_ACTIVATE_GET(x)\
947 FIELD_GET(FDMA_CH_ACTIVATE_CH_ACTIVATE, x)
948
949/* FDMA:FDMA:FDMA_CH_RELOAD */
950#define FDMA_CH_RELOAD __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 4, 0, 1, 4)
951
952#define FDMA_CH_RELOAD_CH_RELOAD GENMASK(7, 0)
953#define FDMA_CH_RELOAD_CH_RELOAD_SET(x)\
954 FIELD_PREP(FDMA_CH_RELOAD_CH_RELOAD, x)
955#define FDMA_CH_RELOAD_CH_RELOAD_GET(x)\
956 FIELD_GET(FDMA_CH_RELOAD_CH_RELOAD, x)
957
958/* FDMA:FDMA:FDMA_CH_DISABLE */
959#define FDMA_CH_DISABLE __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 8, 0, 1, 4)
960
961#define FDMA_CH_DISABLE_CH_DISABLE GENMASK(7, 0)
962#define FDMA_CH_DISABLE_CH_DISABLE_SET(x)\
963 FIELD_PREP(FDMA_CH_DISABLE_CH_DISABLE, x)
964#define FDMA_CH_DISABLE_CH_DISABLE_GET(x)\
965 FIELD_GET(FDMA_CH_DISABLE_CH_DISABLE, x)
966
967/* FDMA:FDMA:FDMA_CH_DB_DISCARD */
968#define FDMA_CH_DB_DISCARD __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 16, 0, 1, 4)
969
970#define FDMA_CH_DB_DISCARD_DB_DISCARD GENMASK(7, 0)
971#define FDMA_CH_DB_DISCARD_DB_DISCARD_SET(x)\
972 FIELD_PREP(FDMA_CH_DB_DISCARD_DB_DISCARD, x)
973#define FDMA_CH_DB_DISCARD_DB_DISCARD_GET(x)\
974 FIELD_GET(FDMA_CH_DB_DISCARD_DB_DISCARD, x)
975
976/* FDMA:FDMA:FDMA_DCB_LLP */
977#define FDMA_DCB_LLP(r) __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 52, r, 8, 4)
978
979/* FDMA:FDMA:FDMA_DCB_LLP1 */
980#define FDMA_DCB_LLP1(r) __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 84, r, 8, 4)
981
982/* FDMA:FDMA:FDMA_CH_ACTIVE */
983#define FDMA_CH_ACTIVE __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 180, 0, 1, 4)
984
985/* FDMA:FDMA:FDMA_CH_CFG */
986#define FDMA_CH_CFG(r) __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 224, r, 8, 4)
987
988#define FDMA_CH_CFG_CH_INTR_DB_EOF_ONLY BIT(4)
989#define FDMA_CH_CFG_CH_INTR_DB_EOF_ONLY_SET(x)\
990 FIELD_PREP(FDMA_CH_CFG_CH_INTR_DB_EOF_ONLY, x)
991#define FDMA_CH_CFG_CH_INTR_DB_EOF_ONLY_GET(x)\
992 FIELD_GET(FDMA_CH_CFG_CH_INTR_DB_EOF_ONLY, x)
993
994#define FDMA_CH_CFG_CH_INJ_PORT BIT(3)
995#define FDMA_CH_CFG_CH_INJ_PORT_SET(x)\
996 FIELD_PREP(FDMA_CH_CFG_CH_INJ_PORT, x)
997#define FDMA_CH_CFG_CH_INJ_PORT_GET(x)\
998 FIELD_GET(FDMA_CH_CFG_CH_INJ_PORT, x)
999
1000#define FDMA_CH_CFG_CH_DCB_DB_CNT GENMASK(2, 1)
1001#define FDMA_CH_CFG_CH_DCB_DB_CNT_SET(x)\
1002 FIELD_PREP(FDMA_CH_CFG_CH_DCB_DB_CNT, x)
1003#define FDMA_CH_CFG_CH_DCB_DB_CNT_GET(x)\
1004 FIELD_GET(FDMA_CH_CFG_CH_DCB_DB_CNT, x)
1005
1006#define FDMA_CH_CFG_CH_MEM BIT(0)
1007#define FDMA_CH_CFG_CH_MEM_SET(x)\
1008 FIELD_PREP(FDMA_CH_CFG_CH_MEM, x)
1009#define FDMA_CH_CFG_CH_MEM_GET(x)\
1010 FIELD_GET(FDMA_CH_CFG_CH_MEM, x)
1011
1012/* FDMA:FDMA:FDMA_PORT_CTRL */
1013#define FDMA_PORT_CTRL(r) __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 376, r, 2, 4)
1014
1015#define FDMA_PORT_CTRL_INJ_STOP BIT(4)
1016#define FDMA_PORT_CTRL_INJ_STOP_SET(x)\
1017 FIELD_PREP(FDMA_PORT_CTRL_INJ_STOP, x)
1018#define FDMA_PORT_CTRL_INJ_STOP_GET(x)\
1019 FIELD_GET(FDMA_PORT_CTRL_INJ_STOP, x)
1020
1021#define FDMA_PORT_CTRL_XTR_STOP BIT(2)
1022#define FDMA_PORT_CTRL_XTR_STOP_SET(x)\
1023 FIELD_PREP(FDMA_PORT_CTRL_XTR_STOP, x)
1024#define FDMA_PORT_CTRL_XTR_STOP_GET(x)\
1025 FIELD_GET(FDMA_PORT_CTRL_XTR_STOP, x)
1026
1027/* FDMA:FDMA:FDMA_INTR_DB */
1028#define FDMA_INTR_DB __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 392, 0, 1, 4)
1029
1030/* FDMA:FDMA:FDMA_INTR_DB_ENA */
1031#define FDMA_INTR_DB_ENA __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 396, 0, 1, 4)
1032
1033#define FDMA_INTR_DB_ENA_INTR_DB_ENA GENMASK(7, 0)
1034#define FDMA_INTR_DB_ENA_INTR_DB_ENA_SET(x)\
1035 FIELD_PREP(FDMA_INTR_DB_ENA_INTR_DB_ENA, x)
1036#define FDMA_INTR_DB_ENA_INTR_DB_ENA_GET(x)\
1037 FIELD_GET(FDMA_INTR_DB_ENA_INTR_DB_ENA, x)
1038
1039/* FDMA:FDMA:FDMA_INTR_ERR */
1040#define FDMA_INTR_ERR __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 400, 0, 1, 4)
1041
1042/* FDMA:FDMA:FDMA_ERRORS */
1043#define FDMA_ERRORS __REG(TARGET_FDMA, 0, 1, 8, 0, 1, 428, 412, 0, 1, 4)
1044
1045/* PTP:PTP_CFG:PTP_PIN_INTR */
1046#define PTP_PIN_INTR __REG(TARGET_PTP, 0, 1, 512, 0, 1, 16, 0, 0, 1, 4)
1047
1048#define PTP_PIN_INTR_INTR_PTP GENMASK(7, 0)
1049#define PTP_PIN_INTR_INTR_PTP_SET(x)\
1050 FIELD_PREP(PTP_PIN_INTR_INTR_PTP, x)
1051#define PTP_PIN_INTR_INTR_PTP_GET(x)\
1052 FIELD_GET(PTP_PIN_INTR_INTR_PTP, x)
1053
1054/* PTP:PTP_CFG:PTP_PIN_INTR_ENA */
1055#define PTP_PIN_INTR_ENA __REG(TARGET_PTP, 0, 1, 512, 0, 1, 16, 4, 0, 1, 4)
1056
1057#define PTP_PIN_INTR_ENA_INTR_ENA GENMASK(7, 0)
1058#define PTP_PIN_INTR_ENA_INTR_ENA_SET(x)\
1059 FIELD_PREP(PTP_PIN_INTR_ENA_INTR_ENA, x)
1060#define PTP_PIN_INTR_ENA_INTR_ENA_GET(x)\
1061 FIELD_GET(PTP_PIN_INTR_ENA_INTR_ENA, x)
1062
1063/* PTP:PTP_CFG:PTP_DOM_CFG */
1064#define PTP_DOM_CFG __REG(TARGET_PTP, 0, 1, 512, 0, 1, 16, 12, 0, 1, 4)
1065
1066#define PTP_DOM_CFG_ENA GENMASK(11, 9)
1067#define PTP_DOM_CFG_ENA_SET(x)\
1068 FIELD_PREP(PTP_DOM_CFG_ENA, x)
1069#define PTP_DOM_CFG_ENA_GET(x)\
1070 FIELD_GET(PTP_DOM_CFG_ENA, x)
1071
1072#define PTP_DOM_CFG_CLKCFG_DIS GENMASK(2, 0)
1073#define PTP_DOM_CFG_CLKCFG_DIS_SET(x)\
1074 FIELD_PREP(PTP_DOM_CFG_CLKCFG_DIS, x)
1075#define PTP_DOM_CFG_CLKCFG_DIS_GET(x)\
1076 FIELD_GET(PTP_DOM_CFG_CLKCFG_DIS, x)
1077
1078/* PTP:PTP_TOD_DOMAINS:CLK_PER_CFG */
1079#define PTP_CLK_PER_CFG(g, r) __REG(TARGET_PTP, 0, 1, 528, g, 3, 28, 0, r, 2, 4)
1080
1081/* PTP:PTP_PINS:PTP_PIN_CFG */
1082#define PTP_PIN_CFG(g) __REG(TARGET_PTP, 0, 1, 0, g, 8, 64, 0, 0, 1, 4)
1083
1084#define PTP_PIN_CFG_PIN_ACTION GENMASK(29, 27)
1085#define PTP_PIN_CFG_PIN_ACTION_SET(x)\
1086 FIELD_PREP(PTP_PIN_CFG_PIN_ACTION, x)
1087#define PTP_PIN_CFG_PIN_ACTION_GET(x)\
1088 FIELD_GET(PTP_PIN_CFG_PIN_ACTION, x)
1089
1090#define PTP_PIN_CFG_PIN_SYNC GENMASK(26, 25)
1091#define PTP_PIN_CFG_PIN_SYNC_SET(x)\
1092 FIELD_PREP(PTP_PIN_CFG_PIN_SYNC, x)
1093#define PTP_PIN_CFG_PIN_SYNC_GET(x)\
1094 FIELD_GET(PTP_PIN_CFG_PIN_SYNC, x)
1095
1096#define PTP_PIN_CFG_PIN_SELECT GENMASK(23, 21)
1097#define PTP_PIN_CFG_PIN_SELECT_SET(x)\
1098 FIELD_PREP(PTP_PIN_CFG_PIN_SELECT, x)
1099#define PTP_PIN_CFG_PIN_SELECT_GET(x)\
1100 FIELD_GET(PTP_PIN_CFG_PIN_SELECT, x)
1101
1102#define PTP_PIN_CFG_PIN_DOM GENMASK(17, 16)
1103#define PTP_PIN_CFG_PIN_DOM_SET(x)\
1104 FIELD_PREP(PTP_PIN_CFG_PIN_DOM, x)
1105#define PTP_PIN_CFG_PIN_DOM_GET(x)\
1106 FIELD_GET(PTP_PIN_CFG_PIN_DOM, x)
1107
1108/* PTP:PTP_PINS:PTP_TOD_SEC_MSB */
1109#define PTP_TOD_SEC_MSB(g) __REG(TARGET_PTP, 0, 1, 0, g, 8, 64, 4, 0, 1, 4)
1110
1111#define PTP_TOD_SEC_MSB_TOD_SEC_MSB GENMASK(15, 0)
1112#define PTP_TOD_SEC_MSB_TOD_SEC_MSB_SET(x)\
1113 FIELD_PREP(PTP_TOD_SEC_MSB_TOD_SEC_MSB, x)
1114#define PTP_TOD_SEC_MSB_TOD_SEC_MSB_GET(x)\
1115 FIELD_GET(PTP_TOD_SEC_MSB_TOD_SEC_MSB, x)
1116
1117/* PTP:PTP_PINS:PTP_TOD_SEC_LSB */
1118#define PTP_TOD_SEC_LSB(g) __REG(TARGET_PTP, 0, 1, 0, g, 8, 64, 8, 0, 1, 4)
1119
1120/* PTP:PTP_PINS:PTP_TOD_NSEC */
1121#define PTP_TOD_NSEC(g) __REG(TARGET_PTP, 0, 1, 0, g, 8, 64, 12, 0, 1, 4)
1122
1123#define PTP_TOD_NSEC_TOD_NSEC GENMASK(29, 0)
1124#define PTP_TOD_NSEC_TOD_NSEC_SET(x)\
1125 FIELD_PREP(PTP_TOD_NSEC_TOD_NSEC, x)
1126#define PTP_TOD_NSEC_TOD_NSEC_GET(x)\
1127 FIELD_GET(PTP_TOD_NSEC_TOD_NSEC, x)
1128
1129/* PTP:PTP_PINS:WF_HIGH_PERIOD */
1130#define PTP_WF_HIGH_PERIOD(g) __REG(TARGET_PTP,\
1131 0, 1, 0, g, 8, 64, 24, 0, 1, 4)
1132
1133#define PTP_WF_HIGH_PERIOD_PIN_WFH(x) ((x) & GENMASK(29, 0))
1134#define PTP_WF_HIGH_PERIOD_PIN_WFH_M GENMASK(29, 0)
1135#define PTP_WF_HIGH_PERIOD_PIN_WFH_X(x) ((x) & GENMASK(29, 0))
1136
1137/* PTP:PTP_PINS:WF_LOW_PERIOD */
1138#define PTP_WF_LOW_PERIOD(g) __REG(TARGET_PTP,\
1139 0, 1, 0, g, 8, 64, 28, 0, 1, 4)
1140
1141#define PTP_WF_LOW_PERIOD_PIN_WFL(x) ((x) & GENMASK(29, 0))
1142#define PTP_WF_LOW_PERIOD_PIN_WFL_M GENMASK(29, 0)
1143#define PTP_WF_LOW_PERIOD_PIN_WFL_X(x) ((x) & GENMASK(29, 0))
1144
1145/* PTP:PTP_TS_FIFO:PTP_TWOSTEP_CTRL */
1146#define PTP_TWOSTEP_CTRL __REG(TARGET_PTP, 0, 1, 612, 0, 1, 12, 0, 0, 1, 4)
1147
1148#define PTP_TWOSTEP_CTRL_NXT BIT(11)
1149#define PTP_TWOSTEP_CTRL_NXT_SET(x)\
1150 FIELD_PREP(PTP_TWOSTEP_CTRL_NXT, x)
1151#define PTP_TWOSTEP_CTRL_NXT_GET(x)\
1152 FIELD_GET(PTP_TWOSTEP_CTRL_NXT, x)
1153
1154#define PTP_TWOSTEP_CTRL_VLD BIT(10)
1155#define PTP_TWOSTEP_CTRL_VLD_SET(x)\
1156 FIELD_PREP(PTP_TWOSTEP_CTRL_VLD, x)
1157#define PTP_TWOSTEP_CTRL_VLD_GET(x)\
1158 FIELD_GET(PTP_TWOSTEP_CTRL_VLD, x)
1159
1160#define PTP_TWOSTEP_CTRL_STAMP_TX BIT(9)
1161#define PTP_TWOSTEP_CTRL_STAMP_TX_SET(x)\
1162 FIELD_PREP(PTP_TWOSTEP_CTRL_STAMP_TX, x)
1163#define PTP_TWOSTEP_CTRL_STAMP_TX_GET(x)\
1164 FIELD_GET(PTP_TWOSTEP_CTRL_STAMP_TX, x)
1165
1166#define PTP_TWOSTEP_CTRL_STAMP_PORT GENMASK(8, 1)
1167#define PTP_TWOSTEP_CTRL_STAMP_PORT_SET(x)\
1168 FIELD_PREP(PTP_TWOSTEP_CTRL_STAMP_PORT, x)
1169#define PTP_TWOSTEP_CTRL_STAMP_PORT_GET(x)\
1170 FIELD_GET(PTP_TWOSTEP_CTRL_STAMP_PORT, x)
1171
1172#define PTP_TWOSTEP_CTRL_OVFL BIT(0)
1173#define PTP_TWOSTEP_CTRL_OVFL_SET(x)\
1174 FIELD_PREP(PTP_TWOSTEP_CTRL_OVFL, x)
1175#define PTP_TWOSTEP_CTRL_OVFL_GET(x)\
1176 FIELD_GET(PTP_TWOSTEP_CTRL_OVFL, x)
1177
1178/* PTP:PTP_TS_FIFO:PTP_TWOSTEP_STAMP */
1179#define PTP_TWOSTEP_STAMP __REG(TARGET_PTP, 0, 1, 612, 0, 1, 12, 4, 0, 1, 4)
1180
1181#define PTP_TWOSTEP_STAMP_STAMP_NSEC GENMASK(31, 2)
1182#define PTP_TWOSTEP_STAMP_STAMP_NSEC_SET(x)\
1183 FIELD_PREP(PTP_TWOSTEP_STAMP_STAMP_NSEC, x)
1184#define PTP_TWOSTEP_STAMP_STAMP_NSEC_GET(x)\
1185 FIELD_GET(PTP_TWOSTEP_STAMP_STAMP_NSEC, x)
1186
1187/* DEVCPU_QS:XTR:XTR_GRP_CFG */
1188#define QS_XTR_GRP_CFG(r) __REG(TARGET_QS, 0, 1, 0, 0, 1, 36, 0, r, 2, 4)
1189
1190#define QS_XTR_GRP_CFG_MODE GENMASK(3, 2)
1191#define QS_XTR_GRP_CFG_MODE_SET(x)\
1192 FIELD_PREP(QS_XTR_GRP_CFG_MODE, x)
1193#define QS_XTR_GRP_CFG_MODE_GET(x)\
1194 FIELD_GET(QS_XTR_GRP_CFG_MODE, x)
1195
1196#define QS_XTR_GRP_CFG_BYTE_SWAP BIT(0)
1197#define QS_XTR_GRP_CFG_BYTE_SWAP_SET(x)\
1198 FIELD_PREP(QS_XTR_GRP_CFG_BYTE_SWAP, x)
1199#define QS_XTR_GRP_CFG_BYTE_SWAP_GET(x)\
1200 FIELD_GET(QS_XTR_GRP_CFG_BYTE_SWAP, x)
1201
1202/* DEVCPU_QS:XTR:XTR_RD */
1203#define QS_XTR_RD(r) __REG(TARGET_QS, 0, 1, 0, 0, 1, 36, 8, r, 2, 4)
1204
1205/* DEVCPU_QS:XTR:XTR_FLUSH */
1206#define QS_XTR_FLUSH __REG(TARGET_QS, 0, 1, 0, 0, 1, 36, 24, 0, 1, 4)
1207
1208/* DEVCPU_QS:XTR:XTR_DATA_PRESENT */
1209#define QS_XTR_DATA_PRESENT __REG(TARGET_QS, 0, 1, 0, 0, 1, 36, 28, 0, 1, 4)
1210
1211/* DEVCPU_QS:INJ:INJ_GRP_CFG */
1212#define QS_INJ_GRP_CFG(r) __REG(TARGET_QS, 0, 1, 36, 0, 1, 40, 0, r, 2, 4)
1213
1214#define QS_INJ_GRP_CFG_MODE GENMASK(3, 2)
1215#define QS_INJ_GRP_CFG_MODE_SET(x)\
1216 FIELD_PREP(QS_INJ_GRP_CFG_MODE, x)
1217#define QS_INJ_GRP_CFG_MODE_GET(x)\
1218 FIELD_GET(QS_INJ_GRP_CFG_MODE, x)
1219
1220#define QS_INJ_GRP_CFG_BYTE_SWAP BIT(0)
1221#define QS_INJ_GRP_CFG_BYTE_SWAP_SET(x)\
1222 FIELD_PREP(QS_INJ_GRP_CFG_BYTE_SWAP, x)
1223#define QS_INJ_GRP_CFG_BYTE_SWAP_GET(x)\
1224 FIELD_GET(QS_INJ_GRP_CFG_BYTE_SWAP, x)
1225
1226/* DEVCPU_QS:INJ:INJ_WR */
1227#define QS_INJ_WR(r) __REG(TARGET_QS, 0, 1, 36, 0, 1, 40, 8, r, 2, 4)
1228
1229/* DEVCPU_QS:INJ:INJ_CTRL */
1230#define QS_INJ_CTRL(r) __REG(TARGET_QS, 0, 1, 36, 0, 1, 40, 16, r, 2, 4)
1231
1232#define QS_INJ_CTRL_GAP_SIZE GENMASK(24, 21)
1233#define QS_INJ_CTRL_GAP_SIZE_SET(x)\
1234 FIELD_PREP(QS_INJ_CTRL_GAP_SIZE, x)
1235#define QS_INJ_CTRL_GAP_SIZE_GET(x)\
1236 FIELD_GET(QS_INJ_CTRL_GAP_SIZE, x)
1237
1238#define QS_INJ_CTRL_EOF BIT(19)
1239#define QS_INJ_CTRL_EOF_SET(x)\
1240 FIELD_PREP(QS_INJ_CTRL_EOF, x)
1241#define QS_INJ_CTRL_EOF_GET(x)\
1242 FIELD_GET(QS_INJ_CTRL_EOF, x)
1243
1244#define QS_INJ_CTRL_SOF BIT(18)
1245#define QS_INJ_CTRL_SOF_SET(x)\
1246 FIELD_PREP(QS_INJ_CTRL_SOF, x)
1247#define QS_INJ_CTRL_SOF_GET(x)\
1248 FIELD_GET(QS_INJ_CTRL_SOF, x)
1249
1250#define QS_INJ_CTRL_VLD_BYTES GENMASK(17, 16)
1251#define QS_INJ_CTRL_VLD_BYTES_SET(x)\
1252 FIELD_PREP(QS_INJ_CTRL_VLD_BYTES, x)
1253#define QS_INJ_CTRL_VLD_BYTES_GET(x)\
1254 FIELD_GET(QS_INJ_CTRL_VLD_BYTES, x)
1255
1256/* DEVCPU_QS:INJ:INJ_STATUS */
1257#define QS_INJ_STATUS __REG(TARGET_QS, 0, 1, 36, 0, 1, 40, 24, 0, 1, 4)
1258
1259#define QS_INJ_STATUS_WMARK_REACHED GENMASK(5, 4)
1260#define QS_INJ_STATUS_WMARK_REACHED_SET(x)\
1261 FIELD_PREP(QS_INJ_STATUS_WMARK_REACHED, x)
1262#define QS_INJ_STATUS_WMARK_REACHED_GET(x)\
1263 FIELD_GET(QS_INJ_STATUS_WMARK_REACHED, x)
1264
1265#define QS_INJ_STATUS_FIFO_RDY GENMASK(3, 2)
1266#define QS_INJ_STATUS_FIFO_RDY_SET(x)\
1267 FIELD_PREP(QS_INJ_STATUS_FIFO_RDY, x)
1268#define QS_INJ_STATUS_FIFO_RDY_GET(x)\
1269 FIELD_GET(QS_INJ_STATUS_FIFO_RDY, x)
1270
1271/* QSYS:SYSTEM:PORT_MODE */
1272#define QSYS_PORT_MODE(r) __REG(TARGET_QSYS, 0, 1, 28008, 0, 1, 216, 0, r, 10, 4)
1273
1274#define QSYS_PORT_MODE_DEQUEUE_DIS BIT(1)
1275#define QSYS_PORT_MODE_DEQUEUE_DIS_SET(x)\
1276 FIELD_PREP(QSYS_PORT_MODE_DEQUEUE_DIS, x)
1277#define QSYS_PORT_MODE_DEQUEUE_DIS_GET(x)\
1278 FIELD_GET(QSYS_PORT_MODE_DEQUEUE_DIS, x)
1279
1280/* QSYS:SYSTEM:SWITCH_PORT_MODE */
1281#define QSYS_SW_PORT_MODE(r) __REG(TARGET_QSYS, 0, 1, 28008, 0, 1, 216, 80, r, 9, 4)
1282
1283#define QSYS_SW_PORT_MODE_PORT_ENA BIT(18)
1284#define QSYS_SW_PORT_MODE_PORT_ENA_SET(x)\
1285 FIELD_PREP(QSYS_SW_PORT_MODE_PORT_ENA, x)
1286#define QSYS_SW_PORT_MODE_PORT_ENA_GET(x)\
1287 FIELD_GET(QSYS_SW_PORT_MODE_PORT_ENA, x)
1288
1289#define QSYS_SW_PORT_MODE_SCH_NEXT_CFG GENMASK(16, 14)
1290#define QSYS_SW_PORT_MODE_SCH_NEXT_CFG_SET(x)\
1291 FIELD_PREP(QSYS_SW_PORT_MODE_SCH_NEXT_CFG, x)
1292#define QSYS_SW_PORT_MODE_SCH_NEXT_CFG_GET(x)\
1293 FIELD_GET(QSYS_SW_PORT_MODE_SCH_NEXT_CFG, x)
1294
1295#define QSYS_SW_PORT_MODE_INGRESS_DROP_MODE BIT(12)
1296#define QSYS_SW_PORT_MODE_INGRESS_DROP_MODE_SET(x)\
1297 FIELD_PREP(QSYS_SW_PORT_MODE_INGRESS_DROP_MODE, x)
1298#define QSYS_SW_PORT_MODE_INGRESS_DROP_MODE_GET(x)\
1299 FIELD_GET(QSYS_SW_PORT_MODE_INGRESS_DROP_MODE, x)
1300
1301#define QSYS_SW_PORT_MODE_TX_PFC_ENA GENMASK(11, 4)
1302#define QSYS_SW_PORT_MODE_TX_PFC_ENA_SET(x)\
1303 FIELD_PREP(QSYS_SW_PORT_MODE_TX_PFC_ENA, x)
1304#define QSYS_SW_PORT_MODE_TX_PFC_ENA_GET(x)\
1305 FIELD_GET(QSYS_SW_PORT_MODE_TX_PFC_ENA, x)
1306
1307#define QSYS_SW_PORT_MODE_AGING_MODE GENMASK(1, 0)
1308#define QSYS_SW_PORT_MODE_AGING_MODE_SET(x)\
1309 FIELD_PREP(QSYS_SW_PORT_MODE_AGING_MODE, x)
1310#define QSYS_SW_PORT_MODE_AGING_MODE_GET(x)\
1311 FIELD_GET(QSYS_SW_PORT_MODE_AGING_MODE, x)
1312
1313/* QSYS:SYSTEM:SW_STATUS */
1314#define QSYS_SW_STATUS(r) __REG(TARGET_QSYS, 0, 1, 28008, 0, 1, 216, 164, r, 9, 4)
1315
1316#define QSYS_SW_STATUS_EQ_AVAIL GENMASK(7, 0)
1317#define QSYS_SW_STATUS_EQ_AVAIL_SET(x)\
1318 FIELD_PREP(QSYS_SW_STATUS_EQ_AVAIL, x)
1319#define QSYS_SW_STATUS_EQ_AVAIL_GET(x)\
1320 FIELD_GET(QSYS_SW_STATUS_EQ_AVAIL, x)
1321
1322/* QSYS:SYSTEM:CPU_GROUP_MAP */
1323#define QSYS_CPU_GROUP_MAP __REG(TARGET_QSYS, 0, 1, 28008, 0, 1, 216, 204, 0, 1, 4)
1324
1325/* QSYS:RES_CTRL:RES_CFG */
1326#define QSYS_RES_CFG(g) __REG(TARGET_QSYS, 0, 1, 32768, g, 1024, 8, 0, 0, 1, 4)
1327
1328/* QSYS:HSCH:CIR_CFG */
1329#define QSYS_CIR_CFG(g) __REG(TARGET_QSYS, 0, 1, 16384, g, 90, 128, 0, 0, 1, 4)
1330
1331#define QSYS_CIR_CFG_CIR_RATE GENMASK(20, 6)
1332#define QSYS_CIR_CFG_CIR_RATE_SET(x)\
1333 FIELD_PREP(QSYS_CIR_CFG_CIR_RATE, x)
1334#define QSYS_CIR_CFG_CIR_RATE_GET(x)\
1335 FIELD_GET(QSYS_CIR_CFG_CIR_RATE, x)
1336
1337#define QSYS_CIR_CFG_CIR_BURST GENMASK(5, 0)
1338#define QSYS_CIR_CFG_CIR_BURST_SET(x)\
1339 FIELD_PREP(QSYS_CIR_CFG_CIR_BURST, x)
1340#define QSYS_CIR_CFG_CIR_BURST_GET(x)\
1341 FIELD_GET(QSYS_CIR_CFG_CIR_BURST, x)
1342
1343/* QSYS:HSCH:SE_CFG */
1344#define QSYS_SE_CFG(g) __REG(TARGET_QSYS, 0, 1, 16384, g, 90, 128, 8, 0, 1, 4)
1345
1346#define QSYS_SE_CFG_SE_DWRR_CNT GENMASK(9, 6)
1347#define QSYS_SE_CFG_SE_DWRR_CNT_SET(x)\
1348 FIELD_PREP(QSYS_SE_CFG_SE_DWRR_CNT, x)
1349#define QSYS_SE_CFG_SE_DWRR_CNT_GET(x)\
1350 FIELD_GET(QSYS_SE_CFG_SE_DWRR_CNT, x)
1351
1352#define QSYS_SE_CFG_SE_RR_ENA BIT(5)
1353#define QSYS_SE_CFG_SE_RR_ENA_SET(x)\
1354 FIELD_PREP(QSYS_SE_CFG_SE_RR_ENA, x)
1355#define QSYS_SE_CFG_SE_RR_ENA_GET(x)\
1356 FIELD_GET(QSYS_SE_CFG_SE_RR_ENA, x)
1357
1358#define QSYS_SE_CFG_SE_AVB_ENA BIT(4)
1359#define QSYS_SE_CFG_SE_AVB_ENA_SET(x)\
1360 FIELD_PREP(QSYS_SE_CFG_SE_AVB_ENA, x)
1361#define QSYS_SE_CFG_SE_AVB_ENA_GET(x)\
1362 FIELD_GET(QSYS_SE_CFG_SE_AVB_ENA, x)
1363
1364#define QSYS_SE_CFG_SE_FRM_MODE GENMASK(3, 2)
1365#define QSYS_SE_CFG_SE_FRM_MODE_SET(x)\
1366 FIELD_PREP(QSYS_SE_CFG_SE_FRM_MODE, x)
1367#define QSYS_SE_CFG_SE_FRM_MODE_GET(x)\
1368 FIELD_GET(QSYS_SE_CFG_SE_FRM_MODE, x)
1369
1370#define QSYS_SE_DWRR_CFG(g, r) __REG(TARGET_QSYS, 0, 1, 16384, g, 90, 128, 12, r, 12, 4)
1371
1372#define QSYS_SE_DWRR_CFG_DWRR_COST GENMASK(4, 0)
1373#define QSYS_SE_DWRR_CFG_DWRR_COST_SET(x)\
1374 FIELD_PREP(QSYS_SE_DWRR_CFG_DWRR_COST, x)
1375#define QSYS_SE_DWRR_CFG_DWRR_COST_GET(x)\
1376 FIELD_GET(QSYS_SE_DWRR_CFG_DWRR_COST, x)
1377
1378/* QSYS:TAS_CONFIG:TAS_CFG_CTRL */
1379#define QSYS_TAS_CFG_CTRL __REG(TARGET_QSYS, 0, 1, 57372, 0, 1, 12, 0, 0, 1, 4)
1380
1381#define QSYS_TAS_CFG_CTRL_LIST_NUM_MAX GENMASK(27, 23)
1382#define QSYS_TAS_CFG_CTRL_LIST_NUM_MAX_SET(x)\
1383 FIELD_PREP(QSYS_TAS_CFG_CTRL_LIST_NUM_MAX, x)
1384#define QSYS_TAS_CFG_CTRL_LIST_NUM_MAX_GET(x)\
1385 FIELD_GET(QSYS_TAS_CFG_CTRL_LIST_NUM_MAX, x)
1386
1387#define QSYS_TAS_CFG_CTRL_LIST_NUM GENMASK(22, 18)
1388#define QSYS_TAS_CFG_CTRL_LIST_NUM_SET(x)\
1389 FIELD_PREP(QSYS_TAS_CFG_CTRL_LIST_NUM, x)
1390#define QSYS_TAS_CFG_CTRL_LIST_NUM_GET(x)\
1391 FIELD_GET(QSYS_TAS_CFG_CTRL_LIST_NUM, x)
1392
1393#define QSYS_TAS_CFG_CTRL_ALWAYS_GB_SCH_Q BIT(17)
1394#define QSYS_TAS_CFG_CTRL_ALWAYS_GB_SCH_Q_SET(x)\
1395 FIELD_PREP(QSYS_TAS_CFG_CTRL_ALWAYS_GB_SCH_Q, x)
1396#define QSYS_TAS_CFG_CTRL_ALWAYS_GB_SCH_Q_GET(x)\
1397 FIELD_GET(QSYS_TAS_CFG_CTRL_ALWAYS_GB_SCH_Q, x)
1398
1399#define QSYS_TAS_CFG_CTRL_GCL_ENTRY_NUM GENMASK(16, 5)
1400#define QSYS_TAS_CFG_CTRL_GCL_ENTRY_NUM_SET(x)\
1401 FIELD_PREP(QSYS_TAS_CFG_CTRL_GCL_ENTRY_NUM, x)
1402#define QSYS_TAS_CFG_CTRL_GCL_ENTRY_NUM_GET(x)\
1403 FIELD_GET(QSYS_TAS_CFG_CTRL_GCL_ENTRY_NUM, x)
1404
1405/* QSYS:TAS_CONFIG:TAS_GATE_STATE_CTRL */
1406#define QSYS_TAS_GS_CTRL __REG(TARGET_QSYS, 0, 1, 57372, 0, 1, 12, 4, 0, 1, 4)
1407
1408#define QSYS_TAS_GS_CTRL_HSCH_POS GENMASK(2, 0)
1409#define QSYS_TAS_GS_CTRL_HSCH_POS_SET(x)\
1410 FIELD_PREP(QSYS_TAS_GS_CTRL_HSCH_POS, x)
1411#define QSYS_TAS_GS_CTRL_HSCH_POS_GET(x)\
1412 FIELD_GET(QSYS_TAS_GS_CTRL_HSCH_POS, x)
1413
1414/* QSYS:TAS_CONFIG:TAS_STATEMACHINE_CFG */
1415#define QSYS_TAS_STM_CFG __REG(TARGET_QSYS, 0, 1, 57372, 0, 1, 12, 8, 0, 1, 4)
1416
1417#define QSYS_TAS_STM_CFG_REVISIT_DLY GENMASK(7, 0)
1418#define QSYS_TAS_STM_CFG_REVISIT_DLY_SET(x)\
1419 FIELD_PREP(QSYS_TAS_STM_CFG_REVISIT_DLY, x)
1420#define QSYS_TAS_STM_CFG_REVISIT_DLY_GET(x)\
1421 FIELD_GET(QSYS_TAS_STM_CFG_REVISIT_DLY, x)
1422
1423/* QSYS:TAS_PROFILE_CFG:TAS_PROFILE_CONFIG */
1424#define QSYS_TAS_PROFILE_CFG(g) __REG(TARGET_QSYS, 0, 1, 30720, g, 16, 64, 32, 0, 1, 4)
1425
1426#define QSYS_TAS_PROFILE_CFG_PORT_NUM GENMASK(21, 19)
1427#define QSYS_TAS_PROFILE_CFG_PORT_NUM_SET(x)\
1428 FIELD_PREP(QSYS_TAS_PROFILE_CFG_PORT_NUM, x)
1429#define QSYS_TAS_PROFILE_CFG_PORT_NUM_GET(x)\
1430 FIELD_GET(QSYS_TAS_PROFILE_CFG_PORT_NUM, x)
1431
1432#define QSYS_TAS_PROFILE_CFG_LINK_SPEED GENMASK(18, 16)
1433#define QSYS_TAS_PROFILE_CFG_LINK_SPEED_SET(x)\
1434 FIELD_PREP(QSYS_TAS_PROFILE_CFG_LINK_SPEED, x)
1435#define QSYS_TAS_PROFILE_CFG_LINK_SPEED_GET(x)\
1436 FIELD_GET(QSYS_TAS_PROFILE_CFG_LINK_SPEED, x)
1437
1438/* QSYS:TAS_LIST_CFG:TAS_BASE_TIME_NSEC */
1439#define QSYS_TAS_BT_NSEC __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 0, 0, 1, 4)
1440
1441#define QSYS_TAS_BT_NSEC_NSEC GENMASK(29, 0)
1442#define QSYS_TAS_BT_NSEC_NSEC_SET(x)\
1443 FIELD_PREP(QSYS_TAS_BT_NSEC_NSEC, x)
1444#define QSYS_TAS_BT_NSEC_NSEC_GET(x)\
1445 FIELD_GET(QSYS_TAS_BT_NSEC_NSEC, x)
1446
1447/* QSYS:TAS_LIST_CFG:TAS_BASE_TIME_SEC_LSB */
1448#define QSYS_TAS_BT_SEC_LSB __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 4, 0, 1, 4)
1449
1450/* QSYS:TAS_LIST_CFG:TAS_BASE_TIME_SEC_MSB */
1451#define QSYS_TAS_BT_SEC_MSB __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 8, 0, 1, 4)
1452
1453#define QSYS_TAS_BT_SEC_MSB_SEC_MSB GENMASK(15, 0)
1454#define QSYS_TAS_BT_SEC_MSB_SEC_MSB_SET(x)\
1455 FIELD_PREP(QSYS_TAS_BT_SEC_MSB_SEC_MSB, x)
1456#define QSYS_TAS_BT_SEC_MSB_SEC_MSB_GET(x)\
1457 FIELD_GET(QSYS_TAS_BT_SEC_MSB_SEC_MSB, x)
1458
1459/* QSYS:TAS_LIST_CFG:TAS_CYCLE_TIME_CFG */
1460#define QSYS_TAS_CT_CFG __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 24, 0, 1, 4)
1461
1462/* QSYS:TAS_LIST_CFG:TAS_STARTUP_CFG */
1463#define QSYS_TAS_STARTUP_CFG __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 28, 0, 1, 4)
1464
1465#define QSYS_TAS_STARTUP_CFG_OBSOLETE_IDX GENMASK(27, 23)
1466#define QSYS_TAS_STARTUP_CFG_OBSOLETE_IDX_SET(x)\
1467 FIELD_PREP(QSYS_TAS_STARTUP_CFG_OBSOLETE_IDX, x)
1468#define QSYS_TAS_STARTUP_CFG_OBSOLETE_IDX_GET(x)\
1469 FIELD_GET(QSYS_TAS_STARTUP_CFG_OBSOLETE_IDX, x)
1470
1471/* QSYS:TAS_LIST_CFG:TAS_LIST_CFG */
1472#define QSYS_TAS_LIST_CFG __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 32, 0, 1, 4)
1473
1474#define QSYS_TAS_LIST_CFG_LIST_BASE_ADDR GENMASK(11, 0)
1475#define QSYS_TAS_LIST_CFG_LIST_BASE_ADDR_SET(x)\
1476 FIELD_PREP(QSYS_TAS_LIST_CFG_LIST_BASE_ADDR, x)
1477#define QSYS_TAS_LIST_CFG_LIST_BASE_ADDR_GET(x)\
1478 FIELD_GET(QSYS_TAS_LIST_CFG_LIST_BASE_ADDR, x)
1479
1480/* QSYS:TAS_LIST_CFG:TAS_LIST_STATE */
1481#define QSYS_TAS_LST __REG(TARGET_QSYS, 0, 1, 27904, 0, 1, 64, 36, 0, 1, 4)
1482
1483#define QSYS_TAS_LST_LIST_STATE GENMASK(2, 0)
1484#define QSYS_TAS_LST_LIST_STATE_SET(x)\
1485 FIELD_PREP(QSYS_TAS_LST_LIST_STATE, x)
1486#define QSYS_TAS_LST_LIST_STATE_GET(x)\
1487 FIELD_GET(QSYS_TAS_LST_LIST_STATE, x)
1488
1489/* QSYS:TAS_GCL_CFG:TAS_GCL_CTRL_CFG */
1490#define QSYS_TAS_GCL_CT_CFG __REG(TARGET_QSYS, 0, 1, 27968, 0, 1, 16, 0, 0, 1, 4)
1491
1492#define QSYS_TAS_GCL_CT_CFG_HSCH_POS GENMASK(12, 10)
1493#define QSYS_TAS_GCL_CT_CFG_HSCH_POS_SET(x)\
1494 FIELD_PREP(QSYS_TAS_GCL_CT_CFG_HSCH_POS, x)
1495#define QSYS_TAS_GCL_CT_CFG_HSCH_POS_GET(x)\
1496 FIELD_GET(QSYS_TAS_GCL_CT_CFG_HSCH_POS, x)
1497
1498#define QSYS_TAS_GCL_CT_CFG_GATE_STATE GENMASK(9, 2)
1499#define QSYS_TAS_GCL_CT_CFG_GATE_STATE_SET(x)\
1500 FIELD_PREP(QSYS_TAS_GCL_CT_CFG_GATE_STATE, x)
1501#define QSYS_TAS_GCL_CT_CFG_GATE_STATE_GET(x)\
1502 FIELD_GET(QSYS_TAS_GCL_CT_CFG_GATE_STATE, x)
1503
1504#define QSYS_TAS_GCL_CT_CFG_OP_TYPE GENMASK(1, 0)
1505#define QSYS_TAS_GCL_CT_CFG_OP_TYPE_SET(x)\
1506 FIELD_PREP(QSYS_TAS_GCL_CT_CFG_OP_TYPE, x)
1507#define QSYS_TAS_GCL_CT_CFG_OP_TYPE_GET(x)\
1508 FIELD_GET(QSYS_TAS_GCL_CT_CFG_OP_TYPE, x)
1509
1510/* QSYS:TAS_GCL_CFG:TAS_GCL_CTRL_CFG2 */
1511#define QSYS_TAS_GCL_CT_CFG2 __REG(TARGET_QSYS, 0, 1, 27968, 0, 1, 16, 4, 0, 1, 4)
1512
1513#define QSYS_TAS_GCL_CT_CFG2_PORT_PROFILE GENMASK(15, 12)
1514#define QSYS_TAS_GCL_CT_CFG2_PORT_PROFILE_SET(x)\
1515 FIELD_PREP(QSYS_TAS_GCL_CT_CFG2_PORT_PROFILE, x)
1516#define QSYS_TAS_GCL_CT_CFG2_PORT_PROFILE_GET(x)\
1517 FIELD_GET(QSYS_TAS_GCL_CT_CFG2_PORT_PROFILE, x)
1518
1519#define QSYS_TAS_GCL_CT_CFG2_NEXT_GCL GENMASK(11, 0)
1520#define QSYS_TAS_GCL_CT_CFG2_NEXT_GCL_SET(x)\
1521 FIELD_PREP(QSYS_TAS_GCL_CT_CFG2_NEXT_GCL, x)
1522#define QSYS_TAS_GCL_CT_CFG2_NEXT_GCL_GET(x)\
1523 FIELD_GET(QSYS_TAS_GCL_CT_CFG2_NEXT_GCL, x)
1524
1525/* QSYS:TAS_GCL_CFG:TAS_GCL_TIME_CFG */
1526#define QSYS_TAS_GCL_TM_CFG __REG(TARGET_QSYS, 0, 1, 27968, 0, 1, 16, 8, 0, 1, 4)
1527
1528/* QSYS:HSCH_TAS_STATE:TAS_GATE_STATE */
1529#define QSYS_TAS_GATE_STATE __REG(TARGET_QSYS, 0, 1, 28004, 0, 1, 4, 0, 0, 1, 4)
1530
1531#define QSYS_TAS_GATE_STATE_TAS_GATE_STATE GENMASK(7, 0)
1532#define QSYS_TAS_GATE_STATE_TAS_GATE_STATE_SET(x)\
1533 FIELD_PREP(QSYS_TAS_GATE_STATE_TAS_GATE_STATE, x)
1534#define QSYS_TAS_GATE_STATE_TAS_GATE_STATE_GET(x)\
1535 FIELD_GET(QSYS_TAS_GATE_STATE_TAS_GATE_STATE, x)
1536
1537/* REW:PORT:PORT_VLAN_CFG */
1538#define REW_PORT_VLAN_CFG(g) __REG(TARGET_REW, 0, 1, 0, g, 10, 128, 0, 0, 1, 4)
1539
1540#define REW_PORT_VLAN_CFG_PORT_TPID GENMASK(31, 16)
1541#define REW_PORT_VLAN_CFG_PORT_TPID_SET(x)\
1542 FIELD_PREP(REW_PORT_VLAN_CFG_PORT_TPID, x)
1543#define REW_PORT_VLAN_CFG_PORT_TPID_GET(x)\
1544 FIELD_GET(REW_PORT_VLAN_CFG_PORT_TPID, x)
1545
1546#define REW_PORT_VLAN_CFG_PORT_VID GENMASK(11, 0)
1547#define REW_PORT_VLAN_CFG_PORT_VID_SET(x)\
1548 FIELD_PREP(REW_PORT_VLAN_CFG_PORT_VID, x)
1549#define REW_PORT_VLAN_CFG_PORT_VID_GET(x)\
1550 FIELD_GET(REW_PORT_VLAN_CFG_PORT_VID, x)
1551
1552/* REW:PORT:TAG_CFG */
1553#define REW_TAG_CFG(g) __REG(TARGET_REW, 0, 1, 0, g, 10, 128, 4, 0, 1, 4)
1554
1555#define REW_TAG_CFG_TAG_CFG GENMASK(8, 7)
1556#define REW_TAG_CFG_TAG_CFG_SET(x)\
1557 FIELD_PREP(REW_TAG_CFG_TAG_CFG, x)
1558#define REW_TAG_CFG_TAG_CFG_GET(x)\
1559 FIELD_GET(REW_TAG_CFG_TAG_CFG, x)
1560
1561#define REW_TAG_CFG_TAG_TPID_CFG GENMASK(6, 5)
1562#define REW_TAG_CFG_TAG_TPID_CFG_SET(x)\
1563 FIELD_PREP(REW_TAG_CFG_TAG_TPID_CFG, x)
1564#define REW_TAG_CFG_TAG_TPID_CFG_GET(x)\
1565 FIELD_GET(REW_TAG_CFG_TAG_TPID_CFG, x)
1566
1567#define REW_TAG_CFG_TAG_PCP_CFG GENMASK(3, 2)
1568#define REW_TAG_CFG_TAG_PCP_CFG_SET(x)\
1569 FIELD_PREP(REW_TAG_CFG_TAG_PCP_CFG, x)
1570#define REW_TAG_CFG_TAG_PCP_CFG_GET(x)\
1571 FIELD_GET(REW_TAG_CFG_TAG_PCP_CFG, x)
1572
1573#define REW_TAG_CFG_TAG_DEI_CFG GENMASK(1, 0)
1574#define REW_TAG_CFG_TAG_DEI_CFG_SET(x)\
1575 FIELD_PREP(REW_TAG_CFG_TAG_DEI_CFG, x)
1576#define REW_TAG_CFG_TAG_DEI_CFG_GET(x)\
1577 FIELD_GET(REW_TAG_CFG_TAG_DEI_CFG, x)
1578
1579/* REW:PORT:PORT_CFG */
1580#define REW_PORT_CFG(g) __REG(TARGET_REW, 0, 1, 0, g, 10, 128, 8, 0, 1, 4)
1581
1582#define REW_PORT_CFG_ES0_EN BIT(4)
1583#define REW_PORT_CFG_ES0_EN_SET(x)\
1584 FIELD_PREP(REW_PORT_CFG_ES0_EN, x)
1585#define REW_PORT_CFG_ES0_EN_GET(x)\
1586 FIELD_GET(REW_PORT_CFG_ES0_EN, x)
1587
1588#define REW_PORT_CFG_NO_REWRITE BIT(0)
1589#define REW_PORT_CFG_NO_REWRITE_SET(x)\
1590 FIELD_PREP(REW_PORT_CFG_NO_REWRITE, x)
1591#define REW_PORT_CFG_NO_REWRITE_GET(x)\
1592 FIELD_GET(REW_PORT_CFG_NO_REWRITE, x)
1593
1594/* REW:PORT:DSCP_CFG */
1595#define REW_DSCP_CFG(g) __REG(TARGET_REW, 0, 1, 0, g, 10, 128, 12, 0, 1, 4)
1596
1597#define REW_DSCP_CFG_DSCP_REWR_CFG GENMASK(1, 0)
1598#define REW_DSCP_CFG_DSCP_REWR_CFG_SET(x)\
1599 FIELD_PREP(REW_DSCP_CFG_DSCP_REWR_CFG, x)
1600#define REW_DSCP_CFG_DSCP_REWR_CFG_GET(x)\
1601 FIELD_GET(REW_DSCP_CFG_DSCP_REWR_CFG, x)
1602
1603/* REW:PORT:PCP_DEI_QOS_MAP_CFG */
1604#define REW_PCP_DEI_CFG(g, r) __REG(TARGET_REW, 0, 1, 0, g, 10, 128, 16, r, 16, 4)
1605
1606#define REW_PCP_DEI_CFG_DEI_QOS_VAL BIT(3)
1607#define REW_PCP_DEI_CFG_DEI_QOS_VAL_SET(x)\
1608 FIELD_PREP(REW_PCP_DEI_CFG_DEI_QOS_VAL, x)
1609#define REW_PCP_DEI_CFG_DEI_QOS_VAL_GET(x)\
1610 FIELD_GET(REW_PCP_DEI_CFG_DEI_QOS_VAL, x)
1611
1612#define REW_PCP_DEI_CFG_PCP_QOS_VAL GENMASK(2, 0)
1613#define REW_PCP_DEI_CFG_PCP_QOS_VAL_SET(x)\
1614 FIELD_PREP(REW_PCP_DEI_CFG_PCP_QOS_VAL, x)
1615#define REW_PCP_DEI_CFG_PCP_QOS_VAL_GET(x)\
1616 FIELD_GET(REW_PCP_DEI_CFG_PCP_QOS_VAL, x)
1617
1618/* REW:COMMON:STAT_CFG */
1619#define REW_STAT_CFG __REG(TARGET_REW, 0, 1, 3072, 0, 1, 528, 520, 0, 1, 4)
1620
1621#define REW_STAT_CFG_STAT_MODE GENMASK(1, 0)
1622#define REW_STAT_CFG_STAT_MODE_SET(x)\
1623 FIELD_PREP(REW_STAT_CFG_STAT_MODE, x)
1624#define REW_STAT_CFG_STAT_MODE_GET(x)\
1625 FIELD_GET(REW_STAT_CFG_STAT_MODE, x)
1626
1627/* SYS:SYSTEM:RESET_CFG */
1628#define SYS_RESET_CFG __REG(TARGET_SYS, 0, 1, 4128, 0, 1, 168, 0, 0, 1, 4)
1629
1630#define SYS_RESET_CFG_CORE_ENA BIT(0)
1631#define SYS_RESET_CFG_CORE_ENA_SET(x)\
1632 FIELD_PREP(SYS_RESET_CFG_CORE_ENA, x)
1633#define SYS_RESET_CFG_CORE_ENA_GET(x)\
1634 FIELD_GET(SYS_RESET_CFG_CORE_ENA, x)
1635
1636/* SYS:SYSTEM:PORT_MODE */
1637#define SYS_PORT_MODE(r) __REG(TARGET_SYS, 0, 1, 4128, 0, 1, 168, 44, r, 10, 4)
1638
1639#define SYS_PORT_MODE_INCL_INJ_HDR GENMASK(5, 4)
1640#define SYS_PORT_MODE_INCL_INJ_HDR_SET(x)\
1641 FIELD_PREP(SYS_PORT_MODE_INCL_INJ_HDR, x)
1642#define SYS_PORT_MODE_INCL_INJ_HDR_GET(x)\
1643 FIELD_GET(SYS_PORT_MODE_INCL_INJ_HDR, x)
1644
1645#define SYS_PORT_MODE_INCL_XTR_HDR GENMASK(3, 2)
1646#define SYS_PORT_MODE_INCL_XTR_HDR_SET(x)\
1647 FIELD_PREP(SYS_PORT_MODE_INCL_XTR_HDR, x)
1648#define SYS_PORT_MODE_INCL_XTR_HDR_GET(x)\
1649 FIELD_GET(SYS_PORT_MODE_INCL_XTR_HDR, x)
1650
1651/* SYS:SYSTEM:FRONT_PORT_MODE */
1652#define SYS_FRONT_PORT_MODE(r) __REG(TARGET_SYS, 0, 1, 4128, 0, 1, 168, 84, r, 8, 4)
1653
1654#define SYS_FRONT_PORT_MODE_HDX_MODE BIT(1)
1655#define SYS_FRONT_PORT_MODE_HDX_MODE_SET(x)\
1656 FIELD_PREP(SYS_FRONT_PORT_MODE_HDX_MODE, x)
1657#define SYS_FRONT_PORT_MODE_HDX_MODE_GET(x)\
1658 FIELD_GET(SYS_FRONT_PORT_MODE_HDX_MODE, x)
1659
1660/* SYS:SYSTEM:FRM_AGING */
1661#define SYS_FRM_AGING __REG(TARGET_SYS, 0, 1, 4128, 0, 1, 168, 116, 0, 1, 4)
1662
1663#define SYS_FRM_AGING_AGE_TX_ENA BIT(20)
1664#define SYS_FRM_AGING_AGE_TX_ENA_SET(x)\
1665 FIELD_PREP(SYS_FRM_AGING_AGE_TX_ENA, x)
1666#define SYS_FRM_AGING_AGE_TX_ENA_GET(x)\
1667 FIELD_GET(SYS_FRM_AGING_AGE_TX_ENA, x)
1668
1669/* SYS:SYSTEM:STAT_CFG */
1670#define SYS_STAT_CFG __REG(TARGET_SYS, 0, 1, 4128, 0, 1, 168, 120, 0, 1, 4)
1671
1672#define SYS_STAT_CFG_STAT_VIEW GENMASK(9, 0)
1673#define SYS_STAT_CFG_STAT_VIEW_SET(x)\
1674 FIELD_PREP(SYS_STAT_CFG_STAT_VIEW, x)
1675#define SYS_STAT_CFG_STAT_VIEW_GET(x)\
1676 FIELD_GET(SYS_STAT_CFG_STAT_VIEW, x)
1677
1678/* SYS:PAUSE_CFG:PAUSE_CFG */
1679#define SYS_PAUSE_CFG(r) __REG(TARGET_SYS, 0, 1, 4296, 0, 1, 112, 0, r, 9, 4)
1680
1681#define SYS_PAUSE_CFG_PAUSE_START GENMASK(18, 10)
1682#define SYS_PAUSE_CFG_PAUSE_START_SET(x)\
1683 FIELD_PREP(SYS_PAUSE_CFG_PAUSE_START, x)
1684#define SYS_PAUSE_CFG_PAUSE_START_GET(x)\
1685 FIELD_GET(SYS_PAUSE_CFG_PAUSE_START, x)
1686
1687#define SYS_PAUSE_CFG_PAUSE_STOP GENMASK(9, 1)
1688#define SYS_PAUSE_CFG_PAUSE_STOP_SET(x)\
1689 FIELD_PREP(SYS_PAUSE_CFG_PAUSE_STOP, x)
1690#define SYS_PAUSE_CFG_PAUSE_STOP_GET(x)\
1691 FIELD_GET(SYS_PAUSE_CFG_PAUSE_STOP, x)
1692
1693#define SYS_PAUSE_CFG_PAUSE_ENA BIT(0)
1694#define SYS_PAUSE_CFG_PAUSE_ENA_SET(x)\
1695 FIELD_PREP(SYS_PAUSE_CFG_PAUSE_ENA, x)
1696#define SYS_PAUSE_CFG_PAUSE_ENA_GET(x)\
1697 FIELD_GET(SYS_PAUSE_CFG_PAUSE_ENA, x)
1698
1699/* SYS:PAUSE_CFG:ATOP */
1700#define SYS_ATOP(r) __REG(TARGET_SYS, 0, 1, 4296, 0, 1, 112, 40, r, 9, 4)
1701
1702/* SYS:PAUSE_CFG:ATOP_TOT_CFG */
1703#define SYS_ATOP_TOT_CFG __REG(TARGET_SYS, 0, 1, 4296, 0, 1, 112, 76, 0, 1, 4)
1704
1705/* SYS:PAUSE_CFG:MAC_FC_CFG */
1706#define SYS_MAC_FC_CFG(r) __REG(TARGET_SYS, 0, 1, 4296, 0, 1, 112, 80, r, 8, 4)
1707
1708#define SYS_MAC_FC_CFG_FC_LINK_SPEED GENMASK(27, 26)
1709#define SYS_MAC_FC_CFG_FC_LINK_SPEED_SET(x)\
1710 FIELD_PREP(SYS_MAC_FC_CFG_FC_LINK_SPEED, x)
1711#define SYS_MAC_FC_CFG_FC_LINK_SPEED_GET(x)\
1712 FIELD_GET(SYS_MAC_FC_CFG_FC_LINK_SPEED, x)
1713
1714#define SYS_MAC_FC_CFG_FC_LATENCY_CFG GENMASK(25, 20)
1715#define SYS_MAC_FC_CFG_FC_LATENCY_CFG_SET(x)\
1716 FIELD_PREP(SYS_MAC_FC_CFG_FC_LATENCY_CFG, x)
1717#define SYS_MAC_FC_CFG_FC_LATENCY_CFG_GET(x)\
1718 FIELD_GET(SYS_MAC_FC_CFG_FC_LATENCY_CFG, x)
1719
1720#define SYS_MAC_FC_CFG_ZERO_PAUSE_ENA BIT(18)
1721#define SYS_MAC_FC_CFG_ZERO_PAUSE_ENA_SET(x)\
1722 FIELD_PREP(SYS_MAC_FC_CFG_ZERO_PAUSE_ENA, x)
1723#define SYS_MAC_FC_CFG_ZERO_PAUSE_ENA_GET(x)\
1724 FIELD_GET(SYS_MAC_FC_CFG_ZERO_PAUSE_ENA, x)
1725
1726#define SYS_MAC_FC_CFG_TX_FC_ENA BIT(17)
1727#define SYS_MAC_FC_CFG_TX_FC_ENA_SET(x)\
1728 FIELD_PREP(SYS_MAC_FC_CFG_TX_FC_ENA, x)
1729#define SYS_MAC_FC_CFG_TX_FC_ENA_GET(x)\
1730 FIELD_GET(SYS_MAC_FC_CFG_TX_FC_ENA, x)
1731
1732#define SYS_MAC_FC_CFG_RX_FC_ENA BIT(16)
1733#define SYS_MAC_FC_CFG_RX_FC_ENA_SET(x)\
1734 FIELD_PREP(SYS_MAC_FC_CFG_RX_FC_ENA, x)
1735#define SYS_MAC_FC_CFG_RX_FC_ENA_GET(x)\
1736 FIELD_GET(SYS_MAC_FC_CFG_RX_FC_ENA, x)
1737
1738#define SYS_MAC_FC_CFG_PAUSE_VAL_CFG GENMASK(15, 0)
1739#define SYS_MAC_FC_CFG_PAUSE_VAL_CFG_SET(x)\
1740 FIELD_PREP(SYS_MAC_FC_CFG_PAUSE_VAL_CFG, x)
1741#define SYS_MAC_FC_CFG_PAUSE_VAL_CFG_GET(x)\
1742 FIELD_GET(SYS_MAC_FC_CFG_PAUSE_VAL_CFG, x)
1743
1744/* SYS:STAT:CNT */
1745#define SYS_CNT(g) __REG(TARGET_SYS, 0, 1, 0, g, 896, 4, 0, 0, 1, 4)
1746
1747/* SYS:RAM_CTRL:RAM_INIT */
1748#define SYS_RAM_INIT __REG(TARGET_SYS, 0, 1, 4432, 0, 1, 4, 0, 0, 1, 4)
1749
1750#define SYS_RAM_INIT_RAM_INIT BIT(1)
1751#define SYS_RAM_INIT_RAM_INIT_SET(x)\
1752 FIELD_PREP(SYS_RAM_INIT_RAM_INIT, x)
1753#define SYS_RAM_INIT_RAM_INIT_GET(x)\
1754 FIELD_GET(SYS_RAM_INIT_RAM_INIT, x)
1755
1756/* VCAP:VCAP_CORE_CFG:VCAP_UPDATE_CTRL */
1757#define VCAP_UPDATE_CTRL(t) __REG(TARGET_VCAP, t, 3, 0, 0, 1, 8, 0, 0, 1, 4)
1758
1759#define VCAP_UPDATE_CTRL_UPDATE_CMD GENMASK(24, 22)
1760#define VCAP_UPDATE_CTRL_UPDATE_CMD_SET(x)\
1761 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_CMD, x)
1762#define VCAP_UPDATE_CTRL_UPDATE_CMD_GET(x)\
1763 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_CMD, x)
1764
1765#define VCAP_UPDATE_CTRL_UPDATE_ENTRY_DIS BIT(21)
1766#define VCAP_UPDATE_CTRL_UPDATE_ENTRY_DIS_SET(x)\
1767 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_ENTRY_DIS, x)
1768#define VCAP_UPDATE_CTRL_UPDATE_ENTRY_DIS_GET(x)\
1769 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_ENTRY_DIS, x)
1770
1771#define VCAP_UPDATE_CTRL_UPDATE_ACTION_DIS BIT(20)
1772#define VCAP_UPDATE_CTRL_UPDATE_ACTION_DIS_SET(x)\
1773 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_ACTION_DIS, x)
1774#define VCAP_UPDATE_CTRL_UPDATE_ACTION_DIS_GET(x)\
1775 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_ACTION_DIS, x)
1776
1777#define VCAP_UPDATE_CTRL_UPDATE_CNT_DIS BIT(19)
1778#define VCAP_UPDATE_CTRL_UPDATE_CNT_DIS_SET(x)\
1779 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_CNT_DIS, x)
1780#define VCAP_UPDATE_CTRL_UPDATE_CNT_DIS_GET(x)\
1781 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_CNT_DIS, x)
1782
1783#define VCAP_UPDATE_CTRL_UPDATE_ADDR GENMASK(18, 3)
1784#define VCAP_UPDATE_CTRL_UPDATE_ADDR_SET(x)\
1785 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_ADDR, x)
1786#define VCAP_UPDATE_CTRL_UPDATE_ADDR_GET(x)\
1787 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_ADDR, x)
1788
1789#define VCAP_UPDATE_CTRL_UPDATE_SHOT BIT(2)
1790#define VCAP_UPDATE_CTRL_UPDATE_SHOT_SET(x)\
1791 FIELD_PREP(VCAP_UPDATE_CTRL_UPDATE_SHOT, x)
1792#define VCAP_UPDATE_CTRL_UPDATE_SHOT_GET(x)\
1793 FIELD_GET(VCAP_UPDATE_CTRL_UPDATE_SHOT, x)
1794
1795#define VCAP_UPDATE_CTRL_CLEAR_CACHE BIT(1)
1796#define VCAP_UPDATE_CTRL_CLEAR_CACHE_SET(x)\
1797 FIELD_PREP(VCAP_UPDATE_CTRL_CLEAR_CACHE, x)
1798#define VCAP_UPDATE_CTRL_CLEAR_CACHE_GET(x)\
1799 FIELD_GET(VCAP_UPDATE_CTRL_CLEAR_CACHE, x)
1800
1801#define VCAP_UPDATE_CTRL_MV_TRAFFIC_IGN BIT(0)
1802#define VCAP_UPDATE_CTRL_MV_TRAFFIC_IGN_SET(x)\
1803 FIELD_PREP(VCAP_UPDATE_CTRL_MV_TRAFFIC_IGN, x)
1804#define VCAP_UPDATE_CTRL_MV_TRAFFIC_IGN_GET(x)\
1805 FIELD_GET(VCAP_UPDATE_CTRL_MV_TRAFFIC_IGN, x)
1806
1807/* VCAP:VCAP_CORE_CFG:VCAP_MV_CFG */
1808#define VCAP_MV_CFG(t) __REG(TARGET_VCAP, t, 3, 0, 0, 1, 8, 4, 0, 1, 4)
1809
1810#define VCAP_MV_CFG_MV_NUM_POS GENMASK(31, 16)
1811#define VCAP_MV_CFG_MV_NUM_POS_SET(x)\
1812 FIELD_PREP(VCAP_MV_CFG_MV_NUM_POS, x)
1813#define VCAP_MV_CFG_MV_NUM_POS_GET(x)\
1814 FIELD_GET(VCAP_MV_CFG_MV_NUM_POS, x)
1815
1816#define VCAP_MV_CFG_MV_SIZE GENMASK(15, 0)
1817#define VCAP_MV_CFG_MV_SIZE_SET(x)\
1818 FIELD_PREP(VCAP_MV_CFG_MV_SIZE, x)
1819#define VCAP_MV_CFG_MV_SIZE_GET(x)\
1820 FIELD_GET(VCAP_MV_CFG_MV_SIZE, x)
1821
1822/* VCAP:VCAP_CORE_CACHE:VCAP_ENTRY_DAT */
1823#define VCAP_ENTRY_DAT(t, r) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 0, r, 64, 4)
1824
1825/* VCAP:VCAP_CORE_CACHE:VCAP_MASK_DAT */
1826#define VCAP_MASK_DAT(t, r) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 256, r, 64, 4)
1827
1828/* VCAP:VCAP_CORE_CACHE:VCAP_ACTION_DAT */
1829#define VCAP_ACTION_DAT(t, r) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 512, r, 64, 4)
1830
1831/* VCAP:VCAP_CORE_CACHE:VCAP_CNT_DAT */
1832#define VCAP_CNT_DAT(t, r) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 768, r, 32, 4)
1833
1834/* VCAP:VCAP_CORE_CACHE:VCAP_CNT_FW_DAT */
1835#define VCAP_CNT_FW_DAT(t) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 896, 0, 1, 4)
1836
1837/* VCAP:VCAP_CORE_CACHE:VCAP_TG_DAT */
1838#define VCAP_TG_DAT(t) __REG(TARGET_VCAP, t, 3, 8, 0, 1, 904, 900, 0, 1, 4)
1839
1840/* VCAP:VCAP_CORE_MAP:VCAP_CORE_IDX */
1841#define VCAP_CORE_IDX(t) __REG(TARGET_VCAP, t, 3, 912, 0, 1, 8, 0, 0, 1, 4)
1842
1843#define VCAP_CORE_IDX_CORE_IDX GENMASK(3, 0)
1844#define VCAP_CORE_IDX_CORE_IDX_SET(x)\
1845 FIELD_PREP(VCAP_CORE_IDX_CORE_IDX, x)
1846#define VCAP_CORE_IDX_CORE_IDX_GET(x)\
1847 FIELD_GET(VCAP_CORE_IDX_CORE_IDX, x)
1848
1849/* VCAP:VCAP_CORE_MAP:VCAP_CORE_MAP */
1850#define VCAP_CORE_MAP(t) __REG(TARGET_VCAP, t, 3, 912, 0, 1, 8, 4, 0, 1, 4)
1851
1852#define VCAP_CORE_MAP_CORE_MAP GENMASK(2, 0)
1853#define VCAP_CORE_MAP_CORE_MAP_SET(x)\
1854 FIELD_PREP(VCAP_CORE_MAP_CORE_MAP, x)
1855#define VCAP_CORE_MAP_CORE_MAP_GET(x)\
1856 FIELD_GET(VCAP_CORE_MAP_CORE_MAP, x)
1857
1858/* VCAP:VCAP_CONST:VCAP_VER */
1859#define VCAP_VER(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 0, 0, 1, 4)
1860
1861/* VCAP:VCAP_CONST:ENTRY_WIDTH */
1862#define VCAP_ENTRY_WIDTH(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 4, 0, 1, 4)
1863
1864/* VCAP:VCAP_CONST:ENTRY_CNT */
1865#define VCAP_ENTRY_CNT(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 8, 0, 1, 4)
1866
1867/* VCAP:VCAP_CONST:ENTRY_SWCNT */
1868#define VCAP_ENTRY_SWCNT(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 12, 0, 1, 4)
1869
1870/* VCAP:VCAP_CONST:ENTRY_TG_WIDTH */
1871#define VCAP_ENTRY_TG_WIDTH(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 16, 0, 1, 4)
1872
1873/* VCAP:VCAP_CONST:ACTION_DEF_CNT */
1874#define VCAP_ACTION_DEF_CNT(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 20, 0, 1, 4)
1875
1876/* VCAP:VCAP_CONST:ACTION_WIDTH */
1877#define VCAP_ACTION_WIDTH(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 24, 0, 1, 4)
1878
1879/* VCAP:VCAP_CONST:CNT_WIDTH */
1880#define VCAP_CNT_WIDTH(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 28, 0, 1, 4)
1881
1882/* VCAP:VCAP_CONST:CORE_CNT */
1883#define VCAP_CORE_CNT(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 32, 0, 1, 4)
1884
1885/* VCAP:VCAP_CONST:IF_CNT */
1886#define VCAP_IF_CNT(t) __REG(TARGET_VCAP, t, 3, 924, 0, 1, 40, 36, 0, 1, 4)
1887
1888#endif /* _LAN966X_REGS_H_ */
1889

source code of linux/drivers/net/ethernet/microchip/lan966x/lan966x_regs.h