From: Kevin Traynor <ktraynor@redhat.com>
To: Gavin Hu <gahu@nvidia.com>
Cc: Changqi Dingluo <dingluochangqi.ck@bytedance.com>,
Viacheslav Ovsiienko <viacheslavo@nvidia.com>,
dpdk stable <stable@dpdk.org>
Subject: patch 'net/mlx5: fix polling CQEs' has been queued to stable release 24.11.2
Date: Thu, 13 Feb 2025 09:57:47 +0000 [thread overview]
Message-ID: <20250213095933.362078-20-ktraynor@redhat.com> (raw)
In-Reply-To: <20250213095933.362078-1-ktraynor@redhat.com>
Hi,
FYI, your patch has been queued to stable release 24.11.2
Note it hasn't been pushed to http://dpdk.org/browse/dpdk-stable yet.
It will be pushed if I get no objections before 02/17/25. So please
shout if anyone has objections.
Also note that after the patch there's a diff of the upstream commit vs the
patch applied to the branch. This will indicate if there was any rebasing
needed to apply to the stable branch. If there were code changes for rebasing
(ie: not only metadata diffs), please double check that the rebase was
correctly done.
Queued patches are on a temporary branch at:
https://github.com/kevintraynor/dpdk-stable
This queued commit can be viewed at:
https://github.com/kevintraynor/dpdk-stable/commit/a0008d4df03f25a264ae7a1a88131b2e07d50ad9
Thanks.
Kevin
---
From a0008d4df03f25a264ae7a1a88131b2e07d50ad9 Mon Sep 17 00:00:00 2001
From: Gavin Hu <gahu@nvidia.com>
Date: Fri, 6 Dec 2024 02:58:11 +0200
Subject: [PATCH] net/mlx5: fix polling CQEs
[ upstream commit 73f7ae1d721aa5c388123db11827937205985999 ]
In certain situations, the receive queue (rxq) fails to replenish its
internal ring with memory buffers (mbufs) from the pool. This can happen
when the pool has a limited number of mbufs allocated, and the user
application holds incoming packets for an extended period, resulting in a
delayed release of mbufs. Consequently, the pool becomes depleted,
preventing the rxq from replenishing from it.
There was a bug in the behavior of the vectorized rxq_cq_process_v routine,
which handled completion queue entries (CQEs) in batches of four. This
routine consistently accessed four mbufs from the internal queue ring,
regardless of whether they had been replenished. As a result, it could
access mbufs that no longer belonged to the poll mode driver (PMD).
The fix involves checking if there are four replenished mbufs available
before allowing rxq_cq_process_v to handle the batch. Once replenishment
succeeds during the polling process, the routine will resume its operation.
Fixes: 1ded26239aa0 ("net/mlx5: refactor vectorized Rx")
Reported-by: Changqi Dingluo <dingluochangqi.ck@bytedance.com>
Signed-off-by: Gavin Hu <gahu@nvidia.com>
Acked-by: Viacheslav Ovsiienko <viacheslavo@nvidia.com>
---
.mailmap | 3 ++-
drivers/net/mlx5/mlx5_rxtx_vec.c | 3 +++
2 files changed, 5 insertions(+), 1 deletion(-)
diff --git a/.mailmap b/.mailmap
index 2c7a5d007e..07ae8c48fc 100644
--- a/.mailmap
+++ b/.mailmap
@@ -226,4 +226,5 @@ Chang Miao <chang.miao@corigine.com>
Changchun Ouyang <changchun.ouyang@intel.com>
Changpeng Liu <changpeng.liu@intel.com>
+Changqi Dingluo <dingluochangqi.ck@bytedance.com>
Changqing Wu <changqingx.wu@intel.com>
Chaoyong He <chaoyong.he@corigine.com>
@@ -465,5 +466,5 @@ Gary Mussar <gmussar@ciena.com>
Gaurav Singh <gaurav1086@gmail.com>
Gautam Dawar <gdawar@solarflare.com>
-Gavin Hu <gavin.hu@arm.com> <gavin.hu@linaro.org>
+Gavin Hu <gahu@nvidia.com> <gavin.hu@arm.com> <gavin.hu@linaro.org>
Gavin Li <gavinl@nvidia.com>
Geoffrey Le Gourriérec <geoffrey.le_gourrierec@6wind.com>
diff --git a/drivers/net/mlx5/mlx5_rxtx_vec.c b/drivers/net/mlx5/mlx5_rxtx_vec.c
index 1872bf310c..1b701801c5 100644
--- a/drivers/net/mlx5/mlx5_rxtx_vec.c
+++ b/drivers/net/mlx5/mlx5_rxtx_vec.c
@@ -326,4 +326,7 @@ rxq_burst_v(struct mlx5_rxq_data *rxq, struct rte_mbuf **pkts,
pkts_n = RTE_MIN(pkts_n, q_n - elts_idx);
pkts_n = RTE_MIN(pkts_n, q_n - cq_idx);
+ /* Not to move past the allocated mbufs. */
+ pkts_n = RTE_MIN(pkts_n, RTE_ALIGN_FLOOR(rxq->rq_ci - rxq->rq_pi,
+ MLX5_VPMD_DESCS_PER_LOOP));
if (!pkts_n) {
*no_cq = !rcvd_pkt;
--
2.48.1
---
Diff of the applied patch vs upstream commit (please double-check if non-empty:
---
--- - 2025-02-12 17:29:36.744515995 +0000
+++ 0020-net-mlx5-fix-polling-CQEs.patch 2025-02-12 17:29:34.190944975 +0000
@@ -1 +1 @@
-From 73f7ae1d721aa5c388123db11827937205985999 Mon Sep 17 00:00:00 2001
+From a0008d4df03f25a264ae7a1a88131b2e07d50ad9 Mon Sep 17 00:00:00 2001
@@ -5,0 +6,2 @@
+[ upstream commit 73f7ae1d721aa5c388123db11827937205985999 ]
+
@@ -24 +25,0 @@
-Cc: stable@dpdk.org
@@ -35 +36 @@
-index 38e511a28b..1ed47e1cad 100644
+index 2c7a5d007e..07ae8c48fc 100644
@@ -44 +45 @@
-@@ -466,5 +467,5 @@ Gary Mussar <gmussar@ciena.com>
+@@ -465,5 +466,5 @@ Gary Mussar <gmussar@ciena.com>
next prev parent reply other threads:[~2025-02-13 10:00 UTC|newest]
Thread overview: 123+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-02-13 9:57 patch 'log: fix double free on cleanup' " Kevin Traynor
2025-02-13 9:57 ` patch 'test/ring: fix init with custom number of lcores' " Kevin Traynor
2025-02-13 9:57 ` patch 'vhost: clear ring addresses when getting vring base' " Kevin Traynor
2025-02-13 9:57 ` patch 'vhost: check GSO size validity' " Kevin Traynor
2025-02-13 9:57 ` patch 'vhost: fix log when setting max queue num' " Kevin Traynor
2025-02-13 9:57 ` patch 'vhost: reset packets count when not ready' " Kevin Traynor
2025-02-13 9:57 ` patch 'crypto/cnxk: fix build with GCC 15' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/thunderx/base: " Kevin Traynor
2025-02-13 9:57 ` patch 'examples/flow_filtering: " Kevin Traynor
2025-02-13 9:57 ` patch 'eal/x86: fix some intrinsics header include for Windows' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ena: fix missing default LLQ policy' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/nfp: fix VF link speed' " Kevin Traynor
2025-02-13 9:57 ` patch 'test/bonding: fix active backup receive test' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/bonding: fix dedicated queue setup' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/hns3: fix mbuf freeing in simple Tx path' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/hns3: remove PVID info dump for VF' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/hns3: rename RAS module' " Kevin Traynor
2025-02-13 9:57 ` patch 'examples/flow_filtering: remove duplicate assignment' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/sfc: remove unnecessary " Kevin Traynor
2025-02-13 9:57 ` Kevin Traynor [this message]
2025-02-13 9:57 ` patch 'net/mlx5: fix leak of flow action data list' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/mlx5: fix unneeded stub flow table allocation' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ixgbe: fix E610 support in flow engine' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ixgbe/base: fix TSAM checking return value' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ixgbe/base: remove 2.5/5G from auto-negotiation for E610' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ixgbe/base: fix driver hang in VM' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ixgbe/base: add missing buffer copy for ACI' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/iavf: remove reset of Tx prepare function pointer' " Kevin Traynor
2025-02-13 9:57 ` patch 'net/ice: fix memory leak in scalar Rx' " Kevin Traynor
2025-02-13 9:57 ` patch 'common/cnxk: fix atomic load in batch ops' " Kevin Traynor
2025-02-13 9:57 ` patch 'common/cnxk: fix DPI mailbox structure' " Kevin Traynor
2025-02-13 9:57 ` patch 'eventdev: fix format string data type in log messages' " Kevin Traynor
2025-02-13 9:58 ` patch 'crypto/virtio: fix redundant queue free' " Kevin Traynor
2025-02-13 9:58 ` patch 'crypto/openssl: fix CMAC auth context update' " Kevin Traynor
2025-02-13 15:18 ` Wathsala Wathawana Vithanage
2025-02-13 9:58 ` patch 'cryptodev: fix C++ include' " Kevin Traynor
2025-02-13 9:58 ` patch 'crypto/virtio: fix data queues iteration' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/octeon_ep: remove useless assignment' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/enetfec: " Kevin Traynor
2025-02-13 9:58 ` patch 'net/gve: allocate Rx QPL pages using malloc' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/nfp: fix multiple PFs check from NSP' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/nfp: fix misuse of function return values' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/nfp: fix multi-PF control flag' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/nfp: fix firmware load from flash' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/ice: fix flows handling' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/cnxk: fix NIX send header L3 type' " Kevin Traynor
2025-02-13 9:58 ` patch 'gro: fix unprocessed IPv4 packets' " Kevin Traynor
2025-02-13 9:58 ` patch 'log: fix systemd journal socket open' " Kevin Traynor
2025-02-13 9:58 ` patch 'eal/linux: fix memseg length in legacy mem init' " Kevin Traynor
2025-02-13 9:58 ` patch 'service: fix getting service lcore attributes' " Kevin Traynor
2025-02-13 9:58 ` patch 'ptr_compress: fix build with Arm SVE' " Kevin Traynor
2025-02-13 9:58 ` patch 'buildtools: fix some Python regex syntax warnings' " Kevin Traynor
2025-02-13 9:58 ` patch 'dts: fix MTU set command' " Kevin Traynor
2025-02-13 9:58 ` patch 'dts: fix pass rate edge case in results' " Kevin Traynor
2025-02-13 9:58 ` patch 'use Python raw string notation' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/af_packet: fix socket close on device stop' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mana: do not ring short doorbell for every mbuf alloc' " Kevin Traynor
2025-02-13 9:58 ` patch 'ethdev: fix functions available in new device event' " Kevin Traynor
2025-02-13 9:58 ` patch 'vhost: add null callback checks' " Kevin Traynor
2025-02-13 9:58 ` patch 'vhost: fix FD entries cleanup' " Kevin Traynor
2025-02-13 9:58 ` patch 'build: force GCC 15 to initialize padding bits' " Kevin Traynor
2025-02-13 9:58 ` patch 'random: defer seeding to EAL init' " Kevin Traynor
2025-02-13 9:58 ` patch 'power: defer lcore variable allocation' " Kevin Traynor
2025-02-13 9:58 ` patch 'eal/x86: defer power intrinsics " Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: fix indication of " Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: fix Rx handler' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: fix crash when representor is re-attached' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: fix dead code' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: fix overflow' " Kevin Traynor
2025-02-13 9:58 ` Kevin Traynor
2025-02-13 9:58 ` patch 'net/bnxt: address uninitialized variables' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mlx5: fix Netlink socket leak' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mlx5: adjust actions per rule limitation' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mlx5: fix crash in non-template metadata split' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mlx5: fix flush of non-template flow rules' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/mlx5: fix GRE flow match with SWS' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix deadlock when writing i225 register' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix infinite loop' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix bitwise operation type' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: increase PHY power up delay' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: reset loop variable' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix LTR for i225' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix typo in LTR calculation' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix unused value' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix semaphore timeout " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix iterator type' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix MAC address hash bit shift' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix data type in MAC hash' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/igc/base: fix NVM data type in bit shift' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/e1000/base: fix semaphore timeout value' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/e1000/base: correct mPHY access logic' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/e1000/base: fix iterator type' " Kevin Traynor
2025-02-13 9:58 ` patch 'net/e1000/base: fix MAC address hash bit shift' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix data type in MAC hash' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix uninitialized variable' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix bitwise operation type' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix NVM data type in bit shift' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix reset for 82580' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: fix unchecked return' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/e1000/base: skip management check for 82575' " Kevin Traynor
2025-02-13 9:59 ` patch 'common/idpf: fix void function returning a value' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/intel: fix void functions " Kevin Traynor
2025-02-13 9:59 ` patch 'net/intel: fix build with icx' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/hns3: fix copper port initialization' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/hns3: fix reset timeout' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/cpfl: fix representor parsing log' " Kevin Traynor
2025-02-13 9:59 ` patch 'raw/cnxk_gpio: fix file descriptor leak' " Kevin Traynor
2025-02-13 9:59 ` patch 'eal: fix devargs layers parsing out of bounds' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/qede: fix debug messages array' " Kevin Traynor
2025-02-13 9:59 ` patch 'examples/ptpclient: fix message parsing' " Kevin Traynor
2025-02-13 9:59 ` patch 'net/hinic: fix flow type bitmask overflow' " Kevin Traynor
2025-02-13 9:59 ` patch 'crypto/dpaa2_sec: fix bitmask truncation' " Kevin Traynor
2025-02-13 9:59 ` patch 'crypto/dpaa_sec: " Kevin Traynor
2025-02-13 9:59 ` patch 'event/dpaa: " Kevin Traynor
2025-02-13 9:59 ` patch 'net/dpaa: " Kevin Traynor
2025-02-13 9:59 ` patch 'net/dpaa2: " Kevin Traynor
2025-02-13 9:59 ` patch 'net/qede: fix nested loops' " Kevin Traynor
2025-02-13 9:59 ` patch 'examples/l3fwd: fix socket ID check' " Kevin Traynor
2025-02-13 9:59 ` patch 'common/cnxk: fix null " Kevin Traynor
2025-02-13 9:59 ` patch 'eal/linux: remove useless assignments' " Kevin Traynor
2025-02-13 9:59 ` patch 'mempool: fix errno in empty create' " Kevin Traynor
2025-02-13 9:59 ` patch 'doc: add tested platforms with NVIDIA NICs in 24.11' " Kevin Traynor
2025-02-13 9:59 ` patch 'doc: add two more tested Intel " Kevin Traynor
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250213095933.362078-20-ktraynor@redhat.com \
--to=ktraynor@redhat.com \
--cc=dingluochangqi.ck@bytedance.com \
--cc=gahu@nvidia.com \
--cc=stable@dpdk.org \
--cc=viacheslavo@nvidia.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).