net/fm10k: fix Rx descriptor read timing
We find that when traffic is light, a small number of packets will have wrong metadata (e.g. packet type), however this issue will not happen when traffic is heavy. The root cause is some fields in fm10k_rx_desc are read at the wrong time, since the descriptor (being 16-bytes big) is not read as a single atomic operation. When the input speed is slower than software's capability, fm10k scalar Rx function accesses descriptors at about the same time as HW writes them, so the scenario can occur: some fields like pkt_info in fm10k_rx_desc are read before HW writeback but some fields like DD bit are read after HW writeback, this will lead to the later packet parsing function using incorrect value. This patch fixes this issue by reading and parsing Rx descriptor only after first checking that the DD bit is set. Fixes: 4b61d3bfa941 ("fm10k: add receive and tranmit") Fixes: c82dd0a7bfa5 ("fm10k: add scatter receive") Signed-off-by: Wang Xiao W <xiao.w.wang@intel.com> Acked-by: Bruce Richardson <bruce.richardson@intel.com>
This commit is contained in:
parent
d1d861efef
commit
af15ee640d
@ -114,10 +114,10 @@ fm10k_recv_pkts(void *rx_queue, struct rte_mbuf **rx_pkts,
|
||||
|
||||
nb_pkts = RTE_MIN(nb_pkts, q->alloc_thresh);
|
||||
for (count = 0; count < nb_pkts; ++count) {
|
||||
if (!(q->hw_ring[next_dd].d.staterr & FM10K_RXD_STATUS_DD))
|
||||
break;
|
||||
mbuf = q->sw_ring[next_dd];
|
||||
desc = q->hw_ring[next_dd];
|
||||
if (!(desc.d.staterr & FM10K_RXD_STATUS_DD))
|
||||
break;
|
||||
#ifdef RTE_LIBRTE_FM10K_DEBUG_RX
|
||||
dump_rxd(&desc);
|
||||
#endif
|
||||
@ -228,10 +228,10 @@ fm10k_recv_scattered_pkts(void *rx_queue, struct rte_mbuf **rx_pkts,
|
||||
|
||||
nb_seg = RTE_MIN(nb_pkts, q->alloc_thresh);
|
||||
for (count = 0; count < nb_seg; count++) {
|
||||
if (!(q->hw_ring[next_dd].d.staterr & FM10K_RXD_STATUS_DD))
|
||||
break;
|
||||
mbuf = q->sw_ring[next_dd];
|
||||
desc = q->hw_ring[next_dd];
|
||||
if (!(desc.d.staterr & FM10K_RXD_STATUS_DD))
|
||||
break;
|
||||
#ifdef RTE_LIBRTE_FM10K_DEBUG_RX
|
||||
dump_rxd(&desc);
|
||||
#endif
|
||||
|
Loading…
x
Reference in New Issue
Block a user