Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

kernel: arch: move arch_swap() declaration #82454

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion arch/arm/core/cortex_a_r/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ zephyr_library_sources_ifdef(CONFIG_SEMIHOST semihost.c)
zephyr_library_sources_ifdef(CONFIG_THREAD_LOCAL_STORAGE __aeabi_read_tp.S)
zephyr_library_sources_ifdef(CONFIG_ARCH_CACHE cache.c)
zephyr_library_sources_ifdef(CONFIG_USE_SWITCH switch.S)
zephyr_library_sources_ifndef(CONFIG_USE_SWITCH swap.c swap_helper.S exc_exit.S)
zephyr_library_sources_ifndef(CONFIG_USE_SWITCH swap_helper.S exc_exit.S)
30 changes: 0 additions & 30 deletions arch/arm/core/cortex_a_r/swap.c

This file was deleted.

1 change: 0 additions & 1 deletion arch/arm/core/cortex_m/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ zephyr_library_sources(
scb.c
thread_abort.c
vector_table.S
swap.c
swap_helper.S
irq_manage.c
prep_c.c
Expand Down
49 changes: 0 additions & 49 deletions arch/arm/core/cortex_m/swap.c

This file was deleted.

15 changes: 15 additions & 0 deletions arch/arm/include/cortex_a_r/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,21 @@ static ALWAYS_INLINE void arch_kernel_init(void)

#ifndef CONFIG_USE_SWITCH

static ALWAYS_INLINE int arch_swap(unsigned int key)
{
/* store off key and return value */
arch_current_thread()->arch.basepri = key;
arch_current_thread()->arch.swap_return_value = -EAGAIN;

z_arm_cortex_r_svc();
irq_unlock(key);

/* Context switch is performed here. Returning implies the
* thread has been context-switched-in again.
*/
return arch_current_thread()->arch.swap_return_value;
}

static ALWAYS_INLINE void
arch_thread_return_value_set(struct k_thread *thread, unsigned int value)
{
Expand Down
19 changes: 19 additions & 0 deletions arch/arm/include/cortex_m/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,25 @@ extern FUNC_NORETURN void z_arm_userspace_enter(k_thread_entry_t user_entry,

extern void z_arm_fatal_error(unsigned int reason, const struct arch_esf *esf);

static ALWAYS_INLINE int arch_swap(unsigned int key)
{
/* store off key and return value */
arch_current_thread()->arch.basepri = key;
arch_current_thread()->arch.swap_return_value = -EAGAIN;

/* set pending bit to make sure we will take a PendSV exception */
SCB->ICSR |= SCB_ICSR_PENDSVSET_Msk;

/* clear mask or enable all irqs to take a pendsv */
irq_unlock(0);

/* Context switch is performed here. Returning implies the
* thread has been context-switched-in again.
*/
return arch_current_thread()->arch.swap_return_value;
}


#endif /* _ASMLANGUAGE */

#ifdef __cplusplus
Expand Down
2 changes: 2 additions & 0 deletions arch/mips/include/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ static inline bool arch_is_in_isr(void)
return _current_cpu->nested != 0U;
}

int arch_swap(unsigned int key);

#ifdef CONFIG_IRQ_OFFLOAD
void z_irq_do_offload(void);
#endif
Expand Down
2 changes: 2 additions & 0 deletions arch/nios2/include/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,8 @@ static inline bool arch_is_in_isr(void)
return _kernel.cpus[0].nested != 0U;
}

int arch_swap(unsigned int key);

#ifdef CONFIG_IRQ_OFFLOAD
void z_irq_do_offload(void);
#endif
Expand Down
2 changes: 2 additions & 0 deletions arch/posix/include/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ static inline bool arch_is_in_isr(void)
return _kernel.cpus[0].nested != 0U;
}

int arch_swap(unsigned int key);

#endif /* _ASMLANGUAGE */

#endif /* ZEPHYR_ARCH_POSIX_INCLUDE_KERNEL_ARCH_FUNC_H_ */
2 changes: 2 additions & 0 deletions arch/x86/include/ia32/kernel_arch_func.h
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ arch_thread_return_value_set(struct k_thread *thread, unsigned int value)

extern void arch_cpu_atomic_idle(unsigned int key);

int arch_swap(unsigned int key);

/* ASM code to fiddle with registers to enable the MMU with PAE paging */
void z_x86_enable_paging(void);

Expand Down
8 changes: 6 additions & 2 deletions kernel/include/kernel_arch_interface.h
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,10 @@ void arch_new_thread(struct k_thread *thread, k_thread_stack_t *stack,
* location, which must be updated.
*/
static inline void arch_switch(void *switch_to, void **switched_from);
#else
#endif /* CONFIG_USE_SWITCH */

#if !defined(CONFIG_USE_SWITCH) || defined(__DOXYGEN__)
#if defined(__DOXYGEN__)
/**
* Cooperatively context switch
aescolar marked this conversation as resolved.
Show resolved Hide resolved
*
Expand All @@ -143,6 +146,7 @@ static inline void arch_switch(void *switch_to, void **switched_from);
* blocking operation.
*/
int arch_swap(unsigned int key);
#endif /* __DOXYGEN__ */

/**
* Set the return value for the specified thread.
Expand All @@ -154,7 +158,7 @@ int arch_swap(unsigned int key);
*/
static ALWAYS_INLINE void
arch_thread_return_value_set(struct k_thread *thread, unsigned int value);
#endif /* CONFIG_USE_SWITCH */
#endif /* !CONFIG_USE_SWITCH || __DOXYGEN__ */

#ifdef CONFIG_ARCH_HAS_CUSTOM_SWAP_TO_MAIN
/**
Expand Down
13 changes: 11 additions & 2 deletions tests/arch/arm/arm_thread_swap/src/arm_thread_arch.c
Original file line number Diff line number Diff line change
Expand Up @@ -429,6 +429,13 @@ static void alt_thread_entry(void *p1, void *p2, void *p3)
"Alternative thread: switch flag not false on thread exit\n");
}

#if !defined(CONFIG_NO_OPTIMIZATIONS)
static int __noinline arch_swap_wrapper(void)
{
return arch_swap(BASEPRI_MODIFIED_1);
}
#endif

ZTEST(arm_thread_swap, test_arm_thread_swap)
{
int test_flag;
Expand Down Expand Up @@ -609,9 +616,11 @@ ZTEST(arm_thread_swap, test_arm_thread_swap)

/* Fake a different irq_unlock key when performing swap.
* This will be verified by the alternative test thread.
*
* Force an indirect call to arch_swap() to prevent the compiler from
* changing the saved callee registers as arch_swap() is inlined.
*/
register int swap_return_val __asm__("r0") =
arch_swap(BASEPRI_MODIFIED_1);
register int swap_return_val __asm__("r0") = arch_swap_wrapper();

#endif /* CONFIG_NO_OPTIMIZATIONS */

Expand Down
Loading