From ea4d72c4d4e6144c5e7ac2d3dbe98ede80a42ee2 Mon Sep 17 00:00:00 2001 From: Stuart Henderson Date: Sat, 20 Jun 2009 09:40:30 +0000 Subject: Have hmestop() properly clear the RUNNING/OACTIVE flags and the interface watchdog timer. Copied over from MI hme(4). Tested by nick@. From Brad. --- sys/arch/sparc/dev/hme.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/sys/arch/sparc/dev/hme.c b/sys/arch/sparc/dev/hme.c index d67279ce6ef..75985ff9724 100644 --- a/sys/arch/sparc/dev/hme.c +++ b/sys/arch/sparc/dev/hme.c @@ -1,4 +1,4 @@ -/* $OpenBSD: hme.c,v 1.58 2008/11/28 02:44:17 brad Exp $ */ +/* $OpenBSD: hme.c,v 1.59 2009/06/20 09:40:29 sthen Exp $ */ /* * Copyright (c) 1998 Jason L. Wright (jason@thought.net) @@ -331,8 +331,15 @@ void hmestop(sc) struct hme_softc *sc; { + struct ifnet *ifp = &sc->sc_arpcom.ac_if; int tries = 0; + /* + * Mark the interface down and cancel the watchdog timer. + */ + ifp->if_flags &= ~(IFF_RUNNING | IFF_OACTIVE); + ifp->if_timer = 0; + sc->sc_gr->reset = GR_RESET_ALL; while (sc->sc_gr->reset && (++tries != MAX_STOP_TRIES)) DELAY(20); @@ -414,7 +421,6 @@ hmeioctl(ifp, cmd, data) * stop it. */ hmestop(sc); - ifp->if_flags &= ~IFF_RUNNING; } else if ((ifp->if_flags & IFF_UP) != 0 && (ifp->if_flags & IFF_RUNNING) == 0) { /* @@ -600,7 +606,6 @@ hmeinit(sc) ifp->if_flags |= IFF_RUNNING; ifp->if_flags &= ~IFF_OACTIVE; sc->sc_if_flags = ifp->if_flags; - ifp->if_timer = 0; } void -- cgit v1.2.3