xref: /freebsd/sys/dev/mge/if_mge.c (revision c0a4a7bb942fd3302f0093e4353820916d3661d1)
1 /*-
2  * SPDX-License-Identifier: BSD-3-Clause
3  *
4  * Copyright (C) 2008 MARVELL INTERNATIONAL LTD.
5  * Copyright (C) 2009-2015 Semihalf
6  * Copyright (C) 2015 Stormshield
7  * All rights reserved.
8  *
9  * Developed by Semihalf.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions and the following disclaimer.
16  * 2. Redistributions in binary form must reproduce the above copyright
17  *    notice, this list of conditions and the following disclaimer in the
18  *    documentation and/or other materials provided with the distribution.
19  * 3. Neither the name of MARVELL nor the names of contributors
20  *    may be used to endorse or promote products derived from this software
21  *    without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  * SUCH DAMAGE.
34  */
35 
36 #ifdef HAVE_KERNEL_OPTION_HEADERS
37 #include "opt_device_polling.h"
38 #endif
39 
40 #include <sys/cdefs.h>
41 __FBSDID("$FreeBSD$");
42 
43 #include <sys/param.h>
44 #include <sys/systm.h>
45 #include <sys/endian.h>
46 #include <sys/mbuf.h>
47 #include <sys/lock.h>
48 #include <sys/mutex.h>
49 #include <sys/kernel.h>
50 #include <sys/module.h>
51 #include <sys/socket.h>
52 #include <sys/sysctl.h>
53 
54 #include <net/ethernet.h>
55 #include <net/bpf.h>
56 #include <net/if.h>
57 #include <net/if_arp.h>
58 #include <net/if_dl.h>
59 #include <net/if_media.h>
60 #include <net/if_types.h>
61 #include <net/if_vlan_var.h>
62 
63 #include <netinet/in_systm.h>
64 #include <netinet/in.h>
65 #include <netinet/ip.h>
66 
67 #include <sys/sockio.h>
68 #include <sys/bus.h>
69 #include <machine/bus.h>
70 #include <sys/rman.h>
71 #include <machine/resource.h>
72 
73 #include <dev/mii/mii.h>
74 #include <dev/mii/miivar.h>
75 
76 #include <dev/fdt/fdt_common.h>
77 #include <dev/ofw/ofw_bus.h>
78 #include <dev/ofw/ofw_bus_subr.h>
79 #include <dev/mdio/mdio.h>
80 
81 #include <dev/mge/if_mgevar.h>
82 #include <arm/mv/mvreg.h>
83 #include <arm/mv/mvvar.h>
84 
85 #include "miibus_if.h"
86 #include "mdio_if.h"
87 
88 #define	MGE_DELAY(x)	pause("SMI access sleep", (x) / tick_sbt)
89 
90 static int mge_probe(device_t dev);
91 static int mge_attach(device_t dev);
92 static int mge_detach(device_t dev);
93 static int mge_shutdown(device_t dev);
94 static int mge_suspend(device_t dev);
95 static int mge_resume(device_t dev);
96 
97 static int mge_miibus_readreg(device_t dev, int phy, int reg);
98 static int mge_miibus_writereg(device_t dev, int phy, int reg, int value);
99 
100 static int mge_mdio_readreg(device_t dev, int phy, int reg);
101 static int mge_mdio_writereg(device_t dev, int phy, int reg, int value);
102 
103 static int mge_ifmedia_upd(if_t ifp);
104 static void mge_ifmedia_sts(if_t ifp, struct ifmediareq *ifmr);
105 
106 static void mge_init(void *arg);
107 static void mge_init_locked(void *arg);
108 static void mge_start(if_t ifp);
109 static void mge_start_locked(if_t ifp);
110 static void mge_watchdog(struct mge_softc *sc);
111 static int mge_ioctl(if_t ifp, u_long command, caddr_t data);
112 
113 static uint32_t mge_tfut_ipg(uint32_t val, int ver);
114 static uint32_t mge_rx_ipg(uint32_t val, int ver);
115 static void mge_ver_params(struct mge_softc *sc);
116 
117 static void mge_intrs_ctrl(struct mge_softc *sc, int enable);
118 static void mge_intr_rxtx(void *arg);
119 static void mge_intr_rx(void *arg);
120 static void mge_intr_rx_check(struct mge_softc *sc, uint32_t int_cause,
121     uint32_t int_cause_ext);
122 static int mge_intr_rx_locked(struct mge_softc *sc, int count);
123 static void mge_intr_tx(void *arg);
124 static void mge_intr_tx_locked(struct mge_softc *sc);
125 static void mge_intr_misc(void *arg);
126 static void mge_intr_sum(void *arg);
127 static void mge_intr_err(void *arg);
128 static void mge_stop(struct mge_softc *sc);
129 static void mge_tick(void *msc);
130 static uint32_t mge_set_port_serial_control(uint32_t media);
131 static void mge_get_mac_address(struct mge_softc *sc, uint8_t *addr);
132 static void mge_set_mac_address(struct mge_softc *sc);
133 static void mge_set_ucast_address(struct mge_softc *sc, uint8_t last_byte,
134     uint8_t queue);
135 static void mge_set_prom_mode(struct mge_softc *sc, uint8_t queue);
136 static int mge_allocate_dma(struct mge_softc *sc);
137 static int mge_alloc_desc_dma(struct mge_softc *sc,
138     struct mge_desc_wrapper* desc_tab, uint32_t size,
139     bus_dma_tag_t *buffer_tag);
140 static int mge_new_rxbuf(bus_dma_tag_t tag, bus_dmamap_t map,
141     struct mbuf **mbufp, bus_addr_t *paddr);
142 static void mge_get_dma_addr(void *arg, bus_dma_segment_t *segs, int nseg,
143     int error);
144 static void mge_free_dma(struct mge_softc *sc);
145 static void mge_free_desc(struct mge_softc *sc, struct mge_desc_wrapper* tab,
146     uint32_t size, bus_dma_tag_t buffer_tag, uint8_t free_mbufs);
147 static void mge_offload_process_frame(if_t ifp, struct mbuf *frame,
148     uint32_t status, uint16_t bufsize);
149 static void mge_offload_setup_descriptor(struct mge_softc *sc,
150     struct mge_desc_wrapper *dw);
151 static uint8_t mge_crc8(uint8_t *data, int size);
152 static void mge_setup_multicast(struct mge_softc *sc);
153 static void mge_set_rxic(struct mge_softc *sc);
154 static void mge_set_txic(struct mge_softc *sc);
155 static void mge_add_sysctls(struct mge_softc *sc);
156 static int mge_sysctl_ic(SYSCTL_HANDLER_ARGS);
157 
158 static device_method_t mge_methods[] = {
159 	/* Device interface */
160 	DEVMETHOD(device_probe,		mge_probe),
161 	DEVMETHOD(device_attach,	mge_attach),
162 	DEVMETHOD(device_detach,	mge_detach),
163 	DEVMETHOD(device_shutdown,	mge_shutdown),
164 	DEVMETHOD(device_suspend,	mge_suspend),
165 	DEVMETHOD(device_resume,	mge_resume),
166 	/* MII interface */
167 	DEVMETHOD(miibus_readreg,	mge_miibus_readreg),
168 	DEVMETHOD(miibus_writereg,	mge_miibus_writereg),
169 	/* MDIO interface */
170 	DEVMETHOD(mdio_readreg,		mge_mdio_readreg),
171 	DEVMETHOD(mdio_writereg,	mge_mdio_writereg),
172 	{ 0, 0 }
173 };
174 
175 DEFINE_CLASS_0(mge, mge_driver, mge_methods, sizeof(struct mge_softc));
176 
177 static int switch_attached = 0;
178 
179 DRIVER_MODULE(mge, simplebus, mge_driver, 0, 0);
180 DRIVER_MODULE(miibus, mge, miibus_driver, 0, 0);
181 DRIVER_MODULE(mdio, mge, mdio_driver, 0, 0);
182 MODULE_DEPEND(mge, ether, 1, 1, 1);
183 MODULE_DEPEND(mge, miibus, 1, 1, 1);
184 MODULE_DEPEND(mge, mdio, 1, 1, 1);
185 
186 static struct resource_spec res_spec[] = {
187 	{ SYS_RES_MEMORY, 0, RF_ACTIVE },
188 	{ SYS_RES_IRQ, 0, RF_ACTIVE | RF_SHAREABLE },
189 	{ SYS_RES_IRQ, 1, RF_ACTIVE | RF_SHAREABLE },
190 	{ SYS_RES_IRQ, 2, RF_ACTIVE | RF_SHAREABLE },
191 	{ -1, 0 }
192 };
193 
194 static struct {
195 	driver_intr_t *handler;
196 	char * description;
197 } mge_intrs[MGE_INTR_COUNT + 1] = {
198 	{ mge_intr_rxtx,"GbE aggregated interrupt" },
199 	{ mge_intr_rx,	"GbE receive interrupt" },
200 	{ mge_intr_tx,	"GbE transmit interrupt" },
201 	{ mge_intr_misc,"GbE misc interrupt" },
202 	{ mge_intr_sum,	"GbE summary interrupt" },
203 	{ mge_intr_err,	"GbE error interrupt" },
204 };
205 
206 /* SMI access interlock */
207 static struct sx sx_smi;
208 
209 static uint32_t
210 mv_read_ge_smi(device_t dev, int phy, int reg)
211 {
212 	uint32_t timeout;
213 	uint32_t ret;
214 	struct mge_softc *sc;
215 
216 	sc = device_get_softc(dev);
217 	KASSERT(sc != NULL, ("NULL softc ptr!"));
218 	timeout = MGE_SMI_WRITE_RETRIES;
219 
220 	MGE_SMI_LOCK();
221 	while (--timeout &&
222 	    (MGE_READ(sc, MGE_REG_SMI) & MGE_SMI_BUSY))
223 		MGE_DELAY(MGE_SMI_WRITE_DELAY);
224 
225 	if (timeout == 0) {
226 		device_printf(dev, "SMI write timeout.\n");
227 		ret = ~0U;
228 		goto out;
229 	}
230 
231 	MGE_WRITE(sc, MGE_REG_SMI, MGE_SMI_MASK &
232 	    (MGE_SMI_READ | (reg << 21) | (phy << 16)));
233 
234 	/* Wait till finished. */
235 	timeout = MGE_SMI_WRITE_RETRIES;
236 	while (--timeout &&
237 	    !((MGE_READ(sc, MGE_REG_SMI) & MGE_SMI_READVALID)))
238 		MGE_DELAY(MGE_SMI_WRITE_DELAY);
239 
240 	if (timeout == 0) {
241 		device_printf(dev, "SMI write validation timeout.\n");
242 		ret = ~0U;
243 		goto out;
244 	}
245 
246 	/* Wait for the data to update in the SMI register */
247 	MGE_DELAY(MGE_SMI_DELAY);
248 	ret = MGE_READ(sc, MGE_REG_SMI) & MGE_SMI_DATA_MASK;
249 
250 out:
251 	MGE_SMI_UNLOCK();
252 	return (ret);
253 
254 }
255 
256 static void
257 mv_write_ge_smi(device_t dev, int phy, int reg, uint32_t value)
258 {
259 	uint32_t timeout;
260 	struct mge_softc *sc;
261 
262 	sc = device_get_softc(dev);
263 	KASSERT(sc != NULL, ("NULL softc ptr!"));
264 
265 	MGE_SMI_LOCK();
266 	timeout = MGE_SMI_READ_RETRIES;
267 	while (--timeout &&
268 	    (MGE_READ(sc, MGE_REG_SMI) & MGE_SMI_BUSY))
269 		MGE_DELAY(MGE_SMI_READ_DELAY);
270 
271 	if (timeout == 0) {
272 		device_printf(dev, "SMI read timeout.\n");
273 		goto out;
274 	}
275 
276 	MGE_WRITE(sc, MGE_REG_SMI, MGE_SMI_MASK &
277 	    (MGE_SMI_WRITE | (reg << 21) | (phy << 16) |
278 	    (value & MGE_SMI_DATA_MASK)));
279 
280 out:
281 	MGE_SMI_UNLOCK();
282 }
283 
284 static int
285 mv_read_ext_phy(device_t dev, int phy, int reg)
286 {
287 	uint32_t retries;
288 	struct mge_softc *sc;
289 	uint32_t ret;
290 
291 	sc = device_get_softc(dev);
292 
293 	MGE_SMI_LOCK();
294 	MGE_WRITE(sc->phy_sc, MGE_REG_SMI, MGE_SMI_MASK &
295 	    (MGE_SMI_READ | (reg << 21) | (phy << 16)));
296 
297 	retries = MGE_SMI_READ_RETRIES;
298 	while (--retries &&
299 	    !(MGE_READ(sc->phy_sc, MGE_REG_SMI) & MGE_SMI_READVALID))
300 		DELAY(MGE_SMI_READ_DELAY);
301 
302 	if (retries == 0)
303 		device_printf(dev, "Timeout while reading from PHY\n");
304 
305 	ret = MGE_READ(sc->phy_sc, MGE_REG_SMI) & MGE_SMI_DATA_MASK;
306 	MGE_SMI_UNLOCK();
307 
308 	return (ret);
309 }
310 
311 static void
312 mv_write_ext_phy(device_t dev, int phy, int reg, int value)
313 {
314 	uint32_t retries;
315 	struct mge_softc *sc;
316 
317 	sc = device_get_softc(dev);
318 
319 	MGE_SMI_LOCK();
320 	MGE_WRITE(sc->phy_sc, MGE_REG_SMI, MGE_SMI_MASK &
321 	    (MGE_SMI_WRITE | (reg << 21) | (phy << 16) |
322 	    (value & MGE_SMI_DATA_MASK)));
323 
324 	retries = MGE_SMI_WRITE_RETRIES;
325 	while (--retries && MGE_READ(sc->phy_sc, MGE_REG_SMI) & MGE_SMI_BUSY)
326 		DELAY(MGE_SMI_WRITE_DELAY);
327 
328 	if (retries == 0)
329 		device_printf(dev, "Timeout while writing to PHY\n");
330 	MGE_SMI_UNLOCK();
331 }
332 
333 static void
334 mge_get_mac_address(struct mge_softc *sc, uint8_t *addr)
335 {
336 	uint32_t mac_l, mac_h;
337 	uint8_t lmac[6];
338 	int i, valid;
339 
340 	/*
341 	 * Retrieve hw address from the device tree.
342 	 */
343 	i = OF_getprop(sc->node, "local-mac-address", (void *)lmac, 6);
344 	if (i == 6) {
345 		valid = 0;
346 		for (i = 0; i < 6; i++)
347 			if (lmac[i] != 0) {
348 				valid = 1;
349 				break;
350 			}
351 
352 		if (valid) {
353 			bcopy(lmac, addr, 6);
354 			return;
355 		}
356 	}
357 
358 	/*
359 	 * Fall back -- use the currently programmed address.
360 	 */
361 	mac_l = MGE_READ(sc, MGE_MAC_ADDR_L);
362 	mac_h = MGE_READ(sc, MGE_MAC_ADDR_H);
363 
364 	addr[0] = (mac_h & 0xff000000) >> 24;
365 	addr[1] = (mac_h & 0x00ff0000) >> 16;
366 	addr[2] = (mac_h & 0x0000ff00) >> 8;
367 	addr[3] = (mac_h & 0x000000ff);
368 	addr[4] = (mac_l & 0x0000ff00) >> 8;
369 	addr[5] = (mac_l & 0x000000ff);
370 }
371 
372 static uint32_t
373 mge_tfut_ipg(uint32_t val, int ver)
374 {
375 
376 	switch (ver) {
377 	case 1:
378 		return ((val & 0x3fff) << 4);
379 	case 2:
380 	default:
381 		return ((val & 0xffff) << 4);
382 	}
383 }
384 
385 static uint32_t
386 mge_rx_ipg(uint32_t val, int ver)
387 {
388 
389 	switch (ver) {
390 	case 1:
391 		return ((val & 0x3fff) << 8);
392 	case 2:
393 	default:
394 		return (((val & 0x8000) << 10) | ((val & 0x7fff) << 7));
395 	}
396 }
397 
398 static void
399 mge_ver_params(struct mge_softc *sc)
400 {
401 	uint32_t d, r;
402 
403 	soc_id(&d, &r);
404 	if (d == MV_DEV_88F6281 || d == MV_DEV_88F6781 ||
405 	    d == MV_DEV_88F6282 ||
406 	    d == MV_DEV_MV78100 ||
407 	    d == MV_DEV_MV78100_Z0 ||
408 	    (d & MV_DEV_FAMILY_MASK) == MV_DEV_DISCOVERY) {
409 		sc->mge_ver = 2;
410 		sc->mge_mtu = 0x4e8;
411 		sc->mge_tfut_ipg_max = 0xFFFF;
412 		sc->mge_rx_ipg_max = 0xFFFF;
413 		sc->mge_tx_arb_cfg = 0xFC0000FF;
414 		sc->mge_tx_tok_cfg = 0xFFFF7FFF;
415 		sc->mge_tx_tok_cnt = 0x3FFFFFFF;
416 	} else {
417 		sc->mge_ver = 1;
418 		sc->mge_mtu = 0x458;
419 		sc->mge_tfut_ipg_max = 0x3FFF;
420 		sc->mge_rx_ipg_max = 0x3FFF;
421 		sc->mge_tx_arb_cfg = 0x000000FF;
422 		sc->mge_tx_tok_cfg = 0x3FFFFFFF;
423 		sc->mge_tx_tok_cnt = 0x3FFFFFFF;
424 	}
425 	if (d == MV_DEV_88RC8180)
426 		sc->mge_intr_cnt = 1;
427 	else
428 		sc->mge_intr_cnt = 2;
429 
430 	if (d == MV_DEV_MV78160 || d == MV_DEV_MV78260 || d == MV_DEV_MV78460)
431 		sc->mge_hw_csum = 0;
432 	else
433 		sc->mge_hw_csum = 1;
434 }
435 
436 static void
437 mge_set_mac_address(struct mge_softc *sc)
438 {
439 	char *if_mac;
440 	uint32_t mac_l, mac_h;
441 
442 	MGE_GLOBAL_LOCK_ASSERT(sc);
443 
444 	if_mac = (char *)if_getlladdr(sc->ifp);
445 
446 	mac_l = (if_mac[4] << 8) | (if_mac[5]);
447 	mac_h = (if_mac[0] << 24)| (if_mac[1] << 16) |
448 	    (if_mac[2] << 8) | (if_mac[3] << 0);
449 
450 	MGE_WRITE(sc, MGE_MAC_ADDR_L, mac_l);
451 	MGE_WRITE(sc, MGE_MAC_ADDR_H, mac_h);
452 
453 	mge_set_ucast_address(sc, if_mac[5], MGE_RX_DEFAULT_QUEUE);
454 }
455 
456 static void
457 mge_set_ucast_address(struct mge_softc *sc, uint8_t last_byte, uint8_t queue)
458 {
459 	uint32_t reg_idx, reg_off, reg_val, i;
460 
461 	last_byte &= 0xf;
462 	reg_idx = last_byte / MGE_UCAST_REG_NUMBER;
463 	reg_off = (last_byte % MGE_UCAST_REG_NUMBER) * 8;
464 	reg_val = (1 | (queue << 1)) << reg_off;
465 
466 	for (i = 0; i < MGE_UCAST_REG_NUMBER; i++) {
467 		if ( i == reg_idx)
468 			MGE_WRITE(sc, MGE_DA_FILTER_UCAST(i), reg_val);
469 		else
470 			MGE_WRITE(sc, MGE_DA_FILTER_UCAST(i), 0);
471 	}
472 }
473 
474 static void
475 mge_set_prom_mode(struct mge_softc *sc, uint8_t queue)
476 {
477 	uint32_t port_config;
478 	uint32_t reg_val, i;
479 
480 	/* Enable or disable promiscuous mode as needed */
481 	if (sc->if_getflags(ifp) & IFF_PROMISC) {
482 		port_config = MGE_READ(sc, MGE_PORT_CONFIG);
483 		port_config |= PORT_CONFIG_UPM;
484 		MGE_WRITE(sc, MGE_PORT_CONFIG, port_config);
485 
486 		reg_val = ((1 | (queue << 1)) | (1 | (queue << 1)) << 8 |
487 		   (1 | (queue << 1)) << 16 | (1 | (queue << 1)) << 24);
488 
489 		for (i = 0; i < MGE_MCAST_REG_NUMBER; i++) {
490 			MGE_WRITE(sc, MGE_DA_FILTER_SPEC_MCAST(i), reg_val);
491 			MGE_WRITE(sc, MGE_DA_FILTER_OTH_MCAST(i), reg_val);
492 		}
493 
494 		for (i = 0; i < MGE_UCAST_REG_NUMBER; i++)
495 			MGE_WRITE(sc, MGE_DA_FILTER_UCAST(i), reg_val);
496 
497 	} else {
498 		port_config = MGE_READ(sc, MGE_PORT_CONFIG);
499 		port_config &= ~PORT_CONFIG_UPM;
500 		MGE_WRITE(sc, MGE_PORT_CONFIG, port_config);
501 
502 		for (i = 0; i < MGE_MCAST_REG_NUMBER; i++) {
503 			MGE_WRITE(sc, MGE_DA_FILTER_SPEC_MCAST(i), 0);
504 			MGE_WRITE(sc, MGE_DA_FILTER_OTH_MCAST(i), 0);
505 		}
506 
507 		mge_set_mac_address(sc);
508 	}
509 }
510 
511 static void
512 mge_get_dma_addr(void *arg, bus_dma_segment_t *segs, int nseg, int error)
513 {
514 	u_int32_t *paddr;
515 
516 	KASSERT(nseg == 1, ("wrong number of segments, should be 1"));
517 	paddr = arg;
518 
519 	*paddr = segs->ds_addr;
520 }
521 
522 static int
523 mge_new_rxbuf(bus_dma_tag_t tag, bus_dmamap_t map, struct mbuf **mbufp,
524     bus_addr_t *paddr)
525 {
526 	struct mbuf *new_mbuf;
527 	bus_dma_segment_t seg[1];
528 	int error;
529 	int nsegs;
530 
531 	KASSERT(mbufp != NULL, ("NULL mbuf pointer!"));
532 
533 	new_mbuf = m_getcl(M_NOWAIT, MT_DATA, M_PKTHDR);
534 	if (new_mbuf == NULL)
535 		return (ENOBUFS);
536 	new_mbuf->m_len = new_mbuf->m_pkthdr.len = new_mbuf->m_ext.ext_size;
537 
538 	if (*mbufp) {
539 		bus_dmamap_sync(tag, map, BUS_DMASYNC_POSTREAD);
540 		bus_dmamap_unload(tag, map);
541 	}
542 
543 	error = bus_dmamap_load_mbuf_sg(tag, map, new_mbuf, seg, &nsegs,
544 	    BUS_DMA_NOWAIT);
545 	KASSERT(nsegs == 1, ("Too many segments returned!"));
546 	if (nsegs != 1 || error)
547 		panic("mge_new_rxbuf(): nsegs(%d), error(%d)", nsegs, error);
548 
549 	bus_dmamap_sync(tag, map, BUS_DMASYNC_PREREAD);
550 
551 	(*mbufp) = new_mbuf;
552 	(*paddr) = seg->ds_addr;
553 	return (0);
554 }
555 
556 static int
557 mge_alloc_desc_dma(struct mge_softc *sc, struct mge_desc_wrapper* tab,
558     uint32_t size, bus_dma_tag_t *buffer_tag)
559 {
560 	struct mge_desc_wrapper *dw;
561 	bus_addr_t desc_paddr;
562 	int i, error;
563 
564 	desc_paddr = 0;
565 	for (i = size - 1; i >= 0; i--) {
566 		dw = &(tab[i]);
567 		error = bus_dmamem_alloc(sc->mge_desc_dtag,
568 		    (void**)&(dw->mge_desc),
569 		    BUS_DMA_NOWAIT | BUS_DMA_ZERO | BUS_DMA_COHERENT,
570 		    &(dw->desc_dmap));
571 
572 		if (error) {
573 			if_printf(sc->ifp, "failed to allocate DMA memory\n");
574 			dw->mge_desc = NULL;
575 			return (ENXIO);
576 		}
577 
578 		error = bus_dmamap_load(sc->mge_desc_dtag, dw->desc_dmap,
579 		    dw->mge_desc, sizeof(struct mge_desc), mge_get_dma_addr,
580 		    &(dw->mge_desc_paddr), BUS_DMA_NOWAIT);
581 
582 		if (error) {
583 			if_printf(sc->ifp, "can't load descriptor\n");
584 			bus_dmamem_free(sc->mge_desc_dtag, dw->mge_desc,
585 			    dw->desc_dmap);
586 			dw->mge_desc = NULL;
587 			return (ENXIO);
588 		}
589 
590 		/* Chain descriptors */
591 		dw->mge_desc->next_desc = desc_paddr;
592 		desc_paddr = dw->mge_desc_paddr;
593 	}
594 	tab[size - 1].mge_desc->next_desc = desc_paddr;
595 
596 	/* Allocate a busdma tag for mbufs. */
597 	error = bus_dma_tag_create(bus_get_dma_tag(sc->dev),	/* parent */
598 	    1, 0,				/* alignment, boundary */
599 	    BUS_SPACE_MAXADDR_32BIT,		/* lowaddr */
600 	    BUS_SPACE_MAXADDR,			/* highaddr */
601 	    NULL, NULL,				/* filtfunc, filtfuncarg */
602 	    MCLBYTES, 1,			/* maxsize, nsegments */
603 	    MCLBYTES, 0,			/* maxsegsz, flags */
604 	    NULL, NULL,				/* lockfunc, lockfuncarg */
605 	    buffer_tag);			/* dmat */
606 	if (error) {
607 		if_printf(sc->ifp, "failed to create busdma tag for mbufs\n");
608 		return (ENXIO);
609 	}
610 
611 	/* Create TX busdma maps */
612 	for (i = 0; i < size; i++) {
613 		dw = &(tab[i]);
614 		error = bus_dmamap_create(*buffer_tag, 0, &dw->buffer_dmap);
615 		if (error) {
616 			if_printf(sc->ifp, "failed to create map for mbuf\n");
617 			return (ENXIO);
618 		}
619 
620 		dw->buffer = (struct mbuf*)NULL;
621 		dw->mge_desc->buffer = (bus_addr_t)NULL;
622 	}
623 
624 	return (0);
625 }
626 
627 static int
628 mge_allocate_dma(struct mge_softc *sc)
629 {
630 	struct mge_desc_wrapper *dw;
631 	int i;
632 
633 	/* Allocate a busdma tag and DMA safe memory for TX/RX descriptors. */
634 	bus_dma_tag_create(bus_get_dma_tag(sc->dev),	/* parent */
635 	    16, 0,				/* alignment, boundary */
636 	    BUS_SPACE_MAXADDR_32BIT,		/* lowaddr */
637 	    BUS_SPACE_MAXADDR,			/* highaddr */
638 	    NULL, NULL,				/* filtfunc, filtfuncarg */
639 	    sizeof(struct mge_desc), 1,		/* maxsize, nsegments */
640 	    sizeof(struct mge_desc), 0,		/* maxsegsz, flags */
641 	    NULL, NULL,				/* lockfunc, lockfuncarg */
642 	    &sc->mge_desc_dtag);		/* dmat */
643 
644 
645 	mge_alloc_desc_dma(sc, sc->mge_tx_desc, MGE_TX_DESC_NUM,
646 	    &sc->mge_tx_dtag);
647 	mge_alloc_desc_dma(sc, sc->mge_rx_desc, MGE_RX_DESC_NUM,
648 	    &sc->mge_rx_dtag);
649 
650 	for (i = 0; i < MGE_RX_DESC_NUM; i++) {
651 		dw = &(sc->mge_rx_desc[i]);
652 		mge_new_rxbuf(sc->mge_rx_dtag, dw->buffer_dmap, &dw->buffer,
653 		    &dw->mge_desc->buffer);
654 	}
655 
656 	sc->tx_desc_start = sc->mge_tx_desc[0].mge_desc_paddr;
657 	sc->rx_desc_start = sc->mge_rx_desc[0].mge_desc_paddr;
658 
659 	return (0);
660 }
661 
662 static void
663 mge_free_desc(struct mge_softc *sc, struct mge_desc_wrapper* tab,
664     uint32_t size, bus_dma_tag_t buffer_tag, uint8_t free_mbufs)
665 {
666 	struct mge_desc_wrapper *dw;
667 	int i;
668 
669 	for (i = 0; i < size; i++) {
670 		/* Free RX mbuf */
671 		dw = &(tab[i]);
672 
673 		if (dw->buffer_dmap) {
674 			if (free_mbufs) {
675 				bus_dmamap_sync(buffer_tag, dw->buffer_dmap,
676 				    BUS_DMASYNC_POSTREAD);
677 				bus_dmamap_unload(buffer_tag, dw->buffer_dmap);
678 			}
679 			bus_dmamap_destroy(buffer_tag, dw->buffer_dmap);
680 			if (free_mbufs)
681 				m_freem(dw->buffer);
682 		}
683 		/* Free RX descriptors */
684 		if (dw->desc_dmap) {
685 			bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
686 			    BUS_DMASYNC_POSTREAD);
687 			bus_dmamap_unload(sc->mge_desc_dtag, dw->desc_dmap);
688 			bus_dmamem_free(sc->mge_desc_dtag, dw->mge_desc,
689 			    dw->desc_dmap);
690 		}
691 	}
692 }
693 
694 static void
695 mge_free_dma(struct mge_softc *sc)
696 {
697 
698 	/* Free descriptors and mbufs */
699 	mge_free_desc(sc, sc->mge_rx_desc, MGE_RX_DESC_NUM, sc->mge_rx_dtag, 1);
700 	mge_free_desc(sc, sc->mge_tx_desc, MGE_TX_DESC_NUM, sc->mge_tx_dtag, 0);
701 
702 	/* Destroy mbuf dma tag */
703 	bus_dma_tag_destroy(sc->mge_tx_dtag);
704 	bus_dma_tag_destroy(sc->mge_rx_dtag);
705 	/* Destroy descriptors tag */
706 	bus_dma_tag_destroy(sc->mge_desc_dtag);
707 }
708 
709 static void
710 mge_reinit_rx(struct mge_softc *sc)
711 {
712 	struct mge_desc_wrapper *dw;
713 	int i;
714 
715 	MGE_RECEIVE_LOCK_ASSERT(sc);
716 
717 	mge_free_desc(sc, sc->mge_rx_desc, MGE_RX_DESC_NUM, sc->mge_rx_dtag, 1);
718 
719 	mge_alloc_desc_dma(sc, sc->mge_rx_desc, MGE_RX_DESC_NUM,
720 	    &sc->mge_rx_dtag);
721 
722 	for (i = 0; i < MGE_RX_DESC_NUM; i++) {
723 		dw = &(sc->mge_rx_desc[i]);
724 		mge_new_rxbuf(sc->mge_rx_dtag, dw->buffer_dmap, &dw->buffer,
725 		&dw->mge_desc->buffer);
726 	}
727 
728 	sc->rx_desc_start = sc->mge_rx_desc[0].mge_desc_paddr;
729 	sc->rx_desc_curr = 0;
730 
731 	MGE_WRITE(sc, MGE_RX_CUR_DESC_PTR(MGE_RX_DEFAULT_QUEUE),
732 	    sc->rx_desc_start);
733 
734 	/* Enable RX queue */
735 	MGE_WRITE(sc, MGE_RX_QUEUE_CMD, MGE_ENABLE_RXQ(MGE_RX_DEFAULT_QUEUE));
736 }
737 
738 #ifdef DEVICE_POLLING
739 static poll_handler_t mge_poll;
740 
741 static int
742 mge_poll(if_t ifp, enum poll_cmd cmd, int count)
743 {
744 	struct mge_softc *sc = if_getsoftc(ifp);
745 	uint32_t int_cause, int_cause_ext;
746 	int rx_npkts = 0;
747 
748 	MGE_RECEIVE_LOCK(sc);
749 
750 	if (!(if_getdrvflags(ifp) & IFF_DRV_RUNNING)) {
751 		MGE_RECEIVE_UNLOCK(sc);
752 		return (rx_npkts);
753 	}
754 
755 	if (cmd == POLL_AND_CHECK_STATUS) {
756 		int_cause = MGE_READ(sc, MGE_PORT_INT_CAUSE);
757 		int_cause_ext = MGE_READ(sc, MGE_PORT_INT_CAUSE_EXT);
758 
759 		/* Check for resource error */
760 		if (int_cause & MGE_PORT_INT_RXERRQ0)
761 			mge_reinit_rx(sc);
762 
763 		if (int_cause || int_cause_ext) {
764 			MGE_WRITE(sc, MGE_PORT_INT_CAUSE, ~int_cause);
765 			MGE_WRITE(sc, MGE_PORT_INT_CAUSE_EXT, ~int_cause_ext);
766 		}
767 	}
768 
769 
770 	rx_npkts = mge_intr_rx_locked(sc, count);
771 
772 	MGE_RECEIVE_UNLOCK(sc);
773 	MGE_TRANSMIT_LOCK(sc);
774 	mge_intr_tx_locked(sc);
775 	MGE_TRANSMIT_UNLOCK(sc);
776 	return (rx_npkts);
777 }
778 #endif /* DEVICE_POLLING */
779 
780 static int
781 mge_attach(device_t dev)
782 {
783 	struct mge_softc *sc;
784 	struct mii_softc *miisc;
785 	if_t ifp;
786 	uint8_t hwaddr[ETHER_ADDR_LEN];
787 	int i, error, phy;
788 
789 	sc = device_get_softc(dev);
790 	sc->dev = dev;
791 	sc->node = ofw_bus_get_node(dev);
792 	phy = 0;
793 
794 	if (fdt_get_phyaddr(sc->node, sc->dev, &phy, (void **)&sc->phy_sc) == 0) {
795 		device_printf(dev, "PHY%i attached, phy_sc points to %s\n", phy,
796 		    device_get_nameunit(sc->phy_sc->dev));
797 		sc->phy_attached = 1;
798 	} else {
799 		device_printf(dev, "PHY not attached.\n");
800 		sc->phy_attached = 0;
801 		sc->phy_sc = sc;
802 	}
803 
804 	if (fdt_find_compatible(sc->node, "mrvl,sw", 1) != 0) {
805 		device_printf(dev, "Switch attached.\n");
806 		sc->switch_attached = 1;
807 		/* additional variable available across instances */
808 		switch_attached = 1;
809 	} else {
810 		sc->switch_attached = 0;
811 	}
812 
813 	if (device_get_unit(dev) == 0) {
814 		sx_init(&sx_smi, "mge_tick() SMI access threads interlock");
815 	}
816 
817 	/* Set chip version-dependent parameters */
818 	mge_ver_params(sc);
819 
820 	/* Initialize mutexes */
821 	mtx_init(&sc->transmit_lock, device_get_nameunit(dev), "mge TX lock",
822 	    MTX_DEF);
823 	mtx_init(&sc->receive_lock, device_get_nameunit(dev), "mge RX lock",
824 	    MTX_DEF);
825 
826 	/* Allocate IO and IRQ resources */
827 	error = bus_alloc_resources(dev, res_spec, sc->res);
828 	if (error) {
829 		device_printf(dev, "could not allocate resources\n");
830 		mge_detach(dev);
831 		return (ENXIO);
832 	}
833 
834 	/* Allocate DMA, buffers, buffer descriptors */
835 	error = mge_allocate_dma(sc);
836 	if (error) {
837 		mge_detach(dev);
838 		return (ENXIO);
839 	}
840 
841 	sc->tx_desc_curr = 0;
842 	sc->rx_desc_curr = 0;
843 	sc->tx_desc_used_idx = 0;
844 	sc->tx_desc_used_count = 0;
845 
846 	/* Configure defaults for interrupts coalescing */
847 	sc->rx_ic_time = 768;
848 	sc->tx_ic_time = 768;
849 	mge_add_sysctls(sc);
850 
851 	/* Allocate network interface */
852 	ifp = sc->ifp = if_alloc(IFT_ETHER);
853 	if (ifp == NULL) {
854 		device_printf(dev, "if_alloc() failed\n");
855 		mge_detach(dev);
856 		return (ENOMEM);
857 	}
858 
859 	if_initname(ifp, device_get_name(dev), device_get_unit(dev));
860 	if_setsoftc(ifp, sc);
861 	if_setflags(ifp, IFF_SIMPLEX | IFF_MULTICAST | IFF_BROADCAST);
862 	if_setcapabilities(ifp, IFCAP_VLAN_MTU);
863 	if (sc->mge_hw_csum) {
864 		if_setcapabilitiesbit(ifp, IFCAP_HWCSUM, 0);
865 		if_sethwassist(ifp, MGE_CHECKSUM_FEATURES);
866 	}
867 	if_setcapenable(ifp, if_getcapabilities(ifp));
868 
869 #ifdef DEVICE_POLLING
870 	/* Advertise that polling is supported */
871 	if_setcapabilitiesbit(ifp, IFCAP_POLLING, 0);
872 #endif
873 
874 	if_setinitfn(ifp, mge_init);
875 	if_setstartfn(ifp, mge_start);
876 	if_setioctlfn(ifp, mge_ioctl);
877 
878 	if_setsendqlen(ifp, MGE_TX_DESC_NUM - 1);
879 	if_setsendqready(ifp);
880 
881 	mge_get_mac_address(sc, hwaddr);
882 	ether_ifattach(ifp, hwaddr);
883 	callout_init(&sc->wd_callout, 1);
884 
885 	/* Attach PHY(s) */
886 	if (sc->phy_attached) {
887 		error = mii_attach(dev, &sc->miibus, ifp, mge_ifmedia_upd,
888 		    mge_ifmedia_sts, BMSR_DEFCAPMASK, phy, MII_OFFSET_ANY, 0);
889 		if (error) {
890 			device_printf(dev, "MII failed to find PHY\n");
891 			if_free(ifp);
892 			sc->ifp = NULL;
893 			mge_detach(dev);
894 			return (error);
895 		}
896 		sc->mii = device_get_softc(sc->miibus);
897 
898 		/* Tell the MAC where to find the PHY so autoneg works */
899 		miisc = LIST_FIRST(&sc->mii->mii_phys);
900 		MGE_WRITE(sc, MGE_REG_PHYDEV, miisc->mii_phy);
901 	} else {
902 		/* no PHY, so use hard-coded values */
903 		ifmedia_init(&sc->mge_ifmedia, 0,
904 		    mge_ifmedia_upd,
905 		    mge_ifmedia_sts);
906 		ifmedia_add(&sc->mge_ifmedia,
907 		    IFM_ETHER | IFM_1000_T | IFM_FDX,
908 		    0, NULL);
909 		ifmedia_set(&sc->mge_ifmedia,
910 		    IFM_ETHER | IFM_1000_T | IFM_FDX);
911 	}
912 
913 	/* Attach interrupt handlers */
914 	/* TODO: review flags, in part. mark RX as INTR_ENTROPY ? */
915 	for (i = 1; i <= sc->mge_intr_cnt; ++i) {
916 		error = bus_setup_intr(dev, sc->res[i],
917 		    INTR_TYPE_NET | INTR_MPSAFE,
918 		    NULL, *mge_intrs[(sc->mge_intr_cnt == 1 ? 0 : i)].handler,
919 		    sc, &sc->ih_cookie[i - 1]);
920 		if (error) {
921 			device_printf(dev, "could not setup %s\n",
922 			    mge_intrs[(sc->mge_intr_cnt == 1 ? 0 : i)].description);
923 			mge_detach(dev);
924 			return (error);
925 		}
926 	}
927 
928 	if (sc->switch_attached) {
929 		MGE_WRITE(sc, MGE_REG_PHYDEV, MGE_SWITCH_PHYDEV);
930 		device_add_child(dev, "mdio", -1);
931 		bus_generic_attach(dev);
932 	}
933 
934 	return (0);
935 }
936 
937 static int
938 mge_detach(device_t dev)
939 {
940 	struct mge_softc *sc;
941 	int error,i;
942 
943 	sc = device_get_softc(dev);
944 
945 	/* Stop controller and free TX queue */
946 	if (sc->ifp)
947 		mge_shutdown(dev);
948 
949 	/* Wait for stopping ticks */
950         callout_drain(&sc->wd_callout);
951 
952 	/* Stop and release all interrupts */
953 	for (i = 0; i < sc->mge_intr_cnt; ++i) {
954 		if (!sc->ih_cookie[i])
955 			continue;
956 
957 		error = bus_teardown_intr(dev, sc->res[1 + i],
958 		    sc->ih_cookie[i]);
959 		if (error)
960 			device_printf(dev, "could not release %s\n",
961 			    mge_intrs[(sc->mge_intr_cnt == 1 ? 0 : i + 1)].description);
962 	}
963 
964 	/* Detach network interface */
965 	if (sc->ifp) {
966 		ether_ifdetach(sc->ifp);
967 		if_free(sc->ifp);
968 	}
969 
970 	/* Free DMA resources */
971 	mge_free_dma(sc);
972 
973 	/* Free IO memory handler */
974 	bus_release_resources(dev, res_spec, sc->res);
975 
976 	/* Destroy mutexes */
977 	mtx_destroy(&sc->receive_lock);
978 	mtx_destroy(&sc->transmit_lock);
979 
980 	if (device_get_unit(dev) == 0)
981 		sx_destroy(&sx_smi);
982 
983 	return (0);
984 }
985 
986 static void
987 mge_ifmedia_sts(if_t ifp, struct ifmediareq *ifmr)
988 {
989 	struct mge_softc *sc;
990 	struct mii_data *mii;
991 
992 	sc = if_getsoftc(ifp);
993 	MGE_GLOBAL_LOCK(sc);
994 
995 	if (!sc->phy_attached) {
996 		ifmr->ifm_active = IFM_1000_T | IFM_FDX | IFM_ETHER;
997 		ifmr->ifm_status = IFM_AVALID | IFM_ACTIVE;
998 		goto out_unlock;
999 	}
1000 
1001 	mii = sc->mii;
1002 	mii_pollstat(mii);
1003 
1004 	ifmr->ifm_active = mii->mii_media_active;
1005 	ifmr->ifm_status = mii->mii_media_status;
1006 
1007 out_unlock:
1008 	MGE_GLOBAL_UNLOCK(sc);
1009 }
1010 
1011 static uint32_t
1012 mge_set_port_serial_control(uint32_t media)
1013 {
1014 	uint32_t port_config;
1015 
1016 	port_config = PORT_SERIAL_RES_BIT9 | PORT_SERIAL_FORCE_LINK_FAIL |
1017 	    PORT_SERIAL_MRU(PORT_SERIAL_MRU_1552);
1018 
1019 	if (IFM_TYPE(media) == IFM_ETHER) {
1020 		switch(IFM_SUBTYPE(media)) {
1021 			case IFM_AUTO:
1022 				break;
1023 			case IFM_1000_T:
1024 				port_config  |= (PORT_SERIAL_GMII_SPEED_1000 |
1025 				    PORT_SERIAL_AUTONEG | PORT_SERIAL_AUTONEG_FC
1026 				    | PORT_SERIAL_SPEED_AUTONEG);
1027 				break;
1028 			case IFM_100_TX:
1029 				port_config  |= (PORT_SERIAL_MII_SPEED_100 |
1030 				    PORT_SERIAL_AUTONEG | PORT_SERIAL_AUTONEG_FC
1031 				    | PORT_SERIAL_SPEED_AUTONEG);
1032 				break;
1033 			case IFM_10_T:
1034 				port_config  |= (PORT_SERIAL_AUTONEG |
1035 				    PORT_SERIAL_AUTONEG_FC |
1036 				    PORT_SERIAL_SPEED_AUTONEG);
1037 				break;
1038 		}
1039 		if (media & IFM_FDX)
1040 			port_config |= PORT_SERIAL_FULL_DUPLEX;
1041 	}
1042 	return (port_config);
1043 }
1044 
1045 static int
1046 mge_ifmedia_upd(if_t ifp)
1047 {
1048 	struct mge_softc *sc = if_getsoftc(ifp);
1049 
1050 	/*
1051 	 * Do not do anything for switch here, as updating media between
1052 	 * MGE MAC and switch MAC is hardcoded in PCB. Changing it here would
1053 	 * break the link.
1054 	 */
1055 	if (sc->phy_attached) {
1056 		MGE_GLOBAL_LOCK(sc);
1057 		if (if_getflags(ifp) & IFF_UP) {
1058 			sc->mge_media_status = sc->mii->mii_media.ifm_media;
1059 			mii_mediachg(sc->mii);
1060 
1061 			/* MGE MAC needs to be reinitialized. */
1062 			mge_init_locked(sc);
1063 
1064 		}
1065 		MGE_GLOBAL_UNLOCK(sc);
1066 	}
1067 
1068 	return (0);
1069 }
1070 
1071 static void
1072 mge_init(void *arg)
1073 {
1074 	struct mge_softc *sc;
1075 
1076 	sc = arg;
1077 	MGE_GLOBAL_LOCK(sc);
1078 
1079 	mge_init_locked(arg);
1080 
1081 	MGE_GLOBAL_UNLOCK(sc);
1082 }
1083 
1084 static void
1085 mge_init_locked(void *arg)
1086 {
1087 	struct mge_softc *sc = arg;
1088 	struct mge_desc_wrapper *dw;
1089 	volatile uint32_t reg_val;
1090 	int i, count;
1091 	uint32_t media_status;
1092 
1093 
1094 	MGE_GLOBAL_LOCK_ASSERT(sc);
1095 
1096 	/* Stop interface */
1097 	mge_stop(sc);
1098 
1099 	/* Disable interrupts */
1100 	mge_intrs_ctrl(sc, 0);
1101 
1102 	/* Set MAC address */
1103 	mge_set_mac_address(sc);
1104 
1105 	/* Setup multicast filters */
1106 	mge_setup_multicast(sc);
1107 
1108 	if (sc->mge_ver == 2) {
1109 		MGE_WRITE(sc, MGE_PORT_SERIAL_CTRL1, MGE_RGMII_EN);
1110 		MGE_WRITE(sc, MGE_FIXED_PRIO_CONF, MGE_FIXED_PRIO_EN(0));
1111 	}
1112 
1113 	/* Initialize TX queue configuration registers */
1114 	MGE_WRITE(sc, MGE_TX_TOKEN_COUNT(0), sc->mge_tx_tok_cnt);
1115 	MGE_WRITE(sc, MGE_TX_TOKEN_CONF(0), sc->mge_tx_tok_cfg);
1116 	MGE_WRITE(sc, MGE_TX_ARBITER_CONF(0), sc->mge_tx_arb_cfg);
1117 
1118 	/* Clear TX queue configuration registers for unused queues */
1119 	for (i = 1; i < 7; i++) {
1120 		MGE_WRITE(sc, MGE_TX_TOKEN_COUNT(i), 0);
1121 		MGE_WRITE(sc, MGE_TX_TOKEN_CONF(i), 0);
1122 		MGE_WRITE(sc, MGE_TX_ARBITER_CONF(i), 0);
1123 	}
1124 
1125 	/* Set default MTU */
1126 	MGE_WRITE(sc, sc->mge_mtu, 0);
1127 
1128 	/* Port configuration */
1129 	MGE_WRITE(sc, MGE_PORT_CONFIG,
1130 	    PORT_CONFIG_RXCS | PORT_CONFIG_DFLT_RXQ(0) |
1131 	    PORT_CONFIG_ARO_RXQ(0));
1132 	MGE_WRITE(sc, MGE_PORT_EXT_CONFIG , 0x0);
1133 
1134 	/* Configure promisc mode */
1135 	mge_set_prom_mode(sc, MGE_RX_DEFAULT_QUEUE);
1136 
1137 	media_status = sc->mge_media_status;
1138 	if (sc->switch_attached) {
1139 		media_status &= ~IFM_TMASK;
1140 		media_status |= IFM_1000_T;
1141 	}
1142 
1143 	/* Setup port configuration */
1144 	reg_val = mge_set_port_serial_control(media_status);
1145 	MGE_WRITE(sc, MGE_PORT_SERIAL_CTRL, reg_val);
1146 
1147 	/* Setup SDMA configuration */
1148 	MGE_WRITE(sc, MGE_SDMA_CONFIG , MGE_SDMA_RX_BYTE_SWAP |
1149 	    MGE_SDMA_TX_BYTE_SWAP |
1150 	    MGE_SDMA_RX_BURST_SIZE(MGE_SDMA_BURST_16_WORD) |
1151 	    MGE_SDMA_TX_BURST_SIZE(MGE_SDMA_BURST_16_WORD));
1152 
1153 	MGE_WRITE(sc, MGE_TX_FIFO_URGENT_TRSH, 0x0);
1154 
1155 	MGE_WRITE(sc, MGE_TX_CUR_DESC_PTR, sc->tx_desc_start);
1156 	MGE_WRITE(sc, MGE_RX_CUR_DESC_PTR(MGE_RX_DEFAULT_QUEUE),
1157 	    sc->rx_desc_start);
1158 
1159 	/* Reset descriptor indexes */
1160 	sc->tx_desc_curr = 0;
1161 	sc->rx_desc_curr = 0;
1162 	sc->tx_desc_used_idx = 0;
1163 	sc->tx_desc_used_count = 0;
1164 
1165 	/* Enable RX descriptors */
1166 	for (i = 0; i < MGE_RX_DESC_NUM; i++) {
1167 		dw = &sc->mge_rx_desc[i];
1168 		dw->mge_desc->cmd_status = MGE_RX_ENABLE_INT | MGE_DMA_OWNED;
1169 		dw->mge_desc->buff_size = MCLBYTES;
1170 		bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1171 		    BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
1172 	}
1173 
1174 	/* Enable RX queue */
1175 	MGE_WRITE(sc, MGE_RX_QUEUE_CMD, MGE_ENABLE_RXQ(MGE_RX_DEFAULT_QUEUE));
1176 
1177 	/* Enable port */
1178 	reg_val = MGE_READ(sc, MGE_PORT_SERIAL_CTRL);
1179 	reg_val |= PORT_SERIAL_ENABLE;
1180 	MGE_WRITE(sc, MGE_PORT_SERIAL_CTRL, reg_val);
1181 	count = 0x100000;
1182 	for (;;) {
1183 		reg_val = MGE_READ(sc, MGE_PORT_STATUS);
1184 		if (reg_val & MGE_STATUS_LINKUP)
1185 			break;
1186 		DELAY(100);
1187 		if (--count == 0) {
1188 			if_printf(sc->ifp, "Timeout on link-up\n");
1189 			break;
1190 		}
1191 	}
1192 
1193 	/* Setup interrupts coalescing */
1194 	mge_set_rxic(sc);
1195 	mge_set_txic(sc);
1196 
1197 	/* Enable interrupts */
1198 #ifdef DEVICE_POLLING
1199         /*
1200 	 * * ...only if polling is not turned on. Disable interrupts explicitly
1201 	 * if polling is enabled.
1202 	 */
1203 	if (sc->if_getcapenable(ifp) & IFCAP_POLLING)
1204 		mge_intrs_ctrl(sc, 0);
1205 	else
1206 #endif /* DEVICE_POLLING */
1207 	mge_intrs_ctrl(sc, 1);
1208 
1209 	/* Activate network interface */
1210 	if_setdrvflagbits(ifp, IFF_DRV_RUNNING, 0);
1211 	if_setdrvflagbits(ifp, 0, IFF_DRV_OACTIVE);
1212 	sc->wd_timer = 0;
1213 
1214 	/* Schedule watchdog timeout */
1215 	if (sc->phy_attached)
1216 		callout_reset(&sc->wd_callout, hz, mge_tick, sc);
1217 }
1218 
1219 static void
1220 mge_intr_rxtx(void *arg)
1221 {
1222 	struct mge_softc *sc;
1223 	uint32_t int_cause, int_cause_ext;
1224 
1225 	sc = arg;
1226 	MGE_GLOBAL_LOCK(sc);
1227 
1228 #ifdef DEVICE_POLLING
1229 	if (sc->if_getcapenable(ifp) & IFCAP_POLLING) {
1230 		MGE_GLOBAL_UNLOCK(sc);
1231 		return;
1232 	}
1233 #endif
1234 
1235 	/* Get interrupt cause */
1236 	int_cause = MGE_READ(sc, MGE_PORT_INT_CAUSE);
1237 	int_cause_ext = MGE_READ(sc, MGE_PORT_INT_CAUSE_EXT);
1238 
1239 	/* Check for Transmit interrupt */
1240 	if (int_cause_ext & (MGE_PORT_INT_EXT_TXBUF0 |
1241 	    MGE_PORT_INT_EXT_TXUR)) {
1242 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE_EXT, ~(int_cause_ext &
1243 		    (MGE_PORT_INT_EXT_TXBUF0 | MGE_PORT_INT_EXT_TXUR)));
1244 		mge_intr_tx_locked(sc);
1245 	}
1246 
1247 	MGE_TRANSMIT_UNLOCK(sc);
1248 
1249 	/* Check for Receive interrupt */
1250 	mge_intr_rx_check(sc, int_cause, int_cause_ext);
1251 
1252 	MGE_RECEIVE_UNLOCK(sc);
1253 }
1254 
1255 static void
1256 mge_intr_err(void *arg)
1257 {
1258 	struct mge_softc *sc;
1259 	if_t ifp;
1260 
1261 	sc = arg;
1262 	ifp = sc->ifp;
1263 	if_printf(ifp, "%s\n", __FUNCTION__);
1264 }
1265 
1266 static void
1267 mge_intr_misc(void *arg)
1268 {
1269 	struct mge_softc *sc;
1270 	if_t ifp;
1271 
1272 	sc = arg;
1273 	ifp = sc->ifp;
1274 	if_printf(ifp, "%s\n", __FUNCTION__);
1275 }
1276 
1277 static void
1278 mge_intr_rx(void *arg) {
1279 	struct mge_softc *sc;
1280 	uint32_t int_cause, int_cause_ext;
1281 
1282 	sc = arg;
1283 	MGE_RECEIVE_LOCK(sc);
1284 
1285 #ifdef DEVICE_POLLING
1286 	if (sc->if_getcapenable(ifp) & IFCAP_POLLING) {
1287 		MGE_RECEIVE_UNLOCK(sc);
1288 		return;
1289 	}
1290 #endif
1291 
1292 	/* Get interrupt cause */
1293 	int_cause = MGE_READ(sc, MGE_PORT_INT_CAUSE);
1294 	int_cause_ext = MGE_READ(sc, MGE_PORT_INT_CAUSE_EXT);
1295 
1296 	mge_intr_rx_check(sc, int_cause, int_cause_ext);
1297 
1298 	MGE_RECEIVE_UNLOCK(sc);
1299 }
1300 
1301 static void
1302 mge_intr_rx_check(struct mge_softc *sc, uint32_t int_cause,
1303     uint32_t int_cause_ext)
1304 {
1305 	/* Check for resource error */
1306 	if (int_cause & MGE_PORT_INT_RXERRQ0) {
1307 		mge_reinit_rx(sc);
1308 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE,
1309 		    ~(int_cause & MGE_PORT_INT_RXERRQ0));
1310 	}
1311 
1312 	int_cause &= MGE_PORT_INT_RXQ0;
1313 	int_cause_ext &= MGE_PORT_INT_EXT_RXOR;
1314 
1315 	if (int_cause || int_cause_ext) {
1316 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE, ~int_cause);
1317 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE_EXT, ~int_cause_ext);
1318 		mge_intr_rx_locked(sc, -1);
1319 	}
1320 }
1321 
1322 static int
1323 mge_intr_rx_locked(struct mge_softc *sc, int count)
1324 {
1325 	if_t ifp = sc->ifp;
1326 	uint32_t status;
1327 	uint16_t bufsize;
1328 	struct mge_desc_wrapper* dw;
1329 	struct mbuf *mb;
1330 	int rx_npkts = 0;
1331 
1332 	MGE_RECEIVE_LOCK_ASSERT(sc);
1333 
1334 	while (count != 0) {
1335 		dw = &sc->mge_rx_desc[sc->rx_desc_curr];
1336 		bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1337 		    BUS_DMASYNC_POSTREAD);
1338 
1339 		/* Get status */
1340 		status = dw->mge_desc->cmd_status;
1341 		bufsize = dw->mge_desc->buff_size;
1342 		if ((status & MGE_DMA_OWNED) != 0)
1343 			break;
1344 
1345 		if (dw->mge_desc->byte_count &&
1346 		    ~(status & MGE_ERR_SUMMARY)) {
1347 
1348 			bus_dmamap_sync(sc->mge_rx_dtag, dw->buffer_dmap,
1349 			    BUS_DMASYNC_POSTREAD);
1350 
1351 			mb = m_devget(dw->buffer->m_data,
1352 			    dw->mge_desc->byte_count - ETHER_CRC_LEN,
1353 			    0, ifp, NULL);
1354 
1355 			if (mb == NULL)
1356 				/* Give up if no mbufs */
1357 				break;
1358 
1359 			mb->m_len -= 2;
1360 			mb->m_pkthdr.len -= 2;
1361 			mb->m_data += 2;
1362 
1363 			mb->m_pkthdr.rcvif = ifp;
1364 
1365 			mge_offload_process_frame(ifp, mb, status,
1366 			    bufsize);
1367 
1368 			MGE_RECEIVE_UNLOCK(sc);
1369 			if_input(ifp, mb);
1370 			MGE_RECEIVE_LOCK(sc);
1371 			rx_npkts++;
1372 		}
1373 
1374 		dw->mge_desc->byte_count = 0;
1375 		dw->mge_desc->cmd_status = MGE_RX_ENABLE_INT | MGE_DMA_OWNED;
1376 		sc->rx_desc_curr = (++sc->rx_desc_curr % MGE_RX_DESC_NUM);
1377 		bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1378 		    BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
1379 
1380 		if (count > 0)
1381 			count -= 1;
1382 	}
1383 
1384 	if_inc_counter(ifp, IFCOUNTER_IPACKETS, rx_npkts);
1385 
1386 	return (rx_npkts);
1387 }
1388 
1389 static void
1390 mge_intr_sum(void *arg)
1391 {
1392 	struct mge_softc *sc = arg;
1393 	if_t ifp;
1394 
1395 	ifp = sc->ifp;
1396 	if_printf(ifp, "%s\n", __FUNCTION__);
1397 }
1398 
1399 static void
1400 mge_intr_tx(void *arg)
1401 {
1402 	struct mge_softc *sc = arg;
1403 	uint32_t int_cause_ext;
1404 
1405 	MGE_TRANSMIT_LOCK(sc);
1406 
1407 #ifdef DEVICE_POLLING
1408 	if (sc->if_getcapenable(ifp) & IFCAP_POLLING) {
1409 		MGE_TRANSMIT_UNLOCK(sc);
1410 		return;
1411 	}
1412 #endif
1413 
1414 	/* Ack the interrupt */
1415 	int_cause_ext = MGE_READ(sc, MGE_PORT_INT_CAUSE_EXT);
1416 	MGE_WRITE(sc, MGE_PORT_INT_CAUSE_EXT, ~(int_cause_ext &
1417 	    (MGE_PORT_INT_EXT_TXBUF0 | MGE_PORT_INT_EXT_TXUR)));
1418 
1419 	mge_intr_tx_locked(sc);
1420 
1421 	MGE_TRANSMIT_UNLOCK(sc);
1422 }
1423 
1424 static void
1425 mge_intr_tx_locked(struct mge_softc *sc)
1426 {
1427 	if_t ifp = sc->ifp;
1428 	struct mge_desc_wrapper *dw;
1429 	struct mge_desc *desc;
1430 	uint32_t status;
1431 	int send = 0;
1432 
1433 	MGE_TRANSMIT_LOCK_ASSERT(sc);
1434 
1435 	/* Disable watchdog */
1436 	sc->wd_timer = 0;
1437 
1438 	while (sc->tx_desc_used_count) {
1439 		/* Get the descriptor */
1440 		dw = &sc->mge_tx_desc[sc->tx_desc_used_idx];
1441 		desc = dw->mge_desc;
1442 		bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1443 		    BUS_DMASYNC_POSTREAD);
1444 
1445 		/* Get descriptor status */
1446 		status = desc->cmd_status;
1447 
1448 		if (status & MGE_DMA_OWNED)
1449 			break;
1450 
1451 		sc->tx_desc_used_idx =
1452 			(++sc->tx_desc_used_idx) % MGE_TX_DESC_NUM;
1453 		sc->tx_desc_used_count--;
1454 
1455 		/* Update collision statistics */
1456 		if (status & MGE_ERR_SUMMARY) {
1457 			if ((status & MGE_ERR_MASK) == MGE_TX_ERROR_LC)
1458 				if_inc_counter(ifp, IFCOUNTER_COLLISIONS, 1);
1459 			if ((status & MGE_ERR_MASK) == MGE_TX_ERROR_RL)
1460 				if_inc_counter(ifp, IFCOUNTER_COLLISIONS, 16);
1461 		}
1462 
1463 		bus_dmamap_sync(sc->mge_tx_dtag, dw->buffer_dmap,
1464 		    BUS_DMASYNC_POSTWRITE);
1465 		bus_dmamap_unload(sc->mge_tx_dtag, dw->buffer_dmap);
1466 		m_freem(dw->buffer);
1467 		dw->buffer = (struct mbuf*)NULL;
1468 		send++;
1469 
1470 		if_inc_counter(ifp, IFCOUNTER_OPACKETS, 1);
1471 	}
1472 
1473 	if (send) {
1474 		/* Now send anything that was pending */
1475 		if_setdrvflagbits(ifp, 0, IFF_DRV_OACTIVE);
1476 		mge_start_locked(ifp);
1477 	}
1478 }
1479 static int
1480 mge_ioctl(if_t ifp, u_long command, caddr_t data)
1481 {
1482 	struct mge_softc *sc = if_getsoftc(ifp);
1483 	struct ifreq *ifr = (struct ifreq *)data;
1484 	int mask, error;
1485 	uint32_t flags;
1486 
1487 	error = 0;
1488 
1489 	switch (command) {
1490 	case SIOCSIFFLAGS:
1491 		MGE_GLOBAL_LOCK(sc);
1492 
1493 		if (if_getflags(ifp) & IFF_UP) {
1494 			if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) {
1495 				flags = if_getflags(ifp) ^ sc->mge_if_flags;
1496 				if (flags & IFF_PROMISC)
1497 					mge_set_prom_mode(sc,
1498 					    MGE_RX_DEFAULT_QUEUE);
1499 
1500 				if (flags & IFF_ALLMULTI)
1501 					mge_setup_multicast(sc);
1502 			} else
1503 				mge_init_locked(sc);
1504 		}
1505 		else if (if_getdrvflags(ifp) & IFF_DRV_RUNNING)
1506 			mge_stop(sc);
1507 
1508 		sc->mge_if_flags = if_getflags(ifp);
1509 		MGE_GLOBAL_UNLOCK(sc);
1510 		break;
1511 	case SIOCADDMULTI:
1512 	case SIOCDELMULTI:
1513 		if (if_getdrvflags(ifp) & IFF_DRV_RUNNING) {
1514 			MGE_GLOBAL_LOCK(sc);
1515 			mge_setup_multicast(sc);
1516 			MGE_GLOBAL_UNLOCK(sc);
1517 		}
1518 		break;
1519 	case SIOCSIFCAP:
1520 		mask = if_getcapenable(ifp) ^ ifr->ifr_reqcap;
1521 		if (mask & IFCAP_HWCSUM) {
1522 			if_setcapenablebit(ifp, 0, IFCAP_HWCSUM);
1523 			if_setcapenablebit(ifp, IFCAP_HWCSUM & ifr->ifr_reqcap, 0);
1524 			if (if_getcapenable(ifp) & IFCAP_TXCSUM)
1525 				if_sethwassist(ifp, MGE_CHECKSUM_FEATURES);
1526 			else
1527 				if_sethwassist(ifp, 0);
1528 		}
1529 #ifdef DEVICE_POLLING
1530 		if (mask & IFCAP_POLLING) {
1531 			if (ifr->ifr_reqcap & IFCAP_POLLING) {
1532 				error = ether_poll_register(mge_poll, ifp);
1533 				if (error)
1534 					return(error);
1535 
1536 				MGE_GLOBAL_LOCK(sc);
1537 				mge_intrs_ctrl(sc, 0);
1538 				if_setcapenablebit(ifp, IFCAP_POLLING, 0);
1539 				MGE_GLOBAL_UNLOCK(sc);
1540 			} else {
1541 				error = ether_poll_deregister(ifp);
1542 				MGE_GLOBAL_LOCK(sc);
1543 				mge_intrs_ctrl(sc, 1);
1544 				if_setcapenablebit(ifp, 0, IFCAP_POLLING);
1545 				MGE_GLOBAL_UNLOCK(sc);
1546 			}
1547 		}
1548 #endif
1549 		break;
1550 	case SIOCGIFMEDIA: /* fall through */
1551 	case SIOCSIFMEDIA:
1552 		/*
1553 		 * Setting up media type via ioctls is *not* supported for MAC
1554 		 * which is connected to switch. Use etherswitchcfg.
1555 		 */
1556 		if (!sc->phy_attached && (command == SIOCSIFMEDIA))
1557 			return (0);
1558 		else if (!sc->phy_attached) {
1559 			error = ifmedia_ioctl(ifp, ifr, &sc->mge_ifmedia,
1560 			    command);
1561 			break;
1562 		}
1563 
1564 		if (IFM_SUBTYPE(ifr->ifr_media) == IFM_1000_T
1565 		    && !(ifr->ifr_media & IFM_FDX)) {
1566 			device_printf(sc->dev,
1567 			    "1000baseTX half-duplex unsupported\n");
1568 			return 0;
1569 		}
1570 		error = ifmedia_ioctl(ifp, ifr, &sc->mii->mii_media, command);
1571 		break;
1572 	default:
1573 		error = ether_ioctl(ifp, command, data);
1574 	}
1575 	return (error);
1576 }
1577 
1578 static int
1579 mge_miibus_readreg(device_t dev, int phy, int reg)
1580 {
1581 
1582 	KASSERT(!switch_attached, ("miibus used with switch attached"));
1583 
1584 	return (mv_read_ext_phy(dev, phy, reg));
1585 }
1586 
1587 static int
1588 mge_miibus_writereg(device_t dev, int phy, int reg, int value)
1589 {
1590 
1591 	KASSERT(!switch_attached, ("miibus used with switch attached"));
1592 
1593 	mv_write_ext_phy(dev, phy, reg, value);
1594 
1595 	return (0);
1596 }
1597 
1598 static int
1599 mge_probe(device_t dev)
1600 {
1601 
1602 	if (!ofw_bus_status_okay(dev))
1603 		return (ENXIO);
1604 
1605 	if (!ofw_bus_is_compatible(dev, "mrvl,ge"))
1606 		return (ENXIO);
1607 
1608 	device_set_desc(dev, "Marvell Gigabit Ethernet controller");
1609 	return (BUS_PROBE_DEFAULT);
1610 }
1611 
1612 static int
1613 mge_resume(device_t dev)
1614 {
1615 
1616 	device_printf(dev, "%s\n", __FUNCTION__);
1617 	return (0);
1618 }
1619 
1620 static int
1621 mge_shutdown(device_t dev)
1622 {
1623 	struct mge_softc *sc = device_get_softc(dev);
1624 
1625 	MGE_GLOBAL_LOCK(sc);
1626 
1627 #ifdef DEVICE_POLLING
1628         if (sc->if_getcapenable(ifp) & IFCAP_POLLING)
1629 		ether_poll_deregister(sc->ifp);
1630 #endif
1631 
1632 	mge_stop(sc);
1633 
1634 	MGE_GLOBAL_UNLOCK(sc);
1635 
1636 	return (0);
1637 }
1638 
1639 static int
1640 mge_encap(struct mge_softc *sc, struct mbuf *m0)
1641 {
1642 	struct mge_desc_wrapper *dw = NULL;
1643 	bus_dma_segment_t segs[MGE_TX_DESC_NUM];
1644 	bus_dmamap_t mapp;
1645 	int error;
1646 	int seg, nsegs;
1647 	int desc_no;
1648 
1649 	/* Fetch unused map */
1650 	desc_no = sc->tx_desc_curr;
1651 	dw = &sc->mge_tx_desc[desc_no];
1652 	mapp = dw->buffer_dmap;
1653 
1654 	/* Create mapping in DMA memory */
1655 	error = bus_dmamap_load_mbuf_sg(sc->mge_tx_dtag, mapp, m0, segs, &nsegs,
1656 	    BUS_DMA_NOWAIT);
1657 	if (error != 0) {
1658 		m_freem(m0);
1659 		return (error);
1660 	}
1661 
1662 	/* Only one segment is supported. */
1663 	if (nsegs != 1) {
1664 		bus_dmamap_unload(sc->mge_tx_dtag, mapp);
1665 		m_freem(m0);
1666 		return (-1);
1667 	}
1668 
1669 	bus_dmamap_sync(sc->mge_tx_dtag, mapp, BUS_DMASYNC_PREWRITE);
1670 
1671 	/* Everything is ok, now we can send buffers */
1672 	for (seg = 0; seg < nsegs; seg++) {
1673 		dw->mge_desc->byte_count = segs[seg].ds_len;
1674 		dw->mge_desc->buffer = segs[seg].ds_addr;
1675 		dw->buffer = m0;
1676 		dw->mge_desc->cmd_status = 0;
1677 		if (seg == 0)
1678 			mge_offload_setup_descriptor(sc, dw);
1679 		dw->mge_desc->cmd_status |= MGE_TX_LAST | MGE_TX_FIRST |
1680 		    MGE_TX_ETH_CRC | MGE_TX_EN_INT | MGE_TX_PADDING |
1681 		    MGE_DMA_OWNED;
1682 	}
1683 
1684 	bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1685 	    BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
1686 
1687 	sc->tx_desc_curr = (++sc->tx_desc_curr) % MGE_TX_DESC_NUM;
1688 	sc->tx_desc_used_count++;
1689 	return (0);
1690 }
1691 
1692 static void
1693 mge_tick(void *msc)
1694 {
1695 	struct mge_softc *sc = msc;
1696 
1697 	KASSERT(sc->phy_attached == 1, ("mge_tick while PHY not attached"));
1698 
1699 	MGE_GLOBAL_LOCK(sc);
1700 
1701 	/* Check for TX timeout */
1702 	mge_watchdog(sc);
1703 
1704 	mii_tick(sc->mii);
1705 
1706 	/* Check for media type change */
1707 	if(sc->mge_media_status != sc->mii->mii_media.ifm_media)
1708 		mge_ifmedia_upd(sc->ifp);
1709 
1710 	MGE_GLOBAL_UNLOCK(sc);
1711 
1712 	/* Schedule another timeout one second from now */
1713 	callout_reset(&sc->wd_callout, hz, mge_tick, sc);
1714 
1715 	return;
1716 }
1717 
1718 static void
1719 mge_watchdog(struct mge_softc *sc)
1720 {
1721 	if_t ifp;
1722 
1723 	ifp = sc->ifp;
1724 
1725 	if (sc->wd_timer == 0 || --sc->wd_timer) {
1726 		return;
1727 	}
1728 
1729 	if_inc_counter(ifp, IFCOUNTER_OERRORS, 1);
1730 	if_printf(ifp, "watchdog timeout\n");
1731 
1732 	mge_stop(sc);
1733 	mge_init_locked(sc);
1734 }
1735 
1736 static void
1737 mge_start(if_t ifp)
1738 {
1739 	struct mge_softc *sc = if_getsoftc(ifp);
1740 
1741 	MGE_TRANSMIT_LOCK(sc);
1742 
1743 	mge_start_locked(ifp);
1744 
1745 	MGE_TRANSMIT_UNLOCK(sc);
1746 }
1747 
1748 static void
1749 mge_start_locked(if_t ifp)
1750 {
1751 	struct mge_softc *sc;
1752 	struct mbuf *m0, *mtmp;
1753 	uint32_t reg_val, queued = 0;
1754 
1755 	sc = if_getsoftc(ifp);
1756 
1757 	MGE_TRANSMIT_LOCK_ASSERT(sc);
1758 
1759 	if ((if_getdrvflags(ifp) & (IFF_DRV_RUNNING | IFF_DRV_OACTIVE)) !=
1760 	    IFF_DRV_RUNNING)
1761 		return;
1762 
1763 	for (;;) {
1764 		/* Get packet from the queue */
1765 		m0 = if_dequeue(ifp);
1766 		if (m0 == NULL)
1767 			break;
1768 
1769 		if (m0->m_pkthdr.csum_flags & (CSUM_IP|CSUM_TCP|CSUM_UDP) ||
1770 		    m0->m_flags & M_VLANTAG) {
1771 			if (M_WRITABLE(m0) == 0) {
1772 				mtmp = m_dup(m0, M_NOWAIT);
1773 				m_freem(m0);
1774 				if (mtmp == NULL)
1775 					continue;
1776 				m0 = mtmp;
1777 			}
1778 		}
1779 		/* The driver support only one DMA fragment. */
1780 		if (m0->m_next != NULL) {
1781 			mtmp = m_defrag(m0, M_NOWAIT);
1782 			if (mtmp != NULL)
1783 				m0 = mtmp;
1784 		}
1785 
1786 		/* Check for free descriptors */
1787 		if (sc->tx_desc_used_count + 1 >= MGE_TX_DESC_NUM) {
1788 			if_sendq_prepend(ifp, m0);
1789 			if_setdrvflagbits(ifp, IFF_DRV_OACTIVE, 0);
1790 			break;
1791 		}
1792 
1793 		if (mge_encap(sc, m0) != 0)
1794 			break;
1795 
1796 		queued++;
1797 		BPF_MTAP(ifp, m0);
1798 	}
1799 
1800 	if (queued) {
1801 		/* Enable transmitter and watchdog timer */
1802 		reg_val = MGE_READ(sc, MGE_TX_QUEUE_CMD);
1803 		MGE_WRITE(sc, MGE_TX_QUEUE_CMD, reg_val | MGE_ENABLE_TXQ);
1804 		sc->wd_timer = 5;
1805 	}
1806 }
1807 
1808 static void
1809 mge_stop(struct mge_softc *sc)
1810 {
1811 	if_t ifp;
1812 	volatile uint32_t reg_val, status;
1813 	struct mge_desc_wrapper *dw;
1814 	struct mge_desc *desc;
1815 	int count;
1816 
1817 	ifp = sc->ifp;
1818 
1819 	if ((if_getdrvflags(ifp) & IFF_DRV_RUNNING) == 0)
1820 		return;
1821 
1822 	/* Stop tick engine */
1823 	callout_stop(&sc->wd_callout);
1824 
1825 	/* Disable interface */
1826 	if_setdrvflagbits(ifp, 0, (IFF_DRV_RUNNING | IFF_DRV_OACTIVE));
1827 	sc->wd_timer = 0;
1828 
1829 	/* Disable interrupts */
1830 	mge_intrs_ctrl(sc, 0);
1831 
1832 	/* Disable Rx and Tx */
1833 	reg_val = MGE_READ(sc, MGE_TX_QUEUE_CMD);
1834 	MGE_WRITE(sc, MGE_TX_QUEUE_CMD, reg_val | MGE_DISABLE_TXQ);
1835 	MGE_WRITE(sc, MGE_RX_QUEUE_CMD, MGE_DISABLE_RXQ_ALL);
1836 
1837 	/* Remove pending data from TX queue */
1838 	while (sc->tx_desc_used_idx != sc->tx_desc_curr &&
1839 	    sc->tx_desc_used_count) {
1840 		/* Get the descriptor */
1841 		dw = &sc->mge_tx_desc[sc->tx_desc_used_idx];
1842 		desc = dw->mge_desc;
1843 		bus_dmamap_sync(sc->mge_desc_dtag, dw->desc_dmap,
1844 		    BUS_DMASYNC_POSTREAD);
1845 
1846 		/* Get descriptor status */
1847 		status = desc->cmd_status;
1848 
1849 		if (status & MGE_DMA_OWNED)
1850 			break;
1851 
1852 		sc->tx_desc_used_idx = (++sc->tx_desc_used_idx) %
1853 		    MGE_TX_DESC_NUM;
1854 		sc->tx_desc_used_count--;
1855 
1856 		bus_dmamap_sync(sc->mge_tx_dtag, dw->buffer_dmap,
1857 		    BUS_DMASYNC_POSTWRITE);
1858 		bus_dmamap_unload(sc->mge_tx_dtag, dw->buffer_dmap);
1859 
1860 		m_freem(dw->buffer);
1861 		dw->buffer = (struct mbuf*)NULL;
1862 	}
1863 
1864 	/* Wait for end of transmission */
1865 	count = 0x100000;
1866 	while (count--) {
1867 		reg_val = MGE_READ(sc, MGE_PORT_STATUS);
1868 		if ( !(reg_val & MGE_STATUS_TX_IN_PROG) &&
1869 		    (reg_val & MGE_STATUS_TX_FIFO_EMPTY))
1870 			break;
1871 		DELAY(100);
1872 	}
1873 
1874 	if (count == 0)
1875 		if_printf(ifp,
1876 		    "%s: timeout while waiting for end of transmission\n",
1877 		    __FUNCTION__);
1878 
1879 	reg_val = MGE_READ(sc, MGE_PORT_SERIAL_CTRL);
1880 	reg_val &= ~(PORT_SERIAL_ENABLE);
1881 	MGE_WRITE(sc, MGE_PORT_SERIAL_CTRL ,reg_val);
1882 }
1883 
1884 static int
1885 mge_suspend(device_t dev)
1886 {
1887 
1888 	device_printf(dev, "%s\n", __FUNCTION__);
1889 	return (0);
1890 }
1891 
1892 static void
1893 mge_offload_process_frame(if_t ifp, struct mbuf *frame,
1894     uint32_t status, uint16_t bufsize)
1895 {
1896 	int csum_flags = 0;
1897 
1898 	if (if_getcapenable(ifp) & IFCAP_RXCSUM) {
1899 		if ((status & MGE_RX_L3_IS_IP) && (status & MGE_RX_IP_OK))
1900 			csum_flags |= CSUM_IP_CHECKED | CSUM_IP_VALID;
1901 
1902 		if ((bufsize & MGE_RX_IP_FRAGMENT) == 0 &&
1903 		    (MGE_RX_L4_IS_TCP(status) || MGE_RX_L4_IS_UDP(status)) &&
1904 		    (status & MGE_RX_L4_CSUM_OK)) {
1905 			csum_flags |= CSUM_DATA_VALID | CSUM_PSEUDO_HDR;
1906 			frame->m_pkthdr.csum_data = 0xFFFF;
1907 		}
1908 
1909 		frame->m_pkthdr.csum_flags = csum_flags;
1910 	}
1911 }
1912 
1913 static void
1914 mge_offload_setup_descriptor(struct mge_softc *sc, struct mge_desc_wrapper *dw)
1915 {
1916 	struct mbuf *m0 = dw->buffer;
1917 	struct ether_vlan_header *eh = mtod(m0, struct ether_vlan_header *);
1918 	int csum_flags = m0->m_pkthdr.csum_flags;
1919 	int cmd_status = 0;
1920 	struct ip *ip;
1921 	int ehlen, etype;
1922 
1923 	if (csum_flags != 0) {
1924 		if (eh->evl_encap_proto == htons(ETHERTYPE_VLAN)) {
1925 			etype = ntohs(eh->evl_proto);
1926 			ehlen = ETHER_HDR_LEN + ETHER_VLAN_ENCAP_LEN;
1927 			csum_flags |= MGE_TX_VLAN_TAGGED;
1928 		} else {
1929 			etype = ntohs(eh->evl_encap_proto);
1930 			ehlen = ETHER_HDR_LEN;
1931 		}
1932 
1933 		if (etype != ETHERTYPE_IP) {
1934 			if_printf(sc->ifp,
1935 			    "TCP/IP Offload enabled for unsupported "
1936 			    "protocol!\n");
1937 			return;
1938 		}
1939 
1940 		ip = (struct ip *)(m0->m_data + ehlen);
1941 		cmd_status |= MGE_TX_IP_HDR_SIZE(ip->ip_hl);
1942 		cmd_status |= MGE_TX_NOT_FRAGMENT;
1943 	}
1944 
1945 	if (csum_flags & CSUM_IP)
1946 		cmd_status |= MGE_TX_GEN_IP_CSUM;
1947 
1948 	if (csum_flags & CSUM_TCP)
1949 		cmd_status |= MGE_TX_GEN_L4_CSUM;
1950 
1951 	if (csum_flags & CSUM_UDP)
1952 		cmd_status |= MGE_TX_GEN_L4_CSUM | MGE_TX_UDP;
1953 
1954 	dw->mge_desc->cmd_status |= cmd_status;
1955 }
1956 
1957 static void
1958 mge_intrs_ctrl(struct mge_softc *sc, int enable)
1959 {
1960 
1961 	if (enable) {
1962 		MGE_WRITE(sc, MGE_PORT_INT_MASK , MGE_PORT_INT_RXQ0 |
1963 		    MGE_PORT_INT_EXTEND | MGE_PORT_INT_RXERRQ0);
1964 		MGE_WRITE(sc, MGE_PORT_INT_MASK_EXT , MGE_PORT_INT_EXT_TXERR0 |
1965 		    MGE_PORT_INT_EXT_RXOR | MGE_PORT_INT_EXT_TXUR |
1966 		    MGE_PORT_INT_EXT_TXBUF0);
1967 	} else {
1968 		MGE_WRITE(sc, MGE_INT_CAUSE, 0x0);
1969 		MGE_WRITE(sc, MGE_INT_MASK, 0x0);
1970 
1971 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE, 0x0);
1972 		MGE_WRITE(sc, MGE_PORT_INT_CAUSE_EXT, 0x0);
1973 
1974 		MGE_WRITE(sc, MGE_PORT_INT_MASK, 0x0);
1975 		MGE_WRITE(sc, MGE_PORT_INT_MASK_EXT, 0x0);
1976 	}
1977 }
1978 
1979 static uint8_t
1980 mge_crc8(uint8_t *data, int size)
1981 {
1982 	uint8_t crc = 0;
1983 	static const uint8_t ct[256] = {
1984 		0x00, 0x07, 0x0E, 0x09, 0x1C, 0x1B, 0x12, 0x15,
1985 		0x38, 0x3F, 0x36, 0x31, 0x24, 0x23, 0x2A, 0x2D,
1986 		0x70, 0x77, 0x7E, 0x79, 0x6C, 0x6B, 0x62, 0x65,
1987 		0x48, 0x4F, 0x46, 0x41, 0x54, 0x53, 0x5A, 0x5D,
1988 		0xE0, 0xE7, 0xEE, 0xE9, 0xFC, 0xFB, 0xF2, 0xF5,
1989 		0xD8, 0xDF, 0xD6, 0xD1, 0xC4, 0xC3, 0xCA, 0xCD,
1990 		0x90, 0x97, 0x9E, 0x99, 0x8C, 0x8B, 0x82, 0x85,
1991 		0xA8, 0xAF, 0xA6, 0xA1, 0xB4, 0xB3, 0xBA, 0xBD,
1992 		0xC7, 0xC0, 0xC9, 0xCE, 0xDB, 0xDC, 0xD5, 0xD2,
1993 		0xFF, 0xF8, 0xF1, 0xF6, 0xE3, 0xE4, 0xED, 0xEA,
1994 		0xB7, 0xB0, 0xB9, 0xBE, 0xAB, 0xAC, 0xA5, 0xA2,
1995 		0x8F, 0x88, 0x81, 0x86, 0x93, 0x94, 0x9D, 0x9A,
1996 		0x27, 0x20, 0x29, 0x2E, 0x3B, 0x3C, 0x35, 0x32,
1997 		0x1F, 0x18, 0x11, 0x16, 0x03, 0x04, 0x0D, 0x0A,
1998 		0x57, 0x50, 0x59, 0x5E, 0x4B, 0x4C, 0x45, 0x42,
1999 		0x6F, 0x68, 0x61, 0x66, 0x73, 0x74, 0x7D, 0x7A,
2000 		0x89, 0x8E, 0x87, 0x80, 0x95, 0x92, 0x9B, 0x9C,
2001 		0xB1, 0xB6, 0xBF, 0xB8, 0xAD, 0xAA, 0xA3, 0xA4,
2002 		0xF9, 0xFE, 0xF7, 0xF0, 0xE5, 0xE2, 0xEB, 0xEC,
2003 		0xC1, 0xC6, 0xCF, 0xC8, 0xDD, 0xDA, 0xD3, 0xD4,
2004 		0x69, 0x6E, 0x67, 0x60, 0x75, 0x72, 0x7B, 0x7C,
2005 		0x51, 0x56, 0x5F, 0x58, 0x4D, 0x4A, 0x43, 0x44,
2006 		0x19, 0x1E, 0x17, 0x10, 0x05, 0x02, 0x0B, 0x0C,
2007 		0x21, 0x26, 0x2F, 0x28, 0x3D, 0x3A, 0x33, 0x34,
2008 		0x4E, 0x49, 0x40, 0x47, 0x52, 0x55, 0x5C, 0x5B,
2009 		0x76, 0x71, 0x78, 0x7F, 0x6A, 0x6D, 0x64, 0x63,
2010 		0x3E, 0x39, 0x30, 0x37, 0x22, 0x25, 0x2C, 0x2B,
2011 		0x06, 0x01, 0x08, 0x0F, 0x1A, 0x1D, 0x14, 0x13,
2012 		0xAE, 0xA9, 0xA0, 0xA7, 0xB2, 0xB5, 0xBC, 0xBB,
2013 		0x96, 0x91, 0x98, 0x9F, 0x8A, 0x8D, 0x84, 0x83,
2014 		0xDE, 0xD9, 0xD0, 0xD7, 0xC2, 0xC5, 0xCC, 0xCB,
2015 		0xE6, 0xE1, 0xE8, 0xEF, 0xFA, 0xFD, 0xF4, 0xF3
2016 	};
2017 
2018 	while(size--)
2019 		crc = ct[crc ^ *(data++)];
2020 
2021 	return(crc);
2022 }
2023 
2024 struct mge_hash_maddr_ctx {
2025 	uint32_t smt[MGE_MCAST_REG_NUMBER];
2026 	uint32_t omt[MGE_MCAST_REG_NUMBER];
2027 };
2028 
2029 static u_int
2030 mge_hash_maddr(void *arg, struct sockaddr_dl *sdl, u_int cnt)
2031 {
2032 	static const uint8_t special[5] = { 0x01, 0x00, 0x5E, 0x00, 0x00 };
2033 	struct mge_hash_maddr_ctx *ctx = arg;
2034 	static const uint8_t v = (MGE_RX_DEFAULT_QUEUE << 1) | 1;
2035 	uint8_t *mac;
2036 	int i;
2037 
2038 	mac = LLADDR(sdl);
2039 	if (memcmp(mac, special, sizeof(special)) == 0) {
2040 		i = mac[5];
2041 		ctx->smt[i >> 2] |= v << ((i & 0x03) << 3);
2042 	} else {
2043 		i = mge_crc8(mac, ETHER_ADDR_LEN);
2044 		ctx->omt[i >> 2] |= v << ((i & 0x03) << 3);
2045 	}
2046 	return (1);
2047 }
2048 
2049 static void
2050 mge_setup_multicast(struct mge_softc *sc)
2051 {
2052 	struct mge_hash_maddr_ctx ctx;
2053 	if_t ifp = sc->ifp;
2054 	static const uint8_t v = (MGE_RX_DEFAULT_QUEUE << 1) | 1;
2055 	int i;
2056 
2057 	if (if_getflags(ifp) & IFF_ALLMULTI) {
2058 		for (i = 0; i < MGE_MCAST_REG_NUMBER; i++)
2059 			ctx.smt[i] = ctx.omt[i] =
2060 			    (v << 24) | (v << 16) | (v << 8) | v;
2061 	} else {
2062 		memset(&ctx, 0, sizeof(ctx));
2063 		if_foreach_llmaddr(ifp, mge_hash_maddr, &ctx);
2064 	}
2065 
2066 	for (i = 0; i < MGE_MCAST_REG_NUMBER; i++) {
2067 		MGE_WRITE(sc, MGE_DA_FILTER_SPEC_MCAST(i), ctx.smt[i]);
2068 		MGE_WRITE(sc, MGE_DA_FILTER_OTH_MCAST(i), ctx.omt[i]);
2069 	}
2070 }
2071 
2072 static void
2073 mge_set_rxic(struct mge_softc *sc)
2074 {
2075 	uint32_t reg;
2076 
2077 	if (sc->rx_ic_time > sc->mge_rx_ipg_max)
2078 		sc->rx_ic_time = sc->mge_rx_ipg_max;
2079 
2080 	reg = MGE_READ(sc, MGE_SDMA_CONFIG);
2081 	reg &= ~mge_rx_ipg(sc->mge_rx_ipg_max, sc->mge_ver);
2082 	reg |= mge_rx_ipg(sc->rx_ic_time, sc->mge_ver);
2083 	MGE_WRITE(sc, MGE_SDMA_CONFIG, reg);
2084 }
2085 
2086 static void
2087 mge_set_txic(struct mge_softc *sc)
2088 {
2089 	uint32_t reg;
2090 
2091 	if (sc->tx_ic_time > sc->mge_tfut_ipg_max)
2092 		sc->tx_ic_time = sc->mge_tfut_ipg_max;
2093 
2094 	reg = MGE_READ(sc, MGE_TX_FIFO_URGENT_TRSH);
2095 	reg &= ~mge_tfut_ipg(sc->mge_tfut_ipg_max, sc->mge_ver);
2096 	reg |= mge_tfut_ipg(sc->tx_ic_time, sc->mge_ver);
2097 	MGE_WRITE(sc, MGE_TX_FIFO_URGENT_TRSH, reg);
2098 }
2099 
2100 static int
2101 mge_sysctl_ic(SYSCTL_HANDLER_ARGS)
2102 {
2103 	struct mge_softc *sc = (struct mge_softc *)arg1;
2104 	uint32_t time;
2105 	int error;
2106 
2107 	time = (arg2 == MGE_IC_RX) ? sc->rx_ic_time : sc->tx_ic_time;
2108 	error = sysctl_handle_int(oidp, &time, 0, req);
2109 	if (error != 0)
2110 		return(error);
2111 
2112 	MGE_GLOBAL_LOCK(sc);
2113 	if (arg2 == MGE_IC_RX) {
2114 		sc->rx_ic_time = time;
2115 		mge_set_rxic(sc);
2116 	} else {
2117 		sc->tx_ic_time = time;
2118 		mge_set_txic(sc);
2119 	}
2120 	MGE_GLOBAL_UNLOCK(sc);
2121 
2122 	return(0);
2123 }
2124 
2125 static void
2126 mge_add_sysctls(struct mge_softc *sc)
2127 {
2128 	struct sysctl_ctx_list *ctx;
2129 	struct sysctl_oid_list *children;
2130 	struct sysctl_oid *tree;
2131 
2132 	ctx = device_get_sysctl_ctx(sc->dev);
2133 	children = SYSCTL_CHILDREN(device_get_sysctl_tree(sc->dev));
2134 	tree = SYSCTL_ADD_NODE(ctx, children, OID_AUTO, "int_coal",
2135 	    CTLFLAG_RD | CTLFLAG_MPSAFE, 0, "MGE Interrupts coalescing");
2136 	children = SYSCTL_CHILDREN(tree);
2137 
2138 	SYSCTL_ADD_PROC(ctx, children, OID_AUTO, "rx_time",
2139 	    CTLTYPE_UINT | CTLFLAG_RW | CTLFLAG_MPSAFE, sc, MGE_IC_RX,
2140 	    mge_sysctl_ic, "I", "IC RX time threshold");
2141 	SYSCTL_ADD_PROC(ctx, children, OID_AUTO, "tx_time",
2142 	    CTLTYPE_UINT | CTLFLAG_RW | CTLFLAG_MPSAFE, sc, MGE_IC_TX,
2143 	    mge_sysctl_ic, "I", "IC TX time threshold");
2144 }
2145 
2146 static int
2147 mge_mdio_writereg(device_t dev, int phy, int reg, int value)
2148 {
2149 
2150 	mv_write_ge_smi(dev, phy, reg, value);
2151 
2152 	return (0);
2153 }
2154 
2155 
2156 static int
2157 mge_mdio_readreg(device_t dev, int phy, int reg)
2158 {
2159 	int ret;
2160 
2161 	ret = mv_read_ge_smi(dev, phy, reg);
2162 
2163 	return (ret);
2164 }
2165