1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* Renesas Ethernet Switch device driver
3  *
4  * Copyright (C) 2022 Renesas Electronics Corporation
5  */
6 
7 #ifndef __RSWITCH_H__
8 #define __RSWITCH_H__
9 
10 #include <linux/platform_device.h>
11 #include "rcar_gen4_ptp.h"
12 
13 #define RSWITCH_MAX_NUM_QUEUES	128
14 
15 #define RSWITCH_NUM_PORTS	3
16 #define rswitch_for_each_enabled_port(priv, i)		\
17 	for (i = 0; i < RSWITCH_NUM_PORTS; i++)		\
18 		if (priv->rdev[i]->disabled)		\
19 			continue;			\
20 		else
21 
22 #define rswitch_for_each_enabled_port_continue_reverse(priv, i)	\
23 	for (i--; i >= 0; i--)					\
24 		if (priv->rdev[i]->disabled)			\
25 			continue;				\
26 		else
27 
28 #define TX_RING_SIZE		1024
29 #define RX_RING_SIZE		1024
30 #define TS_RING_SIZE		(TX_RING_SIZE * RSWITCH_NUM_PORTS)
31 
32 #define PKT_BUF_SZ		1584
33 #define RSWITCH_ALIGN		128
34 #define RSWITCH_MAX_CTAG_PCP	7
35 
36 #define RSWITCH_TIMEOUT_US	100000
37 
38 #define RSWITCH_TOP_OFFSET	0x00008000
39 #define RSWITCH_COMA_OFFSET	0x00009000
40 #define RSWITCH_ETHA_OFFSET	0x0000a000	/* with RMAC */
41 #define RSWITCH_ETHA_SIZE	0x00002000	/* with RMAC */
42 #define RSWITCH_GWCA0_OFFSET	0x00010000
43 #define RSWITCH_GWCA1_OFFSET	0x00012000
44 
45 /* TODO: hardcoded ETHA/GWCA settings for now */
46 #define GWCA_IRQ_RESOURCE_NAME	"gwca0_rxtx%d"
47 #define GWCA_IRQ_NAME		"rswitch: gwca0_rxtx%d"
48 #define GWCA_NUM_IRQS		8
49 #define GWCA_INDEX		0
50 #define AGENT_INDEX_GWCA	3
51 #define GWCA_IPV_NUM		0
52 #define GWRO			RSWITCH_GWCA0_OFFSET
53 
54 #define GWCA_TS_IRQ_RESOURCE_NAME	"gwca0_rxts0"
55 #define GWCA_TS_IRQ_NAME		"rswitch: gwca0_rxts0"
56 #define GWCA_TS_IRQ_BIT			BIT(0)
57 
58 #define FWRO	0
59 #define TPRO	RSWITCH_TOP_OFFSET
60 #define CARO	RSWITCH_COMA_OFFSET
61 #define TARO	0
62 #define RMRO	0x1000
63 enum rswitch_reg {
64 	FWGC		= FWRO + 0x0000,
65 	FWTTC0		= FWRO + 0x0010,
66 	FWTTC1		= FWRO + 0x0014,
67 	FWLBMC		= FWRO + 0x0018,
68 	FWCEPTC		= FWRO + 0x0020,
69 	FWCEPRC0	= FWRO + 0x0024,
70 	FWCEPRC1	= FWRO + 0x0028,
71 	FWCEPRC2	= FWRO + 0x002c,
72 	FWCLPTC		= FWRO + 0x0030,
73 	FWCLPRC		= FWRO + 0x0034,
74 	FWCMPTC		= FWRO + 0x0040,
75 	FWEMPTC		= FWRO + 0x0044,
76 	FWSDMPTC	= FWRO + 0x0050,
77 	FWSDMPVC	= FWRO + 0x0054,
78 	FWLBWMC0	= FWRO + 0x0080,
79 	FWPC00		= FWRO + 0x0100,
80 	FWPC10		= FWRO + 0x0104,
81 	FWPC20		= FWRO + 0x0108,
82 	FWCTGC00	= FWRO + 0x0400,
83 	FWCTGC10	= FWRO + 0x0404,
84 	FWCTTC00	= FWRO + 0x0408,
85 	FWCTTC10	= FWRO + 0x040c,
86 	FWCTTC200	= FWRO + 0x0410,
87 	FWCTSC00	= FWRO + 0x0420,
88 	FWCTSC10	= FWRO + 0x0424,
89 	FWCTSC20	= FWRO + 0x0428,
90 	FWCTSC30	= FWRO + 0x042c,
91 	FWCTSC40	= FWRO + 0x0430,
92 	FWTWBFC0	= FWRO + 0x1000,
93 	FWTWBFVC0	= FWRO + 0x1004,
94 	FWTHBFC0	= FWRO + 0x1400,
95 	FWTHBFV0C0	= FWRO + 0x1404,
96 	FWTHBFV1C0	= FWRO + 0x1408,
97 	FWFOBFC0	= FWRO + 0x1800,
98 	FWFOBFV0C0	= FWRO + 0x1804,
99 	FWFOBFV1C0	= FWRO + 0x1808,
100 	FWRFC0		= FWRO + 0x1c00,
101 	FWRFVC0		= FWRO + 0x1c04,
102 	FWCFC0		= FWRO + 0x2000,
103 	FWCFMC00	= FWRO + 0x2004,
104 	FWIP4SC		= FWRO + 0x4008,
105 	FWIP6SC		= FWRO + 0x4018,
106 	FWIP6OC		= FWRO + 0x401c,
107 	FWL2SC		= FWRO + 0x4020,
108 	FWSFHEC		= FWRO + 0x4030,
109 	FWSHCR0		= FWRO + 0x4040,
110 	FWSHCR1		= FWRO + 0x4044,
111 	FWSHCR2		= FWRO + 0x4048,
112 	FWSHCR3		= FWRO + 0x404c,
113 	FWSHCR4		= FWRO + 0x4050,
114 	FWSHCR5		= FWRO + 0x4054,
115 	FWSHCR6		= FWRO + 0x4058,
116 	FWSHCR7		= FWRO + 0x405c,
117 	FWSHCR8		= FWRO + 0x4060,
118 	FWSHCR9		= FWRO + 0x4064,
119 	FWSHCR10	= FWRO + 0x4068,
120 	FWSHCR11	= FWRO + 0x406c,
121 	FWSHCR12	= FWRO + 0x4070,
122 	FWSHCR13	= FWRO + 0x4074,
123 	FWSHCRR		= FWRO + 0x4078,
124 	FWLTHHEC	= FWRO + 0x4090,
125 	FWLTHHC		= FWRO + 0x4094,
126 	FWLTHTL0	= FWRO + 0x40a0,
127 	FWLTHTL1	= FWRO + 0x40a4,
128 	FWLTHTL2	= FWRO + 0x40a8,
129 	FWLTHTL3	= FWRO + 0x40ac,
130 	FWLTHTL4	= FWRO + 0x40b0,
131 	FWLTHTL5	= FWRO + 0x40b4,
132 	FWLTHTL6	= FWRO + 0x40b8,
133 	FWLTHTL7	= FWRO + 0x40bc,
134 	FWLTHTL80	= FWRO + 0x40c0,
135 	FWLTHTL9	= FWRO + 0x40d0,
136 	FWLTHTLR	= FWRO + 0x40d4,
137 	FWLTHTIM	= FWRO + 0x40e0,
138 	FWLTHTEM	= FWRO + 0x40e4,
139 	FWLTHTS0	= FWRO + 0x4100,
140 	FWLTHTS1	= FWRO + 0x4104,
141 	FWLTHTS2	= FWRO + 0x4108,
142 	FWLTHTS3	= FWRO + 0x410c,
143 	FWLTHTS4	= FWRO + 0x4110,
144 	FWLTHTSR0	= FWRO + 0x4120,
145 	FWLTHTSR1	= FWRO + 0x4124,
146 	FWLTHTSR2	= FWRO + 0x4128,
147 	FWLTHTSR3	= FWRO + 0x412c,
148 	FWLTHTSR40	= FWRO + 0x4130,
149 	FWLTHTSR5	= FWRO + 0x4140,
150 	FWLTHTR		= FWRO + 0x4150,
151 	FWLTHTRR0	= FWRO + 0x4154,
152 	FWLTHTRR1	= FWRO + 0x4158,
153 	FWLTHTRR2	= FWRO + 0x415c,
154 	FWLTHTRR3	= FWRO + 0x4160,
155 	FWLTHTRR4	= FWRO + 0x4164,
156 	FWLTHTRR5	= FWRO + 0x4168,
157 	FWLTHTRR6	= FWRO + 0x416c,
158 	FWLTHTRR7	= FWRO + 0x4170,
159 	FWLTHTRR8	= FWRO + 0x4174,
160 	FWLTHTRR9	= FWRO + 0x4180,
161 	FWLTHTRR10	= FWRO + 0x4190,
162 	FWIPHEC		= FWRO + 0x4214,
163 	FWIPHC		= FWRO + 0x4218,
164 	FWIPTL0		= FWRO + 0x4220,
165 	FWIPTL1		= FWRO + 0x4224,
166 	FWIPTL2		= FWRO + 0x4228,
167 	FWIPTL3		= FWRO + 0x422c,
168 	FWIPTL4		= FWRO + 0x4230,
169 	FWIPTL5		= FWRO + 0x4234,
170 	FWIPTL6		= FWRO + 0x4238,
171 	FWIPTL7		= FWRO + 0x4240,
172 	FWIPTL8		= FWRO + 0x4250,
173 	FWIPTLR		= FWRO + 0x4254,
174 	FWIPTIM		= FWRO + 0x4260,
175 	FWIPTEM		= FWRO + 0x4264,
176 	FWIPTS0		= FWRO + 0x4270,
177 	FWIPTS1		= FWRO + 0x4274,
178 	FWIPTS2		= FWRO + 0x4278,
179 	FWIPTS3		= FWRO + 0x427c,
180 	FWIPTS4		= FWRO + 0x4280,
181 	FWIPTSR0	= FWRO + 0x4284,
182 	FWIPTSR1	= FWRO + 0x4288,
183 	FWIPTSR2	= FWRO + 0x428c,
184 	FWIPTSR3	= FWRO + 0x4290,
185 	FWIPTSR4	= FWRO + 0x42a0,
186 	FWIPTR		= FWRO + 0x42b0,
187 	FWIPTRR0	= FWRO + 0x42b4,
188 	FWIPTRR1	= FWRO + 0x42b8,
189 	FWIPTRR2	= FWRO + 0x42bc,
190 	FWIPTRR3	= FWRO + 0x42c0,
191 	FWIPTRR4	= FWRO + 0x42c4,
192 	FWIPTRR5	= FWRO + 0x42c8,
193 	FWIPTRR6	= FWRO + 0x42cc,
194 	FWIPTRR7	= FWRO + 0x42d0,
195 	FWIPTRR8	= FWRO + 0x42e0,
196 	FWIPTRR9	= FWRO + 0x42f0,
197 	FWIPHLEC	= FWRO + 0x4300,
198 	FWIPAGUSPC	= FWRO + 0x4500,
199 	FWIPAGC		= FWRO + 0x4504,
200 	FWIPAGM0	= FWRO + 0x4510,
201 	FWIPAGM1	= FWRO + 0x4514,
202 	FWIPAGM2	= FWRO + 0x4518,
203 	FWIPAGM3	= FWRO + 0x451c,
204 	FWIPAGM4	= FWRO + 0x4520,
205 	FWMACHEC	= FWRO + 0x4620,
206 	FWMACHC		= FWRO + 0x4624,
207 	FWMACTL0	= FWRO + 0x4630,
208 	FWMACTL1	= FWRO + 0x4634,
209 	FWMACTL2	= FWRO + 0x4638,
210 	FWMACTL3	= FWRO + 0x463c,
211 	FWMACTL4	= FWRO + 0x4640,
212 	FWMACTL5	= FWRO + 0x4650,
213 	FWMACTLR	= FWRO + 0x4654,
214 	FWMACTIM	= FWRO + 0x4660,
215 	FWMACTEM	= FWRO + 0x4664,
216 	FWMACTS0	= FWRO + 0x4670,
217 	FWMACTS1	= FWRO + 0x4674,
218 	FWMACTSR0	= FWRO + 0x4678,
219 	FWMACTSR1	= FWRO + 0x467c,
220 	FWMACTSR2	= FWRO + 0x4680,
221 	FWMACTSR3	= FWRO + 0x4690,
222 	FWMACTR		= FWRO + 0x46a0,
223 	FWMACTRR0	= FWRO + 0x46a4,
224 	FWMACTRR1	= FWRO + 0x46a8,
225 	FWMACTRR2	= FWRO + 0x46ac,
226 	FWMACTRR3	= FWRO + 0x46b0,
227 	FWMACTRR4	= FWRO + 0x46b4,
228 	FWMACTRR5	= FWRO + 0x46c0,
229 	FWMACTRR6	= FWRO + 0x46d0,
230 	FWMACHLEC	= FWRO + 0x4700,
231 	FWMACAGUSPC	= FWRO + 0x4880,
232 	FWMACAGC	= FWRO + 0x4884,
233 	FWMACAGM0	= FWRO + 0x4888,
234 	FWMACAGM1	= FWRO + 0x488c,
235 	FWVLANTEC	= FWRO + 0x4900,
236 	FWVLANTL0	= FWRO + 0x4910,
237 	FWVLANTL1	= FWRO + 0x4914,
238 	FWVLANTL2	= FWRO + 0x4918,
239 	FWVLANTL3	= FWRO + 0x4920,
240 	FWVLANTL4	= FWRO + 0x4930,
241 	FWVLANTLR	= FWRO + 0x4934,
242 	FWVLANTIM	= FWRO + 0x4940,
243 	FWVLANTEM	= FWRO + 0x4944,
244 	FWVLANTS	= FWRO + 0x4950,
245 	FWVLANTSR0	= FWRO + 0x4954,
246 	FWVLANTSR1	= FWRO + 0x4958,
247 	FWVLANTSR2	= FWRO + 0x4960,
248 	FWVLANTSR3	= FWRO + 0x4970,
249 	FWPBFC0		= FWRO + 0x4a00,
250 	FWPBFCSDC00	= FWRO + 0x4a04,
251 	FWL23URL0	= FWRO + 0x4e00,
252 	FWL23URL1	= FWRO + 0x4e04,
253 	FWL23URL2	= FWRO + 0x4e08,
254 	FWL23URL3	= FWRO + 0x4e0c,
255 	FWL23URLR	= FWRO + 0x4e10,
256 	FWL23UTIM	= FWRO + 0x4e20,
257 	FWL23URR	= FWRO + 0x4e30,
258 	FWL23URRR0	= FWRO + 0x4e34,
259 	FWL23URRR1	= FWRO + 0x4e38,
260 	FWL23URRR2	= FWRO + 0x4e3c,
261 	FWL23URRR3	= FWRO + 0x4e40,
262 	FWL23URMC0	= FWRO + 0x4f00,
263 	FWPMFGC0	= FWRO + 0x5000,
264 	FWPGFC0		= FWRO + 0x5100,
265 	FWPGFIGSC0	= FWRO + 0x5104,
266 	FWPGFENC0	= FWRO + 0x5108,
267 	FWPGFENM0	= FWRO + 0x510c,
268 	FWPGFCSTC00	= FWRO + 0x5110,
269 	FWPGFCSTC10	= FWRO + 0x5114,
270 	FWPGFCSTM00	= FWRO + 0x5118,
271 	FWPGFCSTM10	= FWRO + 0x511c,
272 	FWPGFCTC0	= FWRO + 0x5120,
273 	FWPGFCTM0	= FWRO + 0x5124,
274 	FWPGFHCC0	= FWRO + 0x5128,
275 	FWPGFSM0	= FWRO + 0x512c,
276 	FWPGFGC0	= FWRO + 0x5130,
277 	FWPGFGL0	= FWRO + 0x5500,
278 	FWPGFGL1	= FWRO + 0x5504,
279 	FWPGFGLR	= FWRO + 0x5518,
280 	FWPGFGR		= FWRO + 0x5510,
281 	FWPGFGRR0	= FWRO + 0x5514,
282 	FWPGFGRR1	= FWRO + 0x5518,
283 	FWPGFRIM	= FWRO + 0x5520,
284 	FWPMTRFC0	= FWRO + 0x5600,
285 	FWPMTRCBSC0	= FWRO + 0x5604,
286 	FWPMTRC0RC0	= FWRO + 0x5608,
287 	FWPMTREBSC0	= FWRO + 0x560c,
288 	FWPMTREIRC0	= FWRO + 0x5610,
289 	FWPMTRFM0	= FWRO + 0x5614,
290 	FWFTL0		= FWRO + 0x6000,
291 	FWFTL1		= FWRO + 0x6004,
292 	FWFTLR		= FWRO + 0x6008,
293 	FWFTOC		= FWRO + 0x6010,
294 	FWFTOPC		= FWRO + 0x6014,
295 	FWFTIM		= FWRO + 0x6020,
296 	FWFTR		= FWRO + 0x6030,
297 	FWFTRR0		= FWRO + 0x6034,
298 	FWFTRR1		= FWRO + 0x6038,
299 	FWFTRR2		= FWRO + 0x603c,
300 	FWSEQNGC0	= FWRO + 0x6100,
301 	FWSEQNGM0	= FWRO + 0x6104,
302 	FWSEQNRC	= FWRO + 0x6200,
303 	FWCTFDCN0	= FWRO + 0x6300,
304 	FWLTHFDCN0	= FWRO + 0x6304,
305 	FWIPFDCN0	= FWRO + 0x6308,
306 	FWLTWFDCN0	= FWRO + 0x630c,
307 	FWPBFDCN0	= FWRO + 0x6310,
308 	FWMHLCN0	= FWRO + 0x6314,
309 	FWIHLCN0	= FWRO + 0x6318,
310 	FWICRDCN0	= FWRO + 0x6500,
311 	FWWMRDCN0	= FWRO + 0x6504,
312 	FWCTRDCN0	= FWRO + 0x6508,
313 	FWLTHRDCN0	= FWRO + 0x650c,
314 	FWIPRDCN0	= FWRO + 0x6510,
315 	FWLTWRDCN0	= FWRO + 0x6514,
316 	FWPBRDCN0	= FWRO + 0x6518,
317 	FWPMFDCN0	= FWRO + 0x6700,
318 	FWPGFDCN0	= FWRO + 0x6780,
319 	FWPMGDCN0	= FWRO + 0x6800,
320 	FWPMYDCN0	= FWRO + 0x6804,
321 	FWPMRDCN0	= FWRO + 0x6808,
322 	FWFRPPCN0	= FWRO + 0x6a00,
323 	FWFRDPCN0	= FWRO + 0x6a04,
324 	FWEIS00		= FWRO + 0x7900,
325 	FWEIE00		= FWRO + 0x7904,
326 	FWEID00		= FWRO + 0x7908,
327 	FWEIS1		= FWRO + 0x7a00,
328 	FWEIE1		= FWRO + 0x7a04,
329 	FWEID1		= FWRO + 0x7a08,
330 	FWEIS2		= FWRO + 0x7a10,
331 	FWEIE2		= FWRO + 0x7a14,
332 	FWEID2		= FWRO + 0x7a18,
333 	FWEIS3		= FWRO + 0x7a20,
334 	FWEIE3		= FWRO + 0x7a24,
335 	FWEID3		= FWRO + 0x7a28,
336 	FWEIS4		= FWRO + 0x7a30,
337 	FWEIE4		= FWRO + 0x7a34,
338 	FWEID4		= FWRO + 0x7a38,
339 	FWEIS5		= FWRO + 0x7a40,
340 	FWEIE5		= FWRO + 0x7a44,
341 	FWEID5		= FWRO + 0x7a48,
342 	FWEIS60		= FWRO + 0x7a50,
343 	FWEIE60		= FWRO + 0x7a54,
344 	FWEID60		= FWRO + 0x7a58,
345 	FWEIS61		= FWRO + 0x7a60,
346 	FWEIE61		= FWRO + 0x7a64,
347 	FWEID61		= FWRO + 0x7a68,
348 	FWEIS62		= FWRO + 0x7a70,
349 	FWEIE62		= FWRO + 0x7a74,
350 	FWEID62		= FWRO + 0x7a78,
351 	FWEIS63		= FWRO + 0x7a80,
352 	FWEIE63		= FWRO + 0x7a84,
353 	FWEID63		= FWRO + 0x7a88,
354 	FWEIS70		= FWRO + 0x7a90,
355 	FWEIE70		= FWRO + 0x7A94,
356 	FWEID70		= FWRO + 0x7a98,
357 	FWEIS71		= FWRO + 0x7aa0,
358 	FWEIE71		= FWRO + 0x7aa4,
359 	FWEID71		= FWRO + 0x7aa8,
360 	FWEIS72		= FWRO + 0x7ab0,
361 	FWEIE72		= FWRO + 0x7ab4,
362 	FWEID72		= FWRO + 0x7ab8,
363 	FWEIS73		= FWRO + 0x7ac0,
364 	FWEIE73		= FWRO + 0x7ac4,
365 	FWEID73		= FWRO + 0x7ac8,
366 	FWEIS80		= FWRO + 0x7ad0,
367 	FWEIE80		= FWRO + 0x7ad4,
368 	FWEID80		= FWRO + 0x7ad8,
369 	FWEIS81		= FWRO + 0x7ae0,
370 	FWEIE81		= FWRO + 0x7ae4,
371 	FWEID81		= FWRO + 0x7ae8,
372 	FWEIS82		= FWRO + 0x7af0,
373 	FWEIE82		= FWRO + 0x7af4,
374 	FWEID82		= FWRO + 0x7af8,
375 	FWEIS83		= FWRO + 0x7b00,
376 	FWEIE83		= FWRO + 0x7b04,
377 	FWEID83		= FWRO + 0x7b08,
378 	FWMIS0		= FWRO + 0x7c00,
379 	FWMIE0		= FWRO + 0x7c04,
380 	FWMID0		= FWRO + 0x7c08,
381 	FWSCR0		= FWRO + 0x7d00,
382 	FWSCR1		= FWRO + 0x7d04,
383 	FWSCR2		= FWRO + 0x7d08,
384 	FWSCR3		= FWRO + 0x7d0c,
385 	FWSCR4		= FWRO + 0x7d10,
386 	FWSCR5		= FWRO + 0x7d14,
387 	FWSCR6		= FWRO + 0x7d18,
388 	FWSCR7		= FWRO + 0x7d1c,
389 	FWSCR8		= FWRO + 0x7d20,
390 	FWSCR9		= FWRO + 0x7d24,
391 	FWSCR10		= FWRO + 0x7d28,
392 	FWSCR11		= FWRO + 0x7d2c,
393 	FWSCR12		= FWRO + 0x7d30,
394 	FWSCR13		= FWRO + 0x7d34,
395 	FWSCR14		= FWRO + 0x7d38,
396 	FWSCR15		= FWRO + 0x7d3c,
397 	FWSCR16		= FWRO + 0x7d40,
398 	FWSCR17		= FWRO + 0x7d44,
399 	FWSCR18		= FWRO + 0x7d48,
400 	FWSCR19		= FWRO + 0x7d4c,
401 	FWSCR20		= FWRO + 0x7d50,
402 	FWSCR21		= FWRO + 0x7d54,
403 	FWSCR22		= FWRO + 0x7d58,
404 	FWSCR23		= FWRO + 0x7d5c,
405 	FWSCR24		= FWRO + 0x7d60,
406 	FWSCR25		= FWRO + 0x7d64,
407 	FWSCR26		= FWRO + 0x7d68,
408 	FWSCR27		= FWRO + 0x7d6c,
409 	FWSCR28		= FWRO + 0x7d70,
410 	FWSCR29		= FWRO + 0x7d74,
411 	FWSCR30		= FWRO + 0x7d78,
412 	FWSCR31		= FWRO + 0x7d7c,
413 	FWSCR32		= FWRO + 0x7d80,
414 	FWSCR33		= FWRO + 0x7d84,
415 	FWSCR34		= FWRO + 0x7d88,
416 	FWSCR35		= FWRO + 0x7d8c,
417 	FWSCR36		= FWRO + 0x7d90,
418 	FWSCR37		= FWRO + 0x7d94,
419 	FWSCR38		= FWRO + 0x7d98,
420 	FWSCR39		= FWRO + 0x7d9c,
421 	FWSCR40		= FWRO + 0x7da0,
422 	FWSCR41		= FWRO + 0x7da4,
423 	FWSCR42		= FWRO + 0x7da8,
424 	FWSCR43		= FWRO + 0x7dac,
425 	FWSCR44		= FWRO + 0x7db0,
426 	FWSCR45		= FWRO + 0x7db4,
427 	FWSCR46		= FWRO + 0x7db8,
428 
429 	TPEMIMC0	= TPRO + 0x0000,
430 	TPEMIMC1	= TPRO + 0x0004,
431 	TPEMIMC2	= TPRO + 0x0008,
432 	TPEMIMC3	= TPRO + 0x000c,
433 	TPEMIMC4	= TPRO + 0x0010,
434 	TPEMIMC5	= TPRO + 0x0014,
435 	TPEMIMC60	= TPRO + 0x0080,
436 	TPEMIMC70	= TPRO + 0x0100,
437 	TSIM		= TPRO + 0x0700,
438 	TFIM		= TPRO + 0x0704,
439 	TCIM		= TPRO + 0x0708,
440 	TGIM0		= TPRO + 0x0710,
441 	TGIM1		= TPRO + 0x0714,
442 	TEIM0		= TPRO + 0x0720,
443 	TEIM1		= TPRO + 0x0724,
444 	TEIM2		= TPRO + 0x0728,
445 
446 	RIPV		= CARO + 0x0000,
447 	RRC		= CARO + 0x0004,
448 	RCEC		= CARO + 0x0008,
449 	RCDC		= CARO + 0x000c,
450 	RSSIS		= CARO + 0x0010,
451 	RSSIE		= CARO + 0x0014,
452 	RSSID		= CARO + 0x0018,
453 	CABPIBWMC	= CARO + 0x0020,
454 	CABPWMLC	= CARO + 0x0040,
455 	CABPPFLC0	= CARO + 0x0050,
456 	CABPPWMLC0	= CARO + 0x0060,
457 	CABPPPFLC00	= CARO + 0x00a0,
458 	CABPULC		= CARO + 0x0100,
459 	CABPIRM		= CARO + 0x0140,
460 	CABPPCM		= CARO + 0x0144,
461 	CABPLCM		= CARO + 0x0148,
462 	CABPCPM		= CARO + 0x0180,
463 	CABPMCPM	= CARO + 0x0200,
464 	CARDNM		= CARO + 0x0280,
465 	CARDMNM		= CARO + 0x0284,
466 	CARDCN		= CARO + 0x0290,
467 	CAEIS0		= CARO + 0x0300,
468 	CAEIE0		= CARO + 0x0304,
469 	CAEID0		= CARO + 0x0308,
470 	CAEIS1		= CARO + 0x0310,
471 	CAEIE1		= CARO + 0x0314,
472 	CAEID1		= CARO + 0x0318,
473 	CAMIS0		= CARO + 0x0340,
474 	CAMIE0		= CARO + 0x0344,
475 	CAMID0		= CARO + 0x0348,
476 	CAMIS1		= CARO + 0x0350,
477 	CAMIE1		= CARO + 0x0354,
478 	CAMID1		= CARO + 0x0358,
479 	CASCR		= CARO + 0x0380,
480 
481 	EAMC		= TARO + 0x0000,
482 	EAMS		= TARO + 0x0004,
483 	EAIRC		= TARO + 0x0010,
484 	EATDQSC		= TARO + 0x0014,
485 	EATDQC		= TARO + 0x0018,
486 	EATDQAC		= TARO + 0x001c,
487 	EATPEC		= TARO + 0x0020,
488 	EATMFSC0	= TARO + 0x0040,
489 	EATDQDC0	= TARO + 0x0060,
490 	EATDQM0		= TARO + 0x0080,
491 	EATDQMLM0	= TARO + 0x00a0,
492 	EACTQC		= TARO + 0x0100,
493 	EACTDQDC	= TARO + 0x0104,
494 	EACTDQM		= TARO + 0x0108,
495 	EACTDQMLM	= TARO + 0x010c,
496 	EAVCC		= TARO + 0x0130,
497 	EAVTC		= TARO + 0x0134,
498 	EATTFC		= TARO + 0x0138,
499 	EACAEC		= TARO + 0x0200,
500 	EACC		= TARO + 0x0204,
501 	EACAIVC0	= TARO + 0x0220,
502 	EACAULC0	= TARO + 0x0240,
503 	EACOEM		= TARO + 0x0260,
504 	EACOIVM0	= TARO + 0x0280,
505 	EACOULM0	= TARO + 0x02a0,
506 	EACGSM		= TARO + 0x02c0,
507 	EATASC		= TARO + 0x0300,
508 	EATASENC0	= TARO + 0x0320,
509 	EATASCTENC	= TARO + 0x0340,
510 	EATASENM0	= TARO + 0x0360,
511 	EATASCTENM	= TARO + 0x0380,
512 	EATASCSTC0	= TARO + 0x03a0,
513 	EATASCSTC1	= TARO + 0x03a4,
514 	EATASCSTM0	= TARO + 0x03a8,
515 	EATASCSTM1	= TARO + 0x03ac,
516 	EATASCTC	= TARO + 0x03b0,
517 	EATASCTM	= TARO + 0x03b4,
518 	EATASGL0	= TARO + 0x03c0,
519 	EATASGL1	= TARO + 0x03c4,
520 	EATASGLR	= TARO + 0x03c8,
521 	EATASGR		= TARO + 0x03d0,
522 	EATASGRR	= TARO + 0x03d4,
523 	EATASHCC	= TARO + 0x03e0,
524 	EATASRIRM	= TARO + 0x03e4,
525 	EATASSM		= TARO + 0x03e8,
526 	EAUSMFSECN	= TARO + 0x0400,
527 	EATFECN		= TARO + 0x0404,
528 	EAFSECN		= TARO + 0x0408,
529 	EADQOECN	= TARO + 0x040c,
530 	EADQSECN	= TARO + 0x0410,
531 	EACKSECN	= TARO + 0x0414,
532 	EAEIS0		= TARO + 0x0500,
533 	EAEIE0		= TARO + 0x0504,
534 	EAEID0		= TARO + 0x0508,
535 	EAEIS1		= TARO + 0x0510,
536 	EAEIE1		= TARO + 0x0514,
537 	EAEID1		= TARO + 0x0518,
538 	EAEIS2		= TARO + 0x0520,
539 	EAEIE2		= TARO + 0x0524,
540 	EAEID2		= TARO + 0x0528,
541 	EASCR		= TARO + 0x0580,
542 
543 	MPSM		= RMRO + 0x0000,
544 	MPIC		= RMRO + 0x0004,
545 	MPIM		= RMRO + 0x0008,
546 	MIOC		= RMRO + 0x0010,
547 	MIOM		= RMRO + 0x0014,
548 	MXMS		= RMRO + 0x0018,
549 	MTFFC		= RMRO + 0x0020,
550 	MTPFC		= RMRO + 0x0024,
551 	MTPFC2		= RMRO + 0x0028,
552 	MTPFC30		= RMRO + 0x0030,
553 	MTATC0		= RMRO + 0x0050,
554 	MTIM		= RMRO + 0x0060,
555 	MRGC		= RMRO + 0x0080,
556 	MRMAC0		= RMRO + 0x0084,
557 	MRMAC1		= RMRO + 0x0088,
558 	MRAFC		= RMRO + 0x008c,
559 	MRSCE		= RMRO + 0x0090,
560 	MRSCP		= RMRO + 0x0094,
561 	MRSCC		= RMRO + 0x0098,
562 	MRFSCE		= RMRO + 0x009c,
563 	MRFSCP		= RMRO + 0x00a0,
564 	MTRC		= RMRO + 0x00a4,
565 	MRIM		= RMRO + 0x00a8,
566 	MRPFM		= RMRO + 0x00ac,
567 	MPFC0		= RMRO + 0x0100,
568 	MLVC		= RMRO + 0x0180,
569 	MEEEC		= RMRO + 0x0184,
570 	MLBC		= RMRO + 0x0188,
571 	MXGMIIC		= RMRO + 0x0190,
572 	MPCH		= RMRO + 0x0194,
573 	MANC		= RMRO + 0x0198,
574 	MANM		= RMRO + 0x019c,
575 	MPLCA1		= RMRO + 0x01a0,
576 	MPLCA2		= RMRO + 0x01a4,
577 	MPLCA3		= RMRO + 0x01a8,
578 	MPLCA4		= RMRO + 0x01ac,
579 	MPLCAM		= RMRO + 0x01b0,
580 	MHDC1		= RMRO + 0x01c0,
581 	MHDC2		= RMRO + 0x01c4,
582 	MEIS		= RMRO + 0x0200,
583 	MEIE		= RMRO + 0x0204,
584 	MEID		= RMRO + 0x0208,
585 	MMIS0		= RMRO + 0x0210,
586 	MMIE0		= RMRO + 0x0214,
587 	MMID0		= RMRO + 0x0218,
588 	MMIS1		= RMRO + 0x0220,
589 	MMIE1		= RMRO + 0x0224,
590 	MMID1		= RMRO + 0x0228,
591 	MMIS2		= RMRO + 0x0230,
592 	MMIE2		= RMRO + 0x0234,
593 	MMID2		= RMRO + 0x0238,
594 	MMPFTCT		= RMRO + 0x0300,
595 	MAPFTCT		= RMRO + 0x0304,
596 	MPFRCT		= RMRO + 0x0308,
597 	MFCICT		= RMRO + 0x030c,
598 	MEEECT		= RMRO + 0x0310,
599 	MMPCFTCT0	= RMRO + 0x0320,
600 	MAPCFTCT0	= RMRO + 0x0330,
601 	MPCFRCT0	= RMRO + 0x0340,
602 	MHDCC		= RMRO + 0x0350,
603 	MROVFC		= RMRO + 0x0354,
604 	MRHCRCEC	= RMRO + 0x0358,
605 	MRXBCE		= RMRO + 0x0400,
606 	MRXBCP		= RMRO + 0x0404,
607 	MRGFCE		= RMRO + 0x0408,
608 	MRGFCP		= RMRO + 0x040c,
609 	MRBFC		= RMRO + 0x0410,
610 	MRMFC		= RMRO + 0x0414,
611 	MRUFC		= RMRO + 0x0418,
612 	MRPEFC		= RMRO + 0x041c,
613 	MRNEFC		= RMRO + 0x0420,
614 	MRFMEFC		= RMRO + 0x0424,
615 	MRFFMEFC	= RMRO + 0x0428,
616 	MRCFCEFC	= RMRO + 0x042c,
617 	MRFCEFC		= RMRO + 0x0430,
618 	MRRCFEFC	= RMRO + 0x0434,
619 	MRUEFC		= RMRO + 0x043c,
620 	MROEFC		= RMRO + 0x0440,
621 	MRBOEC		= RMRO + 0x0444,
622 	MTXBCE		= RMRO + 0x0500,
623 	MTXBCP		= RMRO + 0x0504,
624 	MTGFCE		= RMRO + 0x0508,
625 	MTGFCP		= RMRO + 0x050c,
626 	MTBFC		= RMRO + 0x0510,
627 	MTMFC		= RMRO + 0x0514,
628 	MTUFC		= RMRO + 0x0518,
629 	MTEFC		= RMRO + 0x051c,
630 
631 	GWMC		= GWRO + 0x0000,
632 	GWMS		= GWRO + 0x0004,
633 	GWIRC		= GWRO + 0x0010,
634 	GWRDQSC		= GWRO + 0x0014,
635 	GWRDQC		= GWRO + 0x0018,
636 	GWRDQAC		= GWRO + 0x001c,
637 	GWRGC		= GWRO + 0x0020,
638 	GWRMFSC0	= GWRO + 0x0040,
639 	GWRDQDC0	= GWRO + 0x0060,
640 	GWRDQM0		= GWRO + 0x0080,
641 	GWRDQMLM0	= GWRO + 0x00a0,
642 	GWMTIRM		= GWRO + 0x0100,
643 	GWMSTLS		= GWRO + 0x0104,
644 	GWMSTLR		= GWRO + 0x0108,
645 	GWMSTSS		= GWRO + 0x010c,
646 	GWMSTSR		= GWRO + 0x0110,
647 	GWMAC0		= GWRO + 0x0120,
648 	GWMAC1		= GWRO + 0x0124,
649 	GWVCC		= GWRO + 0x0130,
650 	GWVTC		= GWRO + 0x0134,
651 	GWTTFC		= GWRO + 0x0138,
652 	GWTDCAC00	= GWRO + 0x0140,
653 	GWTDCAC10	= GWRO + 0x0144,
654 	GWTSDCC0	= GWRO + 0x0160,
655 	GWTNM		= GWRO + 0x0180,
656 	GWTMNM		= GWRO + 0x0184,
657 	GWAC		= GWRO + 0x0190,
658 	GWDCBAC0	= GWRO + 0x0194,
659 	GWDCBAC1	= GWRO + 0x0198,
660 	GWIICBSC	= GWRO + 0x019c,
661 	GWMDNC		= GWRO + 0x01a0,
662 	GWTRC0		= GWRO + 0x0200,
663 	GWTPC0		= GWRO + 0x0300,
664 	GWARIRM		= GWRO + 0x0380,
665 	GWDCC0		= GWRO + 0x0400,
666 	GWAARSS		= GWRO + 0x0800,
667 	GWAARSR0	= GWRO + 0x0804,
668 	GWAARSR1	= GWRO + 0x0808,
669 	GWIDAUAS0	= GWRO + 0x0840,
670 	GWIDASM0	= GWRO + 0x0880,
671 	GWIDASAM00	= GWRO + 0x0900,
672 	GWIDASAM10	= GWRO + 0x0904,
673 	GWIDACAM00	= GWRO + 0x0980,
674 	GWIDACAM10	= GWRO + 0x0984,
675 	GWGRLC		= GWRO + 0x0a00,
676 	GWGRLULC	= GWRO + 0x0a04,
677 	GWRLIVC0	= GWRO + 0x0a80,
678 	GWRLULC0	= GWRO + 0x0a84,
679 	GWIDPC		= GWRO + 0x0b00,
680 	GWIDC0		= GWRO + 0x0c00,
681 	GWDIS0		= GWRO + 0x1100,
682 	GWDIE0		= GWRO + 0x1104,
683 	GWDID0		= GWRO + 0x1108,
684 	GWTSDIS		= GWRO + 0x1180,
685 	GWTSDIE		= GWRO + 0x1184,
686 	GWTSDID		= GWRO + 0x1188,
687 	GWEIS0		= GWRO + 0x1190,
688 	GWEIE0		= GWRO + 0x1194,
689 	GWEID0		= GWRO + 0x1198,
690 	GWEIS1		= GWRO + 0x11a0,
691 	GWEIE1		= GWRO + 0x11a4,
692 	GWEID1		= GWRO + 0x11a8,
693 	GWEIS20		= GWRO + 0x1200,
694 	GWEIE20		= GWRO + 0x1204,
695 	GWEID20		= GWRO + 0x1208,
696 	GWEIS3		= GWRO + 0x1280,
697 	GWEIE3		= GWRO + 0x1284,
698 	GWEID3		= GWRO + 0x1288,
699 	GWEIS4		= GWRO + 0x1290,
700 	GWEIE4		= GWRO + 0x1294,
701 	GWEID4		= GWRO + 0x1298,
702 	GWEIS5		= GWRO + 0x12a0,
703 	GWEIE5		= GWRO + 0x12a4,
704 	GWEID5		= GWRO + 0x12a8,
705 	GWSCR0		= GWRO + 0x1800,
706 	GWSCR1		= GWRO + 0x1900,
707 };
708 
709 /* ETHA/RMAC */
710 enum rswitch_etha_mode {
711 	EAMC_OPC_RESET,
712 	EAMC_OPC_DISABLE,
713 	EAMC_OPC_CONFIG,
714 	EAMC_OPC_OPERATION,
715 };
716 
717 #define EAMS_OPS_MASK		EAMC_OPC_OPERATION
718 
719 #define EAVCC_VEM_SC_TAG	(0x3 << 16)
720 
721 #define MPIC_PIS_MII		0x00
722 #define MPIC_PIS_GMII		0x02
723 #define MPIC_PIS_XGMII		0x04
724 #define MPIC_LSC_SHIFT		3
725 #define MPIC_LSC_100M		(1 << MPIC_LSC_SHIFT)
726 #define MPIC_LSC_1G		(2 << MPIC_LSC_SHIFT)
727 #define MPIC_LSC_2_5G		(3 << MPIC_LSC_SHIFT)
728 
729 #define MDIO_READ_C45		0x03
730 #define MDIO_WRITE_C45		0x01
731 
732 #define MPSM_PSME		BIT(0)
733 #define MPSM_MFF_C45		BIT(2)
734 #define MPSM_PRD_SHIFT		16
735 #define MPSM_PRD_MASK		GENMASK(31, MPSM_PRD_SHIFT)
736 
737 /* Completion flags */
738 #define MMIS1_PAACS             BIT(2) /* Address */
739 #define MMIS1_PWACS             BIT(1) /* Write */
740 #define MMIS1_PRACS             BIT(0) /* Read */
741 #define MMIS1_CLEAR_FLAGS       0xf
742 
743 #define MPIC_PSMCS_SHIFT	16
744 #define MPIC_PSMCS_MASK		GENMASK(22, MPIC_PSMCS_SHIFT)
745 #define MPIC_PSMCS(val)		((val) << MPIC_PSMCS_SHIFT)
746 
747 #define MPIC_PSMHT_SHIFT	24
748 #define MPIC_PSMHT_MASK		GENMASK(26, MPIC_PSMHT_SHIFT)
749 #define MPIC_PSMHT(val)		((val) << MPIC_PSMHT_SHIFT)
750 
751 #define MLVC_PLV		BIT(16)
752 
753 /* GWCA */
754 enum rswitch_gwca_mode {
755 	GWMC_OPC_RESET,
756 	GWMC_OPC_DISABLE,
757 	GWMC_OPC_CONFIG,
758 	GWMC_OPC_OPERATION,
759 };
760 
761 #define GWMS_OPS_MASK		GWMC_OPC_OPERATION
762 
763 #define GWMTIRM_MTIOG		BIT(0)
764 #define GWMTIRM_MTR		BIT(1)
765 
766 #define GWVCC_VEM_SC_TAG	(0x3 << 16)
767 
768 #define GWARIRM_ARIOG		BIT(0)
769 #define GWARIRM_ARR		BIT(1)
770 
771 #define GWDCC_BALR		BIT(24)
772 #define GWDCC_DCP_MASK		GENMASK(18, 16)
773 #define GWDCC_DCP(prio)		FIELD_PREP(GWDCC_DCP_MASK, (prio))
774 #define GWDCC_DQT		BIT(11)
775 #define GWDCC_ETS		BIT(9)
776 #define GWDCC_EDE		BIT(8)
777 
778 #define GWTRC(queue)		(GWTRC0 + (queue) / 32 * 4)
779 #define GWTPC_PPPL(ipv)		BIT(ipv)
780 #define GWDCC_OFFS(queue)	(GWDCC0 + (queue) * 4)
781 
782 #define GWDIS(i)		(GWDIS0 + (i) * 0x10)
783 #define GWDIE(i)		(GWDIE0 + (i) * 0x10)
784 #define GWDID(i)		(GWDID0 + (i) * 0x10)
785 
786 /* COMA */
787 #define RRC_RR			BIT(0)
788 #define RRC_RR_CLR		0
789 #define	RCEC_ACE_DEFAULT	(BIT(0) | BIT(AGENT_INDEX_GWCA))
790 #define RCEC_RCE		BIT(16)
791 #define RCDC_RCD		BIT(16)
792 
793 #define CABPIRM_BPIOG		BIT(0)
794 #define CABPIRM_BPR		BIT(1)
795 
796 #define CABPPFLC_INIT_VALUE	0x00800080
797 
798 /* MFWD */
799 #define FWPC0_LTHTA		BIT(0)
800 #define FWPC0_IP4UE		BIT(3)
801 #define FWPC0_IP4TE		BIT(4)
802 #define FWPC0_IP4OE		BIT(5)
803 #define FWPC0_L2SE		BIT(9)
804 #define FWPC0_IP4EA		BIT(10)
805 #define FWPC0_IPDSA		BIT(12)
806 #define FWPC0_IPHLA		BIT(18)
807 #define FWPC0_MACSDA		BIT(20)
808 #define FWPC0_MACHLA		BIT(26)
809 #define FWPC0_MACHMA		BIT(27)
810 #define FWPC0_VLANSA		BIT(28)
811 
812 #define FWPC0(i)		(FWPC00 + (i) * 0x10)
813 #define FWPC0_DEFAULT		(FWPC0_LTHTA | FWPC0_IP4UE | FWPC0_IP4TE | \
814 				 FWPC0_IP4OE | FWPC0_L2SE | FWPC0_IP4EA | \
815 				 FWPC0_IPDSA | FWPC0_IPHLA | FWPC0_MACSDA | \
816 				 FWPC0_MACHLA |	FWPC0_MACHMA | FWPC0_VLANSA)
817 #define FWPC1(i)		(FWPC10 + (i) * 0x10)
818 #define FWPC1_DDE		BIT(0)
819 
820 #define	FWPBFC(i)		(FWPBFC0 + (i) * 0x10)
821 
822 #define FWPBFCSDC(j, i)         (FWPBFCSDC00 + (i) * 0x10 + (j) * 0x04)
823 
824 /* TOP */
825 #define TPEMIMC7(queue)		(TPEMIMC70 + (queue) * 4)
826 
827 /* Descriptors */
828 enum RX_DS_CC_BIT {
829 	RX_DS	= 0x0fff, /* Data size */
830 	RX_TR	= 0x1000, /* Truncation indication */
831 	RX_EI	= 0x2000, /* Error indication */
832 	RX_PS	= 0xc000, /* Padding selection */
833 };
834 
835 enum TX_DS_TAGL_BIT {
836 	TX_DS	= 0x0fff, /* Data size */
837 	TX_TAGL	= 0xf000, /* Frame tag LSBs */
838 };
839 
840 enum DIE_DT {
841 	/* Frame data */
842 	DT_FSINGLE	= 0x80,
843 	DT_FSTART	= 0x90,
844 	DT_FMID		= 0xa0,
845 	DT_FEND		= 0xb0,
846 
847 	/* Chain control */
848 	DT_LEMPTY	= 0xc0,
849 	DT_EEMPTY	= 0xd0,
850 	DT_LINKFIX	= 0x00,
851 	DT_LINK		= 0xe0,
852 	DT_EOS		= 0xf0,
853 	/* HW/SW arbitration */
854 	DT_FEMPTY	= 0x40,
855 	DT_FEMPTY_IS	= 0x10,
856 	DT_FEMPTY_IC	= 0x20,
857 	DT_FEMPTY_ND	= 0x30,
858 	DT_FEMPTY_START	= 0x50,
859 	DT_FEMPTY_MID	= 0x60,
860 	DT_FEMPTY_END	= 0x70,
861 
862 	DT_MASK		= 0xf0,
863 	DIE		= 0x08,	/* Descriptor Interrupt Enable */
864 };
865 
866 /* Both transmission and reception */
867 #define INFO1_FMT		BIT(2)
868 #define INFO1_TXC		BIT(3)
869 
870 /* For transmission */
871 #define INFO1_TSUN(val)		((u64)(val) << 8ULL)
872 #define INFO1_IPV(prio)		((u64)(prio) << 28ULL)
873 #define INFO1_CSD0(index)	((u64)(index) << 32ULL)
874 #define INFO1_CSD1(index)	((u64)(index) << 40ULL)
875 #define INFO1_DV(port_vector)	((u64)(port_vector) << 48ULL)
876 
877 /* For reception */
878 #define INFO1_SPN(port)		((u64)(port) << 36ULL)
879 
880 /* For timestamp descriptor in dptrl (Byte 4 to 7) */
881 #define TS_DESC_TSUN(dptrl)	((dptrl) & GENMASK(7, 0))
882 #define TS_DESC_SPN(dptrl)	(((dptrl) & GENMASK(10, 8)) >> 8)
883 #define TS_DESC_DPN(dptrl)	(((dptrl) & GENMASK(17, 16)) >> 16)
884 #define TS_DESC_TN(dptrl)	((dptrl) & BIT(24))
885 
886 struct rswitch_desc {
887 	__le16 info_ds;	/* Descriptor size */
888 	u8 die_dt;	/* Descriptor interrupt enable and type */
889 	__u8  dptrh;	/* Descriptor pointer MSB */
890 	__le32 dptrl;	/* Descriptor pointer LSW */
891 } __packed;
892 
893 struct rswitch_ts_desc {
894 	struct rswitch_desc desc;
895 	__le32 ts_nsec;
896 	__le32 ts_sec;
897 } __packed;
898 
899 struct rswitch_ext_desc {
900 	struct rswitch_desc desc;
901 	__le64 info1;
902 } __packed;
903 
904 struct rswitch_ext_ts_desc {
905 	struct rswitch_desc desc;
906 	__le64 info1;
907 	__le32 ts_nsec;
908 	__le32 ts_sec;
909 } __packed;
910 
911 struct rswitch_etha {
912 	int index;
913 	void __iomem *addr;
914 	void __iomem *coma_addr;
915 	bool external_phy;
916 	struct mii_bus *mii;
917 	phy_interface_t phy_interface;
918 	u8 mac_addr[MAX_ADDR_LEN];
919 	int link;
920 	int speed;
921 
922 	/* This hardware could not be initialized twice so that marked
923 	 * this flag to avoid multiple initialization.
924 	 */
925 	bool operated;
926 };
927 
928 /* The datasheet said descriptor "chain" and/or "queue". For consistency of
929  * name, this driver calls "queue".
930  */
931 struct rswitch_gwca_queue {
932 	union {
933 		struct rswitch_ext_desc *tx_ring;
934 		struct rswitch_ext_ts_desc *rx_ring;
935 		struct rswitch_ts_desc *ts_ring;
936 	};
937 
938 	/* Common */
939 	dma_addr_t ring_dma;
940 	int ring_size;
941 	int cur;
942 	int dirty;
943 
944 	/* For [rt]_ring */
945 	int index;
946 	bool dir_tx;
947 	struct sk_buff **skbs;
948 	struct net_device *ndev;	/* queue to ndev for irq */
949 };
950 
951 struct rswitch_gwca_ts_info {
952 	struct sk_buff *skb;
953 	struct list_head list;
954 
955 	int port;
956 	u8 tag;
957 };
958 
959 #define RSWITCH_NUM_IRQ_REGS	(RSWITCH_MAX_NUM_QUEUES / BITS_PER_TYPE(u32))
960 struct rswitch_gwca {
961 	int index;
962 	struct rswitch_desc *linkfix_table;
963 	dma_addr_t linkfix_table_dma;
964 	u32 linkfix_table_size;
965 	struct rswitch_gwca_queue *queues;
966 	int num_queues;
967 	struct rswitch_gwca_queue ts_queue;
968 	struct list_head ts_info_list;
969 	DECLARE_BITMAP(used, RSWITCH_MAX_NUM_QUEUES);
970 	u32 tx_irq_bits[RSWITCH_NUM_IRQ_REGS];
971 	u32 rx_irq_bits[RSWITCH_NUM_IRQ_REGS];
972 	int speed;
973 };
974 
975 #define NUM_QUEUES_PER_NDEV	2
976 struct rswitch_device {
977 	struct rswitch_private *priv;
978 	struct net_device *ndev;
979 	struct napi_struct napi;
980 	void __iomem *addr;
981 	struct rswitch_gwca_queue *tx_queue;
982 	struct rswitch_gwca_queue *rx_queue;
983 	u8 ts_tag;
984 	bool disabled;
985 
986 	int port;
987 	struct rswitch_etha *etha;
988 	struct device_node *np_port;
989 	struct phy *serdes;
990 };
991 
992 struct rswitch_mfwd_mac_table_entry {
993 	int queue_index;
994 	unsigned char addr[MAX_ADDR_LEN];
995 };
996 
997 struct rswitch_mfwd {
998 	struct rswitch_mac_table_entry *mac_table_entries;
999 	int num_mac_table_entries;
1000 };
1001 
1002 struct rswitch_private {
1003 	struct platform_device *pdev;
1004 	void __iomem *addr;
1005 	struct rcar_gen4_ptp_private *ptp_priv;
1006 
1007 	struct rswitch_device *rdev[RSWITCH_NUM_PORTS];
1008 	DECLARE_BITMAP(opened_ports, RSWITCH_NUM_PORTS);
1009 
1010 	struct rswitch_gwca gwca;
1011 	struct rswitch_etha etha[RSWITCH_NUM_PORTS];
1012 	struct rswitch_mfwd mfwd;
1013 
1014 	spinlock_t lock;	/* lock interrupt registers' control */
1015 
1016 	bool etha_no_runtime_change;
1017 	bool gwca_halt;
1018 };
1019 
1020 #endif	/* #ifndef __RSWITCH_H__ */
1021