kernel: move spinlock validation to own file
Move spin_lock validation outside of thread.c into own file. This code really has nothing to do with the thread code. Signed-off-by: Anas Nashif <anas.nashif@intel.com>
This commit is contained in:
parent
7df7e834d9
commit
a7d74f80ce
|
@ -84,6 +84,11 @@ endif()
|
||||||
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(CONFIG_SPIN_VALIDATE)
|
||||||
|
list(APPEND kernel_files
|
||||||
|
spinlock_validate.c)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CONFIG_XIP)
|
if(CONFIG_XIP)
|
||||||
list(APPEND kernel_files
|
list(APPEND kernel_files
|
||||||
xip.c)
|
xip.c)
|
||||||
|
|
40
kernel/spinlock_validate.c
Normal file
40
kernel/spinlock_validate.c
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2018,2024 Intel Corporation
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
#include <zephyr/kernel.h>
|
||||||
|
#include <zephyr/spinlock.h>
|
||||||
|
|
||||||
|
bool z_spin_lock_valid(struct k_spinlock *l)
|
||||||
|
{
|
||||||
|
uintptr_t thread_cpu = l->thread_cpu;
|
||||||
|
|
||||||
|
if (thread_cpu != 0U) {
|
||||||
|
if ((thread_cpu & 3U) == _current_cpu->id) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool z_spin_unlock_valid(struct k_spinlock *l)
|
||||||
|
{
|
||||||
|
if (l->thread_cpu != (_current_cpu->id | (uintptr_t)_current)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
l->thread_cpu = 0;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void z_spin_lock_set_owner(struct k_spinlock *l)
|
||||||
|
{
|
||||||
|
l->thread_cpu = _current_cpu->id | (uintptr_t)_current;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_KERNEL_COHERENCE
|
||||||
|
bool z_spin_lock_mem_coherent(struct k_spinlock *l)
|
||||||
|
{
|
||||||
|
return arch_mem_coherent((void *)l);
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_KERNEL_COHERENCE */
|
|
@ -945,45 +945,6 @@ FUNC_NORETURN void k_thread_user_mode_enter(k_thread_entry_t entry,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* These spinlock assertion predicates are defined here because having
|
|
||||||
* them in spinlock.h is a giant header ordering headache.
|
|
||||||
*/
|
|
||||||
#ifdef CONFIG_SPIN_VALIDATE
|
|
||||||
bool z_spin_lock_valid(struct k_spinlock *l)
|
|
||||||
{
|
|
||||||
uintptr_t thread_cpu = l->thread_cpu;
|
|
||||||
|
|
||||||
if (thread_cpu != 0U) {
|
|
||||||
if ((thread_cpu & 3U) == _current_cpu->id) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool z_spin_unlock_valid(struct k_spinlock *l)
|
|
||||||
{
|
|
||||||
if (l->thread_cpu != (_current_cpu->id | (uintptr_t)_current)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
l->thread_cpu = 0;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
void z_spin_lock_set_owner(struct k_spinlock *l)
|
|
||||||
{
|
|
||||||
l->thread_cpu = _current_cpu->id | (uintptr_t)_current;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_KERNEL_COHERENCE
|
|
||||||
bool z_spin_lock_mem_coherent(struct k_spinlock *l)
|
|
||||||
{
|
|
||||||
return arch_mem_coherent((void *)l);
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_KERNEL_COHERENCE */
|
|
||||||
|
|
||||||
#endif /* CONFIG_SPIN_VALIDATE */
|
|
||||||
|
|
||||||
int z_impl_k_float_disable(struct k_thread *thread)
|
int z_impl_k_float_disable(struct k_thread *thread)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_FPU) && defined(CONFIG_FPU_SHARING)
|
#if defined(CONFIG_FPU) && defined(CONFIG_FPU_SHARING)
|
||||||
|
|
Loading…
Reference in a new issue