1 /* 2 * Copyright (c) 2018,2024 Intel Corporation 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 #include <kernel_internal.h> 7 #include <zephyr/spinlock.h> 8 z_spin_lock_valid(struct k_spinlock * l)9bool z_spin_lock_valid(struct k_spinlock *l) 10 { 11 uintptr_t thread_cpu = l->thread_cpu; 12 13 if (thread_cpu != 0U) { 14 if ((thread_cpu & 3U) == _current_cpu->id) { 15 return false; 16 } 17 } 18 return true; 19 } 20 z_spin_unlock_valid(struct k_spinlock * l)21bool z_spin_unlock_valid(struct k_spinlock *l) 22 { 23 uintptr_t tcpu = l->thread_cpu; 24 25 l->thread_cpu = 0; 26 27 if (arch_is_in_isr() && arch_current_thread()->base.thread_state & _THREAD_DUMMY) { 28 /* Edge case where an ISR aborted arch_current_thread() */ 29 return true; 30 } 31 if (tcpu != (_current_cpu->id | (uintptr_t)arch_current_thread())) { 32 return false; 33 } 34 return true; 35 } 36 z_spin_lock_set_owner(struct k_spinlock * l)37void z_spin_lock_set_owner(struct k_spinlock *l) 38 { 39 l->thread_cpu = _current_cpu->id | (uintptr_t)arch_current_thread(); 40 } 41 42 #ifdef CONFIG_KERNEL_COHERENCE z_spin_lock_mem_coherent(struct k_spinlock * l)43bool z_spin_lock_mem_coherent(struct k_spinlock *l) 44 { 45 return arch_mem_coherent((void *)l); 46 } 47 #endif /* CONFIG_KERNEL_COHERENCE */ 48