xref: /linux/drivers/net/ethernet/freescale/enetc/enetc4_hw.h (revision 98a4f3d341322f3c6dd341902b419f701f3e678e)
1 /* SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) */
2 /*
3  * This header file defines the register offsets and bit fields
4  * of ENETC4 PF and VFs. Note that the same registers as ENETC
5  * version 1.0 are defined in the enetc_hw.h file.
6  *
7  * Copyright 2024 NXP
8  */
9 #ifndef __ENETC4_HW_H_
10 #define __ENETC4_HW_H_
11 
12 #define NXP_ENETC_VENDOR_ID		0x1131
13 #define NXP_ENETC_PF_DEV_ID		0xe101
14 #define NXP_ENETC_PPM_DEV_ID		0xe110
15 
16 /**********************Station interface registers************************/
17 /* Station interface LSO segmentation flag mask register 0/1 */
18 #define ENETC4_SILSOSFMR0		0x1300
19 #define  SILSOSFMR0_TCP_MID_SEG		GENMASK(27, 16)
20 #define  SILSOSFMR0_TCP_1ST_SEG		GENMASK(11, 0)
21 #define  SILSOSFMR0_VAL_SET(first, mid)	(FIELD_PREP(SILSOSFMR0_TCP_MID_SEG, mid) | \
22 					 FIELD_PREP(SILSOSFMR0_TCP_1ST_SEG, first))
23 
24 #define ENETC4_SILSOSFMR1		0x1304
25 #define  SILSOSFMR1_TCP_LAST_SEG	GENMASK(11, 0)
26 #define   ENETC4_TCP_FLAGS_FIN		BIT(0)
27 #define   ENETC4_TCP_FLAGS_SYN		BIT(1)
28 #define   ENETC4_TCP_FLAGS_RST		BIT(2)
29 #define   ENETC4_TCP_FLAGS_PSH		BIT(3)
30 #define   ENETC4_TCP_FLAGS_ACK		BIT(4)
31 #define   ENETC4_TCP_FLAGS_URG		BIT(5)
32 #define   ENETC4_TCP_FLAGS_ECE		BIT(6)
33 #define   ENETC4_TCP_FLAGS_CWR		BIT(7)
34 #define   ENETC4_TCP_FLAGS_NS		BIT(8)
35 /* According to tso_build_hdr(), clear all special flags for not last packet. */
36 #define ENETC4_TCP_NL_SEG_FLAGS_DMASK	(ENETC4_TCP_FLAGS_FIN | \
37 					 ENETC4_TCP_FLAGS_RST | ENETC4_TCP_FLAGS_PSH)
38 
39 /***************************ENETC port registers**************************/
40 #define ENETC4_ECAPR0			0x0
41 #define  ECAPR0_RFS			BIT(2)
42 #define  ECAPR0_TSD			BIT(5)
43 #define  ECAPR0_RSS			BIT(8)
44 #define  ECAPR0_RSC			BIT(9)
45 #define  ECAPR0_LSO			BIT(10)
46 #define  ECAPR0_WO			BIT(13)
47 
48 #define ENETC4_ECAPR1			0x4
49 #define  ECAPR1_NUM_TCS			GENMASK(6, 4)
50 #define  ECAPR1_NUM_MCH			GENMASK(9, 8)
51 #define  ECAPR1_NUM_UCH			GENMASK(11, 10)
52 #define  ECAPR1_NUM_MSIX		GENMASK(22, 12)
53 #define  ECAPR1_NUM_VSI			GENMASK(27, 24)
54 #define  ECAPR1_NUM_IPV			BIT(31)
55 
56 #define ENETC4_ECAPR2			0x8
57 #define  ECAPR2_NUM_TX_BDR		GENMASK(9, 0)
58 #define  ECAPR2_NUM_RX_BDR		GENMASK(25, 16)
59 
60 #define ENETC4_PMR			0x10
61 #define  PMR_SI_EN(a)			BIT((16 + (a)))
62 
63 /* Port Pause ON/OFF threshold register */
64 #define ENETC4_PPAUONTR			0x108
65 #define ENETC4_PPAUOFFTR		0x10c
66 
67 /* Port ingress congestion DRa (a=0,1,2,3) discard count register */
68 #define ENETC4_PICDRDCR(a)		((a) * 0x10 + 0x140)
69 
70 /* Port Station interface promiscuous MAC mode register */
71 #define ENETC4_PSIPMMR			0x200
72 #define  PSIPMMR_SI_MAC_UP(a)		BIT(a) /* a = SI index */
73 #define  PSIPMMR_SI_MAC_MP(a)		BIT((a) + 16)
74 
75 /* Port Station interface promiscuous VLAN mode register */
76 #define ENETC4_PSIPVMR			0x204
77 
78 /* Port broadcast frames dropped due to MAC filtering register */
79 #define ENETC4_PBFDSIR			0x208
80 
81 /* Port frame drop MAC source address pruning register */
82 #define ENETC4_PFDMSAPR			0x20c
83 
84 /* Port RSS key register n. n = 0,1,2,...,9 */
85 #define ENETC4_PRSSKR(n)		((n) * 0x4 + 0x250)
86 
87 /* Port station interface MAC address filtering capability register */
88 #define ENETC4_PSIMAFCAPR		0x280
89 #define  PSIMAFCAPR_NUM_MAC_AFTE	GENMASK(11, 0)
90 
91 /* Port unicast frames dropped due to MAC filtering register */
92 #define ENETC4_PUFDMFR			0x284
93 
94 /* Port multicast frames dropped due to MAC filtering register */
95 #define ENETC4_PMFDMFR			0x288
96 
97 /* Port station interface VLAN filtering capability register */
98 #define ENETC4_PSIVLANFCAPR		0x2c0
99 #define  PSIVLANFCAPR_NUM_VLAN_FTE	GENMASK(11, 0)
100 
101 /* Port station interface VLAN filtering mode register */
102 #define ENETC4_PSIVLANFMR		0x2c4
103 #define  PSIVLANFMR_VS			BIT(0)
104 
105 /* Port unicast frames dropped VLAN filtering register */
106 #define ENETC4_PUFDVFR			0x2d0
107 
108 /* Port multicast frames dropped VLAN filtering register */
109 #define ENETC4_PMFDVFR			0x2d4
110 
111 /* Port broadcast frames dropped VLAN filtering register */
112 #define ENETC4_PBFDVFR			0x2d8
113 
114 /* Port Station interface a primary MAC address registers */
115 #define ENETC4_PSIPMAR0(a)		((a) * 0x80 + 0x2000)
116 #define ENETC4_PSIPMAR1(a)		((a) * 0x80 + 0x2004)
117 
118 /* Port station interface a configuration register 0/2 */
119 #define ENETC4_PSICFGR0(a)		((a) * 0x80 + 0x2010)
120 #define  PSICFGR0_VASE			BIT(13)
121 #define  PSICFGR0_ASE			BIT(15)
122 #define  PSICFGR0_ANTI_SPOOFING		(PSICFGR0_VASE | PSICFGR0_ASE)
123 
124 #define ENETC4_PSICFGR2(a)		((a) * 0x80 + 0x2018)
125 #define  PSICFGR2_NUM_MSIX		GENMASK(5, 0)
126 
127 /* Port station interface a unicast MAC hash filter register 0/1 */
128 #define ENETC4_PSIUMHFR0(a)		((a) * 0x80 + 0x2050)
129 #define ENETC4_PSIUMHFR1(a)		((a) * 0x80 + 0x2054)
130 
131 /* Port station interface a multicast MAC hash filter register 0/1 */
132 #define ENETC4_PSIMMHFR0(a)		((a) * 0x80 + 0x2058)
133 #define ENETC4_PSIMMHFR1(a)		((a) * 0x80 + 0x205c)
134 
135 /* Port station interface a VLAN hash filter register 0/1 */
136 #define ENETC4_PSIVHFR0(a)		((a) * 0x80 + 0x2060)
137 #define ENETC4_PSIVHFR1(a)		((a) * 0x80 + 0x2064)
138 
139 #define ENETC4_PMCAPR			0x4004
140 #define  PMCAPR_HD			BIT(8)
141 #define  PMCAPR_FP			GENMASK(10, 9)
142 
143 /* Port capability register */
144 #define ENETC4_PCAPR			0x4000
145 #define  PCAPR_LINK_TYPE		BIT(4)
146 
147 /* Port configuration register */
148 #define ENETC4_PCR			0x4010
149 #define  PCR_HDR_FMT			BIT(0)
150 #define  PCR_L2DOSE			BIT(4)
151 #define  PCR_TIMER_CS			BIT(8)
152 #define  PCR_PSPEED			GENMASK(29, 16)
153 #define  PCR_PSPEED_VAL(speed)		(((speed) / 10 - 1) << 16)
154 
155 /* Port MAC address register 0/1 */
156 #define ENETC4_PMAR0			0x4020
157 #define ENETC4_PMAR1			0x4024
158 
159 /* Port operational register */
160 #define ENETC4_POR			0x4100
161 #define  POR_TXDIS			BIT(0)
162 #define  POR_RXDIS			BIT(1)
163 
164 /* Port status register */
165 #define ENETC4_PSR			0x4104
166 #define  PSR_RX_BUSY			BIT(1)
167 
168 /* Port Rx discard count register */
169 #define ENETC4_PRXDCR			0x41c0
170 
171 /* Port Rx discard count read-reset register */
172 #define ENETC4_PRXDCRRR			0x41c4
173 
174 /* Port Rx discard count reason register 0 */
175 #define ENETC4_PRXDCRR0			0x41c8
176 
177 /* Port Rx discard count reason register 1 */
178 #define ENETC4_PRXDCRR1			0x41cc
179 
180 /* Port traffic class a transmit maximum SDU register */
181 #define ENETC4_PTCTMSDUR(a)		((a) * 0x20 + 0x4208)
182 #define  PTCTMSDUR_MAXSDU		GENMASK(15, 0)
183 #define  PTCTMSDUR_SDU_TYPE		GENMASK(17, 16)
184 #define   SDU_TYPE_PPDU			0
185 #define   SDU_TYPE_MPDU			1
186 #define   SDU_TYPE_MSDU			2
187 
188 #define ENETC4_PMAC_OFFSET		0x400
189 #define ENETC4_PM_CMD_CFG(mac)		(0x5008 + (mac) * 0x400)
190 #define  PM_CMD_CFG_TX_EN		BIT(0)
191 #define  PM_CMD_CFG_RX_EN		BIT(1)
192 #define  PM_CMD_CFG_PAUSE_FWD		BIT(7)
193 #define  PM_CMD_CFG_PAUSE_IGN		BIT(8)
194 #define  PM_CMD_CFG_TX_ADDR_INS		BIT(9)
195 #define  PM_CMD_CFG_LOOP_EN		BIT(10)
196 #define  PM_CMD_CFG_LPBK_MODE		GENMASK(12, 11)
197 #define   LPBCK_MODE_EXT_TX_CLK		0
198 #define   LPBCK_MODE_MAC_LEVEL		1
199 #define   LPBCK_MODE_INT_TX_CLK		2
200 #define  PM_CMD_CFG_CNT_FRM_EN		BIT(13)
201 #define  PM_CMD_CFG_TXP			BIT(15)
202 #define  PM_CMD_CFG_SEND_IDLE		BIT(16)
203 #define  PM_CMD_CFG_HD_FCEN		BIT(18)
204 #define  PM_CMD_CFG_SFD			BIT(21)
205 #define  PM_CMD_CFG_TX_FLUSH		BIT(22)
206 #define  PM_CMD_CFG_TX_LOWP_EN		BIT(23)
207 #define  PM_CMD_CFG_RX_LOWP_EMPTY	BIT(24)
208 #define  PM_CMD_CFG_SWR			BIT(26)
209 #define  PM_CMD_CFG_TS_MODE		BIT(30)
210 #define  PM_CMD_CFG_MG			BIT(31)
211 
212 /* Port MAC 0/1 Maximum Frame Length Register */
213 #define ENETC4_PM_MAXFRM(mac)		(0x5014 + (mac) * 0x400)
214 
215 /* Port internal MDIO base address, use to access PCS */
216 #define ENETC4_PM_IMDIO_BASE		0x5030
217 
218 /* Port MAC 0/1 Interrupt Event Register */
219 #define ENETC4_PM_IEVENT(mac)		(0x5040 + (mac) * 0x400)
220 #define  PM_IEVENT_TX_EMPTY		BIT(5)
221 #define  PM_IEVENT_RX_EMPTY		BIT(6)
222 
223 /* Port MAC 0/1 Pause Quanta Register */
224 #define ENETC4_PM_PAUSE_QUANTA(mac)	(0x5054 + (mac) * 0x400)
225 
226 /* Port MAC 0/1 Pause Quanta Threshold Register */
227 #define ENETC4_PM_PAUSE_THRESH(mac)	(0x5064 + (mac) * 0x400)
228 
229 #define ENETC4_PM_SINGLE_STEP(mac)	(0x50c0 + (mac) * 0x400)
230 #define  PM_SINGLE_STEP_CH		BIT(6)
231 #define  PM_SINGLE_STEP_OFFSET		GENMASK(15, 7)
232 #define  PM_SINGLE_STEP_OFFSET_SET(o)	FIELD_PREP(PM_SINGLE_STEP_OFFSET, o)
233 #define  PM_SINGLE_STEP_EN		BIT(31)
234 
235 /* Port MAC 0/1 Receive Ethernet Octets Counter */
236 #define ENETC4_PM_REOCT(mac)		(0x5100 + (mac) * 0x400)
237 
238 /* Port MAC 0/1 Receive Octets Counter */
239 #define ENETC4_PM_ROCT(mac)		(0x5108 + (mac) * 0x400)
240 
241 /* Port MAC 0/1 Receive Alignment Error Counter Register */
242 #define ENETC4_PM_RALN(mac)		(0x5110 + (mac) * 0x400)
243 
244 /* Port MAC 0/1 Receive Valid Pause Frame Counter */
245 #define ENETC4_PM_RXPF(mac)		(0x5118 + (mac) * 0x400)
246 
247 /* Port MAC 0/1 Receive Frame Counter */
248 #define ENETC4_PM_RFRM(mac)		(0x5120 + (mac) * 0x400)
249 
250 /* Port MAC 0/1 Receive Frame Check Sequence Error Counter */
251 #define ENETC4_PM_RFCS(mac)		(0x5128 + (mac) * 0x400)
252 
253 /* Port MAC 0/1 Receive VLAN Frame Counter */
254 #define ENETC4_PM_RVLAN(mac)		(0x5130 + (mac) * 0x400)
255 
256 /* Port MAC 0/1 Receive Frame Error Counter */
257 #define ENETC4_PM_RERR(mac)		(0x5138 + (mac) * 0x400)
258 
259 /* Port MAC 0/1 Receive Unicast Frame Counter */
260 #define ENETC4_PM_RUCA(mac)		(0x5140 + (mac) * 0x400)
261 
262 /* Port MAC 0/1 Receive Multicast Frame Counter */
263 #define ENETC4_PM_RMCA(mac)		(0x5148 + (mac) * 0x400)
264 
265 /* Port MAC 0/1 Receive Broadcast Frame Counter */
266 #define ENETC4_PM_RBCA(mac)		(0x5150 + (mac) * 0x400)
267 
268 /* Port MAC 0/1 Receive Dropped Packets Counter */
269 #define ENETC4_PM_RDRP(mac)		(0x5158 + (mac) * 0x400)
270 
271 /* Port MAC 0/1 Receive Packets Counter */
272 #define ENETC4_PM_RPKT(mac)		(0x5160 + (mac) * 0x400)
273 
274 /* Port MAC 0/1 Receive Undersized Packet Counter */
275 #define ENETC4_PM_RUND(mac)		(0x5168 + (mac) * 0x400)
276 
277 /* Port MAC 0/1 Receive 64-Octet Packet Counter */
278 #define ENETC4_PM_R64(mac)		(0x5170 + (mac) * 0x400)
279 
280 /* Port MAC 0/1 Receive 65 to 127-Octet Packet Counter */
281 #define ENETC4_PM_R127(mac)		(0x5178 + (mac) * 0x400)
282 
283 /* Port MAC 0/1 Receive 128 to 255-Octet Packet Counter */
284 #define ENETC4_PM_R255(mac)		(0x5180 + (mac) * 0x400)
285 
286 /* Port MAC 0/1 Receive 256 to 511-Octet Packet Counter */
287 #define ENETC4_PM_R511(mac)		(0x5188 + (mac) * 0x400)
288 
289 /* Port MAC 0/1 Receive 512 to 1023-Octet Packet Counter */
290 #define ENETC4_PM_R1023(mac)		(0x5190 + (mac) * 0x400)
291 
292 /* Port MAC 0/1 Receive 1024 to 1522-Octet Packet Counter */
293 #define ENETC4_PM_R1522(mac)		(0x5198 + (mac) * 0x400)
294 
295 /* Port MAC 0/1 Receive 1523 to Max-Octet Packet Counter */
296 #define ENETC4_PM_R1523X(mac)		(0x51a0 + (mac) * 0x400)
297 
298 /* Port MAC 0/1 Receive Oversized Packet Counter */
299 #define ENETC4_PM_ROVR(mac)		(0x51a8 + (mac) * 0x400)
300 
301 /* Port MAC 0/1 Receive Jabber Packet Counter */
302 #define ENETC4_PM_RJBR(mac)		(0x51b0 + (mac) * 0x400)
303 
304 /* Port MAC 0/1 Receive Fragment Packet Counter */
305 #define ENETC4_PM_RFRG(mac)		(0x51b8 + (mac) * 0x400)
306 
307 /* Port MAC 0/1 Receive Control Packet Counter */
308 #define ENETC4_PM_RCNP(mac)		(0x51c0 + (mac) * 0x400)
309 
310 /* Port MAC 0/1 Receive Dropped Not Truncated Packets Counter */
311 #define ENETC4_PM_RDRNTP(mac)		(0x51c8 + (mac) * 0x400)
312 
313 /* Port MAC 0/1 Transmit Ethernet Octets Counter */
314 #define ENETC4_PM_TEOCT(mac)		(0x5200 + (mac) * 0x400)
315 
316 /* Port MAC 0/1 Transmit Octets Counter */
317 #define ENETC4_PM_TOCT(mac)		(0x5208 + (mac) * 0x400)
318 
319 /* Port MAC 0/1 Transmit Valid Pause Frame Counter */
320 #define ENETC4_PM_TXPF(mac)		(0x5218 + (mac) * 0x400)
321 
322 /* Port MAC 0/1 Transmit Frame Counter */
323 #define ENETC4_PM_TFRM(mac)		(0x5220 + (mac) * 0x400)
324 
325 /* Port MAC 0/1 Transmit Frame Check Sequence Error Counter */
326 #define ENETC4_PM_TFCS(mac)		(0x5228 + (mac) * 0x400)
327 
328 /* Port MAC 0/1 Transmit VLAN Frame Counter */
329 #define ENETC4_PM_TVLAN(mac)		(0x5230 + (mac) * 0x400)
330 
331 /* Port MAC 0/1 Transmit Frame Error Counter */
332 #define ENETC4_PM_TERR(mac)		(0x5238 + (mac) * 0x400)
333 
334 /* Port MAC 0/1 Transmit Unicast Frame Counter */
335 #define ENETC4_PM_TUCA(mac)		(0x5240 + (mac) * 0x400)
336 
337 /* Port MAC 0/1 Transmit Multicast Frame Counter */
338 #define ENETC4_PM_TMCA(mac)		(0x5248 + (mac) * 0x400)
339 
340 /* Port MAC 0/1 Transmit Broadcast Frame Counter */
341 #define ENETC4_PM_TBCA(mac)		(0x5250 + (mac) * 0x400)
342 
343 /* Port MAC 0/1 Transmit Packets Counter */
344 #define ENETC4_PM_TPKT(mac)		(0x5260 + (mac) * 0x400)
345 
346 /* Port MAC 0/1 Transmit Undersized Packet Counter */
347 #define ENETC4_PM_TUND(mac)		(0x5268 + (mac) * 0x400)
348 
349 /* Port MAC 0/1 Transmit 64-Octet Packet Counter */
350 #define ENETC4_PM_T64(mac)		(0x5270 + (mac) * 0x400)
351 
352 /* Port MAC 0/1 Transmit 65 to 127-Octet Packet Counter */
353 #define ENETC4_PM_T127(mac)		(0x5278 + (mac) * 0x400)
354 
355 /* Port MAC 0/1 Transmit 128 to 255-Octet Packet Counter */
356 #define ENETC4_PM_T255(mac)		(0x5280 + (mac) * 0x400)
357 
358 /* Port MAC 0/1 Transmit 256 to 511-Octet Packet Counter */
359 #define ENETC4_PM_T511(mac)		(0x5288 + (mac) * 0x400)
360 
361 /* Port MAC 0/1 Transmit 512 to 1023-Octet Packet Counter */
362 #define ENETC4_PM_T1023(mac)		(0x5290 + (mac) * 0x400)
363 
364 /* Port MAC 0/1 Transmit 1024 to 1522-Octet Packet Counter */
365 #define ENETC4_PM_T1522(mac)		(0x5298 + (mac) * 0x400)
366 
367 /* Port MAC 0/1 Transmit 1523 to TX_MTU-Octet Packet Counter */
368 #define ENETC4_PM_T1523X(mac)		(0x52a0 + (mac) * 0x400)
369 
370 /* Port MAC 0/1 Transmit Control Packet Counter */
371 #define ENETC4_PM_TCNP(mac)		(0x52c0 + (mac) * 0x400)
372 
373 /* Port MAC 0/1 Transmit Deferred Packet Counter */
374 #define ENETC4_PM_TDFR(mac)		(0x52d0 + (mac) * 0x400)
375 
376 /* Port MAC 0/1 Transmit Multiple Collisions Counter */
377 #define ENETC4_PM_TMCOL(mac)		(0x52d8 + (mac) * 0x400)
378 
379 /* Port MAC 0/1 Transmit Single Collision */
380 #define ENETC4_PM_TSCOL(mac)		(0x52e0 + (mac) * 0x400)
381 
382 /* Port MAC 0/1 Transmit Late Collision Counter */
383 #define ENETC4_PM_TLCOL(mac)		(0x52e8 + (mac) * 0x400)
384 
385 /* Port MAC 0/1 Transmit Excessive Collisions Counter */
386 #define ENETC4_PM_TECOL(mac)		(0x52f0 + (mac) * 0x400)
387 
388 /* Port MAC 0/1 Transmit Invalid Octets Counter */
389 #define ENETC4_PM_TIOCT(mac)		(0x52f8 + (mac) * 0x400)
390 
391 /* Port MAC 0 Interface Mode Control Register */
392 #define ENETC4_PM_IF_MODE(mac)		(0x5300 + (mac) * 0x400)
393 #define  PM_IF_MODE_IFMODE		GENMASK(2, 0)
394 #define   IFMODE_XGMII			0
395 #define   IFMODE_RMII			3
396 #define   IFMODE_RGMII			4
397 #define   IFMODE_SGMII			5
398 #define  PM_IF_MODE_REVMII		BIT(3)
399 #define  PM_IF_MODE_M10			BIT(4)
400 #define  PM_IF_MODE_HD			BIT(6)
401 #define  PM_IF_MODE_SSP			GENMASK(14, 13)
402 #define   SSP_100M			0
403 #define   SSP_10M			1
404 #define   SSP_1G			2
405 #define  PM_IF_MODE_ENA			BIT(15)
406 
407 /* Port external MDIO Base address, use to access off-chip PHY */
408 #define ENETC4_EMDIO_BASE		0x5c00
409 
410 /**********************ENETC Pseudo MAC port registers************************/
411 /* Port pseudo MAC receive octets counter (64-bit) */
412 #define ENETC4_PPMROCR			0x5080
413 
414 /* Port pseudo MAC receive unicast frame counter register (64-bit) */
415 #define ENETC4_PPMRUFCR			0x5088
416 
417 /* Port pseudo MAC receive multicast frame counter register (64-bit) */
418 #define ENETC4_PPMRMFCR			0x5090
419 
420 /* Port pseudo MAC receive broadcast frame counter register (64-bit) */
421 #define ENETC4_PPMRBFCR			0x5098
422 
423 /* Port pseudo MAC transmit octets counter (64-bit) */
424 #define ENETC4_PPMTOCR			0x50c0
425 
426 /* Port pseudo MAC transmit unicast frame counter register (64-bit) */
427 #define ENETC4_PPMTUFCR			0x50c8
428 
429 /* Port pseudo MAC transmit multicast frame counter register (64-bit) */
430 #define ENETC4_PPMTMFCR			0x50d0
431 
432 /* Port pseudo MAC transmit broadcast frame counter register (64-bit) */
433 #define ENETC4_PPMTBFCR			0x50d8
434 
435 #endif
436