summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBenno Rice <benno@FreeBSD.org>2008-06-17 05:48:42 +0000
committerBenno Rice <benno@FreeBSD.org>2008-06-17 05:48:42 +0000
commitaec9f8e993baa6914ba55cee23f7125e6c75ce3a (patch)
treef888879b691756341227b59ad668f6721a89d1d4
parent74572e9e635525e04a4e61b8a1e35b8b434da8ed (diff)
Notes
-rw-r--r--sys/dev/smc/if_smc.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/sys/dev/smc/if_smc.c b/sys/dev/smc/if_smc.c
index 9293b3e72bdf..0040f9ccea17 100644
--- a/sys/dev/smc/if_smc.c
+++ b/sys/dev/smc/if_smc.c
@@ -394,6 +394,13 @@ smc_detach(device_t dev)
smc_stop(sc);
SMC_UNLOCK(sc);
+ if (sc->smc_ifp != NULL) {
+ ether_ifdetach(sc->smc_ifp);
+ }
+
+ callout_drain(&sc->smc_watchdog);
+ callout_drain(&sc->smc_mii_tick_ch);
+
#ifdef DEVICE_POLLING
if (sc->smc_ifp->if_capenable & IFCAP_POLLING)
ether_poll_deregister(sc->smc_ifp);
@@ -409,10 +416,8 @@ smc_detach(device_t dev)
taskqueue_free(sc->smc_tq);
sc->smc_tq = NULL;
}
-
if (sc->smc_ifp != NULL) {
- ether_ifdetach(sc->smc_ifp);
if_free(sc->smc_ifp);
}