summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoryongari <yongari@FreeBSD.org>2009-11-09 23:09:18 +0000
committeryongari <yongari@FreeBSD.org>2009-11-09 23:09:18 +0000
commite0865281b02715f2c9d9e684ad0dcf7c07a990d5 (patch)
treede1b8677a71133c77d81b4c15b898ad727fa512c
parent29574e2b2eb0e44633bd2b9e3ea8085e101ca103 (diff)
downloadFreeBSD-src-e0865281b02715f2c9d9e684ad0dcf7c07a990d5.zip
FreeBSD-src-e0865281b02715f2c9d9e684ad0dcf7c07a990d5.tar.gz
Zero out Tx/Rx descriptors before using them. Also add missing
bus_dmamap_sync(9) after Tx descriptor initialization.
-rw-r--r--sys/dev/bge/if_bge.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/sys/dev/bge/if_bge.c b/sys/dev/bge/if_bge.c
index 8687d16..3ecbcbe 100644
--- a/sys/dev/bge/if_bge.c
+++ b/sys/dev/bge/if_bge.c
@@ -1046,6 +1046,7 @@ bge_init_rx_ring_std(struct bge_softc *sc)
{
int error, i;
+ bzero(sc->bge_ldata.bge_rx_std_ring, BGE_STD_RX_RING_SZ);
sc->bge_std = 0;
for (i = 0; i < BGE_SSLOTS; i++) {
if ((error = bge_newbuf_std(sc, i)) != 0)
@@ -1089,6 +1090,7 @@ bge_init_rx_ring_jumbo(struct bge_softc *sc)
struct bge_rcb *rcb;
int error, i;
+ bzero(sc->bge_ldata.bge_rx_jumbo_ring, BGE_JUMBO_RX_RING_SZ);
sc->bge_jumbo = 0;
for (i = 0; i < BGE_JUMBO_RX_RING_CNT; i++) {
if ((error = bge_newbuf_jumbo(sc, i)) != 0)
@@ -1161,6 +1163,11 @@ bge_init_tx_ring(struct bge_softc *sc)
sc->bge_txcnt = 0;
sc->bge_tx_saved_considx = 0;
+ bzero(sc->bge_ldata.bge_tx_ring, BGE_TX_RING_SZ);
+ bus_dmamap_sync(sc->bge_cdata.bge_tx_ring_tag,
+ sc->bge_cdata.bge_tx_ring_map,
+ BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
+
/* Initialize transmit producer index for host-memory send ring. */
sc->bge_tx_prodidx = 0;
bge_writembx(sc, BGE_MBX_TX_HOST_PROD0_LO, sc->bge_tx_prodidx);
OpenPOWER on IntegriCloud