On Mon, May 11, 2026 at 02:39:35PM +0530, Shaiq Wani wrote:
> Clamp burst size to tx_rs_thresh to prevent crossing completion
> boundaries.  Update tx_next_rs on ring wrap and after each burst
> so that completion tracking in idpf_splitq_scan_cq_ring works
> correctly.  Fix sw_ring pointer to use base-plus-offset.
> 
> Fixes: 57560a92167a ("net/idpf: add AVX2 Tx path for split queue config")
> Signed-off-by: Shaiq Wani <[email protected]>
Acked-by: Bruce Richardson <[email protected]>
> ---
>  .../net/intel/idpf/idpf_common_rxtx_avx2.c    | 24 ++++++++++++++-----
>  1 file changed, 18 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c 
> b/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
> index 7c547b5f09..b6c4fdf20e 100644
> --- a/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
> +++ b/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
> @@ -884,17 +884,21 @@ idpf_splitq_xmit_fixed_burst_vec_avx2(void *tx_queue, 
> struct rte_mbuf **tx_pkts,
>       struct ci_tx_queue *txq = (struct ci_tx_queue *)tx_queue;
>       struct idpf_flex_tx_sched_desc *txdp;
>       struct ci_tx_entry_vec *txep;
> -     uint16_t n, nb_commit;
> +     uint16_t n, nb_commit, tx_id;
>       uint64_t cmd_dtype = IDPF_TXD_FLEX_FLOW_CMD_EOP;
> -     uint16_t tx_id = txq->tx_tail;
>  
> -     nb_commit = (uint16_t)RTE_MIN(txq->nb_tx_free, nb_pkts);
> -     nb_pkts = nb_commit;
> +     /* cross rs_thresh boundary is not allowed */
> +     nb_pkts = RTE_MIN(nb_pkts, txq->tx_rs_thresh);
> +
> +     nb_pkts = (uint16_t)RTE_MIN(txq->nb_tx_free, nb_pkts);
> +     nb_commit = nb_pkts;
>       if (unlikely(nb_pkts == 0))
>               return 0;
>  
> -     txdp = (struct idpf_flex_tx_sched_desc *)&txq->desc_ring[tx_id];
> -     txep = &txq->sw_ring_vec[tx_id];
> +     tx_id = txq->tx_tail;
> +     txdp = &txq->desc_ring[tx_id];
> +     txep = (void *)txq->sw_ring;
> +     txep += tx_id;
>  
>       txq->nb_tx_free = (uint16_t)(txq->nb_tx_free - nb_pkts);
>  
> @@ -909,10 +913,14 @@ idpf_splitq_xmit_fixed_burst_vec_avx2(void *tx_queue, 
> struct rte_mbuf **tx_pkts,
>               idpf_splitq_vtx1_avx2(txdp, *tx_pkts++, cmd_dtype);
>  
>               nb_commit = (uint16_t)(nb_commit - n);
> +
>               tx_id = 0;
> +             txq->tx_next_rs = (uint16_t)(txq->tx_rs_thresh - 1);
>  
> +             /* avoid reach the end of ring */
>               txdp = &txq->desc_ring[tx_id];
>               txep = (void *)txq->sw_ring;
> +             txep += tx_id;
>       }
>  
>       ci_tx_backlog_entry_vec(txep, tx_pkts, nb_commit);
> @@ -920,6 +928,10 @@ idpf_splitq_xmit_fixed_burst_vec_avx2(void *tx_queue, 
> struct rte_mbuf **tx_pkts,
>       idpf_splitq_vtx_avx2(txdp, tx_pkts, nb_commit, cmd_dtype);
>  
>       tx_id = (uint16_t)(tx_id + nb_commit);
> +     if (tx_id > txq->tx_next_rs)
> +             txq->tx_next_rs =
> +                     (uint16_t)(txq->tx_next_rs + txq->tx_rs_thresh);
> +
>       txq->tx_tail = tx_id;
>  
>       IDPF_PCI_REG_WRITE(txq->qtx_tail, txq->tx_tail);
> -- 
> 2.34.1
> 

Reply via email to