The generation bit in the pktlen_gen_bufq_id field of the split queue
completion descriptor (virtchnl2_rx_flex_desc_adv_nic_3) must be
extracted by masking first and then shifting, not the other way around.
With shift-then-mask, the mask is applied to already-shifted bits,
which can produce incorrect results when upper bits (packet length,
buffer queue ID) leak into the extracted value.
Change to mask-then-shift to correctly isolate the generation bit
before comparing it with the expected generation ID.
Fixes: 1f065f9d75ff ("net/idpf: add AVX2 Rx path for split queue config")
Signed-off-by: Shaiq Wani <[email protected]>
---
.../net/intel/idpf/idpf_common_rxtx_avx2.c | 20 +++++++++----------
1 file changed, 10 insertions(+), 10 deletions(-)
diff --git a/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
b/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
index db7728afad..cd10c27a30 100644
--- a/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
+++ b/drivers/net/intel/idpf/idpf_common_rxtx_avx2.c
@@ -524,8 +524,8 @@ idpf_dp_splitq_recv_pkts_avx2(void *rxq, struct rte_mbuf
**rx_pkts, uint16_t nb_
/* check if there is at least one packet available */
head_gen = rxdp->flex_adv_nic_3_wb.pktlen_gen_bufq_id;
- if (((head_gen >> VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) &
- VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) != queue->expected_gen_id)
+ if (((head_gen & VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) >>
+ VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) != queue->expected_gen_id)
return 0;
for (i = 0; i < nb_pkts;
@@ -599,17 +599,17 @@ idpf_dp_splitq_recv_pkts_avx2(void *rxq, struct rte_mbuf
**rx_pkts, uint16_t nb_
pktlen_gen3 = (uint16_t)_mm_extract_epi16(d3, 2);
valid0 = (stat0 & 1) &&
- (((pktlen_gen0 >> VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) &
- VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) ==
queue->expected_gen_id);
+ (((pktlen_gen0 & VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) >>
+ VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) ==
queue->expected_gen_id);
valid1 = (stat1 & 1) &&
- (((pktlen_gen1 >> VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) &
- VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) ==
queue->expected_gen_id);
+ (((pktlen_gen1 & VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) >>
+ VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) ==
queue->expected_gen_id);
valid2 = (stat2 & 1) &&
- (((pktlen_gen2 >> VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) &
- VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) ==
queue->expected_gen_id);
+ (((pktlen_gen2 & VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) >>
+ VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) ==
queue->expected_gen_id);
valid3 = (stat3 & 1) &&
- (((pktlen_gen3 >> VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) &
- VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) ==
queue->expected_gen_id);
+ (((pktlen_gen3 & VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_M) >>
+ VIRTCHNL2_RX_FLEX_DESC_ADV_GEN_S) ==
queue->expected_gen_id);
/* count valid descriptors (holes are impossible because
* descriptors are read in reverse order while the NIC
--
2.34.1