patches for DPDK stable branches
 help / color / mirror / Atom feed
From: Shani Peretz <shperetz@nvidia.com>
To: Wathsala Vithanage <wathsala.vithanage@arm.com>
Cc: Ola Liljedahl <ola.liljedahl@arm.com>,
	Honnappa Nagarahalli <honnappa.nagarahalli@arm.com>,
	Dhruv Tripathi <dhruv.tripathi@arm.com>,
	Konstantin Ananyev <konstantin.ananyev@huawei.com>,
	dpdk stable <stable@dpdk.org>
Subject: patch 'ring: establish safe partial order in default mode' has been queued to stable release 23.11.6
Date: Thu, 25 Dec 2025 11:18:30 +0200	[thread overview]
Message-ID: <20251225091938.345892-69-shperetz@nvidia.com> (raw)
In-Reply-To: <20251225091938.345892-1-shperetz@nvidia.com>

Hi,

FYI, your patch has been queued to stable release 23.11.6

Note it hasn't been pushed to http://dpdk.org/browse/dpdk-stable yet.
It will be pushed if I get no objections before 12/30/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/shanipr/dpdk-stable

This queued commit can be viewed at:
https://github.com/shanipr/dpdk-stable/commit/942163a489126848c2ae10fcb60df2fb59f3aac8

Thanks.

Shani

---
From 942163a489126848c2ae10fcb60df2fb59f3aac8 Mon Sep 17 00:00:00 2001
From: Wathsala Vithanage <wathsala.vithanage@arm.com>
Date: Tue, 2 Dec 2025 20:39:26 +0000
Subject: [PATCH] ring: establish safe partial order in default mode
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

[ upstream commit a4ad0eba9def1d1d071da8afe5e96eb2a2e0d71f]

The function __rte_ring_headtail_move_head() assumes that the barrier
(fence) between the load of the head and the load-acquire of the
opposing tail guarantees the following: if a first thread reads tail
and then writes head and a second thread reads the new value of head
and then reads tail, then it should observe the same (or a later)
value of tail.

This assumption is incorrect under the C11 memory model. If the barrier
(fence) is intended to establish a total ordering of ring operations,
it fails to do so. Instead, the current implementation only enforces a
partial ordering, which can lead to unsafe interleavings. In particular,
some partial orders can cause underflows in free slot or available
element computations, potentially resulting in data corruption.

The issue manifests when a CPU first acts as a producer and later as a
consumer. In this scenario, the barrier assumption may fail when another
core takes the consumer role. A Herd7 litmus test in C11 can demonstrate
this violation. The problem has not been widely observed so far because:
  (a) on strong memory models (e.g., x86-64) the assumption holds, and
  (b) on relaxed models with RCsc semantics the ordering is still strong
      enough to prevent hazards.
The problem becomes visible only on weaker models, when load-acquire is
implemented with RCpc semantics (e.g. some AArch64 CPUs which support
the LDAPR and LDAPUR instructions).

Three possible solutions exist:
  1. Strengthen ordering by upgrading release/acquire semantics to
     sequential consistency. This requires using seq-cst for stores,
     loads, and CAS operations. However, this approach introduces a
     significant performance penalty on relaxed-memory architectures.

  2. Establish a safe partial order by enforcing a pair-wise
     happens-before relationship between thread of same role by changing
     the CAS and the preceding load of the head by converting them to
     release and acquire respectively. This approach makes the original
     barrier assumption unnecessary and allows its removal.

  3. Retain partial ordering but ensure only safe partial orders are
     committed. This can be done by detecting underflow conditions
     (producer < consumer) and quashing the update in such cases.
     This approach makes the original barrier assumption unnecessary
     and allows its removal.

This patch implements solution (2) to preserve the “enqueue always
succeeds” contract expected by dependent libraries (e.g., mempool).
While solution (3) offers higher performance, adopting it now would
break that assumption.

Signed-off-by: Wathsala Vithanage <wathsala.vithanage@arm.com>
Signed-off-by: Ola Liljedahl <ola.liljedahl@arm.com>
Reviewed-by: Honnappa Nagarahalli <honnappa.nagarahalli@arm.com>
Reviewed-by: Dhruv Tripathi <dhruv.tripathi@arm.com>
Acked-by: Konstantin Ananyev <konstantin.ananyev@huawei.com>
Tested-by: Konstantin Ananyev <konstantin.ananyev@huawei.com>
---
 lib/ring/rte_ring_c11_pvt.h | 71 ++++++++++++++++++++++++++++---------
 1 file changed, 54 insertions(+), 17 deletions(-)

diff --git a/lib/ring/rte_ring_c11_pvt.h b/lib/ring/rte_ring_c11_pvt.h
index 5c10ad88f5..fb00889fdf 100644
--- a/lib/ring/rte_ring_c11_pvt.h
+++ b/lib/ring/rte_ring_c11_pvt.h
@@ -24,7 +24,12 @@ __rte_ring_update_tail(struct rte_ring_headtail *ht, uint32_t old_val,
 	if (!single)
 		rte_wait_until_equal_32((uint32_t *)(uintptr_t)&ht->tail, old_val,
 			rte_memory_order_relaxed);
-
+	/*
+	 * R0: Establishes a synchronizing edge with load-acquire of
+	 * cons_tail at A1 or prod_tail at A4.
+	 * Ensures that memory effects by this thread on ring elements array
+	 * is observed by a different thread of the other type.
+	 */
 	rte_atomic_store_explicit(&ht->tail, new_val, rte_memory_order_release);
 }
 
@@ -62,16 +67,24 @@ __rte_ring_move_prod_head(struct rte_ring *r, unsigned int is_sp,
 	unsigned int max = n;
 	int success;
 
-	*old_head = rte_atomic_load_explicit(&r->prod.head, rte_memory_order_relaxed);
+	/*
+	 * A0: Establishes a synchronizing edge with R1.
+	 * Ensure that this thread observes same values
+	 * to cons_tail observed by the thread that
+	 * updated r->prod.head.
+	 * If not, an unsafe partial order may ensue.
+	 */
+	*old_head = rte_atomic_load_explicit(&r->prod.head, rte_memory_order_acquire);
 	do {
 		/* Reset n to the initial burst count */
 		n = max;
 
-		/* Ensure the head is read before tail */
-		__atomic_thread_fence(rte_memory_order_acquire);
 
-		/* load-acquire synchronize with store-release of ht->tail
-		 * in update_tail.
+		/*
+		 * A1: Establishes a synchronizing edge with R0.
+		 * Ensures that other thread's memory effects on
+		 * ring elements array is observed by the time
+		 * this thread observes its tail update.
 		 */
 		cons_tail = rte_atomic_load_explicit(&r->cons.tail,
 					rte_memory_order_acquire);
@@ -97,10 +110,19 @@ __rte_ring_move_prod_head(struct rte_ring *r, unsigned int is_sp,
 			success = 1;
 		} else
 			/* on failure, *old_head is updated */
+			/*
+			 * R1/A2.
+			 * R1: Establishes a synchronizing edge with A0 of a
+			 * different thread.
+			 * A2: Establishes a synchronizing edge with R1 of a
+			 * different thread to observe same value for
+			 * cons_tail observed by that thread on CAS failure
+			 * (to retry with an updated *old_head).
+			 */
 			success = rte_atomic_compare_exchange_strong_explicit(&r->prod.head,
 					old_head, *new_head,
-					rte_memory_order_relaxed,
-					rte_memory_order_relaxed);
+					rte_memory_order_release,
+					rte_memory_order_acquire);
 	} while (unlikely(success == 0));
 	return n;
 }
@@ -138,17 +160,23 @@ __rte_ring_move_cons_head(struct rte_ring *r, int is_sc,
 	uint32_t prod_tail;
 	int success;
 
-	/* move cons.head atomically */
-	*old_head = rte_atomic_load_explicit(&r->cons.head, rte_memory_order_relaxed);
+	/*
+	 * A3: Establishes a synchronizing edge with R2.
+	 * Ensure that this thread observes same values
+	 * to prod_tail observed by the thread that
+	 * updated r->cons.head.
+	 * If not, an unsafe partial order may ensue.
+	 */
+	*old_head = rte_atomic_load_explicit(&r->cons.head, rte_memory_order_acquire);
 	do {
 		/* Restore n as it may change every loop */
 		n = max;
 
-		/* Ensure the head is read before tail */
-		__atomic_thread_fence(rte_memory_order_acquire);
-
-		/* this load-acquire synchronize with store-release of ht->tail
-		 * in update_tail.
+		/*
+		 * A4: Establishes a synchronizing edge with R0.
+		 * Ensures that other thread's memory effects on
+		 * ring elements array is observed by the time
+		 * this thread observes its tail update.
 		 */
 		prod_tail = rte_atomic_load_explicit(&r->prod.tail,
 					rte_memory_order_acquire);
@@ -173,10 +201,19 @@ __rte_ring_move_cons_head(struct rte_ring *r, int is_sc,
 			success = 1;
 		} else
 			/* on failure, *old_head will be updated */
+			/*
+			 * R2/A5.
+			 * R2: Establishes a synchronizing edge with A3 of a
+			 * different thread.
+			 * A5: Establishes a synchronizing edge with R2 of a
+			 * different thread to observe same value for
+			 * prod_tail observed by that thread on CAS failure
+			 * (to retry with an updated *old_head).
+			 */
 			success = rte_atomic_compare_exchange_strong_explicit(&r->cons.head,
 							old_head, *new_head,
-							rte_memory_order_relaxed,
-							rte_memory_order_relaxed);
+							rte_memory_order_release,
+							rte_memory_order_acquire);
 	} while (unlikely(success == 0));
 	return n;
 }
-- 
2.43.0

---
  Diff of the applied patch vs upstream commit (please double-check if non-empty:
---
--- -	2025-12-25 11:16:39.805462717 +0200
+++ 0069-ring-establish-safe-partial-order-in-default-mode.patch	2025-12-25 11:16:36.069837000 +0200
@@ -0,0 +1,194 @@
+From 942163a489126848c2ae10fcb60df2fb59f3aac8 Mon Sep 17 00:00:00 2001
+From: Wathsala Vithanage <wathsala.vithanage@arm.com>
+Date: Tue, 2 Dec 2025 20:39:26 +0000
+Subject: [PATCH] ring: establish safe partial order in default mode
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+[ upstream commit a4ad0eba9def1d1d071da8afe5e96eb2a2e0d71f]
+
+The function __rte_ring_headtail_move_head() assumes that the barrier
+(fence) between the load of the head and the load-acquire of the
+opposing tail guarantees the following: if a first thread reads tail
+and then writes head and a second thread reads the new value of head
+and then reads tail, then it should observe the same (or a later)
+value of tail.
+
+This assumption is incorrect under the C11 memory model. If the barrier
+(fence) is intended to establish a total ordering of ring operations,
+it fails to do so. Instead, the current implementation only enforces a
+partial ordering, which can lead to unsafe interleavings. In particular,
+some partial orders can cause underflows in free slot or available
+element computations, potentially resulting in data corruption.
+
+The issue manifests when a CPU first acts as a producer and later as a
+consumer. In this scenario, the barrier assumption may fail when another
+core takes the consumer role. A Herd7 litmus test in C11 can demonstrate
+this violation. The problem has not been widely observed so far because:
+  (a) on strong memory models (e.g., x86-64) the assumption holds, and
+  (b) on relaxed models with RCsc semantics the ordering is still strong
+      enough to prevent hazards.
+The problem becomes visible only on weaker models, when load-acquire is
+implemented with RCpc semantics (e.g. some AArch64 CPUs which support
+the LDAPR and LDAPUR instructions).
+
+Three possible solutions exist:
+  1. Strengthen ordering by upgrading release/acquire semantics to
+     sequential consistency. This requires using seq-cst for stores,
+     loads, and CAS operations. However, this approach introduces a
+     significant performance penalty on relaxed-memory architectures.
+
+  2. Establish a safe partial order by enforcing a pair-wise
+     happens-before relationship between thread of same role by changing
+     the CAS and the preceding load of the head by converting them to
+     release and acquire respectively. This approach makes the original
+     barrier assumption unnecessary and allows its removal.
+
+  3. Retain partial ordering but ensure only safe partial orders are
+     committed. This can be done by detecting underflow conditions
+     (producer < consumer) and quashing the update in such cases.
+     This approach makes the original barrier assumption unnecessary
+     and allows its removal.
+
+This patch implements solution (2) to preserve the “enqueue always
+succeeds” contract expected by dependent libraries (e.g., mempool).
+While solution (3) offers higher performance, adopting it now would
+break that assumption.
+
+Signed-off-by: Wathsala Vithanage <wathsala.vithanage@arm.com>
+Signed-off-by: Ola Liljedahl <ola.liljedahl@arm.com>
+Reviewed-by: Honnappa Nagarahalli <honnappa.nagarahalli@arm.com>
+Reviewed-by: Dhruv Tripathi <dhruv.tripathi@arm.com>
+Acked-by: Konstantin Ananyev <konstantin.ananyev@huawei.com>
+Tested-by: Konstantin Ananyev <konstantin.ananyev@huawei.com>
+---
+ lib/ring/rte_ring_c11_pvt.h | 71 ++++++++++++++++++++++++++++---------
+ 1 file changed, 54 insertions(+), 17 deletions(-)
+
+diff --git a/lib/ring/rte_ring_c11_pvt.h b/lib/ring/rte_ring_c11_pvt.h
+index 5c10ad88f5..fb00889fdf 100644
+--- a/lib/ring/rte_ring_c11_pvt.h
++++ b/lib/ring/rte_ring_c11_pvt.h
+@@ -24,7 +24,12 @@ __rte_ring_update_tail(struct rte_ring_headtail *ht, uint32_t old_val,
+ 	if (!single)
+ 		rte_wait_until_equal_32((uint32_t *)(uintptr_t)&ht->tail, old_val,
+ 			rte_memory_order_relaxed);
+-
++	/*
++	 * R0: Establishes a synchronizing edge with load-acquire of
++	 * cons_tail at A1 or prod_tail at A4.
++	 * Ensures that memory effects by this thread on ring elements array
++	 * is observed by a different thread of the other type.
++	 */
+ 	rte_atomic_store_explicit(&ht->tail, new_val, rte_memory_order_release);
+ }
+ 
+@@ -62,16 +67,24 @@ __rte_ring_move_prod_head(struct rte_ring *r, unsigned int is_sp,
+ 	unsigned int max = n;
+ 	int success;
+ 
+-	*old_head = rte_atomic_load_explicit(&r->prod.head, rte_memory_order_relaxed);
++	/*
++	 * A0: Establishes a synchronizing edge with R1.
++	 * Ensure that this thread observes same values
++	 * to cons_tail observed by the thread that
++	 * updated r->prod.head.
++	 * If not, an unsafe partial order may ensue.
++	 */
++	*old_head = rte_atomic_load_explicit(&r->prod.head, rte_memory_order_acquire);
+ 	do {
+ 		/* Reset n to the initial burst count */
+ 		n = max;
+ 
+-		/* Ensure the head is read before tail */
+-		__atomic_thread_fence(rte_memory_order_acquire);
+ 
+-		/* load-acquire synchronize with store-release of ht->tail
+-		 * in update_tail.
++		/*
++		 * A1: Establishes a synchronizing edge with R0.
++		 * Ensures that other thread's memory effects on
++		 * ring elements array is observed by the time
++		 * this thread observes its tail update.
+ 		 */
+ 		cons_tail = rte_atomic_load_explicit(&r->cons.tail,
+ 					rte_memory_order_acquire);
+@@ -97,10 +110,19 @@ __rte_ring_move_prod_head(struct rte_ring *r, unsigned int is_sp,
+ 			success = 1;
+ 		} else
+ 			/* on failure, *old_head is updated */
++			/*
++			 * R1/A2.
++			 * R1: Establishes a synchronizing edge with A0 of a
++			 * different thread.
++			 * A2: Establishes a synchronizing edge with R1 of a
++			 * different thread to observe same value for
++			 * cons_tail observed by that thread on CAS failure
++			 * (to retry with an updated *old_head).
++			 */
+ 			success = rte_atomic_compare_exchange_strong_explicit(&r->prod.head,
+ 					old_head, *new_head,
+-					rte_memory_order_relaxed,
+-					rte_memory_order_relaxed);
++					rte_memory_order_release,
++					rte_memory_order_acquire);
+ 	} while (unlikely(success == 0));
+ 	return n;
+ }
+@@ -138,17 +160,23 @@ __rte_ring_move_cons_head(struct rte_ring *r, int is_sc,
+ 	uint32_t prod_tail;
+ 	int success;
+ 
+-	/* move cons.head atomically */
+-	*old_head = rte_atomic_load_explicit(&r->cons.head, rte_memory_order_relaxed);
++	/*
++	 * A3: Establishes a synchronizing edge with R2.
++	 * Ensure that this thread observes same values
++	 * to prod_tail observed by the thread that
++	 * updated r->cons.head.
++	 * If not, an unsafe partial order may ensue.
++	 */
++	*old_head = rte_atomic_load_explicit(&r->cons.head, rte_memory_order_acquire);
+ 	do {
+ 		/* Restore n as it may change every loop */
+ 		n = max;
+ 
+-		/* Ensure the head is read before tail */
+-		__atomic_thread_fence(rte_memory_order_acquire);
+-
+-		/* this load-acquire synchronize with store-release of ht->tail
+-		 * in update_tail.
++		/*
++		 * A4: Establishes a synchronizing edge with R0.
++		 * Ensures that other thread's memory effects on
++		 * ring elements array is observed by the time
++		 * this thread observes its tail update.
+ 		 */
+ 		prod_tail = rte_atomic_load_explicit(&r->prod.tail,
+ 					rte_memory_order_acquire);
+@@ -173,10 +201,19 @@ __rte_ring_move_cons_head(struct rte_ring *r, int is_sc,
+ 			success = 1;
+ 		} else
+ 			/* on failure, *old_head will be updated */
++			/*
++			 * R2/A5.
++			 * R2: Establishes a synchronizing edge with A3 of a
++			 * different thread.
++			 * A5: Establishes a synchronizing edge with R2 of a
++			 * different thread to observe same value for
++			 * prod_tail observed by that thread on CAS failure
++			 * (to retry with an updated *old_head).
++			 */
+ 			success = rte_atomic_compare_exchange_strong_explicit(&r->cons.head,
+ 							old_head, *new_head,
+-							rte_memory_order_relaxed,
+-							rte_memory_order_relaxed);
++							rte_memory_order_release,
++							rte_memory_order_acquire);
+ 	} while (unlikely(success == 0));
+ 	return n;
+ }
+-- 
+2.43.0
+

  parent reply	other threads:[~2025-12-25  9:24 UTC|newest]

Thread overview: 195+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-12-21 14:55 patch 'test/telemetry: fix test calling all commands' " Shani Peretz
2025-12-21 14:55 ` patch 'eal: fix plugin dir walk' " Shani Peretz
2025-12-21 14:55 ` patch 'cmdline: fix port list parsing' " Shani Peretz
2025-12-21 14:55 ` patch 'cmdline: fix highest bit " Shani Peretz
2025-12-21 14:55 ` patch 'tailq: fix lookup macro' " Shani Peretz
2025-12-21 14:55 ` patch 'hash: fix unaligned access in predictable RSS' " Shani Peretz
2025-12-21 14:55 ` patch 'graph: fix unaligned access in stats' " Shani Peretz
2025-12-21 14:55 ` patch 'eventdev: fix listing timer adapters with telemetry' " Shani Peretz
2025-12-21 14:55 ` patch 'cfgfile: fix section count with no name' " Shani Peretz
2025-12-21 14:55 ` patch 'net/gve: do not write zero-length descriptors' " Shani Peretz
2025-12-21 14:55 ` patch 'net/gve: validate Tx packet before sending' " Shani Peretz
2025-12-21 14:56 ` patch 'net/vmxnet3: fix mapping of mempools to queues' " Shani Peretz
2025-12-21 14:56 ` patch 'app/testpmd: increase size of set cores list command' " Shani Peretz
2025-12-21 14:56 ` patch 'net/dpaa2: fix shaper rate' " Shani Peretz
2025-12-21 14:56 ` patch 'app/testpmd: monitor state of primary process' " Shani Peretz
2025-12-21 14:56 ` patch 'net/gve: fix disabling interrupts on DQ' " Shani Peretz
2025-12-21 14:56 ` patch 'app/testpmd: fix conntrack action query' " Shani Peretz
2025-12-21 14:56 ` patch 'doc: add conntrack state inspect command to testpmd guide' " Shani Peretz
2025-12-21 14:56 ` patch 'net/gve: free Rx mbufs if allocation fails on ring setup' " Shani Peretz
2025-12-21 14:56 ` patch 'app/testpmd: validate DSCP and VLAN for meter creation' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix min and max MTU reporting' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix storage of shared Rx queues' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5/hws: fix ESP header match in strict mode' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix unsupported flow rule port action' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix non-template age rules flush' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix connection tracking state item validation' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5/hws: fix TIR action support in FDB' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix indirect flow age action handling' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix Direct Verbs counter offset detection' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix interface name parameter definition' " Shani Peretz
2025-12-21 14:56 ` patch 'net/iavf: fix Tx vector path selection logic' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice: fix vector Rx VLAN offload flags' " Shani Peretz
2025-12-21 14:56 ` patch 'net/intel: fix assumption about tag placement order' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice: fix VLAN tag reporting on Rx' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice/base: fix adding special words' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice/base: fix memory leak in HW profile handling' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice/base: fix memory leak in recipe " Shani Peretz
2025-12-21 14:56 ` patch 'gro: fix payload corruption in coalescing packets' " Shani Peretz
2025-12-21 14:56 ` patch 'eal: fix DMA mask validation with IOVA mode option' " Shani Peretz
2025-12-21 14:56 ` patch 'eal: fix MP socket cleanup' " Shani Peretz
2025-12-21 14:56 ` patch 'crypto/ipsec_mb: fix QP release in secondary' " Shani Peretz
2025-12-21 14:56 ` patch 'efd: fix AVX2 support' " Shani Peretz
2025-12-21 14:56 ` patch 'net/octeon_ep: fix device start' " Shani Peretz
2025-12-21 14:56 ` patch 'common/cnxk: fix async event handling' " Shani Peretz
2025-12-21 14:56 ` patch 'doc: fix feature list of ice driver' " Shani Peretz
2025-12-21 14:56 ` patch 'doc: fix feature list of iavf " Shani Peretz
2025-12-21 14:56 ` patch 'baseband/acc: fix exported header' " Shani Peretz
2025-12-21 14:56 ` patch 'eventdev: do not include driver header in DMA adapter' " Shani Peretz
2025-12-21 14:56 ` patch 'gpudev: fix driver header for Windows' " Shani Peretz
2025-12-21 14:56 ` patch 'drivers: fix some exported headers' " Shani Peretz
2025-12-21 14:56 ` patch 'test/debug: fix crash with mlx5 devices' " Shani Peretz
2025-12-21 14:56 ` patch 'bus/pci: fix build with MinGW 13' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: " Shani Peretz
2025-12-21 14:56 ` patch 'dma/hisilicon: fix stop with pending transfers' " Shani Peretz
2025-12-21 14:56 ` patch 'test/dma: fix failure condition' " Shani Peretz
2025-12-21 14:56 ` patch 'eal/x86: enable timeout in AMD power monitor' " Shani Peretz
2025-12-21 14:56 ` patch 'fib6: fix tbl8 allocation check logic' " Shani Peretz
2025-12-21 14:56 ` patch 'vhost: add VDUSE virtqueue ready state polling workaround' " Shani Peretz
2025-12-21 14:56 ` patch 'vhost: fix virtqueue info init in VDUSE vring setup' " Shani Peretz
2025-12-21 14:56 ` patch 'vhost: fix double fetch when dequeue offloading' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice/base: fix integer overflow on NVM init' " Shani Peretz
2025-12-21 14:56 ` patch 'doc: fix display of commands in cpfl guide' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice: fix initialization with 8 ports' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice: remove indirection for FDIR filters' " Shani Peretz
2025-12-21 14:56 ` patch 'net/ice: fix memory leak in raw pattern parse' " Shani Peretz
2025-12-21 14:56 ` patch 'net/i40e: fix symmetric Toeplitz hashing for SCTP' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5/hws: fix ESP header match in strict mode' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix ESP header match after UDP for group 0' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix multicast' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix indirect flow action memory leak' " Shani Peretz
2025-12-21 14:56 ` patch 'net/mlx5: fix MTU initialization' " Shani Peretz
2025-12-21 14:57 ` patch 'net/mlx5: fix leak of flow indexed pools' " Shani Peretz
2025-12-21 14:57 ` patch 'net/hns3: fix inconsistent lock' " Shani Peretz
2025-12-21 14:57 ` patch 'net/hns3: fix VLAN resources freeing' " Shani Peretz
2025-12-21 14:57 ` patch 'net/hns3: fix overwrite mbuf in vector path' " Shani Peretz
2025-12-21 14:57 ` patch 'net/af_packet: fix crash in secondary process' " Shani Peretz
2025-12-21 14:57 ` patch 'net/ark: remove double mbuf free' " Shani Peretz
2025-12-21 14:57 ` patch 'app/testpmd: stop forwarding in secondary process' " Shani Peretz
2025-12-21 14:57 ` patch 'net/tap: fix build with LTO' " Shani Peretz
2025-12-21 14:57 ` patch 'net/hns3: fix VLAN tag loss for short tunnel frame' " Shani Peretz
2025-12-21 14:57 ` patch 'ethdev: fix VLAN filter parameter description' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix file descriptor leak on read error' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix out-of-bounds access in UIO mapping' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix buffer descriptor size configuration' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix Tx queue free' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix checksum flag handling and error return' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: reject multi-queue configuration' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: fix memory leak in Rx buffer cleanup' " Shani Peretz
2025-12-21 14:57 ` patch 'net/enetfec: reject Tx deferred queue' " Shani Peretz
2025-12-21 14:57 ` patch 'net/tap: fix interrupt callback crash after failed start' " Shani Peretz
2025-12-21 14:57 ` patch 'net/ena: fix PCI BAR mapping on 64K page size' " Shani Peretz
2025-12-21 14:57 ` patch 'net/ena/base: fix unsafe memcpy on invalid memory' " Shani Peretz
2025-12-21 14:57 ` patch 'net/dpaa2: fix uninitialized variable' " Shani Peretz
2025-12-25  9:17   ` patch 'net/dpaa2: fix L3/L4 checksum results' " Shani Peretz
2025-12-25  9:17     ` patch 'net/dpaa2: receive packets with additional parse errors' " Shani Peretz
2025-12-25  9:17     ` patch 'crypto/qat: fix ECDH' " Shani Peretz
2025-12-25  9:17     ` patch 'crypto/cnxk: refactor RSA verification' " Shani Peretz
2025-12-25  9:17     ` patch 'test/crypto: fix mbuf handling' " Shani Peretz
2025-12-25  9:17     ` patch 'app/crypto-perf: fix plaintext size exceeds buffer size' " Shani Peretz
2025-12-25  9:17     ` patch 'test/crypto: fix vector initialization' " Shani Peretz
2025-12-25  9:17     ` patch 'crypto/virtio: fix cookies leak' " Shani Peretz
2025-12-25  9:17     ` patch 'bitops: improve power of 2 alignment documentation' " Shani Peretz
2025-12-25  9:17     ` patch 'sched: fix WRR parameter data type' " Shani Peretz
2025-12-25  9:17     ` patch 'config/arm: enable NUMA for Neoverse N2' " Shani Peretz
2025-12-25  9:17     ` patch 'bus/pci: fix resource leak in secondary process' " Shani Peretz
2025-12-25  9:17     ` patch 'test/hash: check memory allocation' " Shani Peretz
2025-12-25  9:17     ` patch 'dmadev: fix debug build with tracepoints' " Shani Peretz
2025-12-25  9:17     ` patch 'bus/cdx: fix device name in probing error message' " Shani Peretz
2025-12-25  9:17     ` patch 'bus/cdx: fix release in probing for secondary process' " Shani Peretz
2025-12-25  9:17     ` patch 'buildtools/pmdinfogen: fix warning with python 3.14' " Shani Peretz
2025-12-25  9:17     ` patch 'net/iavf: fix build with clang 21' " Shani Peretz
2025-12-25  9:17     ` patch 'test: " Shani Peretz
2025-12-25  9:17     ` patch 'eventdev/crypto: " Shani Peretz
2025-12-25  9:17     ` patch 'rawdev: " Shani Peretz
2025-12-25  9:17     ` patch 'vdpa/mlx5: remove unused constant' " Shani Peretz
2025-12-25  9:17     ` patch 'crypto/mlx5: remove unused constants' " Shani Peretz
2025-12-25  9:17     ` patch 'regex/mlx5: remove useless " Shani Peretz
2025-12-25  9:17     ` patch 'common/mlx5: " Shani Peretz
2025-12-25  9:17     ` patch 'net/mlx5: " Shani Peretz
2025-12-25  9:17     ` patch 'net/mlx5: remove unused macros' " Shani Peretz
2025-12-25  9:17     ` patch 'doc: fix NVIDIA bifurcated driver presentation link' " Shani Peretz
2025-12-25  9:17     ` patch 'app/dma-perf: fix use after free' " Shani Peretz
2025-12-25  9:17     ` patch 'app/dma-perf: fix on-flight DMA when verifying data' " Shani Peretz
2025-12-25  9:17     ` patch 'net/vmxnet3: disable RSS for single queue for ESX8.0+' " Shani Peretz
2025-12-25  9:17     ` patch 'net/dpaa: fix resource leak' " Shani Peretz
2025-12-25  9:17     ` patch 'net/txgbe: reduce memory size of ring descriptors' " Shani Peretz
2025-12-25  9:17     ` patch 'net/ngbe: " Shani Peretz
2025-12-25  9:17     ` patch 'net/txgbe: fix VF Rx buffer size in config register' " Shani Peretz
2025-12-25  9:17     ` patch 'net/txgbe: add device arguments for FDIR' " Shani Peretz
2025-12-25  9:17     ` patch 'net/txgbe: fix maximum number of FDIR filters' " Shani Peretz
2025-12-25  9:17     ` patch 'net/txgbe: fix FDIR mode clearing' " Shani Peretz
2025-12-25  9:18     ` patch 'net/txgbe: fix FDIR drop action for L4 match packets' " Shani Peretz
2025-12-25  9:18     ` patch 'net/txgbe: fix FDIR rule raw relative for L3 " Shani Peretz
2025-12-25  9:18     ` patch 'net/txgbe: switch to FDIR when ntuple filter is full' " Shani Peretz
2025-12-25  9:18     ` patch 'net/txgbe: remove unsupported flow action mark' " Shani Peretz
2025-12-25  9:18     ` patch 'net/nfp: fix metering cleanup' " Shani Peretz
2025-12-25  9:18     ` patch 'net/bonding: fix MAC address propagation in 802.3ad mode' " Shani Peretz
2025-12-25  9:18     ` patch 'app/testpmd: fix DCB Tx port' " Shani Peretz
2025-12-25  9:18     ` patch 'app/testpmd: fix DCB Rx queues' " Shani Peretz
2025-12-25  9:18     ` patch 'net/e1000/base: fix crash on init with GCC 13' " Shani Peretz
2025-12-25  9:18     ` patch 'net/fm10k: fix build with GCC 16' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx4: fix unnecessary comma' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix unnecessary commas' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix multi-process Tx default rules' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix control flow leakage for external SQ' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: store MTU at Rx queue allocation time' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix indirect RSS action hash' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix external queues access' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix modify field action restriction' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix meter mark allocation' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix indirect meter index leak' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix error reporting on masked indirect actions' " Shani Peretz
2025-12-25  9:18     ` patch 'vhost: fix external buffer in VDUSE' " Shani Peretz
2025-12-25  9:18     ` patch 'net: fix L2 length for GRE packets' " Shani Peretz
2025-12-25  9:18     ` patch 'graph: fix updating edge with active graph' " Shani Peretz
2025-12-25  9:18     ` patch 'app/pdump: remove hard-coded memory channels' " Shani Peretz
2025-12-25  9:18     ` patch 'pdump: handle primary process exit' " Shani Peretz
2025-12-25  9:18     ` patch 'telemetry: make socket handler typedef private' " Shani Peretz
2025-12-25  9:18     ` patch 'examples/l3fwd-power: fix telemetry command registration' " Shani Peretz
2025-12-25  9:18     ` patch 'lib: fix backticks matching in Doxygen comments' " Shani Peretz
2025-12-25  9:18     ` patch 'mcslock: fix memory ordering' " Shani Peretz
2025-12-25  9:18     ` Shani Peretz [this message]
2025-12-25  9:18     ` patch 'ring: establish a safe partial order in hts-ring' " Shani Peretz
2025-12-25  9:18     ` patch 'ring: establish safe partial order in RTS mode' " Shani Peretz
2025-12-25  9:18     ` patch 'doc: add device arguments in txgbe guide' " Shani Peretz
2025-12-25  9:18     ` patch 'net/axgbe: fix build with GCC 16' " Shani Peretz
2025-12-25  9:18     ` patch 'net/dpaa2: fix duplicate call of close' " Shani Peretz
2025-12-25  9:18     ` patch 'app/testpmd: fix flex item link parsing' " Shani Peretz
2025-12-25  9:18     ` patch 'net/ice: fix path selection for QinQ Tx offload' " Shani Peretz
2025-12-25  9:18     ` patch 'net/ice: fix statistics' " Shani Peretz
2025-12-25  9:18     ` patch 'net/idpf: fix queue setup with TSO offload' " Shani Peretz
2025-12-25  9:18     ` patch 'net/iavf: fix check for PF Rx timestamp support' " Shani Peretz
2025-12-25  9:18     ` patch 'net/iavf: fix Rx timestamp validity check' " Shani Peretz
2025-12-25  9:18     ` patch 'common/cnxk: fix max number of SQB buffers in clean up' " Shani Peretz
2025-12-25  9:18     ` patch 'common/cnxk: fix null SQ access' " Shani Peretz
2025-12-25  9:18     ` patch 'net/cnxk: fix default meter pre-color' " Shani Peretz
2025-12-25  9:18     ` patch 'crypto/qat: fix CCM request descriptor hash state size' " Shani Peretz
2025-12-25  9:18     ` patch 'net/dpaa2: remove ethdev pointer from bus device' " Shani Peretz
2025-12-25  9:18     ` patch 'app/flow-perf: fix rules array length' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix spurious CPU wakeups' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix send to kernel action resources release' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: release representor interrupt handler' " Shani Peretz
2025-12-25  9:18     ` patch 'common/mlx5: release unused mempool entries' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5/hws: fix buddy memory allocation' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix device start error handling' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix uninitialized variable' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5: fix flow tag indexes support on root table' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5/hws: fix flow rule hash capability' " Shani Peretz
2025-12-25  9:18     ` patch 'net/mlx5/windows: fix match criteria in flow creation' " Shani Peretz
2025-12-25  9:18     ` patch 'examples/server_node_efd: fix format overflow' " Shani Peretz
2025-12-25  9:18     ` patch 'examples/vdpa: " Shani Peretz
2025-12-25  9:19     ` patch 'net/mlx5: fix flex flow item header length' " Shani Peretz
2025-12-25  9:19     ` patch 'doc: add Pollara 400 device in ionic guide' " Shani Peretz
2025-12-25  9:19     ` patch 'doc: fix note in FreeBSD " Shani Peretz
2025-12-25  9:19     ` patch 'net/mlx5: fix Tx metadata pattern template mismatch' " Shani Peretz

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=20251225091938.345892-69-shperetz@nvidia.com \
    --to=shperetz@nvidia.com \
    --cc=dhruv.tripathi@arm.com \
    --cc=honnappa.nagarahalli@arm.com \
    --cc=konstantin.ananyev@huawei.com \
    --cc=ola.liljedahl@arm.com \
    --cc=stable@dpdk.org \
    --cc=wathsala.vithanage@arm.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).