summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorOwain Ainsworth <oga@cvs.openbsd.org>2010-05-19 14:39:08 +0000
committerOwain Ainsworth <oga@cvs.openbsd.org>2010-05-19 14:39:08 +0000
commit7926ce0bd67ae148cf1f17650980a268f74894c7 (patch)
treea0212eaab2706e6d5f3b2a3f8547c368d1095004 /sys
parent610091436580c6e42fc28af09bfb1ba92e8dd9c2 (diff)
BUS_DMA_ZERO love.
ok kevlo@, krw@
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/if_age.c22
-rw-r--r--sys/dev/pci/if_ale.c19
2 files changed, 12 insertions, 29 deletions
diff --git a/sys/dev/pci/if_age.c b/sys/dev/pci/if_age.c
index a9f1e04644d..2bdb8ae629d 100644
--- a/sys/dev/pci/if_age.c
+++ b/sys/dev/pci/if_age.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_age.c,v 1.10 2010/04/08 00:23:53 tedu Exp $ */
+/* $OpenBSD: if_age.c,v 1.11 2010/05/19 14:39:07 oga Exp $ */
/*-
* Copyright (c) 2008, Pyun YongHyeon <yongari@FreeBSD.org>
@@ -666,7 +666,7 @@ age_dma_alloc(struct age_softc *sc)
/* Allocate DMA'able memory for TX ring */
error = bus_dmamem_alloc(sc->sc_dmat, AGE_TX_RING_SZ,
ETHER_ALIGN, 0, &sc->age_rdata.age_tx_ring_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for Tx ring.\n",
sc->sc_dev.dv_xname);
@@ -679,8 +679,6 @@ age_dma_alloc(struct age_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->age_rdata.age_tx_ring, AGE_TX_RING_SZ);
-
/* Load the DMA map for Tx ring. */
error = bus_dmamap_load(sc->sc_dmat, sc->age_cdata.age_tx_ring_map,
sc->age_rdata.age_tx_ring, AGE_TX_RING_SZ, NULL, BUS_DMA_WAITOK);
@@ -706,7 +704,7 @@ age_dma_alloc(struct age_softc *sc)
/* Allocate DMA'able memory for RX ring */
error = bus_dmamem_alloc(sc->sc_dmat, AGE_RX_RING_SZ,
ETHER_ALIGN, 0, &sc->age_rdata.age_rx_ring_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for Rx ring.\n",
sc->sc_dev.dv_xname);
@@ -719,8 +717,6 @@ age_dma_alloc(struct age_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->age_rdata.age_rx_ring, AGE_RX_RING_SZ);
-
/* Load the DMA map for Rx ring. */
error = bus_dmamap_load(sc->sc_dmat, sc->age_cdata.age_rx_ring_map,
sc->age_rdata.age_rx_ring, AGE_RX_RING_SZ, NULL, BUS_DMA_WAITOK);
@@ -746,7 +742,7 @@ age_dma_alloc(struct age_softc *sc)
/* Allocate DMA'able memory for RX return ring */
error = bus_dmamem_alloc(sc->sc_dmat, AGE_RR_RING_SZ,
ETHER_ALIGN, 0, &sc->age_rdata.age_rr_ring_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for Rx "
"return ring.\n", sc->sc_dev.dv_xname);
@@ -759,8 +755,6 @@ age_dma_alloc(struct age_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->age_rdata.age_rr_ring, AGE_RR_RING_SZ);
-
/* Load the DMA map for Rx return ring. */
error = bus_dmamap_load(sc->sc_dmat, sc->age_cdata.age_rr_ring_map,
sc->age_rdata.age_rr_ring, AGE_RR_RING_SZ, NULL, BUS_DMA_WAITOK);
@@ -787,7 +781,7 @@ age_dma_alloc(struct age_softc *sc)
/* Allocate DMA'able memory for CMB block */
error = bus_dmamem_alloc(sc->sc_dmat, AGE_CMB_BLOCK_SZ,
ETHER_ALIGN, 0, &sc->age_rdata.age_cmb_block_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for "
"CMB block\n", sc->sc_dev.dv_xname);
@@ -800,8 +794,6 @@ age_dma_alloc(struct age_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->age_rdata.age_cmb_block, AGE_CMB_BLOCK_SZ);
-
/* Load the DMA map for CMB block. */
error = bus_dmamap_load(sc->sc_dmat, sc->age_cdata.age_cmb_block_map,
sc->age_rdata.age_cmb_block, AGE_CMB_BLOCK_SZ, NULL,
@@ -829,7 +821,7 @@ age_dma_alloc(struct age_softc *sc)
/* Allocate DMA'able memory for SMB block */
error = bus_dmamem_alloc(sc->sc_dmat, AGE_SMB_BLOCK_SZ,
ETHER_ALIGN, 0, &sc->age_rdata.age_smb_block_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for "
"SMB block\n", sc->sc_dev.dv_xname);
@@ -842,8 +834,6 @@ age_dma_alloc(struct age_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->age_rdata.age_smb_block, AGE_SMB_BLOCK_SZ);
-
/* Load the DMA map for SMB block */
error = bus_dmamap_load(sc->sc_dmat, sc->age_cdata.age_smb_block_map,
sc->age_rdata.age_smb_block, AGE_SMB_BLOCK_SZ, NULL,
diff --git a/sys/dev/pci/if_ale.c b/sys/dev/pci/if_ale.c
index 5d2dba05edd..1a3920c3f82 100644
--- a/sys/dev/pci/if_ale.c
+++ b/sys/dev/pci/if_ale.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ale.c,v 1.12 2010/04/08 00:23:53 tedu Exp $ */
+/* $OpenBSD: if_ale.c,v 1.13 2010/05/19 14:39:07 oga Exp $ */
/*-
* Copyright (c) 2008, Pyun YongHyeon <yongari@FreeBSD.org>
* All rights reserved.
@@ -622,7 +622,7 @@ ale_dma_alloc(struct ale_softc *sc)
/* Allocate DMA'able memory for TX ring */
error = bus_dmamem_alloc(sc->sc_dmat, ALE_TX_RING_SZ,
ETHER_ALIGN, 0, &sc->ale_cdata.ale_tx_ring_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for Tx ring.\n",
sc->sc_dev.dv_xname);
@@ -635,8 +635,6 @@ ale_dma_alloc(struct ale_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->ale_cdata.ale_tx_ring, ALE_TX_RING_SZ);
-
/* Load the DMA map for Tx ring. */
error = bus_dmamap_load(sc->sc_dmat, sc->ale_cdata.ale_tx_ring_map,
sc->ale_cdata.ale_tx_ring, ALE_TX_RING_SZ, NULL, BUS_DMA_WAITOK);
@@ -663,7 +661,7 @@ ale_dma_alloc(struct ale_softc *sc)
/* Allocate DMA'able memory for RX pages */
error = bus_dmamem_alloc(sc->sc_dmat, sc->ale_pagesize,
ETHER_ALIGN, 0, &sc->ale_cdata.ale_rx_page[i].page_seg,
- 1, &nsegs, BUS_DMA_WAITOK);
+ 1, &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for "
"Rx ring.\n", sc->sc_dev.dv_xname);
@@ -677,8 +675,6 @@ ale_dma_alloc(struct ale_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->ale_cdata.ale_rx_page[i].page_addr, sc->ale_pagesize);
-
/* Load the DMA map for Rx pages. */
error = bus_dmamap_load(sc->sc_dmat,
sc->ale_cdata.ale_rx_page[i].page_map,
@@ -705,7 +701,8 @@ ale_dma_alloc(struct ale_softc *sc)
/* Allocate DMA'able memory for Tx CMB. */
error = bus_dmamem_alloc(sc->sc_dmat, ALE_TX_CMB_SZ, ETHER_ALIGN, 0,
- &sc->ale_cdata.ale_tx_cmb_seg, 1, &nsegs, BUS_DMA_WAITOK);
+ &sc->ale_cdata.ale_tx_cmb_seg, 1, &nsegs,
+ BUS_DMA_WAITOK |BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for Tx CMB.\n",
@@ -719,8 +716,6 @@ ale_dma_alloc(struct ale_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->ale_cdata.ale_tx_cmb, ALE_TX_CMB_SZ);
-
/* Load the DMA map for Tx CMB. */
error = bus_dmamap_load(sc->sc_dmat, sc->ale_cdata.ale_tx_cmb_map,
sc->ale_cdata.ale_tx_cmb, ALE_TX_CMB_SZ, NULL, BUS_DMA_WAITOK);
@@ -748,7 +743,7 @@ ale_dma_alloc(struct ale_softc *sc)
/* Allocate DMA'able memory for Rx CMB */
error = bus_dmamem_alloc(sc->sc_dmat, ALE_RX_CMB_SZ,
ETHER_ALIGN, 0, &sc->ale_cdata.ale_rx_page[i].cmb_seg, 1,
- &nsegs, BUS_DMA_WAITOK);
+ &nsegs, BUS_DMA_WAITOK | BUS_DMA_ZERO);
if (error) {
printf("%s: could not allocate DMA'able memory for "
"Rx CMB\n", sc->sc_dev.dv_xname);
@@ -762,8 +757,6 @@ ale_dma_alloc(struct ale_softc *sc)
if (error)
return (ENOBUFS);
- bzero(sc->ale_cdata.ale_rx_page[i].cmb_addr, ALE_RX_CMB_SZ);
-
/* Load the DMA map for Rx CMB */
error = bus_dmamap_load(sc->sc_dmat,
sc->ale_cdata.ale_rx_page[i].cmb_map,