From: Stephen Hemminger <stephen@networkplumber.org>
To: dev@dpdk.org
Cc: Stephen Hemminger <stephen@networkplumber.org>
Subject: [PATCH v3 00/14] test: fix test failures on high cores
Date: Wed, 21 Jan 2026 16:50:16 -0800 [thread overview]
Message-ID: <20260122005356.1168221-1-stephen@networkplumber.org> (raw)
In-Reply-To: <20260118201223.323024-1-stephen@networkplumber.org>
This series addresses several categories of test infrastructure issues:
1. Spinloop synchronization fixes (patch 1)
Tests using tight spinloops for thread synchronization cause sporadic
failures on high core count AMD Zen systems. The loops starve SMT
sibling threads and create race conditions. Adding rte_pause() to
all synchronization spinloops fixes these issues.
2. Test scaling for high core count systems (patches 2-5)
Several tests use fixed iteration counts that cause timeouts on
systems with many cores due to increased lock contention. A new
helper function test_scale_iterations() scales iterations inversely
with core count to maintain roughly constant test duration.
Affected tests:
- atomic_autotest (Bugzilla #952)
- mcslock_autotest
- stack_autotest
- timer_secondary_autotest
3. BPF test fixes (patches 6-8, 14)
- Fix missing error handling in ELF load tests
- Fix clang 20+ compatibility by restricting to BPF v2 instruction
set (Bugzilla #1844)
- Skip ELF test gracefully if null PMD is disabled
- Fix incorrect size parameter in Rx/Tx load tests
4. Parallel test execution fixes (patches 9-10)
Multiple tests colliding on the default "rte" file-prefix causes EAL
initialization failures when running tests in parallel. Restore unique
file-prefix for all fast-tests on Linux, including a separate prefix
for trace_autotest_with_traces.
5. Test skip conditions (patches 11-13)
Tests that depend on optional drivers (null PMD, eventdev) should skip
gracefully when those drivers are disabled via -Ddisable_drivers=
rather than failing.
v4 - add additional scaling for failures reported on 96 core system
- gracefully handle case where null PMD disabled in build
Stephen Hemminger (14):
test: add pause to synchronization spinloops
test: scale atomic test based on core count
test/mcslock: scale test based on number of cores
test/stack: scale test based on number of cores
test/timer: scale test based on number of cores
test/bpf: fix error handling in ELF load tests
test/bpf: fix unsupported BPF instructions in ELF load test
test/bpf: skip ELF test if null PMD disabled
test: add file-prefix for all fast-tests on Linux
test: fix trace_autotest_with_traces parallel execution
test/eventdev: skip test if eventdev driver disabled
test/pcapng: skip test if null driver missing
test/vdev: skip test if no null PMD
test/bpf: pass correct size for Rx/Tx load tests
app/test/bpf/meson.build | 3 +-
app/test/meson.build | 4 +-
app/test/suites/meson.build | 19 +++++---
app/test/test.h | 19 ++++++++
app/test/test_atomic.c | 66 ++++++++++++++++------------
app/test/test_bpf.c | 13 ++++--
app/test/test_event_eth_tx_adapter.c | 11 +++--
app/test/test_mcslock.c | 10 +++--
app/test/test_stack.c | 8 ++--
app/test/test_threads.c | 17 +++----
app/test/test_timer_secondary.c | 14 +++---
11 files changed, 121 insertions(+), 63 deletions(-)
--
2.51.0
next prev parent reply other threads:[~2026-01-22 0:54 UTC|newest]
Thread overview: 53+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-18 20:09 [PATCH 0/6] test: fix sporadic failures on high core count systems Stephen Hemminger
2026-01-18 20:09 ` [PATCH 1/6] test: add pause to synchronization spinloops Stephen Hemminger
2026-01-18 20:09 ` [PATCH 2/6] test: fix timeout for atomic test on high core count systems Stephen Hemminger
2026-01-18 20:09 ` [PATCH 3/6] test: fix race condition in ELF load tests Stephen Hemminger
2026-01-19 11:42 ` Marat Khalili
2026-01-20 0:03 ` Stephen Hemminger
2026-01-20 10:30 ` Marat Khalili
2026-01-19 18:24 ` Stephen Hemminger
2026-01-18 20:09 ` [PATCH 4/6] test: fix unsupported BPF instructions in elf load test Stephen Hemminger
2026-01-19 11:43 ` Marat Khalili
2026-01-18 20:09 ` [PATCH 5/6] test: add file-prefix for all fast-tests on Linux Stephen Hemminger
2026-01-19 13:06 ` Marat Khalili
2026-01-19 14:01 ` Bruce Richardson
2026-01-18 20:09 ` [PATCH 6/6] test: fix trace_autotest_with_traces parallel execution Stephen Hemminger
2026-01-19 13:13 ` Marat Khalili
2026-01-20 0:07 ` Stephen Hemminger
2026-01-20 11:36 ` Marat Khalili
2026-01-22 0:50 ` Stephen Hemminger [this message]
2026-01-22 0:50 ` [PATCH v3 01/14] test: add pause to synchronization spinloops Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 02/14] test: scale atomic test based on core count Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 03/14] test/mcslock: scale test based on number of cores Stephen Hemminger
2026-01-22 10:41 ` Konstantin Ananyev
2026-01-27 20:31 ` Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 04/14] test/stack: " Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 05/14] test/timer: " Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 06/14] test/bpf: fix error handling in ELF load tests Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 07/14] test/bpf: fix unsupported BPF instructions in ELF load test Stephen Hemminger
2026-01-22 10:33 ` Konstantin Ananyev
2026-01-22 0:50 ` [PATCH v3 08/14] test/bpf: skip ELF test if null PMD disabled Stephen Hemminger
2026-01-23 11:56 ` Marat Khalili
2026-01-22 0:50 ` [PATCH v3 09/14] test: add file-prefix for all fast-tests on Linux Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 10/14] test: fix trace_autotest_with_traces parallel execution Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 11/14] test/eventdev: skip test if eventdev driver disabled Stephen Hemminger
2026-01-22 20:40 ` Stephen Hemminger
2026-01-23 9:06 ` Bruce Richardson
2026-01-22 0:50 ` [PATCH v3 12/14] test/pcapng: skip test if null driver missing Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 13/14] test/vdev: skip test if no null PMD Stephen Hemminger
2026-01-22 0:50 ` [PATCH v3 14/14] test/bpf: pass correct size for Rx/Tx load tests Stephen Hemminger
2026-01-23 11:50 ` Marat Khalili
2026-03-05 16:39 ` [PATCH v3 00/14] test: fix test failures on high cores David Marchand
2026-03-05 17:50 ` [PATCH v4 00/11] test: fix test failures on high core count systems Stephen Hemminger
2026-03-05 17:50 ` [PATCH v4 01/11] test: add pause to synchronization spinloops Stephen Hemminger
2026-03-05 17:50 ` [PATCH v4 02/11] test/atomic: scale test based on core count Stephen Hemminger
2026-03-05 17:50 ` [PATCH v4 03/11] test/mcslock: scale test based on number of cores Stephen Hemminger
2026-03-05 17:50 ` [PATCH v4 04/11] test/stack: " Stephen Hemminger
2026-03-05 17:50 ` [PATCH v4 05/11] test/timer: " Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 06/11] test/timer: replace volatile with C11 atomics Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 07/11] test: add file-prefix for all fast-tests on Linux Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 08/11] test: fix trace_autotest_with_traces parallel execution Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 09/11] test/bpf: fix error handling in ELF load tests Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 10/11] test/bpf: fix unsupported BPF instructions in ELF load test Stephen Hemminger
2026-03-05 17:51 ` [PATCH v4 11/11] test/bpf: pass correct size for Rx/Tx load tests Stephen Hemminger
2026-03-17 13:28 ` [PATCH v4 00/11] test: fix test failures on high core count systems Thomas Monjalon
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=20260122005356.1168221-1-stephen@networkplumber.org \
--to=stephen@networkplumber.org \
--cc=dev@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