summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorkeramida <keramida@FreeBSD.org>2005-09-15 17:51:39 +0000
committerkeramida <keramida@FreeBSD.org>2005-09-15 17:51:39 +0000
commit96a74ed6d2d1d7673ad0e354a7224e2468151c6b (patch)
treed9b12d00129e98306e85a2984d1fd86900e284a4 /sys
parentd032e7fca37d794f5e169437ead6635ee8f62cf2 (diff)
downloadFreeBSD-src-96a74ed6d2d1d7673ad0e354a7224e2468151c6b.zip
FreeBSD-src-96a74ed6d2d1d7673ad0e354a7224e2468151c6b.tar.gz
When bus_alloc_resource_any() fails, dc_detach() is called and it
attempts to deallocate busdma tags and resources that haven't been allocated yet, causing a panic every time a dc interface fails to attach. Fix by checking that we really have something to dealloc before calling bus_dma*() functions. Approved by: jhb MFC after: 1 week
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/dc/if_dc.c16
-rw-r--r--sys/pci/if_dc.c16
2 files changed, 22 insertions, 10 deletions
diff --git a/sys/dev/dc/if_dc.c b/sys/dev/dc/if_dc.c
index 34a8012..1dab374 100644
--- a/sys/dev/dc/if_dc.c
+++ b/sys/dev/dc/if_dc.c
@@ -2364,11 +2364,17 @@ dc_detach(device_t dev)
bus_dmamem_free(sc->dc_stag, sc->dc_cdata.dc_sbuf, sc->dc_smap);
if (sc->dc_ldata != NULL)
bus_dmamem_free(sc->dc_ltag, sc->dc_ldata, sc->dc_lmap);
- for (i = 0; i < DC_TX_LIST_CNT; i++)
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_cdata.dc_tx_map[i]);
- for (i = 0; i < DC_RX_LIST_CNT; i++)
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_cdata.dc_rx_map[i]);
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_sparemap);
+ if (sc->dc_mtag) {
+ for (i = 0; i < DC_TX_LIST_CNT; i++)
+ if (sc->dc_cdata.dc_tx_map[i] != NULL)
+ bus_dmamap_destroy(sc->dc_mtag,
+ sc->dc_cdata.dc_tx_map[i]);
+ for (i = 0; i < DC_RX_LIST_CNT; i++)
+ if (sc->dc_cdata.dc_rx_map[i] != NULL)
+ bus_dmamap_destroy(sc->dc_mtag,
+ sc->dc_cdata.dc_rx_map[i]);
+ bus_dmamap_destroy(sc->dc_mtag, sc->dc_sparemap);
+ }
if (sc->dc_stag)
bus_dma_tag_destroy(sc->dc_stag);
if (sc->dc_mtag)
diff --git a/sys/pci/if_dc.c b/sys/pci/if_dc.c
index 34a8012..1dab374 100644
--- a/sys/pci/if_dc.c
+++ b/sys/pci/if_dc.c
@@ -2364,11 +2364,17 @@ dc_detach(device_t dev)
bus_dmamem_free(sc->dc_stag, sc->dc_cdata.dc_sbuf, sc->dc_smap);
if (sc->dc_ldata != NULL)
bus_dmamem_free(sc->dc_ltag, sc->dc_ldata, sc->dc_lmap);
- for (i = 0; i < DC_TX_LIST_CNT; i++)
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_cdata.dc_tx_map[i]);
- for (i = 0; i < DC_RX_LIST_CNT; i++)
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_cdata.dc_rx_map[i]);
- bus_dmamap_destroy(sc->dc_mtag, sc->dc_sparemap);
+ if (sc->dc_mtag) {
+ for (i = 0; i < DC_TX_LIST_CNT; i++)
+ if (sc->dc_cdata.dc_tx_map[i] != NULL)
+ bus_dmamap_destroy(sc->dc_mtag,
+ sc->dc_cdata.dc_tx_map[i]);
+ for (i = 0; i < DC_RX_LIST_CNT; i++)
+ if (sc->dc_cdata.dc_rx_map[i] != NULL)
+ bus_dmamap_destroy(sc->dc_mtag,
+ sc->dc_cdata.dc_rx_map[i]);
+ bus_dmamap_destroy(sc->dc_mtag, sc->dc_sparemap);
+ }
if (sc->dc_stag)
bus_dma_tag_destroy(sc->dc_stag);
if (sc->dc_mtag)
OpenPOWER on IntegriCloud