When the miibus for the AX88x90 or TC5299J cards fails to attach, we

would call ed_release_resources() when we should have called
ed_detach() to properly undo the effects of prior calls to
ed_attach().  This would leave a stray ed interface ifnet alive in the
system, which was, well, bad, since we called if_free() on the
underlying memory...  Fix the ed_detach routine to cope being called
in this context now.

This should never come up because the miibus is always there.  Except
for now when it seems to be failing for reasons unknown...  That's a
different bug that hits at least ed, xl, dc and fxp...
This commit is contained in:
Warner Losh 2008-08-06 22:22:27 +00:00
parent 5718b3f2c0
commit 188ddb1837
2 changed files with 10 additions and 8 deletions

View File

@ -380,13 +380,15 @@ ed_detach(device_t dev)
struct ifnet *ifp = sc->ifp; struct ifnet *ifp = sc->ifp;
ED_ASSERT_UNLOCKED(sc); ED_ASSERT_UNLOCKED(sc);
ED_LOCK(sc); if (ifp) {
if (bus_child_present(dev)) ED_LOCK(sc);
ed_stop(sc); if (bus_child_present(dev))
ifp->if_drv_flags &= ~IFF_DRV_RUNNING; ed_stop(sc);
ED_UNLOCK(sc); ifp->if_drv_flags &= ~IFF_DRV_RUNNING;
callout_drain(&sc->tick_ch); ED_UNLOCK(sc);
ether_ifdetach(ifp); callout_drain(&sc->tick_ch);
ether_ifdetach(ifp);
}
bus_teardown_intr(dev, sc->irq_res, sc->irq_handle); bus_teardown_intr(dev, sc->irq_res, sc->irq_handle);
ed_release_resources(dev); ed_release_resources(dev);
ED_LOCK_DESTROY(sc); ED_LOCK_DESTROY(sc);

View File

@ -572,7 +572,7 @@ ed_pccard_attach(device_t dev)
ed_pccard_add_modem(dev); ed_pccard_add_modem(dev);
return (0); return (0);
bad: bad:
ed_release_resources(dev); ed_detach(dev);
return (error); return (error);
} }