summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2009-04-20 12:24:53 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2009-04-20 12:24:53 +0000
commiteb6f96e5e437015a36d400dab7888625c8044243 (patch)
tree80244d5cf231d193400520843ba61da18ed8ccc5
parent23e598a51d0e73f4f53294ae75c7b8b0624f85ff (diff)
when transmitting packets, put the dmamap we used for the packet into the
last descriptor slot in the ring. the tx completion code expects the dmamap to be there so it can unload it. ok reyk@
-rw-r--r--sys/dev/pci/if_bnx.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/sys/dev/pci/if_bnx.c b/sys/dev/pci/if_bnx.c
index 97482570d2a..5038de9d736 100644
--- a/sys/dev/pci/if_bnx.c
+++ b/sys/dev/pci/if_bnx.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bnx.c,v 1.75 2009/04/20 11:39:02 reyk Exp $ */
+/* $OpenBSD: if_bnx.c,v 1.76 2009/04/20 12:24:52 dlg Exp $ */
/*-
* Copyright (c) 2006 Broadcom Corporation
@@ -4314,7 +4314,7 @@ bnx_tx_encap(struct bnx_softc *sc, struct mbuf *m)
bus_dmamap_t map;
struct tx_bd *txbd = NULL;
u_int16_t vlan_tag = 0, flags = 0;
- u_int16_t chain_prod, prod;
+ u_int16_t chain_prod, chain_head, prod;
#ifdef BNX_DEBUG
u_int16_t debug_prod;
#endif
@@ -4340,8 +4340,8 @@ bnx_tx_encap(struct bnx_softc *sc, struct mbuf *m)
/* Map the mbuf into DMAable memory. */
prod = sc->tx_prod;
- chain_prod = TX_CHAIN_IDX(prod);
- map = sc->tx_mbuf_map[chain_prod];
+ chain_head = chain_prod = TX_CHAIN_IDX(prod);
+ map = sc->tx_mbuf_map[chain_head];
/* Map the mbuf into our DMA address space. */
error = bus_dmamap_load_mbuf(sc->bnx_dmatag, map, m, BUS_DMA_NOWAIT);
@@ -4412,6 +4412,8 @@ bnx_tx_encap(struct bnx_softc *sc, struct mbuf *m)
* and we don't want to unload the map before
* all of the segments have been freed.
*/
+ sc->tx_mbuf_map[chain_head] = sc->tx_mbuf_map[chain_prod];
+ sc->tx_mbuf_map[chain_prod] = map;
sc->tx_mbuf_ptr[chain_prod] = m;
sc->used_tx_bd += map->dm_nsegs;
@@ -4424,6 +4426,9 @@ bnx_tx_encap(struct bnx_softc *sc, struct mbuf *m)
DBRUN(BNX_VERBOSE_SEND, bnx_dump_tx_mbuf_chain(sc, chain_prod,
map->dm_nsegs));
+ bus_dmamap_sync(sc->bnx_dmatag, map, 0, map->dm_mapsize,
+ BUS_DMASYNC_PREWRITE);
+
/* prod points to the next free tx_bd at this point. */
sc->tx_prod = prod;
sc->tx_prod_bseq = prod_bseq;