patches for DPDK stable branches
 help / color / mirror / Atom feed
From: Kevin Traynor <ktraynor@redhat.com>
To: David Marchand <david.marchand@redhat.com>
Cc: "Mattias Rönnblom" <mattias.ronnblom@ericsson.com>,
	"Anatoly Burakov" <anatoly.burakov@intel.com>,
	"Frode Nordahl" <frode.nordahl@canonical.com>,
	"dpdk stable" <stable@dpdk.org>
Subject: patch 'random: defer seeding to EAL init' has been queued to stable release 24.11.2
Date: Thu, 13 Feb 2025 09:58:28 +0000	[thread overview]
Message-ID: <20250213095933.362078-61-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/e07b9b8acdbeba76f3db1057d327ff0b13f60201

Thanks.

Kevin

---
From e07b9b8acdbeba76f3db1057d327ff0b13f60201 Mon Sep 17 00:00:00 2001
From: David Marchand <david.marchand@redhat.com>
Date: Mon, 10 Feb 2025 22:31:55 +0100
Subject: [PATCH] random: defer seeding to EAL init
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

[ upstream commit 6b77657ef2e473309a3435cdf63b0f0cbb8328af ]

The RNG is documented as being seeded as part of EAL init.

Move the initialisation (seeding) helper out of a constructor and
call it explicitly from rte_eal_init() as it was done before commit
3f002f069612 ("eal: replace libc-based random generation with LFSR").

This also moves the unconditional lcore variable allocation out of a
constructor.

While at it, mark local symbol rand_state as static.

Fixes: 29c39cd3d54d ("random: keep PRNG state in lcore variable")

Signed-off-by: David Marchand <david.marchand@redhat.com>
Reviewed-by: Mattias Rönnblom <mattias.ronnblom@ericsson.com>
Acked-by: Anatoly Burakov <anatoly.burakov@intel.com>
Acked-by: Frode Nordahl <frode.nordahl@canonical.com>
---
 lib/eal/common/eal_private.h |  6 ++++++
 lib/eal/common/rte_random.c  | 12 +++++++++---
 lib/eal/freebsd/eal.c        |  2 ++
 lib/eal/linux/eal.c          |  2 ++
 lib/eal/windows/eal.c        |  2 ++
 5 files changed, 21 insertions(+), 3 deletions(-)

diff --git a/lib/eal/common/eal_private.h b/lib/eal/common/eal_private.h
index bb315dab04..a10db6a399 100644
--- a/lib/eal/common/eal_private.h
+++ b/lib/eal/common/eal_private.h
@@ -703,4 +703,10 @@ rte_usage_hook_t
 eal_get_application_usage_hook(void);
 
+/**
+ * Initialise random subsystem.
+ */
+void
+eal_rand_init(void);
+
 /**
  * Instruct primary process that a secondary process wants to attach.
diff --git a/lib/eal/common/rte_random.c b/lib/eal/common/rte_random.c
index cf0756f26a..8e62578176 100644
--- a/lib/eal/common/rte_random.c
+++ b/lib/eal/common/rte_random.c
@@ -15,4 +15,6 @@
 #include <rte_random.h>
 
+#include "eal_private.h"
+
 struct __rte_cache_aligned rte_rand_state {
 	uint64_t z1;
@@ -23,5 +25,5 @@ struct __rte_cache_aligned rte_rand_state {
 };
 
-RTE_LCORE_VAR_HANDLE(struct rte_rand_state, rand_state);
+static RTE_LCORE_VAR_HANDLE(struct rte_rand_state, rand_state);
 
 /* instance to be shared by all unregistered non-EAL threads */
@@ -130,6 +132,9 @@ struct rte_rand_state *__rte_rand_get_state(void)
 	idx = rte_lcore_id();
 
-	if (unlikely(idx == LCORE_ID_ANY))
+	if (unlikely(idx == LCORE_ID_ANY)) {
+		/* Make sure rte_*rand() was called after rte_eal_init(). */
+		RTE_ASSERT(rand_state != NULL);
 		return &unregistered_rand_state;
+	}
 
 	return RTE_LCORE_VAR(rand_state);
@@ -229,5 +234,6 @@ __rte_random_initial_seed(void)
 }
 
-RTE_INIT(rte_rand_init)
+void
+eal_rand_init(void)
 {
 	uint64_t seed;
diff --git a/lib/eal/freebsd/eal.c b/lib/eal/freebsd/eal.c
index a96bbf5836..d07cff8651 100644
--- a/lib/eal/freebsd/eal.c
+++ b/lib/eal/freebsd/eal.c
@@ -778,4 +778,6 @@ rte_eal_init(int argc, char **argv)
 	}
 
+	eal_rand_init();
+
 	eal_check_mem_on_local_socket();
 
diff --git a/lib/eal/linux/eal.c b/lib/eal/linux/eal.c
index a6220524a4..b1e63e37fc 100644
--- a/lib/eal/linux/eal.c
+++ b/lib/eal/linux/eal.c
@@ -1174,4 +1174,6 @@ rte_eal_init(int argc, char **argv)
 	}
 
+	eal_rand_init();
+
 	eal_check_mem_on_local_socket();
 
diff --git a/lib/eal/windows/eal.c b/lib/eal/windows/eal.c
index 5cdc053a02..5c7526f922 100644
--- a/lib/eal/windows/eal.c
+++ b/lib/eal/windows/eal.c
@@ -411,4 +411,6 @@ rte_eal_init(int argc, char **argv)
 	}
 
+	eal_rand_init();
+
 	if (rte_thread_set_affinity_by_id(rte_thread_self(),
 			&lcore_config[config->main_lcore].cpuset) != 0) {
-- 
2.48.1

---
  Diff of the applied patch vs upstream commit (please double-check if non-empty:
---
--- -	2025-02-12 17:29:41.005463095 +0000
+++ 0061-random-defer-seeding-to-EAL-init.patch	2025-02-12 17:29:34.389946162 +0000
@@ -1 +1 @@
-From 6b77657ef2e473309a3435cdf63b0f0cbb8328af Mon Sep 17 00:00:00 2001
+From e07b9b8acdbeba76f3db1057d327ff0b13f60201 Mon Sep 17 00:00:00 2001
@@ -8,0 +9,2 @@
+[ upstream commit 6b77657ef2e473309a3435cdf63b0f0cbb8328af ]
+
@@ -21 +22,0 @@
-Cc: stable@dpdk.org
@@ -36 +37 @@
-index b2a80dbec8..04ba8ddb86 100644
+index bb315dab04..a10db6a399 100644


  parent reply	other threads:[~2025-02-13 10:02 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 ` patch 'net/mlx5: fix polling CQEs' " Kevin Traynor
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 ` Kevin Traynor [this message]
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-61-ktraynor@redhat.com \
    --to=ktraynor@redhat.com \
    --cc=anatoly.burakov@intel.com \
    --cc=david.marchand@redhat.com \
    --cc=frode.nordahl@canonical.com \
    --cc=mattias.ronnblom@ericsson.com \
    --cc=stable@dpdk.org \
    /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).