blob: e325a39aac04fdecf919cdf8918a40776de2d874 [file] [log] [blame]
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +09001/*
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +09002 * sh_eth.h - Driver for Renesas SuperH ethernet controler.
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +09003 *
Nobuhiro Iwamatsu4ad2c2a2012-08-02 22:08:40 +00004 * Copyright (C) 2008 - 2012 Renesas Solutions Corp.
5 * Copyright (c) 2008 - 2012 Nobuhiro Iwamatsu
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +09006 * Copyright (c) 2007 Carlos Munoz <carlos@kenati.com>
7 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +09009 */
10
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090011#include <netdev.h>
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090012#include <asm/types.h>
13
14#define SHETHER_NAME "sh_eth"
15
Nobuhiro Iwamatsu4ad2c2a2012-08-02 22:08:40 +000016#if defined(CONFIG_SH)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090017/* Malloc returns addresses in the P1 area (cacheable). However we need to
18 use area P2 (non-cacheable) */
19#define ADDR_TO_P2(addr) ((((int)(addr) & ~0xe0000000) | 0xa0000000))
20
21/* The ethernet controller needs to use physical addresses */
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +090022#if defined(CONFIG_SH_32BIT)
23#define ADDR_TO_PHY(addr) ((((int)(addr) & ~0xe0000000) | 0x40000000))
24#else
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090025#define ADDR_TO_PHY(addr) ((int)(addr) & ~0xe0000000)
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +090026#endif
Nobuhiro Iwamatsu4ad2c2a2012-08-02 22:08:40 +000027#elif defined(CONFIG_ARM)
28#define inl readl
29#define outl writel
30#define ADDR_TO_PHY(addr) ((int)(addr))
31#define ADDR_TO_P2(addr) (addr)
32#endif /* defined(CONFIG_SH) */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090033
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090034/* base padding size is 16 */
35#ifndef CONFIG_SH_ETHER_ALIGNE_SIZE
36#define CONFIG_SH_ETHER_ALIGNE_SIZE 16
37#endif
38
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090039/* Number of supported ports */
40#define MAX_PORT_NUM 2
41
42/* Buffers must be big enough to hold the largest ethernet frame. Also, rx
43 buffers must be a multiple of 32 bytes */
44#define MAX_BUF_SIZE (48 * 32)
45
46/* The number of tx descriptors must be large enough to point to 5 or more
47 frames. If each frame uses 2 descriptors, at least 10 descriptors are needed.
48 We use one descriptor per frame */
49#define NUM_TX_DESC 8
50
51/* The size of the tx descriptor is determined by how much padding is used.
52 4, 20, or 52 bytes of padding can be used */
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090053#define TX_DESC_PADDING (CONFIG_SH_ETHER_ALIGNE_SIZE - 12)
54/* same as CONFIG_SH_ETHER_ALIGNE_SIZE */
55#define TX_DESC_SIZE (12 + TX_DESC_PADDING)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090056
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090057/* Tx descriptor. We always use 3 bytes of padding */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090058struct tx_desc_s {
59 volatile u32 td0;
60 u32 td1;
61 u32 td2; /* Buffer start */
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090062 u8 padding[TX_DESC_PADDING]; /* aligned cache line size */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090063};
64
65/* There is no limitation in the number of rx descriptors */
66#define NUM_RX_DESC 8
67
68/* The size of the rx descriptor is determined by how much padding is used.
69 4, 20, or 52 bytes of padding can be used */
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090070#define RX_DESC_PADDING (CONFIG_SH_ETHER_ALIGNE_SIZE - 12)
71/* same as CONFIG_SH_ETHER_ALIGNE_SIZE */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090072#define RX_DESC_SIZE (12 + RX_DESC_PADDING)
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090073/* aligned cache line size */
74#define RX_BUF_ALIGNE_SIZE (CONFIG_SH_ETHER_ALIGNE_SIZE > 32 ? 64 : 32)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090075
76/* Rx descriptor. We always use 4 bytes of padding */
77struct rx_desc_s {
78 volatile u32 rd0;
79 volatile u32 rd1;
80 u32 rd2; /* Buffer start */
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +090081 u8 padding[TX_DESC_PADDING]; /* aligned cache line size */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090082};
83
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090084struct sh_eth_info {
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090085 struct tx_desc_s *tx_desc_malloc;
86 struct tx_desc_s *tx_desc_base;
87 struct tx_desc_s *tx_desc_cur;
88 struct rx_desc_s *rx_desc_malloc;
89 struct rx_desc_s *rx_desc_base;
90 struct rx_desc_s *rx_desc_cur;
91 u8 *rx_buf_malloc;
92 u8 *rx_buf_base;
93 u8 mac_addr[6];
94 u8 phy_addr;
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090095 struct eth_device *dev;
Yoshihiro Shimoda677f6cd2011-10-11 18:10:14 +090096 struct phy_device *phydev;
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +090097};
98
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +090099struct sh_eth_dev {
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900100 int port;
Nobuhiro Iwamatsud8f5d502008-11-21 12:04:18 +0900101 struct sh_eth_info port_info[MAX_PORT_NUM];
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900102};
103
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000104/* from linux/drivers/net/ethernet/renesas/sh_eth.h */
105enum {
106 /* E-DMAC registers */
107 EDSR = 0,
108 EDMR,
109 EDTRR,
110 EDRRR,
111 EESR,
112 EESIPR,
113 TDLAR,
114 TDFAR,
115 TDFXR,
116 TDFFR,
117 RDLAR,
118 RDFAR,
119 RDFXR,
120 RDFFR,
121 TRSCER,
122 RMFCR,
123 TFTR,
124 FDR,
125 RMCR,
126 EDOCR,
127 TFUCR,
128 RFOCR,
129 FCFTR,
130 RPADIR,
131 TRIMD,
132 RBWAR,
133 TBRAR,
134
135 /* Ether registers */
136 ECMR,
137 ECSR,
138 ECSIPR,
139 PIR,
140 PSR,
141 RDMLR,
142 PIPR,
143 RFLR,
144 IPGR,
145 APR,
146 MPR,
147 PFTCR,
148 PFRCR,
149 RFCR,
150 RFCF,
151 TPAUSER,
152 TPAUSECR,
153 BCFR,
154 BCFRR,
155 GECMR,
156 BCULR,
157 MAHR,
158 MALR,
159 TROCR,
160 CDCR,
161 LCCR,
162 CNDCR,
163 CEFCR,
164 FRECR,
165 TSFRCR,
166 TLFRCR,
167 CERCR,
168 CEECR,
Nobuhiro Iwamatsu72befd32013-08-22 13:22:04 +0900169 RMIIMR, /* R8A7790 */
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000170 MAFCR,
171 RTRATE,
172 CSMR,
173 RMII_MII,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900174
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000175 /* This value must be written at last. */
176 SH_ETH_MAX_REGISTER_OFFSET,
177};
178
179static const u16 sh_eth_offset_gigabit[SH_ETH_MAX_REGISTER_OFFSET] = {
180 [EDSR] = 0x0000,
181 [EDMR] = 0x0400,
182 [EDTRR] = 0x0408,
183 [EDRRR] = 0x0410,
184 [EESR] = 0x0428,
185 [EESIPR] = 0x0430,
186 [TDLAR] = 0x0010,
187 [TDFAR] = 0x0014,
188 [TDFXR] = 0x0018,
189 [TDFFR] = 0x001c,
190 [RDLAR] = 0x0030,
191 [RDFAR] = 0x0034,
192 [RDFXR] = 0x0038,
193 [RDFFR] = 0x003c,
194 [TRSCER] = 0x0438,
195 [RMFCR] = 0x0440,
196 [TFTR] = 0x0448,
197 [FDR] = 0x0450,
198 [RMCR] = 0x0458,
199 [RPADIR] = 0x0460,
200 [FCFTR] = 0x0468,
201 [CSMR] = 0x04E4,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900202
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000203 [ECMR] = 0x0500,
204 [ECSR] = 0x0510,
205 [ECSIPR] = 0x0518,
206 [PIR] = 0x0520,
207 [PSR] = 0x0528,
208 [PIPR] = 0x052c,
209 [RFLR] = 0x0508,
210 [APR] = 0x0554,
211 [MPR] = 0x0558,
212 [PFTCR] = 0x055c,
213 [PFRCR] = 0x0560,
214 [TPAUSER] = 0x0564,
215 [GECMR] = 0x05b0,
216 [BCULR] = 0x05b4,
217 [MAHR] = 0x05c0,
218 [MALR] = 0x05c8,
219 [TROCR] = 0x0700,
220 [CDCR] = 0x0708,
221 [LCCR] = 0x0710,
222 [CEFCR] = 0x0740,
223 [FRECR] = 0x0748,
224 [TSFRCR] = 0x0750,
225 [TLFRCR] = 0x0758,
226 [RFCR] = 0x0760,
227 [CERCR] = 0x0768,
228 [CEECR] = 0x0770,
229 [MAFCR] = 0x0778,
230 [RMII_MII] = 0x0790,
231};
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900232
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900233#if defined(SH_ETH_TYPE_RZ)
234static const u16 sh_eth_offset_rz[SH_ETH_MAX_REGISTER_OFFSET] = {
235 [EDSR] = 0x0000,
236 [EDMR] = 0x0400,
237 [EDTRR] = 0x0408,
238 [EDRRR] = 0x0410,
239 [EESR] = 0x0428,
240 [EESIPR] = 0x0430,
241 [TDLAR] = 0x0010,
242 [TDFAR] = 0x0014,
243 [TDFXR] = 0x0018,
244 [TDFFR] = 0x001c,
245 [RDLAR] = 0x0030,
246 [RDFAR] = 0x0034,
247 [RDFXR] = 0x0038,
248 [RDFFR] = 0x003c,
249 [TRSCER] = 0x0438,
250 [RMFCR] = 0x0440,
251 [TFTR] = 0x0448,
252 [FDR] = 0x0450,
253 [RMCR] = 0x0458,
254 [RPADIR] = 0x0460,
255 [FCFTR] = 0x0468,
256 [CSMR] = 0x04E4,
257
258 [ECMR] = 0x0500,
259 [ECSR] = 0x0510,
260 [ECSIPR] = 0x0518,
261 [PSR] = 0x0528,
262 [PIPR] = 0x052c,
263 [RFLR] = 0x0508,
264 [APR] = 0x0554,
265 [MPR] = 0x0558,
266 [PFTCR] = 0x055c,
267 [PFRCR] = 0x0560,
268 [TPAUSER] = 0x0564,
269 [GECMR] = 0x05b0,
270 [BCULR] = 0x05b4,
271 [MAHR] = 0x05c0,
272 [MALR] = 0x05c8,
273 [TROCR] = 0x0700,
274 [CDCR] = 0x0708,
275 [LCCR] = 0x0710,
276 [CEFCR] = 0x0740,
277 [FRECR] = 0x0748,
278 [TSFRCR] = 0x0750,
279 [TLFRCR] = 0x0758,
280 [RFCR] = 0x0760,
281 [CERCR] = 0x0768,
282 [CEECR] = 0x0770,
283 [MAFCR] = 0x0778,
284 [RMII_MII] = 0x0790,
285};
286#endif
287
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000288static const u16 sh_eth_offset_fast_sh4[SH_ETH_MAX_REGISTER_OFFSET] = {
289 [ECMR] = 0x0100,
290 [RFLR] = 0x0108,
291 [ECSR] = 0x0110,
292 [ECSIPR] = 0x0118,
293 [PIR] = 0x0120,
294 [PSR] = 0x0128,
295 [RDMLR] = 0x0140,
296 [IPGR] = 0x0150,
297 [APR] = 0x0154,
298 [MPR] = 0x0158,
299 [TPAUSER] = 0x0164,
300 [RFCF] = 0x0160,
301 [TPAUSECR] = 0x0168,
302 [BCFRR] = 0x016c,
303 [MAHR] = 0x01c0,
304 [MALR] = 0x01c8,
305 [TROCR] = 0x01d0,
306 [CDCR] = 0x01d4,
307 [LCCR] = 0x01d8,
308 [CNDCR] = 0x01dc,
309 [CEFCR] = 0x01e4,
310 [FRECR] = 0x01e8,
311 [TSFRCR] = 0x01ec,
312 [TLFRCR] = 0x01f0,
313 [RFCR] = 0x01f4,
314 [MAFCR] = 0x01f8,
315 [RTRATE] = 0x01fc,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900316
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000317 [EDMR] = 0x0000,
318 [EDTRR] = 0x0008,
319 [EDRRR] = 0x0010,
320 [TDLAR] = 0x0018,
321 [RDLAR] = 0x0020,
322 [EESR] = 0x0028,
323 [EESIPR] = 0x0030,
324 [TRSCER] = 0x0038,
325 [RMFCR] = 0x0040,
326 [TFTR] = 0x0048,
327 [FDR] = 0x0050,
328 [RMCR] = 0x0058,
329 [TFUCR] = 0x0064,
330 [RFOCR] = 0x0068,
Nobuhiro Iwamatsu72befd32013-08-22 13:22:04 +0900331 [RMIIMR] = 0x006C,
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000332 [FCFTR] = 0x0070,
333 [RPADIR] = 0x0078,
334 [TRIMD] = 0x007c,
335 [RBWAR] = 0x00c8,
336 [RDFAR] = 0x00cc,
337 [TBRAR] = 0x00d4,
338 [TDFAR] = 0x00d8,
339};
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900340
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000341/* Register Address */
342#if defined(CONFIG_CPU_SH7763) || defined(CONFIG_CPU_SH7734)
343#define SH_ETH_TYPE_GETHER
344#define BASE_IO_ADDR 0xfee00000
Yoshihiro Shimodac5901fb2013-12-18 16:04:04 +0900345#elif defined(CONFIG_CPU_SH7757) || \
346 defined(CONFIG_CPU_SH7752) || \
347 defined(CONFIG_CPU_SH7753)
Yoshihiro Shimoda36944902012-06-26 16:38:11 +0000348#if defined(CONFIG_SH_ETHER_USE_GETHER)
349#define SH_ETH_TYPE_GETHER
350#define BASE_IO_ADDR 0xfee00000
351#else
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000352#define SH_ETH_TYPE_ETHER
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +0900353#define BASE_IO_ADDR 0xfef00000
Yoshihiro Shimoda36944902012-06-26 16:38:11 +0000354#endif
Nobuhiro Iwamatsu9dfac0a2011-11-14 16:56:59 +0900355#elif defined(CONFIG_CPU_SH7724)
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000356#define SH_ETH_TYPE_ETHER
Nobuhiro Iwamatsu9dfac0a2011-11-14 16:56:59 +0900357#define BASE_IO_ADDR 0xA4600000
Nobuhiro Iwamatsu4ad2c2a2012-08-02 22:08:40 +0000358#elif defined(CONFIG_R8A7740)
359#define SH_ETH_TYPE_GETHER
360#define BASE_IO_ADDR 0xE9A00000
Nobuhiro Iwamatsua2dd2a12014-06-24 17:01:08 +0900361#elif defined(CONFIG_R8A7790) || defined(CONFIG_R8A7791) || \
362 defined(CONFIG_R8A7794)
Nobuhiro Iwamatsu72befd32013-08-22 13:22:04 +0900363#define SH_ETH_TYPE_ETHER
364#define BASE_IO_ADDR 0xEE700200
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900365#elif defined(CONFIG_R7S72100)
366#define SH_ETH_TYPE_RZ
367#define BASE_IO_ADDR 0xE8203000
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +0900368#endif
369
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900370/*
371 * Register's bits
372 * Copy from Linux driver source code
373 */
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900374#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900375/* EDSR */
376enum EDSR_BIT {
377 EDSR_ENT = 0x01, EDSR_ENR = 0x02,
378};
379#define EDSR_ENALL (EDSR_ENT|EDSR_ENR)
380#endif
381
382/* EDMR */
383enum DMAC_M_BIT {
384 EDMR_DL1 = 0x20, EDMR_DL0 = 0x10,
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900385#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu58802902012-02-02 21:28:49 +0000386 EDMR_SRST = 0x03, /* Receive/Send reset */
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900387 EMDR_DESC_R = 0x30, /* Descriptor reserve size */
388 EDMR_EL = 0x40, /* Litte endian */
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000389#elif defined(SH_ETH_TYPE_ETHER)
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +0900390 EDMR_SRST = 0x01,
391 EMDR_DESC_R = 0x30, /* Descriptor reserve size */
392 EDMR_EL = 0x40, /* Litte endian */
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000393#else
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900394 EDMR_SRST = 0x01,
395#endif
396};
397
Nobuhiro Iwamatsu7a2142c2013-08-22 13:22:02 +0900398#if CONFIG_SH_ETHER_ALIGNE_SIZE == 64
399# define EMDR_DESC EDMR_DL1
400#elif CONFIG_SH_ETHER_ALIGNE_SIZE == 32
401# define EMDR_DESC EDMR_DL0
402#elif CONFIG_SH_ETHER_ALIGNE_SIZE == 16 /* Default */
403# define EMDR_DESC 0
404#endif
405
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900406/* RFLR */
407#define RFLR_RFL_MIN 0x05EE /* Recv Frame length 1518 byte */
408
409/* EDTRR */
410enum DMAC_T_BIT {
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900411#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900412 EDTRR_TRNS = 0x03,
413#else
414 EDTRR_TRNS = 0x01,
415#endif
416};
417
418/* GECMR */
419enum GECMR_BIT {
Yoshihiro Shimodac5901fb2013-12-18 16:04:04 +0900420#if defined(CONFIG_CPU_SH7757) || \
421 defined(CONFIG_CPU_SH7752) || \
422 defined(CONFIG_CPU_SH7753)
Yoshihiro Shimoda36944902012-06-26 16:38:11 +0000423 GECMR_1000B = 0x20, GECMR_100B = 0x01, GECMR_10B = 0x00,
424#else
Simon Muntonc2d704f2009-02-02 09:44:08 +0000425 GECMR_1000B = 0x01, GECMR_100B = 0x04, GECMR_10B = 0x00,
Yoshihiro Shimoda36944902012-06-26 16:38:11 +0000426#endif
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900427};
428
429/* EDRRR*/
430enum EDRRR_R_BIT {
431 EDRRR_R = 0x01,
432};
433
434/* TPAUSER */
435enum TPAUSER_BIT {
436 TPAUSER_TPAUSE = 0x0000ffff,
437 TPAUSER_UNLIMITED = 0,
438};
439
440/* BCFR */
441enum BCFR_BIT {
442 BCFR_RPAUSE = 0x0000ffff,
443 BCFR_UNLIMITED = 0,
444};
445
446/* PIR */
447enum PIR_BIT {
448 PIR_MDI = 0x08, PIR_MDO = 0x04, PIR_MMD = 0x02, PIR_MDC = 0x01,
449};
450
451/* PSR */
452enum PHY_STATUS_BIT { PHY_ST_LINK = 0x01, };
453
454/* EESR */
455enum EESR_BIT {
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000456#if defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900457 EESR_TWB = 0x40000000,
458#else
459 EESR_TWB = 0xC0000000,
460 EESR_TC1 = 0x20000000,
461 EESR_TUC = 0x10000000,
462 EESR_ROC = 0x80000000,
463#endif
464 EESR_TABT = 0x04000000,
465 EESR_RABT = 0x02000000, EESR_RFRMER = 0x01000000,
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000466#if defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900467 EESR_ADE = 0x00800000,
468#endif
469 EESR_ECI = 0x00400000,
470 EESR_FTC = 0x00200000, EESR_TDE = 0x00100000,
471 EESR_TFE = 0x00080000, EESR_FRC = 0x00040000,
472 EESR_RDE = 0x00020000, EESR_RFE = 0x00010000,
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000473#if defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900474 EESR_CND = 0x00000800,
475#endif
476 EESR_DLC = 0x00000400,
477 EESR_CD = 0x00000200, EESR_RTO = 0x00000100,
478 EESR_RMAF = 0x00000080, EESR_CEEF = 0x00000040,
479 EESR_CELF = 0x00000020, EESR_RRF = 0x00000010,
Nobuhiro Iwamatsu8d14b252014-01-23 07:52:20 +0900480 EESR_RTLF = 0x00000008, EESR_RTSF = 0x00000004,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900481 EESR_PRE = 0x00000002, EESR_CERF = 0x00000001,
482};
483
484
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900485#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900486# define TX_CHECK (EESR_TC1 | EESR_FTC)
487# define EESR_ERR_CHECK (EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE \
488 | EESR_RFRMER | EESR_TFE | EESR_TDE | EESR_ECI)
489# define TX_ERROR_CEHCK (EESR_TWB | EESR_TABT | EESR_TDE | EESR_TFE)
490
491#else
492# define TX_CHECK (EESR_FTC | EESR_CND | EESR_DLC | EESR_CD | EESR_RTO)
493# define EESR_ERR_CHECK (EESR_TWB | EESR_TABT | EESR_RABT | EESR_RDE \
494 | EESR_RFRMER | EESR_ADE | EESR_TFE | EESR_TDE | EESR_ECI)
495# define TX_ERROR_CEHCK (EESR_TWB | EESR_TABT | EESR_ADE | EESR_TDE | EESR_TFE)
496#endif
497
498/* EESIPR */
499enum DMAC_IM_BIT {
500 DMAC_M_TWB = 0x40000000, DMAC_M_TABT = 0x04000000,
501 DMAC_M_RABT = 0x02000000,
502 DMAC_M_RFRMER = 0x01000000, DMAC_M_ADF = 0x00800000,
503 DMAC_M_ECI = 0x00400000, DMAC_M_FTC = 0x00200000,
504 DMAC_M_TDE = 0x00100000, DMAC_M_TFE = 0x00080000,
505 DMAC_M_FRC = 0x00040000, DMAC_M_RDE = 0x00020000,
506 DMAC_M_RFE = 0x00010000, DMAC_M_TINT4 = 0x00000800,
507 DMAC_M_TINT3 = 0x00000400, DMAC_M_TINT2 = 0x00000200,
508 DMAC_M_TINT1 = 0x00000100, DMAC_M_RINT8 = 0x00000080,
509 DMAC_M_RINT5 = 0x00000010, DMAC_M_RINT4 = 0x00000008,
510 DMAC_M_RINT3 = 0x00000004, DMAC_M_RINT2 = 0x00000002,
511 DMAC_M_RINT1 = 0x00000001,
512};
513
514/* Receive descriptor bit */
515enum RD_STS_BIT {
516 RD_RACT = 0x80000000, RD_RDLE = 0x40000000,
517 RD_RFP1 = 0x20000000, RD_RFP0 = 0x10000000,
518 RD_RFE = 0x08000000, RD_RFS10 = 0x00000200,
519 RD_RFS9 = 0x00000100, RD_RFS8 = 0x00000080,
520 RD_RFS7 = 0x00000040, RD_RFS6 = 0x00000020,
521 RD_RFS5 = 0x00000010, RD_RFS4 = 0x00000008,
522 RD_RFS3 = 0x00000004, RD_RFS2 = 0x00000002,
523 RD_RFS1 = 0x00000001,
524};
525#define RDF1ST RD_RFP1
526#define RDFEND RD_RFP0
527#define RD_RFP (RD_RFP1|RD_RFP0)
528
529/* RDFFR*/
530enum RDFFR_BIT {
531 RDFFR_RDLF = 0x01,
532};
533
534/* FCFTR */
535enum FCFTR_BIT {
536 FCFTR_RFF2 = 0x00040000, FCFTR_RFF1 = 0x00020000,
537 FCFTR_RFF0 = 0x00010000, FCFTR_RFD2 = 0x00000004,
538 FCFTR_RFD1 = 0x00000002, FCFTR_RFD0 = 0x00000001,
539};
540#define FIFO_F_D_RFF (FCFTR_RFF2|FCFTR_RFF1|FCFTR_RFF0)
541#define FIFO_F_D_RFD (FCFTR_RFD2|FCFTR_RFD1|FCFTR_RFD0)
542
543/* Transfer descriptor bit */
544enum TD_STS_BIT {
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900545#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_ETHER) || \
546 defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900547 TD_TACT = 0x80000000,
548#else
549 TD_TACT = 0x7fffffff,
550#endif
551 TD_TDLE = 0x40000000, TD_TFP1 = 0x20000000,
552 TD_TFP0 = 0x10000000,
553};
554#define TDF1ST TD_TFP1
555#define TDFEND TD_TFP0
556#define TD_TFP (TD_TFP1|TD_TFP0)
557
558/* RMCR */
559enum RECV_RST_BIT { RMCR_RST = 0x01, };
560/* ECMR */
561enum FELIC_MODE_BIT {
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900562#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu31e84df2014-01-23 07:52:19 +0900563 ECMR_TRCCM = 0x04000000, ECMR_RCSC = 0x00800000,
564 ECMR_DPAD = 0x00200000, ECMR_RZPF = 0x00100000,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900565#endif
566 ECMR_ZPF = 0x00080000, ECMR_PFR = 0x00040000, ECMR_RXF = 0x00020000,
567 ECMR_TXF = 0x00010000, ECMR_MCT = 0x00002000, ECMR_PRCEF = 0x00001000,
568 ECMR_PMDE = 0x00000200, ECMR_RE = 0x00000040, ECMR_TE = 0x00000020,
569 ECMR_ILB = 0x00000008, ECMR_ELB = 0x00000004, ECMR_DM = 0x00000002,
570 ECMR_PRM = 0x00000001,
Nobuhiro Iwamatsu9dfac0a2011-11-14 16:56:59 +0900571#ifdef CONFIG_CPU_SH7724
572 ECMR_RTM = 0x00000010,
Nobuhiro Iwamatsua2dd2a12014-06-24 17:01:08 +0900573#elif defined(CONFIG_R8A7790) || defined(CONFIG_R8A7791) || \
574 defined(CONFIG_R8A7794)
Nobuhiro Iwamatsu72befd32013-08-22 13:22:04 +0900575 ECMR_RTM = 0x00000004,
Nobuhiro Iwamatsu9dfac0a2011-11-14 16:56:59 +0900576#endif
577
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900578};
579
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900580#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu31e84df2014-01-23 07:52:19 +0900581#define ECMR_CHG_DM (ECMR_TRCCM | ECMR_RZPF | ECMR_ZPF | ECMR_PFR | \
582 ECMR_RXF | ECMR_TXF | ECMR_MCT)
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000583#elif defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsu9dfac0a2011-11-14 16:56:59 +0900584#define ECMR_CHG_DM (ECMR_ZPF | ECMR_PFR | ECMR_RXF | ECMR_TXF)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900585#else
Yoshihiro Shimoda34cca922011-01-18 17:53:45 +0900586#define ECMR_CHG_DM (ECMR_ZPF | ECMR_PFR | ECMR_RXF | ECMR_TXF | ECMR_MCT)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900587#endif
588
589/* ECSR */
590enum ECSR_STATUS_BIT {
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000591#if defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900592 ECSR_BRCRX = 0x20, ECSR_PSRTO = 0x10,
593#endif
594 ECSR_LCHNG = 0x04,
595 ECSR_MPD = 0x02, ECSR_ICD = 0x01,
596};
597
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900598#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900599# define ECSR_INIT (ECSR_ICD | ECSIPR_MPDIP)
600#else
601# define ECSR_INIT (ECSR_BRCRX | ECSR_PSRTO | \
602 ECSR_LCHNG | ECSR_ICD | ECSIPR_MPDIP)
603#endif
604
605/* ECSIPR */
606enum ECSIPR_STATUS_MASK_BIT {
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000607#if defined(SH_ETH_TYPE_ETHER)
Nobuhiro Iwamatsud8d74e82012-06-05 16:39:06 +0000608 ECSIPR_BRCRXIP = 0x20,
Nobuhiro Iwamatsu58802902012-02-02 21:28:49 +0000609 ECSIPR_PSRTOIP = 0x10,
Yoshihiro Shimoda9d553032012-06-26 16:38:06 +0000610#elif defined(SH_ETY_TYPE_GETHER)
Nobuhiro Iwamatsu58802902012-02-02 21:28:49 +0000611 ECSIPR_PSRTOIP = 0x10,
612 ECSIPR_PHYIP = 0x08,
Nobuhiro Iwamatsud8d74e82012-06-05 16:39:06 +0000613#endif
Nobuhiro Iwamatsu58802902012-02-02 21:28:49 +0000614 ECSIPR_LCHNGIP = 0x04,
615 ECSIPR_MPDIP = 0x02,
616 ECSIPR_ICDIP = 0x01,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900617};
618
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900619#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900620# define ECSIPR_INIT (ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP)
621#else
622# define ECSIPR_INIT (ECSIPR_BRCRXIP | ECSIPR_PSRTOIP | ECSIPR_LCHNGIP | \
623 ECSIPR_ICDIP | ECSIPR_MPDIP)
624#endif
625
626/* APR */
627enum APR_BIT {
628 APR_AP = 0x00000004,
629};
630
631/* MPR */
632enum MPR_BIT {
633 MPR_MP = 0x00000006,
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900634};
635
636/* TRSCER */
637enum DESC_I_BIT {
638 DESC_I_TINT4 = 0x0800, DESC_I_TINT3 = 0x0400, DESC_I_TINT2 = 0x0200,
639 DESC_I_TINT1 = 0x0100, DESC_I_RINT8 = 0x0080, DESC_I_RINT5 = 0x0010,
640 DESC_I_RINT4 = 0x0008, DESC_I_RINT3 = 0x0004, DESC_I_RINT2 = 0x0002,
641 DESC_I_RINT1 = 0x0001,
642};
643
644/* RPADIR */
645enum RPADIR_BIT {
646 RPADIR_PADS1 = 0x20000, RPADIR_PADS0 = 0x10000,
647 RPADIR_PADR = 0x0003f,
648};
649
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900650#if defined(SH_ETH_TYPE_GETHER) || defined(SH_ETH_TYPE_RZ)
Nobuhiro Iwamatsu240b7232008-06-11 21:05:00 +0900651# define RPADIR_INIT (0x00)
652#else
653# define RPADIR_INIT (RPADIR_PADS1)
654#endif
655
656/* FDR */
657enum FIFO_SIZE_BIT {
658 FIFO_SIZE_T = 0x00000700, FIFO_SIZE_R = 0x00000007,
659};
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000660
661static inline unsigned long sh_eth_reg_addr(struct sh_eth_dev *eth,
662 int enum_index)
663{
664#if defined(SH_ETH_TYPE_GETHER)
665 const u16 *reg_offset = sh_eth_offset_gigabit;
666#elif defined(SH_ETH_TYPE_ETHER)
667 const u16 *reg_offset = sh_eth_offset_fast_sh4;
Nobuhiro Iwamatsu46288f42014-01-23 07:52:18 +0900668#elif defined(SH_ETH_TYPE_RZ)
669 const u16 *reg_offset = sh_eth_offset_rz;
Yoshihiro Shimoda4c4aa6c2012-06-26 16:38:09 +0000670#else
671#error
672#endif
673 return BASE_IO_ADDR + reg_offset[enum_index] + 0x800 * eth->port;
674}
675
676static inline void sh_eth_write(struct sh_eth_dev *eth, unsigned long data,
677 int enum_index)
678{
679 outl(data, sh_eth_reg_addr(eth, enum_index));
680}
681
682static inline unsigned long sh_eth_read(struct sh_eth_dev *eth,
683 int enum_index)
684{
685 return inl(sh_eth_reg_addr(eth, enum_index));
686}