/* * Copyright (c) 2006-2021, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * 2018/10/28 Bernard The unify RISC-V porting implementation * 2018/12/27 Jesven Add SMP support * 2021/02/02 lizhirui Add userspace support * 2022/10/22 WangXiaoyao Support User mode RVV; * Trimming process switch context */ #include "cpuport.h" #include "stackframe.h" .macro PUSH_REG reg addi sp, sp, -REGBYTES STORE \reg, (sp) .endm .macro POP_REG reg LOAD \reg, (sp) addi sp, sp, REGBYTES .endm .macro RESERVE_CONTEXT PUSH_REG tp PUSH_REG ra PUSH_REG s0 PUSH_REG s1 PUSH_REG s2 PUSH_REG s3 PUSH_REG s4 PUSH_REG s5 PUSH_REG s6 PUSH_REG s7 PUSH_REG s8 PUSH_REG s9 PUSH_REG s10 PUSH_REG s11 csrr s11, sstatus li s10, (SSTATUS_SPP) or s11, s11, s10 PUSH_REG s11 addi sp, sp, -REGBYTES .endm .macro RESTORE_CONTEXT addi sp, sp, REGBYTES POP_REG s11 csrw sstatus, s11 POP_REG s11 POP_REG s10 POP_REG s9 POP_REG s8 POP_REG s7 POP_REG s6 POP_REG s5 POP_REG s4 POP_REG s3 POP_REG s2 POP_REG s1 POP_REG s0 POP_REG ra POP_REG tp csrw sepc, ra .endm /* * void rt_hw_context_switch_to(rt_ubase_t to); * * a0 --> to SP pointer */ .globl rt_hw_context_switch_to rt_hw_context_switch_to: LOAD sp, (a0) jal rt_thread_self mv s1, a0 #ifdef RT_USING_SMART jal lwp_aspace_switch #endif RESTORE_CONTEXT sret /* * void rt_hw_context_switch(rt_ubase_t from, rt_ubase_t to); * * a0 --> from SP pointer * a1 --> to SP pointer * * It should only be used on local interrupt disable */ .globl rt_hw_context_switch rt_hw_context_switch: RESERVE_CONTEXT STORE sp, (a0) // restore to thread SP LOAD sp, (a1) // restore Address Space jal rt_thread_self mv s1, a0 #ifdef RT_USING_SMART jal lwp_aspace_switch #endif RESTORE_CONTEXT sret #ifdef ENABLE_VECTOR /** * @param a0 pointer to frame bottom */ .global rt_hw_vector_ctx_save rt_hw_vector_ctx_save: SAVE_VECTOR a0 ret /** * @param a0 pointer to frame bottom */ .global rt_hw_vector_ctx_restore rt_hw_vector_ctx_restore: RESTORE_VECTOR a0 ret .global rt_hw_disable_vector rt_hw_disable_vector: li t0, SSTATUS_VS csrc sstatus, t0 ret .global rt_hw_enable_vector rt_hw_enable_vector: li t0, SSTATUS_VS csrs sstatus, t0 ret #endif /* ENABLE_VECTOR */