arch/risc-v: move REGLOAD/REGSTORE macro to riscv_internal.h

Signed-off-by: Petro Karashchenko <petro.karashchenko@gmail.com>
This commit is contained in:
Petro Karashchenko 2022-03-30 17:27:07 +02:00 committed by Xiang Xiao
parent 264e39e121
commit 5d856971db
6 changed files with 54 additions and 75 deletions

View File

@ -31,14 +31,6 @@
* Public Symbols
****************************************************************************/
#ifdef CONFIG_ARCH_RV32
# define REGLOAD lw
# define REGSTORE sw
#else
# define REGLOAD ld
# define REGSTORE sd
#endif
#ifdef CONFIG_IRQ_NSTACKS
# define IRQ_NSTACKS CONFIG_IRQ_NSTACKS
#elif defined CONFIG_SMP

View File

@ -26,12 +26,20 @@
#include <arch/irq.h>
#include "riscv_internal.h"
#ifdef CONFIG_ARCH_FPU
/************************************************************************************
* Pre-processor Definitions
************************************************************************************/
#define FS_MASK 0x6000
#define FS_OFF 0x0000
#define FS_INITIAL 0x2000
#define FS_CLEAN 0x4000
#define FS_DIRTY 0x6000
/************************************************************************************
* Public Symbols
************************************************************************************/
@ -42,31 +50,6 @@
.file "riscv_fpu.S"
#define FS_MASK 0x6000
#define FS_OFF 0x0000
#define FS_INITIAL 0x2000
#define FS_CLEAN 0x4000
#define FS_DIRTY 0x6000
#if defined(CONFIG_ARCH_QPFPU)
# define FLOAD flq
# define FSTORE fsq
#elif defined(CONFIG_ARCH_DPFPU)
# define FLOAD fld
# define FSTORE fsd
#else
# define FLOAD flw
# define FSTORE fsw
#endif
#ifdef CONFIG_ARCH_RV32
# define REGLOAD lw
# define REGSTORE sw
#else
# define REGLOAD ld
# define REGSTORE sd
#endif
/************************************************************************************
* Public Functions
************************************************************************************/

View File

@ -38,6 +38,32 @@
* Pre-processor Definitions
****************************************************************************/
#ifdef __ASSEMBLY__
# define __STR(s) s
#else
# define __STR(s) #s
#endif
#define __XSTR(s) __STR(s)
#if defined(CONFIG_ARCH_QPFPU)
# define FLOAD __STR(flq)
# define FSTORE __STR(fsq)
#elif defined(CONFIG_ARCH_DPFPU)
# define FLOAD __STR(fld)
# define FSTORE __STR(fsd)
#else
# define FLOAD __STR(flw)
# define FSTORE __STR(fsw)
#endif
#ifdef CONFIG_ARCH_RV32
# define REGLOAD __STR(lw)
# define REGSTORE __STR(sw)
#else
# define REGLOAD __STR(ld)
# define REGSTORE __STR(sd)
#endif
/* This is the value used to mark the stack for subsequent stack monitoring
* logic.
*/
@ -49,6 +75,7 @@
/* RISC-V requires a 16-byte stack alignment. */
#define STACK_ALIGNMENT 16
#define STACK_FRAME_SIZE __XSTR(STACK_ALIGNMENT)
/* Stack alignment macros */

View File

@ -26,6 +26,8 @@
#include <arch/syscall.h>
#include "riscv_internal.h"
#if defined(CONFIG_BUILD_PROTECTED) && !defined(__KERNEL__)
/****************************************************************************
@ -69,8 +71,8 @@ up_signal_handler:
/* Save ra on the stack */
addi sp, sp, -16
sd ra, 8(sp)
addi sp, sp, -STACK_FRAME_SIZE
REGSTORE ra, 8(sp)
/* Call the signal handler */
@ -82,8 +84,8 @@ up_signal_handler:
/* Restore the register */
ld ra, 8(sp) /* Restore ra in sp */
addi sp, sp, 16
REGLOAD ra, 8(sp) /* Restore ra in sp */
addi sp, sp, STACK_FRAME_SIZE
/* Execute the SYS_signal_handler_return SVCall (will not return) */

View File

@ -109,45 +109,24 @@ static void riscv_registerdump(const uintptr_t *regs)
#ifdef CONFIG_LIB_SYSCALL
static void dispatch_syscall(void) naked_function;
#ifdef CONFIG_ARCH_RV64
static void dispatch_syscall(void)
{
asm volatile
(
" addi sp, sp, -8\n" /* Create a stack frame to hold ra */
" sd ra, 0(sp)\n" /* Save ra in the stack frame */
"addi sp, sp, -" STACK_FRAME_SIZE "\n" /* Create a stack frame to hold ra */
REGSTORE " ra, 0(sp)\n" /* Save ra in the stack frame */
"la t0, g_stublookup\n" /* t0=The base of the stub lookup table */
"slli a0, a0, 3\n" /* a0=Offset for the stub lookup table */
"add t0, t0, a0\n" /* t0=The address in the table */
" ld t0, 0(t0)\n" /* t0=The address of the stub for this syscall */
REGLOAD " t0, 0(t0)\n" /* t0=The address of the stub for this syscall */
"jalr ra, t0\n" /* Call the stub (modifies ra) */
" ld ra, 0(sp)\n" /* Restore ra */
" addi sp, sp, 8\n" /* Destroy the stack frame */
REGLOAD " ra, 0(sp)\n" /* Restore ra */
"addi sp, sp, " STACK_FRAME_SIZE "\n" /* Destroy the stack frame */
"mv a2, a0\n" /* a2=Save return value in a0 */
"li a0, 3\n" /* a0=SYS_syscall_return (3) */
"ecall" /* Return from the syscall */
);
}
#else
static void dispatch_syscall(void)
{
asm volatile
(
" addi sp, sp, -4\n" /* Create a stack frame to hold ra */
" sw ra, 0(sp)\n" /* Save ra in the stack frame */
" la t0, g_stublookup\n" /* t0=The base of the stub lookup table */
" slli a0, a0, 3\n" /* a0=Offset for the stub lookup table */
" add t0, t0, a0\n" /* t0=The address in the table */
" lw t0, 0(t0)\n" /* t0=The address of the stub for this syscall */
" jalr ra, t0\n" /* Call the stub (modifies ra) */
" lw ra, 0(sp)\n" /* Restore ra */
" addi sp, sp, 4\n" /* Destroy the stack frame */
" mv a2, a0\n" /* a2=Save return value in a0 */
" li a0, 3\n" /* a0=SYS_syscall_return (3) */
" ecall" /* Return from the syscall */
);
}
#endif
#endif
/****************************************************************************

View File

@ -72,11 +72,7 @@ __start:
/* Load idle stack base to sp */
#ifdef CONFIG_ARCH_RV32
lw sp, 0(t0)
#else
ld sp, 0(t0)
#endif
REGLOAD sp, 0(t0)
/*
* sp (stack top) = sp + idle stack size - XCPTCONTEXT_SIZE