Fix bug in VNIC causing phony number of available TX descriptors
TSO packets will signal segments TX completion in the separate CQ descriptors. Each CQ descriptor for HW TSO will point to the same SQ entry. Do not invoke nicvf_put_sq_desc() for secondary segments to avoid free_cnt corruption and eventually integer overflow that will result in the negative free_cnt value and hence impossibility of further transmission. Reviewed by: wma Obtained from: Semihalf Sponsored by: Cavium Differential Revision: https://reviews.freebsd.org/D5535
This commit is contained in:
parent
0196c2e86e
commit
6cac5eb749
@ -722,10 +722,10 @@ nicvf_snd_pkt_handler(struct nicvf *nic, struct cmp_queue *cq,
|
|||||||
if (mbuf != NULL) {
|
if (mbuf != NULL) {
|
||||||
m_freem(mbuf);
|
m_freem(mbuf);
|
||||||
sq->snd_buff[cqe_tx->sqe_ptr].mbuf = NULL;
|
sq->snd_buff[cqe_tx->sqe_ptr].mbuf = NULL;
|
||||||
|
nicvf_put_sq_desc(sq, hdr->subdesc_cnt + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
nicvf_check_cqe_tx_errs(nic, cq, cqe_tx);
|
nicvf_check_cqe_tx_errs(nic, cq, cqe_tx);
|
||||||
nicvf_put_sq_desc(sq, hdr->subdesc_cnt + 1);
|
|
||||||
|
|
||||||
NICVF_TX_UNLOCK(sq);
|
NICVF_TX_UNLOCK(sq);
|
||||||
return (0);
|
return (0);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user