1
0
mirror of https://git.FreeBSD.org/src.git synced 2024-12-31 12:13:10 +00:00

Fix a serious regression from the busdma conversion. Check to make sure

that we don't overrun the tx descriptor ring before actually trying to
overrun it.
This commit is contained in:
Scott Long 2005-12-28 08:14:35 +00:00
parent 0e36e11d57
commit 3c41ebd1f8
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=153776

View File

@ -2935,7 +2935,8 @@ struct ti_dmamap_arg {
struct m_tag *mtag;
struct mbuf *m_head;
u_int16_t csum_flags;
int idx;
int idx;
int error;
};
static void
@ -2963,6 +2964,15 @@ ti_encap_cb(arg, segs, nseg, mapsize, error)
mtag = ctx->mtag;
csum_flags = ctx->csum_flags;
/*
* Sanity check: avoid coming within 16 descriptors
* of the end of the ring.
*/
if ((TI_TX_RING_CNT - (sc->ti_txcnt + nseg)) < 16) {
ctx->error = ENOBUFS;
return;
}
/*
* Start packing the mbufs in this chain into
* the fragment pointers. Stop when we run out
@ -2974,8 +2984,10 @@ ti_encap_cb(arg, segs, nseg, mapsize, error)
f = &txdesc;
} else
f = &sc->ti_rdata->ti_tx_ring[frag];
if (sc->ti_cdata.ti_tx_chain[frag] != NULL)
break;
if (sc->ti_cdata.ti_tx_chain[frag] != NULL) {
ctx->error = ENOBUFS;
return;
}
ti_hostaddr64(&f->ti_addr, segs[cnt].ds_addr);
f->ti_len = segs[cnt].ds_len;
f->ti_flags = csum_flags;
@ -3005,7 +3017,7 @@ ti_encap_cb(arg, segs, nseg, mapsize, error)
sc->ti_txcnt += cnt;
ctx->idx = frag;
ctx->error = 0;
}
/*
@ -3052,12 +3064,7 @@ ti_encap(sc, m_head, txidx)
cnt = ctx.idx - frag;
frag = ctx.idx;
/*
* Sanity check: avoid coming within 16 descriptors
* of the end of the ring.
*/
if (((TI_TX_RING_CNT - (sc->ti_txcnt + cnt)) < 16) ||
(frag == sc->ti_tx_saved_considx)) {
if ((ctx.error != 0) || (frag == sc->ti_tx_saved_considx)) {
bus_dmamap_unload(sc->ti_mbuftx_dmat, map);
return (ENOBUFS);
}