net/bnxt: fix representor data path
1.Representor Rx ring producer index was not getting reset in the ring full case. Fix it by incrementing only in success case. 2.Instead of calling the mbuf specific routine to free the mbuf when representor ring is full rte_free was being called leading to 'invalid memory' errors being logged. 3. Do not account the pkt meant for the representor in the parent Rx ring's array that is returned to the application. Fixes: 6dc83230b43b ("net/bnxt: support port representor data path") Cc: stable@dpdk.org Signed-off-by: Somnath Kotur <somnath.kotur@broadcom.com> Reviewed-by: Sriharsha Basavapatna <sriharsha.basavapatna@broadcom.com> Reviewed-by: Venkat Duvvuru <venkatkumar.duvvuru@broadcom.com> Reviewed-by: Ajit Khaparde <ajit.khaparde@broadcom.com>
This commit is contained in:
parent
9b842a93e2
commit
526e0b0200
@ -55,15 +55,17 @@ bnxt_vfr_recv(uint16_t port_id, uint16_t queue_id, struct rte_mbuf *mbuf)
|
|||||||
mask = rep_rxr->rx_ring_struct->ring_mask;
|
mask = rep_rxr->rx_ring_struct->ring_mask;
|
||||||
|
|
||||||
/* Put this mbuf on the RxQ of the Representor */
|
/* Put this mbuf on the RxQ of the Representor */
|
||||||
prod_rx_buf = &rep_rxr->rx_buf_ring[rep_rxr->rx_prod++ & mask];
|
prod_rx_buf = &rep_rxr->rx_buf_ring[rep_rxr->rx_prod & mask];
|
||||||
if (!*prod_rx_buf) {
|
if (!*prod_rx_buf) {
|
||||||
*prod_rx_buf = mbuf;
|
*prod_rx_buf = mbuf;
|
||||||
vfr_bp->rx_bytes[que] += mbuf->pkt_len;
|
vfr_bp->rx_bytes[que] += mbuf->pkt_len;
|
||||||
vfr_bp->rx_pkts[que]++;
|
vfr_bp->rx_pkts[que]++;
|
||||||
|
rep_rxr->rx_prod++;
|
||||||
} else {
|
} else {
|
||||||
|
/* Representor Rx ring full, drop pkt */
|
||||||
vfr_bp->rx_drop_bytes[que] += mbuf->pkt_len;
|
vfr_bp->rx_drop_bytes[que] += mbuf->pkt_len;
|
||||||
vfr_bp->rx_drop_pkts[que]++;
|
vfr_bp->rx_drop_pkts[que]++;
|
||||||
rte_pktmbuf_free(mbuf); /* Representor Rx ring full, drop pkt */
|
rte_pktmbuf_free(mbuf);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -795,6 +795,19 @@ static int bnxt_rx_pkt(struct rte_mbuf **rx_pkt,
|
|||||||
goto rx;
|
goto rx;
|
||||||
}
|
}
|
||||||
rxr->rx_prod = prod;
|
rxr->rx_prod = prod;
|
||||||
|
|
||||||
|
if (BNXT_TRUFLOW_EN(bp) && (BNXT_VF_IS_TRUSTED(bp) || BNXT_PF(bp)) &&
|
||||||
|
vfr_flag) {
|
||||||
|
bnxt_vfr_recv(mark_id, rxq->queue_id, mbuf);
|
||||||
|
/* Now return an error so that nb_rx_pkts is not
|
||||||
|
* incremented.
|
||||||
|
* This packet was meant to be given to the representor.
|
||||||
|
* So no need to account the packet and give it to
|
||||||
|
* parent Rx burst function.
|
||||||
|
*/
|
||||||
|
rc = -ENODEV;
|
||||||
|
goto next_rx;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* All MBUFs are allocated with the same size under DPDK,
|
* All MBUFs are allocated with the same size under DPDK,
|
||||||
* no optimization for rx_copy_thresh
|
* no optimization for rx_copy_thresh
|
||||||
@ -802,20 +815,6 @@ static int bnxt_rx_pkt(struct rte_mbuf **rx_pkt,
|
|||||||
rx:
|
rx:
|
||||||
*rx_pkt = mbuf;
|
*rx_pkt = mbuf;
|
||||||
|
|
||||||
if (BNXT_TRUFLOW_EN(bp) &&
|
|
||||||
(BNXT_VF_IS_TRUSTED(bp) || BNXT_PF(bp)) &&
|
|
||||||
vfr_flag) {
|
|
||||||
if (!bnxt_vfr_recv(mark_id, rxq->queue_id, mbuf)) {
|
|
||||||
/* Now return an error so that nb_rx_pkts is not
|
|
||||||
* incremented.
|
|
||||||
* This packet was meant to be given to the representor.
|
|
||||||
* So no need to account the packet and give it to
|
|
||||||
* parent Rx burst function.
|
|
||||||
*/
|
|
||||||
rc = -ENODEV;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
next_rx:
|
next_rx:
|
||||||
|
|
||||||
*raw_cons = tmp_raw_cons;
|
*raw_cons = tmp_raw_cons;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user