X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/6b995c8cb722d10aaacba52999f5c43e43daeb85..bb5ae5c85c0812c52e8d53187f2c6b0ee9525c8c:/lunaix-os/arch/aarch64/includes/asm/abi.h diff --git a/lunaix-os/arch/aarch64/includes/asm/abi.h b/lunaix-os/arch/aarch64/includes/asm/abi.h index 7f8d83d..dac3d26 100644 --- a/lunaix-os/arch/aarch64/includes/asm/abi.h +++ b/lunaix-os/arch/aarch64/includes/asm/abi.h @@ -4,11 +4,22 @@ #include #ifndef __ASM__ + +#include +#include + #define align_stack(ptr) ((ptr) & ~15) +#define store_retval(retval) \ + current_thread->hstate->registers.x[0] = (retval) + +#define store_retval_to(th, retval) \ + (th)->hstate->registers.x[0] = (retval) + + static inline void must_inline noret -switch_context() { - // TODO +switch_context() +{ asm ("b _aa64_switch_task"); unreachable; } @@ -29,6 +40,25 @@ abi_get_retaddrat(ptr_t fp) return ((ptr_t*)fp)[1]; } +static inline ptr_t must_inline +abi_get_callframe() +{ + ptr_t val; + asm volatile("mov %0, fp" : "=r"(val)); + return val; +} + +static inline void must_inline +j_usr(ptr_t sp, ptr_t pc) +{ + set_sysreg(SPSR_EL1, SPSR_EL0_preset); + set_sysreg(SP_EL0, sp); + set_sysreg(ELR_E1, pc); + asm ("eret"); + + unreachable; +} + #endif #endif /* __LUNAIX_AA64_ABI_H */