Busy looping on RTE_MAX_LCORES threads is too heavy in some CI environments running the fast-test testsuite. Ask for a reschedule at the threads synchronisation points.
Signed-off-by: David Marchand <david.march...@redhat.com> --- Note: this is a quick patch with no validation, except that it runs fine on my laptop. Luca, can you check and see if it helps in your CI? --- app/test/test_lcores.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/app/test/test_lcores.c b/app/test/test_lcores.c index 22225a9fd3..7adc03d3da 100644 --- a/app/test/test_lcores.c +++ b/app/test/test_lcores.c @@ -2,6 +2,7 @@ * Copyright (c) 2020 Red Hat, Inc. */ +#include <sched.h> #include <string.h> #include <rte_common.h> @@ -43,7 +44,7 @@ static uint32_t thread_loop(void *arg) /* Wait for release from the control thread. */ while (__atomic_load_n(t->registered_count, __ATOMIC_ACQUIRE) != 0) - ; + sched_yield(); rte_thread_unregister(); lcore_id = rte_lcore_id(); if (lcore_id != LCORE_ID_ANY) { @@ -85,7 +86,7 @@ test_non_eal_lcores(unsigned int eal_threads_count) /* Wait all non-EAL threads to register. */ while (__atomic_load_n(®istered_count, __ATOMIC_ACQUIRE) != non_eal_threads_count) - ; + sched_yield(); /* We managed to create the max number of threads, let's try to create * one more. This will allow one more check. @@ -101,7 +102,7 @@ test_non_eal_lcores(unsigned int eal_threads_count) printf("non-EAL threads count: %u\n", non_eal_threads_count); while (__atomic_load_n(®istered_count, __ATOMIC_ACQUIRE) != non_eal_threads_count) - ; + sched_yield(); } skip_lcore_any: @@ -267,7 +268,7 @@ test_non_eal_lcores_callback(unsigned int eal_threads_count) non_eal_threads_count++; while (__atomic_load_n(®istered_count, __ATOMIC_ACQUIRE) != non_eal_threads_count) - ; + sched_yield(); if (l[0].init != eal_threads_count + 1 || l[1].init != eal_threads_count + 1) { printf("Error: incorrect init calls, expected %u, %u, got %u, %u\n", @@ -290,7 +291,7 @@ test_non_eal_lcores_callback(unsigned int eal_threads_count) non_eal_threads_count++; while (__atomic_load_n(®istered_count, __ATOMIC_ACQUIRE) != non_eal_threads_count) - ; + sched_yield(); if (l[0].init != eal_threads_count + 2 || l[1].init != eal_threads_count + 2) { printf("Error: incorrect init calls, expected %u, %u, got %u, %u\n", -- 2.44.0