Revert "tests: thread abort deadlock scenario"
This reverts commit 9f4d9989c6
.
This PR introduced 2 regressions in main CI:
71977 & 71978
Let's revert it by now to get main's CI passing again.
Signed-off-by: Alberto Escolar Piedras <alberto.escolar.piedras@nordicsemi.no>
This commit is contained in:
parent
c9ec937d71
commit
17b4e6cc98
|
@ -1,12 +0,0 @@
|
||||||
# SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.20.0)
|
|
||||||
find_package(Zephyr REQUIRED HINTS $ENV{ZEPHYR_BASE})
|
|
||||||
project(smp_abort)
|
|
||||||
|
|
||||||
target_sources(app PRIVATE src/main.c)
|
|
||||||
|
|
||||||
target_include_directories(app PRIVATE
|
|
||||||
${ZEPHYR_BASE}/kernel/include
|
|
||||||
${ZEPHYR_BASE}/arch/${ARCH}/include
|
|
||||||
)
|
|
|
@ -1,3 +0,0 @@
|
||||||
CONFIG_ZTEST=y
|
|
||||||
CONFIG_IRQ_OFFLOAD=y
|
|
||||||
CONFIG_SMP=y
|
|
|
@ -1,92 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2024 Intel Corporation.
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <zephyr/tc_util.h>
|
|
||||||
#include <zephyr/ztest.h>
|
|
||||||
#include <zephyr/kernel.h>
|
|
||||||
#include <zephyr/irq_offload.h>
|
|
||||||
|
|
||||||
#if CONFIG_MP_MAX_NUM_CPUS < 2
|
|
||||||
#error "SMP test requires at least two CPUs!"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define NUM_THREADS CONFIG_MP_MAX_NUM_CPUS
|
|
||||||
#define STACK_SIZE 1024
|
|
||||||
|
|
||||||
K_THREAD_STACK_ARRAY_DEFINE(thread_stack, NUM_THREADS, STACK_SIZE);
|
|
||||||
struct k_thread thread[NUM_THREADS];
|
|
||||||
|
|
||||||
struct isr_args {
|
|
||||||
volatile bool *sync;
|
|
||||||
volatile bool *wait;
|
|
||||||
struct k_thread *target;
|
|
||||||
};
|
|
||||||
|
|
||||||
volatile bool sync[NUM_THREADS];
|
|
||||||
|
|
||||||
struct isr_args isr_args[NUM_THREADS];
|
|
||||||
|
|
||||||
static void isr(const void *args)
|
|
||||||
{
|
|
||||||
const struct isr_args *var = args;
|
|
||||||
|
|
||||||
*(var->sync) = true; /* Flag that ISR is in progress */
|
|
||||||
|
|
||||||
while (*(var->wait) == false) { /* Wait upon dependent CPU */
|
|
||||||
}
|
|
||||||
|
|
||||||
k_thread_abort(var->target); /* Abort thread on another CPU */
|
|
||||||
}
|
|
||||||
|
|
||||||
static void thread_entry(void *p1, void *p2, void *p3)
|
|
||||||
{
|
|
||||||
unsigned int index = (unsigned int)(uintptr_t)p1;
|
|
||||||
struct isr_args *var = p2;
|
|
||||||
|
|
||||||
printk("Thread %u started\n", index);
|
|
||||||
|
|
||||||
irq_offload(isr, var);
|
|
||||||
|
|
||||||
zassert_true(false, "Thread %u did not abort!", index);
|
|
||||||
}
|
|
||||||
|
|
||||||
ZTEST(smp_abort, test_smp_thread_abort_deadlock)
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
int priority;
|
|
||||||
|
|
||||||
priority = k_thread_priority_get(k_current_get());
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Each thread will run on its own CPU and invoke an ISR.
|
|
||||||
* Each ISR will wait until the next thread enters its ISR
|
|
||||||
* before attempting to abort that thread. This ensures that
|
|
||||||
* we have a scenario where each CPU is attempting to abort
|
|
||||||
* the active thread that was interrupted by an ISR.
|
|
||||||
*/
|
|
||||||
|
|
||||||
for (i = 0; i < NUM_THREADS; i++) {
|
|
||||||
isr_args[i].sync = &sync[i];
|
|
||||||
isr_args[i].wait = &sync[(i + 1) % NUM_THREADS];
|
|
||||||
isr_args[i].target = &thread[(i + 1) % NUM_THREADS];
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < NUM_THREADS; i++) {
|
|
||||||
|
|
||||||
k_thread_create(&thread[i], thread_stack[i],
|
|
||||||
STACK_SIZE, thread_entry,
|
|
||||||
(void *)(uintptr_t)i, &isr_args[i], NULL,
|
|
||||||
priority - 1, 0, K_NO_WAIT);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < NUM_THREADS; i++) {
|
|
||||||
k_thread_join(&thread[i], K_FOREVER);
|
|
||||||
}
|
|
||||||
|
|
||||||
printk("Done!\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
ZTEST_SUITE(smp_abort, NULL, NULL, NULL, NULL, NULL);
|
|
|
@ -1,6 +0,0 @@
|
||||||
tests:
|
|
||||||
kernel.smp_abort:
|
|
||||||
tags:
|
|
||||||
- kernel
|
|
||||||
- smp
|
|
||||||
filter: (CONFIG_MP_MAX_NUM_CPUS > 1)
|
|
Loading…
Reference in a new issue