mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-10-25 05:25:57 +08:00
* Nuclei RISC-V Processor support is added both RV32 and RV64 * Nuclei RVSTAR BSP is added, UART driver is added * MSH works well in RVSTAR board --------------------------- Squashed commit of the following: commitb7368bc2edAuthor: Huaqi Fang <578567190@qq.com> Date: Fri Apr 17 14:38:54 2020 +0800 [BSP][Nuclei] Pretty source code Signed-off-by: Huaqi Fang <578567190@qq.com> commit2c42a997f7Author: Huaqi Fang <578567190@qq.com> Date: Thu Apr 16 15:51:03 2020 +0800 [libcpu] Remove ARCH_NUCLEI in libcpu kconfig Signed-off-by: Huaqi Fang <578567190@qq.com> commit915ad4c076Author: Huaqi Fang <578567190@qq.com> Date: Thu Apr 16 15:50:00 2020 +0800 [BSP][Nuclei] Remove ARCH_NUCLEI in bsp KConfig Signed-off-by: Huaqi Fang <578567190@qq.com> commitfe43869c79Author: Huaqi Fang <578567190@qq.com> Date: Wed Apr 15 12:43:20 2020 +0800 [BSP][NUCLEI] Simply application main.c Remove previous complicated application of gd32vf103_rvstar Signed-off-by: Huaqi Fang <578567190@qq.com> commit8fd31727bcAuthor: Huaqi Fang <578567190@qq.com> Date: Wed Apr 15 12:38:04 2020 +0800 [BSP][NUCLEI] Format application and board source code Signed-off-by: Huaqi Fang <578567190@qq.com> commitb432308b20Author: Huaqi Fang <578567190@qq.com> Date: Wed Apr 15 11:58:28 2020 +0800 [BSP][Nuclei] Format source code of drivers of gd32vf103 Signed-off-by: Huaqi Fang <578567190@qq.com> commit7366173d74Author: Huaqi Fang <578567190@qq.com> Date: Wed Apr 15 11:54:02 2020 +0800 [LIBCPU][NUCLEI] Optimize nuclei cpu portable code Signed-off-by: Huaqi Fang <578567190@qq.com> commit8c2cd4745bAuthor: Huaqi Fang <578567190@qq.com> Date: Tue Apr 14 15:45:42 2020 +0800 nuclei: Update README.md Signed-off-by: Huaqi Fang <578567190@qq.com> commitfa8a2f24eaAuthor: Huaqi Fang <578567190@qq.com> Date: Tue Apr 14 14:06:54 2020 +0800 nuclei: Add gpio driver not tested Signed-off-by: Huaqi Fang <578567190@qq.com> commit1be40bc50bAuthor: Huaqi Fang <578567190@qq.com> Date: Thu Apr 9 14:55:22 2020 +0800 Nuclei: Update README.md Signed-off-by: Huaqi Fang <578567190@qq.com> commit4c8beb204bAuthor: Huaqi Fang <578567190@qq.com> Date: Thu Apr 9 10:20:25 2020 +0800 Nuclei: Change idle stack size from 256 to 396 bytes If changed to 396 bytes, then debug optimization level changed from O2 to O0, and the application can run successfully without stack overflow issue of tidle0 task warning: tidle0 stack is close to end of stack address. Signed-off-by: Huaqi Fang <578567190@qq.com> commitda2bcf5c56Author: Huaqi Fang <578567190@qq.com> Date: Thu Apr 9 10:11:40 2020 +0800 nuclei: Remove unused kconfig Signed-off-by: Huaqi Fang <578567190@qq.com> commit0b932c677aAuthor: Huaqi Fang <578567190@qq.com> Date: Thu Apr 9 09:32:22 2020 +0800 nuclei: optimize drivers support Signed-off-by: Huaqi Fang <578567190@qq.com> commit0431f6f01fAuthor: Huaqi Fang <578567190@qq.com> Date: Wed Apr 8 19:28:02 2020 +0800 tools: Update mkdist.py for nuclei bsp Signed-off-by: Huaqi Fang <578567190@qq.com> commit0e1f502edfAuthor: Huaqi Fang <578567190@qq.com> Date: Wed Apr 8 18:46:58 2020 +0800 nuclei: optimize rvstar support directory Signed-off-by: Huaqi Fang <578567190@qq.com> commit1131f6e648Author: Huaqi Fang <578567190@qq.com> Date: Wed Apr 8 18:37:24 2020 +0800 nuclei: update kconfig Signed-off-by: Huaqi Fang <578567190@qq.com> commitad81c1d3bfAuthor: Huaqi Fang <578567190@qq.com> Date: Wed Apr 8 15:43:00 2020 +0800 nuclei: Rename board name Signed-off-by: Huaqi Fang <578567190@qq.com> commitd780138a1aAuthor: Huaqi Fang <578567190@qq.com> Date: Tue Apr 7 09:36:19 2020 +0800 libcpu: Add Nuclei arch option in KConfig Signed-off-by: Huaqi Fang <578567190@qq.com> commit60320d34b1Author: Huaqi Fang <578567190@qq.com> Date: Fri Apr 3 16:51:01 2020 +0800 nuclei: Update nuclei sdk of rt-thread support Signed-off-by: Huaqi Fang <578567190@qq.com> commita042b806efAuthor: Huaqi Fang <578567190@qq.com> Date: Fri Apr 3 11:34:09 2020 +0800 nuclei: modify application for not print anything Signed-off-by: Huaqi Fang <578567190@qq.com> commit2a9603adcbAuthor: Huaqi Fang <578567190@qq.com> Date: Fri Apr 3 11:31:01 2020 +0800 nuclei: Add .gitignore for nuclei bsp Signed-off-by: Huaqi Fang <578567190@qq.com> commit34aaf6aebaAuthor: Huaqi Fang <578567190@qq.com> Date: Fri Apr 3 11:28:06 2020 +0800 nuclei_sdk: update link script of rvstar to contain rt-thread needed sections /* section information for finsh shell */ . = ALIGN(4); __fsymtab_start = .; KEEP(*(FSymTab)) __fsymtab_end = .; . = ALIGN(4); __vsymtab_start = .; KEEP(*(VSymTab)) __vsymtab_end = .; /* section information for initial. */ . = ALIGN(4); __rt_init_start = .; KEEP(*(SORT(.rti_fn*))) __rt_init_end = .; The above code placed in rodata section Signed-off-by: Huaqi Fang <578567190@qq.com> commit3451466e9dAuthor: Huaqi Fang <578567190@qq.com> Date: Fri Apr 3 10:04:42 2020 +0800 bsp: Add initial commit of nuclei rvstar board bsp Signed-off-by: Huaqi Fang <578567190@qq.com> Signed-off-by: Huaqi Fang <578567190@qq.com>
219 lines
5.7 KiB
ArmAsm
219 lines
5.7 KiB
ArmAsm
/*
|
|
* Copyright (c) 2019-Present Nuclei Limited. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2020/03/26 hqfang First Nuclei RISC-V porting implementation
|
|
*/
|
|
|
|
#include "riscv_encoding.h"
|
|
|
|
.section .text.entry
|
|
.align 8
|
|
|
|
/**
|
|
* \brief Global interrupt disabled
|
|
* \details
|
|
* This function disable global interrupt.
|
|
* \remarks
|
|
* - All the interrupt requests will be ignored by CPU.
|
|
*/
|
|
.macro DISABLE_MIE
|
|
csrc CSR_MSTATUS, MSTATUS_MIE
|
|
.endm
|
|
|
|
/**
|
|
* \brief Macro for context save
|
|
* \details
|
|
* This macro save ABI defined caller saved registers in the stack.
|
|
* \remarks
|
|
* - This Macro could use to save context when you enter to interrupt
|
|
* or exception
|
|
*/
|
|
/* Save caller registers */
|
|
.macro SAVE_CONTEXT
|
|
csrrw sp, CSR_MSCRATCHCSWL, sp
|
|
/* Allocate stack space for context saving */
|
|
#ifndef __riscv_32e
|
|
addi sp, sp, -20*REGBYTES
|
|
#else
|
|
addi sp, sp, -14*REGBYTES
|
|
#endif /* __riscv_32e */
|
|
|
|
STORE x1, 0*REGBYTES(sp)
|
|
STORE x4, 1*REGBYTES(sp)
|
|
STORE x5, 2*REGBYTES(sp)
|
|
STORE x6, 3*REGBYTES(sp)
|
|
STORE x7, 4*REGBYTES(sp)
|
|
STORE x10, 5*REGBYTES(sp)
|
|
STORE x11, 6*REGBYTES(sp)
|
|
STORE x12, 7*REGBYTES(sp)
|
|
STORE x13, 8*REGBYTES(sp)
|
|
STORE x14, 9*REGBYTES(sp)
|
|
STORE x15, 10*REGBYTES(sp)
|
|
#ifndef __riscv_32e
|
|
STORE x16, 14*REGBYTES(sp)
|
|
STORE x17, 15*REGBYTES(sp)
|
|
STORE x28, 16*REGBYTES(sp)
|
|
STORE x29, 17*REGBYTES(sp)
|
|
STORE x30, 18*REGBYTES(sp)
|
|
STORE x31, 19*REGBYTES(sp)
|
|
#endif /* __riscv_32e */
|
|
.endm
|
|
|
|
/**
|
|
* \brief Macro for restore caller registers
|
|
* \details
|
|
* This macro restore ABI defined caller saved registers from stack.
|
|
* \remarks
|
|
* - You could use this macro to restore context before you want return
|
|
* from interrupt or exeception
|
|
*/
|
|
/* Restore caller registers */
|
|
.macro RESTORE_CONTEXT
|
|
LOAD x1, 0*REGBYTES(sp)
|
|
LOAD x4, 1*REGBYTES(sp)
|
|
LOAD x5, 2*REGBYTES(sp)
|
|
LOAD x6, 3*REGBYTES(sp)
|
|
LOAD x7, 4*REGBYTES(sp)
|
|
LOAD x10, 5*REGBYTES(sp)
|
|
LOAD x11, 6*REGBYTES(sp)
|
|
LOAD x12, 7*REGBYTES(sp)
|
|
LOAD x13, 8*REGBYTES(sp)
|
|
LOAD x14, 9*REGBYTES(sp)
|
|
LOAD x15, 10*REGBYTES(sp)
|
|
#ifndef __riscv_32e
|
|
LOAD x16, 14*REGBYTES(sp)
|
|
LOAD x17, 15*REGBYTES(sp)
|
|
LOAD x28, 16*REGBYTES(sp)
|
|
LOAD x29, 17*REGBYTES(sp)
|
|
LOAD x30, 18*REGBYTES(sp)
|
|
LOAD x31, 19*REGBYTES(sp)
|
|
|
|
/* De-allocate the stack space */
|
|
addi sp, sp, 20*REGBYTES
|
|
#else
|
|
/* De-allocate the stack space */
|
|
addi sp, sp, 14*REGBYTES
|
|
#endif /* __riscv_32e */
|
|
csrrw sp, CSR_MSCRATCHCSWL, sp
|
|
.endm
|
|
|
|
/**
|
|
* \brief Macro for save necessary CSRs to stack
|
|
* \details
|
|
* This macro store MCAUSE, MEPC, MSUBM to stack.
|
|
*/
|
|
.macro SAVE_CSR_CONTEXT
|
|
/* Store CSR mcause to stack using pushmcause */
|
|
csrrwi x0, CSR_PUSHMCAUSE, 11
|
|
/* Store CSR mepc to stack using pushmepc */
|
|
csrrwi x0, CSR_PUSHMEPC, 12
|
|
/* Store CSR msub to stack using pushmsub */
|
|
csrrwi x0, CSR_PUSHMSUBM, 13
|
|
.endm
|
|
|
|
/**
|
|
* \brief Macro for restore necessary CSRs from stack
|
|
* \details
|
|
* This macro restore MSUBM, MEPC, MCAUSE from stack.
|
|
*/
|
|
.macro RESTORE_CSR_CONTEXT
|
|
LOAD x5, 13*REGBYTES(sp)
|
|
csrw CSR_MSUBM, x5
|
|
LOAD x5, 12*REGBYTES(sp)
|
|
csrw CSR_MEPC, x5
|
|
LOAD x5, 11*REGBYTES(sp)
|
|
csrw CSR_MCAUSE, x5
|
|
.endm
|
|
|
|
/**
|
|
* \brief Exception/NMI Entry
|
|
* \details
|
|
* This function provide common entry functions for exception/nmi.
|
|
* \remarks
|
|
* This function provide a default exception/nmi entry.
|
|
* ABI defined caller save register and some CSR registers
|
|
* to be saved before enter interrupt handler and be restored before return.
|
|
*/
|
|
.section .text.trap
|
|
/* In CLIC mode, the exeception entry must be 64bytes aligned */
|
|
.align 6
|
|
.global exc_entry
|
|
exc_entry:
|
|
/* Save the caller saving registers (context) */
|
|
SAVE_CONTEXT
|
|
/* Save the necessary CSR registers */
|
|
SAVE_CSR_CONTEXT
|
|
|
|
/*
|
|
* Set the exception handler function arguments
|
|
* argument 1: mcause value
|
|
* argument 2: current stack point(SP) value
|
|
*/
|
|
csrr a0, mcause
|
|
mv a1, sp
|
|
/*
|
|
* TODO: Call the exception handler function
|
|
* By default, the function template is provided in
|
|
* system_Device.c, you can adjust it as you want
|
|
*/
|
|
call core_exception_handler
|
|
|
|
/* Restore the necessary CSR registers */
|
|
RESTORE_CSR_CONTEXT
|
|
/* Restore the caller saving registers (context) */
|
|
RESTORE_CONTEXT
|
|
|
|
/* Return to regular code */
|
|
mret
|
|
|
|
/**
|
|
* \brief Non-Vector Interrupt Entry
|
|
* \details
|
|
* This function provide common entry functions for handling
|
|
* non-vector interrupts
|
|
* \remarks
|
|
* This function provide a default non-vector interrupt entry.
|
|
* ABI defined caller save register and some CSR registers need
|
|
* to be saved before enter interrupt handler and be restored before return.
|
|
*/
|
|
.section .text.irq
|
|
/* In CLIC mode, the interrupt entry must be 4bytes aligned */
|
|
.align 2
|
|
.global irq_entry
|
|
/* This label will be set to MTVT2 register */
|
|
irq_entry:
|
|
/* Save the caller saving registers (context) */
|
|
SAVE_CONTEXT
|
|
/* Save the necessary CSR registers */
|
|
SAVE_CSR_CONTEXT
|
|
|
|
/* This special CSR read/write operation, which is actually
|
|
* claim the CLIC to find its pending highest ID, if the ID
|
|
* is not 0, then automatically enable the mstatus.MIE, and
|
|
* jump to its vector-entry-label, and update the link register
|
|
*/
|
|
csrrw ra, CSR_JALMNXTI, ra
|
|
|
|
/* Critical section with interrupts disabled */
|
|
DISABLE_MIE
|
|
|
|
/* Restore the necessary CSR registers */
|
|
RESTORE_CSR_CONTEXT
|
|
/* Restore the caller saving registers (context) */
|
|
RESTORE_CONTEXT
|
|
|
|
/* Return to regular code */
|
|
mret
|
|
|
|
/* Default Handler for Exceptions / Interrupts */
|
|
.global default_intexc_handler
|
|
Undef_Handler:
|
|
default_intexc_handler:
|
|
1:
|
|
j 1b
|
|
|