xref: /openbmc/u-boot/drivers/net/sh_eth.h (revision ba6d4b64)
1 /*
2  * sh_eth.h - Driver for Renesas SuperH ethernet controler.
3  *
4  * Copyright (C) 2008 - 2012 Renesas Solutions Corp.
5  * Copyright (c) 2008 - 2012 Nobuhiro Iwamatsu
6  * Copyright (c) 2007 Carlos Munoz <carlos@kenati.com>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  *  it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21  */
22 
23 #include <netdev.h>
24 #include <asm/types.h>
25 
26 #define SHETHER_NAME "sh_eth"
27 
28 #if defined(CONFIG_SH)
29 /* Malloc returns addresses in the P1 area (cacheable). However we need to
30    use area P2 (non-cacheable) */
31 #define ADDR_TO_P2(addr)	((((int)(addr) & ~0xe0000000) | 0xa0000000))
32 
33 /* The ethernet controller needs to use physical addresses */
34 #if defined(CONFIG_SH_32BIT)
35 #define ADDR_TO_PHY(addr)	((((int)(addr) & ~0xe0000000) | 0x40000000))
36 #else
37 #define ADDR_TO_PHY(addr)	((int)(addr) & ~0xe0000000)
38 #endif
39 #elif defined(CONFIG_ARM)
40 #define inl		readl
41 #define outl	writel
42 #define ADDR_TO_PHY(addr)	((int)(addr))
43 #define ADDR_TO_P2(addr)	(addr)
44 #endif /* defined(CONFIG_SH) */
45 
46 /* Number of supported ports */
47 #define MAX_PORT_NUM	2
48 
49 /* Buffers must be big enough to hold the largest ethernet frame. Also, rx
50    buffers must be a multiple of 32 bytes */
51 #define MAX_BUF_SIZE	(48 * 32)
52 
53 /* The number of tx descriptors must be large enough to point to 5 or more
54    frames. If each frame uses 2 descriptors, at least 10 descriptors are needed.
55    We use one descriptor per frame */
56 #define NUM_TX_DESC		8
57 
58 /* The size of the tx descriptor is determined by how much padding is used.
59    4, 20, or 52 bytes of padding can be used */
60 #define TX_DESC_PADDING		4
61 #define TX_DESC_SIZE		(12 + TX_DESC_PADDING)
62 
63 /* Tx descriptor. We always use 3 bytes of padding */
64 struct tx_desc_s {
65 	volatile u32 td0;
66 	u32 td1;
67 	u32 td2;		/* Buffer start */
68 	u32 padding;
69 };
70 
71 /* There is no limitation in the number of rx descriptors */
72 #define NUM_RX_DESC	8
73 
74 /* The size of the rx descriptor is determined by how much padding is used.
75    4, 20, or 52 bytes of padding can be used */
76 #define RX_DESC_PADDING		4
77 #define RX_DESC_SIZE		(12 + RX_DESC_PADDING)
78 
79 /* Rx descriptor. We always use 4 bytes of padding */
80 struct rx_desc_s {
81 	volatile u32 rd0;
82 	volatile u32 rd1;
83 	u32 rd2;		/* Buffer start */
84 	u32 padding;
85 };
86 
87 struct sh_eth_info {
88 	struct tx_desc_s *tx_desc_malloc;
89 	struct tx_desc_s *tx_desc_base;
90 	struct tx_desc_s *tx_desc_cur;
91 	struct rx_desc_s *rx_desc_malloc;
92 	struct rx_desc_s *rx_desc_base;
93 	struct rx_desc_s *rx_desc_cur;
94 	u8 *rx_buf_malloc;
95 	u8 *rx_buf_base;
96 	u8 mac_addr[6];
97 	u8 phy_addr;
98 	struct eth_device *dev;
99 	struct phy_device *phydev;
100 };
101 
102 struct sh_eth_dev {
103 	int port;
104 	struct sh_eth_info port_info[MAX_PORT_NUM];
105 };
106 
107 /* from linux/drivers/net/ethernet/renesas/sh_eth.h */
108 enum {
109 	/* E-DMAC registers */
110 	EDSR = 0,
111 	EDMR,
112 	EDTRR,
113 	EDRRR,
114 	EESR,
115 	EESIPR,
116 	TDLAR,
117 	TDFAR,
118 	TDFXR,
119 	TDFFR,
120 	RDLAR,
121 	RDFAR,
122 	RDFXR,
123 	RDFFR,
124 	TRSCER,
125 	RMFCR,
126 	TFTR,
127 	FDR,
128 	RMCR,
129 	EDOCR,
130 	TFUCR,
131 	RFOCR,
132 	FCFTR,
133 	RPADIR,
134 	TRIMD,
135 	RBWAR,
136 	TBRAR,
137 
138 	/* Ether registers */
139 	ECMR,
140 	ECSR,
141 	ECSIPR,
142 	PIR,
143 	PSR,
144 	RDMLR,
145 	PIPR,
146 	RFLR,
147 	IPGR,
148 	APR,
149 	MPR,
150 	PFTCR,
151 	PFRCR,
152 	RFCR,
153 	RFCF,
154 	TPAUSER,
155 	TPAUSECR,
156 	BCFR,
157 	BCFRR,
158 	GECMR,
159 	BCULR,
160 	MAHR,
161 	MALR,
162 	TROCR,
163 	CDCR,
164 	LCCR,
165 	CNDCR,
166 	CEFCR,
167 	FRECR,
168 	TSFRCR,
169 	TLFRCR,
170 	CERCR,
171 	CEECR,
172 	MAFCR,
173 	RTRATE,
174 	CSMR,
175 	RMII_MII,
176 
177 	/* This value must be written at last. */
178 	SH_ETH_MAX_REGISTER_OFFSET,
179 };
180 
181 static const u16 sh_eth_offset_gigabit[SH_ETH_MAX_REGISTER_OFFSET] = {
182 	[EDSR]	= 0x0000,
183 	[EDMR]	= 0x0400,
184 	[EDTRR]	= 0x0408,
185 	[EDRRR]	= 0x0410,
186 	[EESR]	= 0x0428,
187 	[EESIPR]	= 0x0430,
188 	[TDLAR]	= 0x0010,
189 	[TDFAR]	= 0x0014,
190 	[TDFXR]	= 0x0018,
191 	[TDFFR]	= 0x001c,
192 	[RDLAR]	= 0x0030,
193 	[RDFAR]	= 0x0034,
194 	[RDFXR]	= 0x0038,
195 	[RDFFR]	= 0x003c,
196 	[TRSCER]	= 0x0438,
197 	[RMFCR]	= 0x0440,
198 	[TFTR]	= 0x0448,
199 	[FDR]	= 0x0450,
200 	[RMCR]	= 0x0458,
201 	[RPADIR]	= 0x0460,
202 	[FCFTR]	= 0x0468,
203 	[CSMR] = 0x04E4,
204 
205 	[ECMR]	= 0x0500,
206 	[ECSR]	= 0x0510,
207 	[ECSIPR]	= 0x0518,
208 	[PIR]	= 0x0520,
209 	[PSR]	= 0x0528,
210 	[PIPR]	= 0x052c,
211 	[RFLR]	= 0x0508,
212 	[APR]	= 0x0554,
213 	[MPR]	= 0x0558,
214 	[PFTCR]	= 0x055c,
215 	[PFRCR]	= 0x0560,
216 	[TPAUSER]	= 0x0564,
217 	[GECMR]	= 0x05b0,
218 	[BCULR]	= 0x05b4,
219 	[MAHR]	= 0x05c0,
220 	[MALR]	= 0x05c8,
221 	[TROCR]	= 0x0700,
222 	[CDCR]	= 0x0708,
223 	[LCCR]	= 0x0710,
224 	[CEFCR]	= 0x0740,
225 	[FRECR]	= 0x0748,
226 	[TSFRCR]	= 0x0750,
227 	[TLFRCR]	= 0x0758,
228 	[RFCR]	= 0x0760,
229 	[CERCR]	= 0x0768,
230 	[CEECR]	= 0x0770,
231 	[MAFCR]	= 0x0778,
232 	[RMII_MII] =  0x0790,
233 };
234 
235 static const u16 sh_eth_offset_fast_sh4[SH_ETH_MAX_REGISTER_OFFSET] = {
236 	[ECMR]	= 0x0100,
237 	[RFLR]	= 0x0108,
238 	[ECSR]	= 0x0110,
239 	[ECSIPR]	= 0x0118,
240 	[PIR]	= 0x0120,
241 	[PSR]	= 0x0128,
242 	[RDMLR]	= 0x0140,
243 	[IPGR]	= 0x0150,
244 	[APR]	= 0x0154,
245 	[MPR]	= 0x0158,
246 	[TPAUSER]	= 0x0164,
247 	[RFCF]	= 0x0160,
248 	[TPAUSECR]	= 0x0168,
249 	[BCFRR]	= 0x016c,
250 	[MAHR]	= 0x01c0,
251 	[MALR]	= 0x01c8,
252 	[TROCR]	= 0x01d0,
253 	[CDCR]	= 0x01d4,
254 	[LCCR]	= 0x01d8,
255 	[CNDCR]	= 0x01dc,
256 	[CEFCR]	= 0x01e4,
257 	[FRECR]	= 0x01e8,
258 	[TSFRCR]	= 0x01ec,
259 	[TLFRCR]	= 0x01f0,
260 	[RFCR]	= 0x01f4,
261 	[MAFCR]	= 0x01f8,
262 	[RTRATE]	= 0x01fc,
263 
264 	[EDMR]	= 0x0000,
265 	[EDTRR]	= 0x0008,
266 	[EDRRR]	= 0x0010,
267 	[TDLAR]	= 0x0018,
268 	[RDLAR]	= 0x0020,
269 	[EESR]	= 0x0028,
270 	[EESIPR]	= 0x0030,
271 	[TRSCER]	= 0x0038,
272 	[RMFCR]	= 0x0040,
273 	[TFTR]	= 0x0048,
274 	[FDR]	= 0x0050,
275 	[RMCR]	= 0x0058,
276 	[TFUCR]	= 0x0064,
277 	[RFOCR]	= 0x0068,
278 	[FCFTR]	= 0x0070,
279 	[RPADIR]	= 0x0078,
280 	[TRIMD]	= 0x007c,
281 	[RBWAR]	= 0x00c8,
282 	[RDFAR]	= 0x00cc,
283 	[TBRAR]	= 0x00d4,
284 	[TDFAR]	= 0x00d8,
285 };
286 
287 /* Register Address */
288 #if defined(CONFIG_CPU_SH7763) || defined(CONFIG_CPU_SH7734)
289 #define SH_ETH_TYPE_GETHER
290 #define BASE_IO_ADDR	0xfee00000
291 #elif defined(CONFIG_CPU_SH7757) || defined(CONFIG_CPU_SH7752)
292 #if defined(CONFIG_SH_ETHER_USE_GETHER)
293 #define SH_ETH_TYPE_GETHER
294 #define BASE_IO_ADDR	0xfee00000
295 #else
296 #define SH_ETH_TYPE_ETHER
297 #define BASE_IO_ADDR	0xfef00000
298 #endif
299 #elif defined(CONFIG_CPU_SH7724)
300 #define SH_ETH_TYPE_ETHER
301 #define BASE_IO_ADDR	0xA4600000
302 #elif defined(CONFIG_R8A7740)
303 #define SH_ETH_TYPE_GETHER
304 #define BASE_IO_ADDR	0xE9A00000
305 #endif
306 
307 /*
308  * Register's bits
309  * Copy from Linux driver source code
310  */
311 #if defined(SH_ETH_TYPE_GETHER)
312 /* EDSR */
313 enum EDSR_BIT {
314 	EDSR_ENT = 0x01, EDSR_ENR = 0x02,
315 };
316 #define EDSR_ENALL (EDSR_ENT|EDSR_ENR)
317 #endif
318 
319 /* EDMR */
320 enum DMAC_M_BIT {
321 	EDMR_DL1 = 0x20, EDMR_DL0 = 0x10,
322 #if defined(SH_ETH_TYPE_GETHER)
323 	EDMR_SRST	= 0x03, /* Receive/Send reset */
324 	EMDR_DESC_R	= 0x30, /* Descriptor reserve size */
325 	EDMR_EL		= 0x40, /* Litte endian */
326 #elif defined(SH_ETH_TYPE_ETHER)
327 	EDMR_SRST	= 0x01,
328 	EMDR_DESC_R	= 0x30, /* Descriptor reserve size */
329 	EDMR_EL		= 0x40, /* Litte endian */
330 #else
331 	EDMR_SRST = 0x01,
332 #endif
333 };
334 
335 /* RFLR */
336 #define RFLR_RFL_MIN	0x05EE	/* Recv Frame length 1518 byte */
337 
338 /* EDTRR */
339 enum DMAC_T_BIT {
340 #if defined(SH_ETH_TYPE_GETHER)
341 	EDTRR_TRNS = 0x03,
342 #else
343 	EDTRR_TRNS = 0x01,
344 #endif
345 };
346 
347 /* GECMR */
348 enum GECMR_BIT {
349 #if defined(CONFIG_CPU_SH7757) || defined(CONFIG_CPU_SH7752)
350 	GECMR_1000B = 0x20, GECMR_100B = 0x01, GECMR_10B = 0x00,
351 #else
352 	GECMR_1000B = 0x01, GECMR_100B = 0x04, GECMR_10B = 0x00,
353 #endif
354 };
355 
356 /* EDRRR*/
357 enum EDRRR_R_BIT {
358 	EDRRR_R = 0x01,
359 };
360 
361 /* TPAUSER */
362 enum TPAUSER_BIT {
363 	TPAUSER_TPAUSE = 0x0000ffff,
364 	TPAUSER_UNLIMITED = 0,
365 };
366 
367 /* BCFR */
368 enum BCFR_BIT {
369 	BCFR_RPAUSE = 0x0000ffff,
370 	BCFR_UNLIMITED = 0,
371 };
372 
373 /* PIR */
374 enum PIR_BIT {
375 	PIR_MDI = 0x08, PIR_MDO = 0x04, PIR_MMD = 0x02, PIR_MDC = 0x01,
376 };
377 
378 /* PSR */
379 enum PHY_STATUS_BIT { PHY_ST_LINK = 0x01, };
380 
381 /* EESR */
382 enum EESR_BIT {
383 
384 #if defined(SH_ETH_TYPE_ETHER)
385 	EESR_TWB  = 0x40000000,
386 #else
387 	EESR_TWB  = 0xC0000000,
388 	EESR_TC1  = 0x20000000,
389 	EESR_TUC  = 0x10000000,
390 	EESR_ROC  = 0x80000000,
391 #endif
392 	EESR_TABT = 0x04000000,
393 	EESR_RABT = 0x02000000, EESR_RFRMER = 0x01000000,
394 #if defined(SH_ETH_TYPE_ETHER)
395 	EESR_ADE  = 0x00800000,
396 #endif
397 	EESR_ECI  = 0x00400000,
398 	EESR_FTC  = 0x00200000, EESR_TDE  = 0x00100000,
399 	EESR_TFE  = 0x00080000, EESR_FRC  = 0x00040000,
400 	EESR_RDE  = 0x00020000, EESR_RFE  = 0x00010000,
401 #if defined(SH_ETH_TYPE_ETHER)
402 	EESR_CND  = 0x00000800,
403 #endif
404 	EESR_DLC  = 0x00000400,
405 	EESR_CD   = 0x00000200, EESR_RTO  = 0x00000100,
406 	EESR_RMAF = 0x00000080, EESR_CEEF = 0x00000040,
407 	EESR_CELF = 0x00000020, EESR_RRF  = 0x00000010,
408 	rESR_RTLF = 0x00000008, EESR_RTSF = 0x00000004,
409 	EESR_PRE  = 0x00000002, EESR_CERF = 0x00000001,
410 };
411 
412 
413 #if defined(SH_ETH_TYPE_GETHER)
414 # define TX_CHECK (EESR_TC1 | EESR_FTC)
415 # define EESR_ERR_CHECK	(EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE \
416 		| EESR_RFRMER | EESR_TFE | EESR_TDE | EESR_ECI)
417 # define TX_ERROR_CEHCK (EESR_TWB | EESR_TABT | EESR_TDE | EESR_TFE)
418 
419 #else
420 # define TX_CHECK (EESR_FTC | EESR_CND | EESR_DLC | EESR_CD | EESR_RTO)
421 # define EESR_ERR_CHECK	(EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE \
422 		| EESR_RFRMER | EESR_ADE | EESR_TFE | EESR_TDE | EESR_ECI)
423 # define TX_ERROR_CEHCK (EESR_TWB | EESR_TABT | EESR_ADE | EESR_TDE | EESR_TFE)
424 #endif
425 
426 /* EESIPR */
427 enum DMAC_IM_BIT {
428 	DMAC_M_TWB = 0x40000000, DMAC_M_TABT = 0x04000000,
429 	DMAC_M_RABT = 0x02000000,
430 	DMAC_M_RFRMER = 0x01000000, DMAC_M_ADF = 0x00800000,
431 	DMAC_M_ECI = 0x00400000, DMAC_M_FTC = 0x00200000,
432 	DMAC_M_TDE = 0x00100000, DMAC_M_TFE = 0x00080000,
433 	DMAC_M_FRC = 0x00040000, DMAC_M_RDE = 0x00020000,
434 	DMAC_M_RFE = 0x00010000, DMAC_M_TINT4 = 0x00000800,
435 	DMAC_M_TINT3 = 0x00000400, DMAC_M_TINT2 = 0x00000200,
436 	DMAC_M_TINT1 = 0x00000100, DMAC_M_RINT8 = 0x00000080,
437 	DMAC_M_RINT5 = 0x00000010, DMAC_M_RINT4 = 0x00000008,
438 	DMAC_M_RINT3 = 0x00000004, DMAC_M_RINT2 = 0x00000002,
439 	DMAC_M_RINT1 = 0x00000001,
440 };
441 
442 /* Receive descriptor bit */
443 enum RD_STS_BIT {
444 	RD_RACT = 0x80000000, RD_RDLE = 0x40000000,
445 	RD_RFP1 = 0x20000000, RD_RFP0 = 0x10000000,
446 	RD_RFE = 0x08000000, RD_RFS10 = 0x00000200,
447 	RD_RFS9 = 0x00000100, RD_RFS8 = 0x00000080,
448 	RD_RFS7 = 0x00000040, RD_RFS6 = 0x00000020,
449 	RD_RFS5 = 0x00000010, RD_RFS4 = 0x00000008,
450 	RD_RFS3 = 0x00000004, RD_RFS2 = 0x00000002,
451 	RD_RFS1 = 0x00000001,
452 };
453 #define RDF1ST	RD_RFP1
454 #define RDFEND	RD_RFP0
455 #define RD_RFP	(RD_RFP1|RD_RFP0)
456 
457 /* RDFFR*/
458 enum RDFFR_BIT {
459 	RDFFR_RDLF = 0x01,
460 };
461 
462 /* FCFTR */
463 enum FCFTR_BIT {
464 	FCFTR_RFF2 = 0x00040000, FCFTR_RFF1 = 0x00020000,
465 	FCFTR_RFF0 = 0x00010000, FCFTR_RFD2 = 0x00000004,
466 	FCFTR_RFD1 = 0x00000002, FCFTR_RFD0 = 0x00000001,
467 };
468 #define FIFO_F_D_RFF	(FCFTR_RFF2|FCFTR_RFF1|FCFTR_RFF0)
469 #define FIFO_F_D_RFD	(FCFTR_RFD2|FCFTR_RFD1|FCFTR_RFD0)
470 
471 /* Transfer descriptor bit */
472 enum TD_STS_BIT {
473 #if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_ETHER)
474 	TD_TACT = 0x80000000,
475 #else
476 	TD_TACT = 0x7fffffff,
477 #endif
478 	TD_TDLE = 0x40000000, TD_TFP1 = 0x20000000,
479 	TD_TFP0 = 0x10000000,
480 };
481 #define TDF1ST	TD_TFP1
482 #define TDFEND	TD_TFP0
483 #define TD_TFP	(TD_TFP1|TD_TFP0)
484 
485 /* RMCR */
486 enum RECV_RST_BIT { RMCR_RST = 0x01, };
487 /* ECMR */
488 enum FELIC_MODE_BIT {
489 #if defined(SH_ETH_TYPE_GETHER)
490 	ECMR_TRCCM=0x04000000, ECMR_RCSC= 0x00800000, ECMR_DPAD= 0x00200000,
491 	ECMR_RZPF = 0x00100000,
492 #endif
493 	ECMR_ZPF = 0x00080000, ECMR_PFR = 0x00040000, ECMR_RXF = 0x00020000,
494 	ECMR_TXF = 0x00010000, ECMR_MCT = 0x00002000, ECMR_PRCEF = 0x00001000,
495 	ECMR_PMDE = 0x00000200, ECMR_RE = 0x00000040, ECMR_TE = 0x00000020,
496 	ECMR_ILB = 0x00000008, ECMR_ELB = 0x00000004, ECMR_DM = 0x00000002,
497 	ECMR_PRM = 0x00000001,
498 #ifdef CONFIG_CPU_SH7724
499 	ECMR_RTM = 0x00000010,
500 #endif
501 
502 };
503 
504 #if defined(SH_ETH_TYPE_GETHER)
505 #define ECMR_CHG_DM	(ECMR_TRCCM | ECMR_RZPF | ECMR_ZPF | ECMR_PFR | ECMR_RXF | \
506 						ECMR_TXF | ECMR_MCT)
507 #elif defined(SH_ETH_TYPE_ETHER)
508 #define ECMR_CHG_DM (ECMR_ZPF | ECMR_PFR | ECMR_RXF | ECMR_TXF)
509 #else
510 #define ECMR_CHG_DM	(ECMR_ZPF | ECMR_PFR | ECMR_RXF | ECMR_TXF | ECMR_MCT)
511 #endif
512 
513 /* ECSR */
514 enum ECSR_STATUS_BIT {
515 #if defined(SH_ETH_TYPE_ETHER)
516 	ECSR_BRCRX = 0x20, ECSR_PSRTO = 0x10,
517 #endif
518 	ECSR_LCHNG = 0x04,
519 	ECSR_MPD = 0x02, ECSR_ICD = 0x01,
520 };
521 
522 #if defined(SH_ETH_TYPE_GETHER)
523 # define ECSR_INIT (ECSR_ICD | ECSIPR_MPDIP)
524 #else
525 # define ECSR_INIT (ECSR_BRCRX | ECSR_PSRTO | \
526 			ECSR_LCHNG | ECSR_ICD | ECSIPR_MPDIP)
527 #endif
528 
529 /* ECSIPR */
530 enum ECSIPR_STATUS_MASK_BIT {
531 #if defined(SH_ETH_TYPE_ETHER)
532 	ECSIPR_BRCRXIP = 0x20,
533 	ECSIPR_PSRTOIP = 0x10,
534 #elif defined(SH_ETY_TYPE_GETHER)
535 	ECSIPR_PSRTOIP = 0x10,
536 	ECSIPR_PHYIP = 0x08,
537 #endif
538 	ECSIPR_LCHNGIP = 0x04,
539 	ECSIPR_MPDIP = 0x02,
540 	ECSIPR_ICDIP = 0x01,
541 };
542 
543 #if defined(SH_ETH_TYPE_GETHER)
544 # define ECSIPR_INIT (ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP)
545 #else
546 # define ECSIPR_INIT (ECSIPR_BRCRXIP | ECSIPR_PSRTOIP | ECSIPR_LCHNGIP | \
547 				ECSIPR_ICDIP | ECSIPR_MPDIP)
548 #endif
549 
550 /* APR */
551 enum APR_BIT {
552 	APR_AP = 0x00000004,
553 };
554 
555 /* MPR */
556 enum MPR_BIT {
557 	MPR_MP = 0x00000006,
558 };
559 
560 /* TRSCER */
561 enum DESC_I_BIT {
562 	DESC_I_TINT4 = 0x0800, DESC_I_TINT3 = 0x0400, DESC_I_TINT2 = 0x0200,
563 	DESC_I_TINT1 = 0x0100, DESC_I_RINT8 = 0x0080, DESC_I_RINT5 = 0x0010,
564 	DESC_I_RINT4 = 0x0008, DESC_I_RINT3 = 0x0004, DESC_I_RINT2 = 0x0002,
565 	DESC_I_RINT1 = 0x0001,
566 };
567 
568 /* RPADIR */
569 enum RPADIR_BIT {
570 	RPADIR_PADS1 = 0x20000, RPADIR_PADS0 = 0x10000,
571 	RPADIR_PADR = 0x0003f,
572 };
573 
574 #if defined(SH_ETH_TYPE_GETHER)
575 # define RPADIR_INIT (0x00)
576 #else
577 # define RPADIR_INIT (RPADIR_PADS1)
578 #endif
579 
580 /* FDR */
581 enum FIFO_SIZE_BIT {
582 	FIFO_SIZE_T = 0x00000700, FIFO_SIZE_R = 0x00000007,
583 };
584 
585 static inline unsigned long sh_eth_reg_addr(struct sh_eth_dev *eth,
586 					    int enum_index)
587 {
588 #if defined(SH_ETH_TYPE_GETHER)
589 	const u16 *reg_offset = sh_eth_offset_gigabit;
590 #elif defined(SH_ETH_TYPE_ETHER)
591 	const u16 *reg_offset = sh_eth_offset_fast_sh4;
592 #else
593 #error
594 #endif
595 	return BASE_IO_ADDR + reg_offset[enum_index] + 0x800 * eth->port;
596 }
597 
598 static inline void sh_eth_write(struct sh_eth_dev *eth, unsigned long data,
599 				int enum_index)
600 {
601 	outl(data, sh_eth_reg_addr(eth, enum_index));
602 }
603 
604 static inline unsigned long sh_eth_read(struct sh_eth_dev *eth,
605 					int enum_index)
606 {
607 	return inl(sh_eth_reg_addr(eth, enum_index));
608 }
609