summaryrefslogtreecommitdiffstats
path: root/sys/pci
diff options
context:
space:
mode:
authorimp <imp@FreeBSD.org>2002-10-29 19:02:19 +0000
committerimp <imp@FreeBSD.org>2002-10-29 19:02:19 +0000
commit2fe4c0394319c7de7eeb1cc93683f99423ce1264 (patch)
treee07606dad8d596979528c5c4dcf10403e87b0b11 /sys/pci
parentd52f4602e266012495893d291dea249c444f9ed5 (diff)
downloadFreeBSD-src-2fe4c0394319c7de7eeb1cc93683f99423ce1264.zip
FreeBSD-src-2fe4c0394319c7de7eeb1cc93683f99423ce1264.tar.gz
Don't take out the rl_mtx lock in the attach routine. The only way
we'd need it is if we're interrupted. So, register the interrupt last in the attach routine.
Diffstat (limited to 'sys/pci')
-rw-r--r--sys/pci/if_rl.c34
1 files changed, 15 insertions, 19 deletions
diff --git a/sys/pci/if_rl.c b/sys/pci/if_rl.c
index 737aaea..30baeb6 100644
--- a/sys/pci/if_rl.c
+++ b/sys/pci/if_rl.c
@@ -869,7 +869,6 @@ rl_attach(dev)
mtx_init(&sc->rl_mtx, device_get_nameunit(dev), MTX_NETWORK_LOCK,
MTX_DEF | MTX_RECURSE);
- RL_LOCK(sc);
/*
* Handle power management nonsense.
@@ -952,18 +951,6 @@ rl_attach(dev)
goto fail;
}
- error = bus_setup_intr(dev, sc->rl_irq, INTR_TYPE_NET,
- rl_intr, sc, &sc->rl_intrhand);
-
- if (error) {
- bus_release_resource(dev, SYS_RES_IRQ, 0, sc->rl_irq);
- bus_release_resource(dev, RL_RES, RL_RID, sc->rl_res);
- printf("rl%d: couldn't set up irq\n", unit);
- goto fail;
- }
-
- callout_handle_init(&sc->rl_stat_ch);
-
/* Reset the adapter. */
rl_reset(sc);
sc->rl_eecmd_read = RL_EECMD_READ_6BIT;
@@ -999,7 +986,6 @@ rl_attach(dev)
sc->rl_type = RL_8129;
else {
printf("rl%d: unknown device ID: %x\n", unit, rl_did);
- bus_teardown_intr(dev, sc->rl_irq, sc->rl_intrhand);
bus_release_resource(dev, SYS_RES_IRQ, 0, sc->rl_irq);
bus_release_resource(dev, RL_RES, RL_RID, sc->rl_res);
error = ENXIO;
@@ -1045,7 +1031,6 @@ rl_attach(dev)
if (sc->rl_cdata.rl_rx_buf == NULL) {
printf("rl%d: no memory for list buffers!\n", unit);
- bus_teardown_intr(dev, sc->rl_irq, sc->rl_intrhand);
bus_release_resource(dev, SYS_RES_IRQ, 0, sc->rl_irq);
bus_release_resource(dev, RL_RES, RL_RID, sc->rl_res);
bus_dma_tag_destroy(sc->rl_tag);
@@ -1061,7 +1046,6 @@ rl_attach(dev)
if (mii_phy_probe(dev, &sc->rl_miibus,
rl_ifmedia_upd, rl_ifmedia_sts)) {
printf("rl%d: MII without any phy!\n", sc->rl_unit);
- bus_teardown_intr(dev, sc->rl_irq, sc->rl_intrhand);
bus_release_resource(dev, SYS_RES_IRQ, 0, sc->rl_irq);
bus_release_resource(dev, RL_RES, RL_RID, sc->rl_res);
bus_dmamem_free(sc->rl_tag,
@@ -1089,11 +1073,23 @@ rl_attach(dev)
* Call MI attach routine.
*/
ether_ifattach(ifp, ETHER_BPF_SUPPORTED);
- RL_UNLOCK(sc);
- return(0);
+ error = bus_setup_intr(dev, sc->rl_irq, INTR_TYPE_NET,
+ rl_intr, sc, &sc->rl_intrhand);
+
+ if (error) {
+ printf("rl%d: couldn't set up irq\n", unit);
+ bus_release_resource(dev, SYS_RES_IRQ, 0, sc->rl_irq);
+ bus_release_resource(dev, RL_RES, RL_RID, sc->rl_res);
+ bus_dmamem_free(sc->rl_tag,
+ sc->rl_cdata.rl_rx_buf, sc->rl_cdata.rl_rx_dmamap);
+ bus_dma_tag_destroy(sc->rl_tag);
+ goto fail;
+ }
+
+ callout_handle_init(&sc->rl_stat_ch);
+ return(0);
fail:
- RL_UNLOCK(sc);
mtx_destroy(&sc->rl_mtx);
return(error);
}
OpenPOWER on IntegriCloud