/* * Copyright (c) 2018,2024 Intel Corporation * * SPDX-License-Identifier: Apache-2.0 */ #include #include 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) { uintptr_t tcpu = l->thread_cpu; l->thread_cpu = 0; if (arch_is_in_isr() && arch_current_thread()->base.thread_state & _THREAD_DUMMY) { /* Edge case where an ISR aborted arch_current_thread() */ return true; } if (tcpu != (_current_cpu->id | (uintptr_t)arch_current_thread())) { return false; } return true; } void z_spin_lock_set_owner(struct k_spinlock *l) { l->thread_cpu = _current_cpu->id | (uintptr_t)arch_current_thread(); } #ifdef CONFIG_KERNEL_COHERENCE bool z_spin_lock_mem_coherent(struct k_spinlock *l) { return arch_mem_coherent((void *)l); } #endif /* CONFIG_KERNEL_COHERENCE */