diff options
author | Jonathan Gray <jsg@cvs.openbsd.org> | 2009-06-02 15:39:36 +0000 |
---|---|---|
committer | Jonathan Gray <jsg@cvs.openbsd.org> | 2009-06-02 15:39:36 +0000 |
commit | 3073b2c274e79d673c8f4623f1884596b0a14f66 (patch) | |
tree | 471baff4ab475a0f1b0ca57a5c1aa8f79bdd55a5 | |
parent | 39b8009aea39aeaa44d5bd629dd9ebdc573b2cfa (diff) |
make dc at pci detachable; untested.
-rw-r--r-- | sys/dev/cardbus/if_dc_cardbus.c | 26 | ||||
-rw-r--r-- | sys/dev/ic/dc.c | 26 | ||||
-rw-r--r-- | sys/dev/pci/if_dc_pci.c | 44 |
3 files changed, 62 insertions, 34 deletions
diff --git a/sys/dev/cardbus/if_dc_cardbus.c b/sys/dev/cardbus/if_dc_cardbus.c index 4631a47b5e1..266db43a555 100644 --- a/sys/dev/cardbus/if_dc_cardbus.c +++ b/sys/dev/cardbus/if_dc_cardbus.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_dc_cardbus.c,v 1.27 2008/09/11 06:49:14 brad Exp $ */ +/* $OpenBSD: if_dc_cardbus.c,v 1.28 2009/06/02 15:39:35 jsg Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -240,30 +240,6 @@ dc_cardbus_attach(struct device *parent, struct device *self, void *aux) } int -dc_detach(struct dc_softc *sc) -{ - struct ifnet *ifp = &sc->sc_arpcom.ac_if; - - if (LIST_FIRST(&sc->sc_mii.mii_phys) != NULL) - mii_detach(&sc->sc_mii, MII_PHY_ANY, MII_OFFSET_ANY); - - if (sc->dc_srom) - free(sc->dc_srom, M_DEVBUF); - - timeout_del(&sc->dc_tick_tmo); - - ether_ifdetach(ifp); - if_detach(ifp); - - if (sc->sc_dhook != NULL) - shutdownhook_disestablish(sc->sc_dhook); - if (sc->sc_pwrhook != NULL) - powerhook_disestablish(sc->sc_pwrhook); - - return (0); -} - -int dc_cardbus_detach(struct device *self, int flags) { struct dc_cardbus_softc *csc = (struct dc_cardbus_softc *)self; diff --git a/sys/dev/ic/dc.c b/sys/dev/ic/dc.c index c3e36634817..03ed39e7ca0 100644 --- a/sys/dev/ic/dc.c +++ b/sys/dev/ic/dc.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dc.c,v 1.108 2009/01/11 16:54:59 blambert Exp $ */ +/* $OpenBSD: dc.c,v 1.109 2009/06/02 15:39:35 jsg Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -3142,6 +3142,30 @@ dc_power(int why, void *arg) splx(s); } +int +dc_detach(struct dc_softc *sc) +{ + struct ifnet *ifp = &sc->sc_arpcom.ac_if; + + if (LIST_FIRST(&sc->sc_mii.mii_phys) != NULL) + mii_detach(&sc->sc_mii, MII_PHY_ANY, MII_OFFSET_ANY); + + if (sc->dc_srom) + free(sc->dc_srom, M_DEVBUF); + + timeout_del(&sc->dc_tick_tmo); + + ether_ifdetach(ifp); + if_detach(ifp); + + if (sc->sc_dhook != NULL) + shutdownhook_disestablish(sc->sc_dhook); + if (sc->sc_pwrhook != NULL) + powerhook_disestablish(sc->sc_pwrhook); + + return (0); +} + struct cfdriver dc_cd = { 0, "dc", DV_IFNET }; diff --git a/sys/dev/pci/if_dc_pci.c b/sys/dev/pci/if_dc_pci.c index 45197b2c2e8..d9558e090a8 100644 --- a/sys/dev/pci/if_dc_pci.c +++ b/sys/dev/pci/if_dc_pci.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_dc_pci.c,v 1.62 2009/06/02 04:03:39 jsg Exp $ */ +/* $OpenBSD: if_dc_pci.c,v 1.63 2009/06/02 15:39:35 jsg Exp $ */ /* * Copyright (c) 1997, 1998, 1999 @@ -123,8 +123,15 @@ struct dc_type dc_devs[] = { int dc_pci_match(struct device *, void *, void *); void dc_pci_attach(struct device *, struct device *, void *); +int dc_pci_detach(struct device *, int); void dc_pci_acpi(struct device *, void *); +struct dc_pci_softc { + struct dc_softc psc_softc; + pci_chipset_tag_t psc_pc; + bus_size_t psc_mapsize; +}; + /* * Probe for a 21143 or clone chip. Check the PCI vendor and device * IDs against our list and return a device name if we find a match. @@ -165,7 +172,8 @@ dc_pci_match(struct device *parent, void *match, void *aux) void dc_pci_acpi(struct device *self, void *aux) { - struct dc_softc *sc = (struct dc_softc *)self; + struct dc_pci_softc *psc = (struct dc_pci_softc *)self; + struct dc_softc *sc = &psc->psc_softc; struct pci_attach_args *pa = (struct pci_attach_args *)aux; pci_chipset_tag_t pc = pa->pa_pc; u_int32_t r, cptr; @@ -210,13 +218,14 @@ dc_pci_attach(struct device *parent, struct device *self, void *aux) { const char *intrstr = NULL; pcireg_t command; - struct dc_softc *sc = (struct dc_softc *)self; + struct dc_pci_softc *psc = (struct dc_pci_softc *)self; + struct dc_softc *sc = &psc->psc_softc; struct pci_attach_args *pa = aux; pci_chipset_tag_t pc = pa->pa_pc; pci_intr_handle_t ih; - bus_size_t size; int found = 0; + psc->psc_pc = pa->pa_pc; sc->sc_dmat = pa->pa_dmat; /* @@ -232,14 +241,14 @@ dc_pci_attach(struct device *parent, struct device *self, void *aux) #ifdef DC_USEIOSPACE if (pci_mapreg_map(pa, DC_PCI_CFBIO, PCI_MAPREG_TYPE_IO, 0, - &sc->dc_btag, &sc->dc_bhandle, NULL, &size, 0)) { + &sc->dc_btag, &sc->dc_bhandle, NULL, &psc->psc_mapsize, 0)) { printf(": can't map i/o space\n"); return; } #else if (pci_mapreg_map(pa, DC_PCI_CFBMA, PCI_MAPREG_TYPE_MEM|PCI_MAPREG_MEM_TYPE_32BIT, 0, - &sc->dc_btag, &sc->dc_bhandle, NULL, &size, 0)) { + &sc->dc_btag, &sc->dc_bhandle, NULL, &psc->psc_mapsize, 0)) { printf(": can't map mem space\n"); return; } @@ -531,9 +540,28 @@ fail_2: pci_intr_disestablish(pc, sc->sc_ih); fail_1: - bus_space_unmap(sc->dc_btag, sc->dc_bhandle, size); + bus_space_unmap(sc->dc_btag, sc->dc_bhandle, psc->psc_mapsize); +} + +int +dc_pci_detach(struct device *self, int flags) +{ + struct dc_pci_softc *psc = (void *)self; + struct dc_softc *sc = &psc->psc_softc; + int rv = 0; + + rv = dc_detach(sc); + if (rv) + return (rv); + + if (sc->sc_ih != NULL) + pci_intr_disestablish(psc->psc_pc, sc->sc_ih); + + bus_space_unmap(sc->dc_btag, sc->dc_bhandle, psc->psc_mapsize); + + return (rv); } struct cfattach dc_pci_ca = { - sizeof(struct dc_softc), dc_pci_match, dc_pci_attach + sizeof(struct dc_softc), dc_pci_match, dc_pci_attach, dc_pci_detach }; |