| /* |
| * Copyright (c) 2019-2020 Cobham Gaisler AB |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| /** |
| * @file |
| * @brief Private kernel definitions |
| * |
| * This file contains private kernel function/macro definitions and various |
| * other definitions for the SPARC processor architecture. |
| */ |
| |
| #ifndef ZEPHYR_ARCH_SPARC_INCLUDE_KERNEL_ARCH_FUNC_H_ |
| #define ZEPHYR_ARCH_SPARC_INCLUDE_KERNEL_ARCH_FUNC_H_ |
| |
| #include <kernel_arch_data.h> |
| |
| #include <zephyr/platform/hooks.h> |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| #ifndef _ASMLANGUAGE |
| static ALWAYS_INLINE void arch_kernel_init(void) |
| { |
| #ifdef CONFIG_SOC_PER_CORE_INIT_HOOK |
| soc_per_core_init_hook(); |
| #endif /* CONFIG_SOC_PER_CORE_INIT_HOOK */ |
| } |
| |
| void z_sparc_context_switch(struct k_thread *newt, struct k_thread *oldt); |
| |
| /* |
| * In this implementation, the thread->switch_handle is the thread itself, so |
| * the parameter "switched_from" is assumed to be the address of |
| * thread->switch_handle. |
| */ |
| static inline void arch_switch(void *switch_to, void **switched_from) |
| { |
| struct k_thread *newt = switch_to; |
| struct k_thread *oldt = CONTAINER_OF(switched_from, struct k_thread, |
| switch_handle); |
| |
| z_sparc_context_switch(newt, oldt); |
| } |
| |
| FUNC_NORETURN void z_sparc_fatal_error(unsigned int reason, |
| const struct arch_esf *esf); |
| |
| static inline bool arch_is_in_isr(void) |
| { |
| return _current_cpu->nested != 0U; |
| } |
| |
| #ifdef CONFIG_IRQ_OFFLOAD |
| void z_irq_do_offload(void); |
| #endif |
| |
| #endif /* _ASMLANGUAGE */ |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif /* ZEPHYR_ARCH_SPARC_INCLUDE_KERNEL_ARCH_FUNC_H_ */ |