xref: /openbmc/u-boot/drivers/net/macb.c (revision 5ff10aa7)
1 /*
2  * Copyright (C) 2005-2006 Atmel Corporation
3  *
4  * SPDX-License-Identifier:	GPL-2.0+
5  */
6 #include <common.h>
7 
8 /*
9  * The u-boot networking stack is a little weird.  It seems like the
10  * networking core allocates receive buffers up front without any
11  * regard to the hardware that's supposed to actually receive those
12  * packets.
13  *
14  * The MACB receives packets into 128-byte receive buffers, so the
15  * buffers allocated by the core isn't very practical to use.  We'll
16  * allocate our own, but we need one such buffer in case a packet
17  * wraps around the DMA ring so that we have to copy it.
18  *
19  * Therefore, define CONFIG_SYS_RX_ETH_BUFFER to 1 in the board-specific
20  * configuration header.  This way, the core allocates one RX buffer
21  * and one TX buffer, each of which can hold a ethernet packet of
22  * maximum size.
23  *
24  * For some reason, the networking core unconditionally specifies a
25  * 32-byte packet "alignment" (which really should be called
26  * "padding").  MACB shouldn't need that, but we'll refrain from any
27  * core modifications here...
28  */
29 
30 #include <net.h>
31 #include <netdev.h>
32 #include <malloc.h>
33 #include <miiphy.h>
34 
35 #include <linux/mii.h>
36 #include <asm/io.h>
37 #include <asm/dma-mapping.h>
38 #include <asm/arch/clk.h>
39 #include <asm-generic/errno.h>
40 
41 #include "macb.h"
42 
43 #define MACB_RX_BUFFER_SIZE		4096
44 #define MACB_RX_RING_SIZE		(MACB_RX_BUFFER_SIZE / 128)
45 #define MACB_TX_RING_SIZE		16
46 #define MACB_TX_TIMEOUT		1000
47 #define MACB_AUTONEG_TIMEOUT	5000000
48 
49 struct macb_dma_desc {
50 	u32	addr;
51 	u32	ctrl;
52 };
53 
54 #define DMA_DESC_BYTES(n)	(n * sizeof(struct macb_dma_desc))
55 #define MACB_TX_DMA_DESC_SIZE	(DMA_DESC_BYTES(MACB_TX_RING_SIZE))
56 #define MACB_RX_DMA_DESC_SIZE	(DMA_DESC_BYTES(MACB_RX_RING_SIZE))
57 
58 #define RXADDR_USED		0x00000001
59 #define RXADDR_WRAP		0x00000002
60 
61 #define RXBUF_FRMLEN_MASK	0x00000fff
62 #define RXBUF_FRAME_START	0x00004000
63 #define RXBUF_FRAME_END		0x00008000
64 #define RXBUF_TYPEID_MATCH	0x00400000
65 #define RXBUF_ADDR4_MATCH	0x00800000
66 #define RXBUF_ADDR3_MATCH	0x01000000
67 #define RXBUF_ADDR2_MATCH	0x02000000
68 #define RXBUF_ADDR1_MATCH	0x04000000
69 #define RXBUF_BROADCAST		0x80000000
70 
71 #define TXBUF_FRMLEN_MASK	0x000007ff
72 #define TXBUF_FRAME_END		0x00008000
73 #define TXBUF_NOCRC		0x00010000
74 #define TXBUF_EXHAUSTED		0x08000000
75 #define TXBUF_UNDERRUN		0x10000000
76 #define TXBUF_MAXRETRY		0x20000000
77 #define TXBUF_WRAP		0x40000000
78 #define TXBUF_USED		0x80000000
79 
80 struct macb_device {
81 	void			*regs;
82 
83 	unsigned int		rx_tail;
84 	unsigned int		tx_head;
85 	unsigned int		tx_tail;
86 
87 	void			*rx_buffer;
88 	void			*tx_buffer;
89 	struct macb_dma_desc	*rx_ring;
90 	struct macb_dma_desc	*tx_ring;
91 
92 	unsigned long		rx_buffer_dma;
93 	unsigned long		rx_ring_dma;
94 	unsigned long		tx_ring_dma;
95 
96 	const struct device	*dev;
97 	struct eth_device	netdev;
98 	unsigned short		phy_addr;
99 	struct mii_dev		*bus;
100 };
101 #define to_macb(_nd) container_of(_nd, struct macb_device, netdev)
102 
103 static int macb_is_gem(struct macb_device *macb)
104 {
105 	return MACB_BFEXT(IDNUM, macb_readl(macb, MID)) == 0x2;
106 }
107 
108 static void macb_mdio_write(struct macb_device *macb, u8 reg, u16 value)
109 {
110 	unsigned long netctl;
111 	unsigned long netstat;
112 	unsigned long frame;
113 
114 	netctl = macb_readl(macb, NCR);
115 	netctl |= MACB_BIT(MPE);
116 	macb_writel(macb, NCR, netctl);
117 
118 	frame = (MACB_BF(SOF, 1)
119 		 | MACB_BF(RW, 1)
120 		 | MACB_BF(PHYA, macb->phy_addr)
121 		 | MACB_BF(REGA, reg)
122 		 | MACB_BF(CODE, 2)
123 		 | MACB_BF(DATA, value));
124 	macb_writel(macb, MAN, frame);
125 
126 	do {
127 		netstat = macb_readl(macb, NSR);
128 	} while (!(netstat & MACB_BIT(IDLE)));
129 
130 	netctl = macb_readl(macb, NCR);
131 	netctl &= ~MACB_BIT(MPE);
132 	macb_writel(macb, NCR, netctl);
133 }
134 
135 static u16 macb_mdio_read(struct macb_device *macb, u8 reg)
136 {
137 	unsigned long netctl;
138 	unsigned long netstat;
139 	unsigned long frame;
140 
141 	netctl = macb_readl(macb, NCR);
142 	netctl |= MACB_BIT(MPE);
143 	macb_writel(macb, NCR, netctl);
144 
145 	frame = (MACB_BF(SOF, 1)
146 		 | MACB_BF(RW, 2)
147 		 | MACB_BF(PHYA, macb->phy_addr)
148 		 | MACB_BF(REGA, reg)
149 		 | MACB_BF(CODE, 2));
150 	macb_writel(macb, MAN, frame);
151 
152 	do {
153 		netstat = macb_readl(macb, NSR);
154 	} while (!(netstat & MACB_BIT(IDLE)));
155 
156 	frame = macb_readl(macb, MAN);
157 
158 	netctl = macb_readl(macb, NCR);
159 	netctl &= ~MACB_BIT(MPE);
160 	macb_writel(macb, NCR, netctl);
161 
162 	return MACB_BFEXT(DATA, frame);
163 }
164 
165 void __weak arch_get_mdio_control(const char *name)
166 {
167 	return;
168 }
169 
170 #if defined(CONFIG_CMD_MII) || defined(CONFIG_PHYLIB)
171 
172 int macb_miiphy_read(const char *devname, u8 phy_adr, u8 reg, u16 *value)
173 {
174 	struct eth_device *dev = eth_get_dev_by_name(devname);
175 	struct macb_device *macb = to_macb(dev);
176 
177 	if (macb->phy_addr != phy_adr)
178 		return -1;
179 
180 	arch_get_mdio_control(devname);
181 	*value = macb_mdio_read(macb, reg);
182 
183 	return 0;
184 }
185 
186 int macb_miiphy_write(const char *devname, u8 phy_adr, u8 reg, u16 value)
187 {
188 	struct eth_device *dev = eth_get_dev_by_name(devname);
189 	struct macb_device *macb = to_macb(dev);
190 
191 	if (macb->phy_addr != phy_adr)
192 		return -1;
193 
194 	arch_get_mdio_control(devname);
195 	macb_mdio_write(macb, reg, value);
196 
197 	return 0;
198 }
199 #endif
200 
201 #define RX	1
202 #define TX	0
203 static inline void macb_invalidate_ring_desc(struct macb_device *macb, bool rx)
204 {
205 	if (rx)
206 		invalidate_dcache_range(macb->rx_ring_dma, macb->rx_ring_dma +
207 			MACB_RX_DMA_DESC_SIZE);
208 	else
209 		invalidate_dcache_range(macb->tx_ring_dma, macb->tx_ring_dma +
210 			MACB_TX_DMA_DESC_SIZE);
211 }
212 
213 static inline void macb_flush_ring_desc(struct macb_device *macb, bool rx)
214 {
215 	if (rx)
216 		flush_dcache_range(macb->rx_ring_dma, macb->rx_ring_dma +
217 			MACB_RX_DMA_DESC_SIZE);
218 	else
219 		flush_dcache_range(macb->tx_ring_dma, macb->tx_ring_dma +
220 			MACB_TX_DMA_DESC_SIZE);
221 }
222 
223 static inline void macb_flush_rx_buffer(struct macb_device *macb)
224 {
225 	flush_dcache_range(macb->rx_buffer_dma, macb->rx_buffer_dma +
226 				MACB_RX_BUFFER_SIZE);
227 }
228 
229 static inline void macb_invalidate_rx_buffer(struct macb_device *macb)
230 {
231 	invalidate_dcache_range(macb->rx_buffer_dma, macb->rx_buffer_dma +
232 				MACB_RX_BUFFER_SIZE);
233 }
234 
235 #if defined(CONFIG_CMD_NET)
236 
237 static int macb_send(struct eth_device *netdev, void *packet, int length)
238 {
239 	struct macb_device *macb = to_macb(netdev);
240 	unsigned long paddr, ctrl;
241 	unsigned int tx_head = macb->tx_head;
242 	int i;
243 
244 	paddr = dma_map_single(packet, length, DMA_TO_DEVICE);
245 
246 	ctrl = length & TXBUF_FRMLEN_MASK;
247 	ctrl |= TXBUF_FRAME_END;
248 	if (tx_head == (MACB_TX_RING_SIZE - 1)) {
249 		ctrl |= TXBUF_WRAP;
250 		macb->tx_head = 0;
251 	} else {
252 		macb->tx_head++;
253 	}
254 
255 	macb->tx_ring[tx_head].ctrl = ctrl;
256 	macb->tx_ring[tx_head].addr = paddr;
257 	barrier();
258 	macb_flush_ring_desc(macb, TX);
259 	/* Do we need check paddr and length is dcache line aligned? */
260 	flush_dcache_range(paddr, paddr + length);
261 	macb_writel(macb, NCR, MACB_BIT(TE) | MACB_BIT(RE) | MACB_BIT(TSTART));
262 
263 	/*
264 	 * I guess this is necessary because the networking core may
265 	 * re-use the transmit buffer as soon as we return...
266 	 */
267 	for (i = 0; i <= MACB_TX_TIMEOUT; i++) {
268 		barrier();
269 		macb_invalidate_ring_desc(macb, TX);
270 		ctrl = macb->tx_ring[tx_head].ctrl;
271 		if (ctrl & TXBUF_USED)
272 			break;
273 		udelay(1);
274 	}
275 
276 	dma_unmap_single(packet, length, paddr);
277 
278 	if (i <= MACB_TX_TIMEOUT) {
279 		if (ctrl & TXBUF_UNDERRUN)
280 			printf("%s: TX underrun\n", netdev->name);
281 		if (ctrl & TXBUF_EXHAUSTED)
282 			printf("%s: TX buffers exhausted in mid frame\n",
283 			       netdev->name);
284 	} else {
285 		printf("%s: TX timeout\n", netdev->name);
286 	}
287 
288 	/* No one cares anyway */
289 	return 0;
290 }
291 
292 static void reclaim_rx_buffers(struct macb_device *macb,
293 			       unsigned int new_tail)
294 {
295 	unsigned int i;
296 
297 	i = macb->rx_tail;
298 
299 	macb_invalidate_ring_desc(macb, RX);
300 	while (i > new_tail) {
301 		macb->rx_ring[i].addr &= ~RXADDR_USED;
302 		i++;
303 		if (i > MACB_RX_RING_SIZE)
304 			i = 0;
305 	}
306 
307 	while (i < new_tail) {
308 		macb->rx_ring[i].addr &= ~RXADDR_USED;
309 		i++;
310 	}
311 
312 	barrier();
313 	macb_flush_ring_desc(macb, RX);
314 	macb->rx_tail = new_tail;
315 }
316 
317 static int macb_recv(struct eth_device *netdev)
318 {
319 	struct macb_device *macb = to_macb(netdev);
320 	unsigned int rx_tail = macb->rx_tail;
321 	void *buffer;
322 	int length;
323 	int wrapped = 0;
324 	u32 status;
325 
326 	for (;;) {
327 		macb_invalidate_ring_desc(macb, RX);
328 
329 		if (!(macb->rx_ring[rx_tail].addr & RXADDR_USED))
330 			return -1;
331 
332 		status = macb->rx_ring[rx_tail].ctrl;
333 		if (status & RXBUF_FRAME_START) {
334 			if (rx_tail != macb->rx_tail)
335 				reclaim_rx_buffers(macb, rx_tail);
336 			wrapped = 0;
337 		}
338 
339 		if (status & RXBUF_FRAME_END) {
340 			buffer = macb->rx_buffer + 128 * macb->rx_tail;
341 			length = status & RXBUF_FRMLEN_MASK;
342 
343 			macb_invalidate_rx_buffer(macb);
344 			if (wrapped) {
345 				unsigned int headlen, taillen;
346 
347 				headlen = 128 * (MACB_RX_RING_SIZE
348 						 - macb->rx_tail);
349 				taillen = length - headlen;
350 				memcpy((void *)NetRxPackets[0],
351 				       buffer, headlen);
352 				memcpy((void *)NetRxPackets[0] + headlen,
353 				       macb->rx_buffer, taillen);
354 				buffer = (void *)NetRxPackets[0];
355 			}
356 
357 			NetReceive(buffer, length);
358 			if (++rx_tail >= MACB_RX_RING_SIZE)
359 				rx_tail = 0;
360 			reclaim_rx_buffers(macb, rx_tail);
361 		} else {
362 			if (++rx_tail >= MACB_RX_RING_SIZE) {
363 				wrapped = 1;
364 				rx_tail = 0;
365 			}
366 		}
367 		barrier();
368 	}
369 
370 	return 0;
371 }
372 
373 static void macb_phy_reset(struct macb_device *macb)
374 {
375 	struct eth_device *netdev = &macb->netdev;
376 	int i;
377 	u16 status, adv;
378 
379 	adv = ADVERTISE_CSMA | ADVERTISE_ALL;
380 	macb_mdio_write(macb, MII_ADVERTISE, adv);
381 	printf("%s: Starting autonegotiation...\n", netdev->name);
382 	macb_mdio_write(macb, MII_BMCR, (BMCR_ANENABLE
383 					 | BMCR_ANRESTART));
384 
385 	for (i = 0; i < MACB_AUTONEG_TIMEOUT / 100; i++) {
386 		status = macb_mdio_read(macb, MII_BMSR);
387 		if (status & BMSR_ANEGCOMPLETE)
388 			break;
389 		udelay(100);
390 	}
391 
392 	if (status & BMSR_ANEGCOMPLETE)
393 		printf("%s: Autonegotiation complete\n", netdev->name);
394 	else
395 		printf("%s: Autonegotiation timed out (status=0x%04x)\n",
396 		       netdev->name, status);
397 }
398 
399 #ifdef CONFIG_MACB_SEARCH_PHY
400 static int macb_phy_find(struct macb_device *macb)
401 {
402 	int i;
403 	u16 phy_id;
404 
405 	/* Search for PHY... */
406 	for (i = 0; i < 32; i++) {
407 		macb->phy_addr = i;
408 		phy_id = macb_mdio_read(macb, MII_PHYSID1);
409 		if (phy_id != 0xffff) {
410 			printf("%s: PHY present at %d\n", macb->netdev.name, i);
411 			return 1;
412 		}
413 	}
414 
415 	/* PHY isn't up to snuff */
416 	printf("%s: PHY not found\n", macb->netdev.name);
417 
418 	return 0;
419 }
420 #endif /* CONFIG_MACB_SEARCH_PHY */
421 
422 
423 static int macb_phy_init(struct macb_device *macb)
424 {
425 	struct eth_device *netdev = &macb->netdev;
426 #ifdef CONFIG_PHYLIB
427 	struct phy_device *phydev;
428 #endif
429 	u32 ncfgr;
430 	u16 phy_id, status, adv, lpa;
431 	int media, speed, duplex;
432 	int i;
433 
434 	arch_get_mdio_control(netdev->name);
435 #ifdef CONFIG_MACB_SEARCH_PHY
436 	/* Auto-detect phy_addr */
437 	if (!macb_phy_find(macb))
438 		return 0;
439 #endif /* CONFIG_MACB_SEARCH_PHY */
440 
441 	/* Check if the PHY is up to snuff... */
442 	phy_id = macb_mdio_read(macb, MII_PHYSID1);
443 	if (phy_id == 0xffff) {
444 		printf("%s: No PHY present\n", netdev->name);
445 		return 0;
446 	}
447 
448 #ifdef CONFIG_PHYLIB
449 	/* need to consider other phy interface mode */
450 	phydev = phy_connect(macb->bus, macb->phy_addr, netdev,
451 			     PHY_INTERFACE_MODE_RGMII);
452 	if (!phydev) {
453 		printf("phy_connect failed\n");
454 		return -ENODEV;
455 	}
456 
457 	phy_config(phydev);
458 #endif
459 
460 	status = macb_mdio_read(macb, MII_BMSR);
461 	if (!(status & BMSR_LSTATUS)) {
462 		/* Try to re-negotiate if we don't have link already. */
463 		macb_phy_reset(macb);
464 
465 		for (i = 0; i < MACB_AUTONEG_TIMEOUT / 100; i++) {
466 			status = macb_mdio_read(macb, MII_BMSR);
467 			if (status & BMSR_LSTATUS)
468 				break;
469 			udelay(100);
470 		}
471 	}
472 
473 	if (!(status & BMSR_LSTATUS)) {
474 		printf("%s: link down (status: 0x%04x)\n",
475 		       netdev->name, status);
476 		return 0;
477 	}
478 
479 	/* First check for GMAC */
480 	if (macb_is_gem(macb)) {
481 		lpa = macb_mdio_read(macb, MII_STAT1000);
482 		if (lpa & (1 << 11)) {
483 			speed = 1000;
484 			duplex = 1;
485 		} else {
486 		       if (lpa & (1 << 10)) {
487 				speed = 1000;
488 				duplex = 1;
489 			} else {
490 				speed = 0;
491 			}
492 		}
493 
494 		if (speed == 1000) {
495 			printf("%s: link up, %dMbps %s-duplex (lpa: 0x%04x)\n",
496 			       netdev->name,
497 			       speed,
498 			       duplex ? "full" : "half",
499 			       lpa);
500 
501 			ncfgr = macb_readl(macb, NCFGR);
502 			ncfgr &= ~(GEM_BIT(GBE) | MACB_BIT(SPD) | MACB_BIT(FD));
503 			if (speed)
504 				ncfgr |= GEM_BIT(GBE);
505 			if (duplex)
506 				ncfgr |= MACB_BIT(FD);
507 			macb_writel(macb, NCFGR, ncfgr);
508 
509 			return 1;
510 		}
511 	}
512 
513 	/* fall back for EMAC checking */
514 	adv = macb_mdio_read(macb, MII_ADVERTISE);
515 	lpa = macb_mdio_read(macb, MII_LPA);
516 	media = mii_nway_result(lpa & adv);
517 	speed = (media & (ADVERTISE_100FULL | ADVERTISE_100HALF)
518 		 ? 1 : 0);
519 	duplex = (media & ADVERTISE_FULL) ? 1 : 0;
520 	printf("%s: link up, %sMbps %s-duplex (lpa: 0x%04x)\n",
521 	       netdev->name,
522 	       speed ? "100" : "10",
523 	       duplex ? "full" : "half",
524 	       lpa);
525 
526 	ncfgr = macb_readl(macb, NCFGR);
527 	ncfgr &= ~(MACB_BIT(SPD) | MACB_BIT(FD));
528 	if (speed)
529 		ncfgr |= MACB_BIT(SPD);
530 	if (duplex)
531 		ncfgr |= MACB_BIT(FD);
532 	macb_writel(macb, NCFGR, ncfgr);
533 
534 	return 1;
535 }
536 
537 static int macb_init(struct eth_device *netdev, bd_t *bd)
538 {
539 	struct macb_device *macb = to_macb(netdev);
540 	unsigned long paddr;
541 	int i;
542 
543 	/*
544 	 * macb_halt should have been called at some point before now,
545 	 * so we'll assume the controller is idle.
546 	 */
547 
548 	/* initialize DMA descriptors */
549 	paddr = macb->rx_buffer_dma;
550 	for (i = 0; i < MACB_RX_RING_SIZE; i++) {
551 		if (i == (MACB_RX_RING_SIZE - 1))
552 			paddr |= RXADDR_WRAP;
553 		macb->rx_ring[i].addr = paddr;
554 		macb->rx_ring[i].ctrl = 0;
555 		paddr += 128;
556 	}
557 	macb_flush_ring_desc(macb, RX);
558 	macb_flush_rx_buffer(macb);
559 
560 	for (i = 0; i < MACB_TX_RING_SIZE; i++) {
561 		macb->tx_ring[i].addr = 0;
562 		if (i == (MACB_TX_RING_SIZE - 1))
563 			macb->tx_ring[i].ctrl = TXBUF_USED | TXBUF_WRAP;
564 		else
565 			macb->tx_ring[i].ctrl = TXBUF_USED;
566 	}
567 	macb_flush_ring_desc(macb, TX);
568 
569 	macb->rx_tail = 0;
570 	macb->tx_head = 0;
571 	macb->tx_tail = 0;
572 
573 	macb_writel(macb, RBQP, macb->rx_ring_dma);
574 	macb_writel(macb, TBQP, macb->tx_ring_dma);
575 
576 	if (macb_is_gem(macb)) {
577 #ifdef CONFIG_RGMII
578 		gem_writel(macb, UR, GEM_BIT(RGMII));
579 #else
580 		gem_writel(macb, UR, 0);
581 #endif
582 	} else {
583 	/* choose RMII or MII mode. This depends on the board */
584 #ifdef CONFIG_RMII
585 #ifdef CONFIG_AT91FAMILY
586 	macb_writel(macb, USRIO, MACB_BIT(RMII) | MACB_BIT(CLKEN));
587 #else
588 	macb_writel(macb, USRIO, 0);
589 #endif
590 #else
591 #ifdef CONFIG_AT91FAMILY
592 	macb_writel(macb, USRIO, MACB_BIT(CLKEN));
593 #else
594 	macb_writel(macb, USRIO, MACB_BIT(MII));
595 #endif
596 #endif /* CONFIG_RMII */
597 	}
598 
599 	if (!macb_phy_init(macb))
600 		return -1;
601 
602 	/* Enable TX and RX */
603 	macb_writel(macb, NCR, MACB_BIT(TE) | MACB_BIT(RE));
604 
605 	return 0;
606 }
607 
608 static void macb_halt(struct eth_device *netdev)
609 {
610 	struct macb_device *macb = to_macb(netdev);
611 	u32 ncr, tsr;
612 
613 	/* Halt the controller and wait for any ongoing transmission to end. */
614 	ncr = macb_readl(macb, NCR);
615 	ncr |= MACB_BIT(THALT);
616 	macb_writel(macb, NCR, ncr);
617 
618 	do {
619 		tsr = macb_readl(macb, TSR);
620 	} while (tsr & MACB_BIT(TGO));
621 
622 	/* Disable TX and RX, and clear statistics */
623 	macb_writel(macb, NCR, MACB_BIT(CLRSTAT));
624 }
625 
626 static int macb_write_hwaddr(struct eth_device *dev)
627 {
628 	struct macb_device *macb = to_macb(dev);
629 	u32 hwaddr_bottom;
630 	u16 hwaddr_top;
631 
632 	/* set hardware address */
633 	hwaddr_bottom = dev->enetaddr[0] | dev->enetaddr[1] << 8 |
634 			dev->enetaddr[2] << 16 | dev->enetaddr[3] << 24;
635 	macb_writel(macb, SA1B, hwaddr_bottom);
636 	hwaddr_top = dev->enetaddr[4] | dev->enetaddr[5] << 8;
637 	macb_writel(macb, SA1T, hwaddr_top);
638 	return 0;
639 }
640 
641 static u32 macb_mdc_clk_div(int id, struct macb_device *macb)
642 {
643 	u32 config;
644 	unsigned long macb_hz = get_macb_pclk_rate(id);
645 
646 	if (macb_hz < 20000000)
647 		config = MACB_BF(CLK, MACB_CLK_DIV8);
648 	else if (macb_hz < 40000000)
649 		config = MACB_BF(CLK, MACB_CLK_DIV16);
650 	else if (macb_hz < 80000000)
651 		config = MACB_BF(CLK, MACB_CLK_DIV32);
652 	else
653 		config = MACB_BF(CLK, MACB_CLK_DIV64);
654 
655 	return config;
656 }
657 
658 static u32 gem_mdc_clk_div(int id, struct macb_device *macb)
659 {
660 	u32 config;
661 	unsigned long macb_hz = get_macb_pclk_rate(id);
662 
663 	if (macb_hz < 20000000)
664 		config = GEM_BF(CLK, GEM_CLK_DIV8);
665 	else if (macb_hz < 40000000)
666 		config = GEM_BF(CLK, GEM_CLK_DIV16);
667 	else if (macb_hz < 80000000)
668 		config = GEM_BF(CLK, GEM_CLK_DIV32);
669 	else if (macb_hz < 120000000)
670 		config = GEM_BF(CLK, GEM_CLK_DIV48);
671 	else if (macb_hz < 160000000)
672 		config = GEM_BF(CLK, GEM_CLK_DIV64);
673 	else
674 		config = GEM_BF(CLK, GEM_CLK_DIV96);
675 
676 	return config;
677 }
678 
679 /*
680  * Get the DMA bus width field of the network configuration register that we
681  * should program. We find the width from decoding the design configuration
682  * register to find the maximum supported data bus width.
683  */
684 static u32 macb_dbw(struct macb_device *macb)
685 {
686 	switch (GEM_BFEXT(DBWDEF, gem_readl(macb, DCFG1))) {
687 	case 4:
688 		return GEM_BF(DBW, GEM_DBW128);
689 	case 2:
690 		return GEM_BF(DBW, GEM_DBW64);
691 	case 1:
692 	default:
693 		return GEM_BF(DBW, GEM_DBW32);
694 	}
695 }
696 
697 int macb_eth_initialize(int id, void *regs, unsigned int phy_addr)
698 {
699 	struct macb_device *macb;
700 	struct eth_device *netdev;
701 	u32 ncfgr;
702 
703 	macb = malloc(sizeof(struct macb_device));
704 	if (!macb) {
705 		printf("Error: Failed to allocate memory for MACB%d\n", id);
706 		return -1;
707 	}
708 	memset(macb, 0, sizeof(struct macb_device));
709 
710 	netdev = &macb->netdev;
711 
712 	macb->rx_buffer = dma_alloc_coherent(MACB_RX_BUFFER_SIZE,
713 					     &macb->rx_buffer_dma);
714 	macb->rx_ring = dma_alloc_coherent(MACB_RX_DMA_DESC_SIZE,
715 					   &macb->rx_ring_dma);
716 	macb->tx_ring = dma_alloc_coherent(MACB_TX_DMA_DESC_SIZE,
717 					   &macb->tx_ring_dma);
718 
719 	/* TODO: we need check the rx/tx_ring_dma is dcache line aligned */
720 
721 	macb->regs = regs;
722 	macb->phy_addr = phy_addr;
723 
724 	if (macb_is_gem(macb))
725 		sprintf(netdev->name, "gmac%d", id);
726 	else
727 		sprintf(netdev->name, "macb%d", id);
728 
729 	netdev->init = macb_init;
730 	netdev->halt = macb_halt;
731 	netdev->send = macb_send;
732 	netdev->recv = macb_recv;
733 	netdev->write_hwaddr = macb_write_hwaddr;
734 
735 	/*
736 	 * Do some basic initialization so that we at least can talk
737 	 * to the PHY
738 	 */
739 	if (macb_is_gem(macb)) {
740 		ncfgr = gem_mdc_clk_div(id, macb);
741 		ncfgr |= macb_dbw(macb);
742 	} else {
743 		ncfgr = macb_mdc_clk_div(id, macb);
744 	}
745 
746 	macb_writel(macb, NCFGR, ncfgr);
747 
748 	eth_register(netdev);
749 
750 #if defined(CONFIG_CMD_MII) || defined(CONFIG_PHYLIB)
751 	miiphy_register(netdev->name, macb_miiphy_read, macb_miiphy_write);
752 	macb->bus = miiphy_get_dev_by_name(netdev->name);
753 #endif
754 	return 0;
755 }
756 
757 #endif
758