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:
parent
0e36e11d57
commit
3c41ebd1f8
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=153776
@ -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);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user