diff options
author | Brad Smith <brad@cvs.openbsd.org> | 2006-02-08 22:11:03 +0000 |
---|---|---|
committer | Brad Smith <brad@cvs.openbsd.org> | 2006-02-08 22:11:03 +0000 |
commit | 740326c61d6bdcff1e42f83bc5cf6bea30911f25 (patch) | |
tree | 0ce2d233d723e81df7c6fcb0c7575a610690fe10 | |
parent | 61d5853f15713f19ea6098b9edd088a2001c2024 (diff) |
eliminate a reset when configuring the IP address.
tested by kettenis@
-rw-r--r-- | sys/dev/ic/gem.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/sys/dev/ic/gem.c b/sys/dev/ic/gem.c index 29177fcf5b7..4375b7b579c 100644 --- a/sys/dev/ic/gem.c +++ b/sys/dev/ic/gem.c @@ -1,4 +1,4 @@ -/* $OpenBSD: gem.c,v 1.53 2006/02/05 00:24:26 brad Exp $ */ +/* $OpenBSD: gem.c,v 1.54 2006/02/08 22:11:02 brad Exp $ */ /* $NetBSD: gem.c,v 1.1 2001/09/16 00:11:43 eeh Exp $ */ /* @@ -697,6 +697,11 @@ gem_init(struct ifnet *ifp) s = splnet(); + if (ifp->if_flags & IFF_RUNNING) { + splx(s); + return (0); + } + DPRINTF(sc, ("%s: gem_init: calling stop\n", sc->sc_dev.dv_xname)); /* * Initialization sequence. The numbered steps below correspond @@ -1092,8 +1097,10 @@ gem_intr(v) printf("%s: MAC tx fault, status %x\n", sc->sc_dev.dv_xname, txstat); #endif - if (txstat & (GEM_MAC_TX_UNDERRUN | GEM_MAC_TX_PKT_TOO_LONG)) + if (txstat & (GEM_MAC_TX_UNDERRUN | GEM_MAC_TX_PKT_TOO_LONG)) { + ifp->if_flags &= ~IFF_RUNNING; gem_init(ifp); + } } if (status & GEM_INTR_RX_MAC) { int rxstat = bus_space_read_4(t, seb, GEM_MAC_RX_STATUS); @@ -1108,6 +1115,7 @@ gem_intr(v) */ if (rxstat & GEM_MAC_RX_OVERFLOW) { ifp->if_ierrors++; + ifp->if_flags &= ~IFF_RUNNING; gem_init(ifp); } #ifdef GEM_DEBUG @@ -1136,6 +1144,7 @@ gem_watchdog(ifp) ++ifp->if_oerrors; /* Try to get more packets going. */ + ifp->if_flags &= ~IFF_RUNNING; gem_init(ifp); } |