arch/risc-v: Attach exception handler in common place
Signed-off-by: Huang Qi <huangqi3@xiaomi.com>
This commit is contained in:
parent
36bc8d2131
commit
833211680a
@ -34,7 +34,7 @@ CMN_CSRCS += riscv_releasepending.c riscv_reprioritizertr.c
|
|||||||
CMN_CSRCS += riscv_releasestack.c riscv_stackframe.c riscv_schedulesigaction.c
|
CMN_CSRCS += riscv_releasestack.c riscv_stackframe.c riscv_schedulesigaction.c
|
||||||
CMN_CSRCS += riscv_sigdeliver.c riscv_udelay.c riscv_unblocktask.c riscv_usestack.c
|
CMN_CSRCS += riscv_sigdeliver.c riscv_udelay.c riscv_unblocktask.c riscv_usestack.c
|
||||||
CMN_CSRCS += riscv_idle.c riscv_tcbinfo.c riscv_getnewintctx.c riscv_doirq.c
|
CMN_CSRCS += riscv_idle.c riscv_tcbinfo.c riscv_getnewintctx.c riscv_doirq.c
|
||||||
CMN_CSRCS += riscv_cpuindex.c
|
CMN_CSRCS += riscv_cpuindex.c riscv_exception.c
|
||||||
|
|
||||||
ifeq ($(CONFIG_SCHED_BACKTRACE),y)
|
ifeq ($(CONFIG_SCHED_BACKTRACE),y)
|
||||||
CMN_CSRCS += riscv_backtrace.c
|
CMN_CSRCS += riscv_backtrace.c
|
||||||
|
@ -92,9 +92,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
|
||||||
|
@ -93,13 +93,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifdef CONFIG_BUILD_PROTECTED
|
|
||||||
irq_attach(RISCV_IRQ_ECALLU, riscv_swint, NULL);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
|
||||||
|
@ -54,13 +54,6 @@ void *riscv_dispatch_irq(uintptr_t vector, uintptr_t *regs)
|
|||||||
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
||||||
uintptr_t *mepc = regs;
|
uintptr_t *mepc = regs;
|
||||||
|
|
||||||
/* Check if fault happened */
|
|
||||||
|
|
||||||
if (vector < RISCV_IRQ_ECALLU)
|
|
||||||
{
|
|
||||||
riscv_exception(irq, regs, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Firstly, check if the irq is machine external interrupt */
|
/* Firstly, check if the irq is machine external interrupt */
|
||||||
|
|
||||||
if (RISCV_IRQ_MEXT == irq)
|
if (RISCV_IRQ_MEXT == irq)
|
||||||
|
@ -90,3 +90,51 @@ int riscv_exception(int mcause, void *regs, void *args)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: riscv_exception_attach
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Attach standard exception with suitable handler
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void riscv_exception_attach(void)
|
||||||
|
{
|
||||||
|
irq_attach(RISCV_IRQ_IAMISALIGNED, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_IAFAULT, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_IINSTRUCTION, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_BPOINT, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_LAMISALIGNED, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_LAFAULT, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_SAMISALIGNED, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_SAFAULT, riscv_exception, NULL);
|
||||||
|
|
||||||
|
/* Attach the ecall interrupt handler */
|
||||||
|
|
||||||
|
#ifndef CONFIG_BUILD_FLAT
|
||||||
|
irq_attach(RISCV_IRQ_ECALLU, riscv_swint, NULL);
|
||||||
|
#else
|
||||||
|
irq_attach(RISCV_IRQ_ECALLU, riscv_exception, NULL);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
irq_attach(RISCV_IRQ_ECALLS, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_ECALLH, riscv_exception, NULL);
|
||||||
|
|
||||||
|
#ifndef CONFIG_ARCH_USE_S_MODE
|
||||||
|
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
||||||
|
#else
|
||||||
|
irq_attach(RISCV_IRQ_ECALLM, riscv_exception, NULL);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
irq_attach(RISCV_IRQ_INSTRUCTIONPF, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_LOADPF, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_RESERVED, riscv_exception, NULL);
|
||||||
|
irq_attach(RISCV_IRQ_STOREPF, riscv_exception, NULL);
|
||||||
|
|
||||||
|
#ifdef CONFIG_SMP
|
||||||
|
irq_attach(RISCV_IRQ_MSOFT, riscv_pause_handler, NULL);
|
||||||
|
#else
|
||||||
|
irq_attach(RISCV_IRQ_MSOFT, riscv_exception, NULL);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
@ -229,6 +229,7 @@ void riscv_copystate(uintptr_t *dest, uintptr_t *src);
|
|||||||
void riscv_sigdeliver(void);
|
void riscv_sigdeliver(void);
|
||||||
int riscv_swint(int irq, void *context, void *arg);
|
int riscv_swint(int irq, void *context, void *arg);
|
||||||
uintptr_t riscv_get_newintctx(void);
|
uintptr_t riscv_get_newintctx(void);
|
||||||
|
void riscv_exception_attach(void);
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_FPU
|
#ifdef CONFIG_ARCH_FPU
|
||||||
void riscv_fpuconfig(void);
|
void riscv_fpuconfig(void);
|
||||||
|
@ -112,9 +112,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
putreg32(ESP32C3_DEFAULT_INT_THRESHOLD, INTERRUPT_CPU_INT_THRESH_REG);
|
putreg32(ESP32C3_DEFAULT_INT_THRESHOLD, INTERRUPT_CPU_INT_THRESH_REG);
|
||||||
|
|
||||||
/* Attach the ECALL interrupt. */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifdef CONFIG_ESP32C3_GPIO_IRQ
|
#ifdef CONFIG_ESP32C3_GPIO_IRQ
|
||||||
/* Initialize GPIO interrupt support */
|
/* Initialize GPIO interrupt support */
|
||||||
|
@ -26,7 +26,7 @@ HEAD_ASRC = fe310_head.S
|
|||||||
CMN_ASRCS += riscv_vectors.S riscv_testset.S riscv_exception_common.S
|
CMN_ASRCS += riscv_vectors.S riscv_testset.S riscv_exception_common.S
|
||||||
|
|
||||||
# Specify C code within the common directory to be included
|
# Specify C code within the common directory to be included
|
||||||
CMN_CSRCS += riscv_initialize.c riscv_swint.c
|
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_exception.c
|
||||||
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
||||||
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
||||||
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c riscv_mdelay.c
|
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c riscv_mdelay.c
|
||||||
|
@ -86,9 +86,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
|
||||||
|
@ -90,22 +90,15 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifdef CONFIG_BUILD_PROTECTED
|
|
||||||
irq_attach(RISCV_IRQ_ECALLU, riscv_swint, NULL);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
/* Clear MSOFT for CPU0 */
|
/* Clear MSOFT for CPU0 */
|
||||||
|
|
||||||
putreg32(0, K210_CLINT_MSIP);
|
putreg32(0, K210_CLINT_MSIP);
|
||||||
|
|
||||||
/* Setup MSOFT for CPU0 with pause handler */
|
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_MSOFT, riscv_pause_handler, NULL);
|
|
||||||
up_enable_irq(RISCV_IRQ_MSOFT);
|
up_enable_irq(RISCV_IRQ_MSOFT);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -55,13 +55,6 @@ void *riscv_dispatch_irq(uintptr_t vector, uintptr_t *regs)
|
|||||||
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
||||||
uintptr_t *mepc = regs;
|
uintptr_t *mepc = regs;
|
||||||
|
|
||||||
/* Check if fault happened */
|
|
||||||
|
|
||||||
if (vector < RISCV_IRQ_ECALLU)
|
|
||||||
{
|
|
||||||
riscv_exception(irq, regs, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Firstly, check if the irq is machine external interrupt */
|
/* Firstly, check if the irq is machine external interrupt */
|
||||||
|
|
||||||
if (RISCV_IRQ_MEXT == irq)
|
if (RISCV_IRQ_MEXT == irq)
|
||||||
|
@ -26,7 +26,7 @@ HEAD_ASRC = litex_head.S
|
|||||||
CMN_ASRCS += riscv_vectors.S riscv_testset.S riscv_exception_common.S
|
CMN_ASRCS += riscv_vectors.S riscv_testset.S riscv_exception_common.S
|
||||||
|
|
||||||
# Specify C code within the common directory to be included
|
# Specify C code within the common directory to be included
|
||||||
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_doirq.c
|
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_doirq.c riscv_exception.c
|
||||||
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
||||||
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
||||||
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c riscv_mdelay.c
|
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c riscv_mdelay.c
|
||||||
|
@ -72,9 +72,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
|
||||||
|
@ -52,17 +52,6 @@ void *riscv_dispatch_irq(uintptr_t vector, uintptr_t *regs)
|
|||||||
int irq = (vector & 0x3f);
|
int irq = (vector & 0x3f);
|
||||||
uintptr_t *epc = regs;
|
uintptr_t *epc = regs;
|
||||||
|
|
||||||
/* Check if fault happened */
|
|
||||||
|
|
||||||
if (vector < RISCV_IRQ_ECALLU ||
|
|
||||||
vector == RISCV_IRQ_INSTRUCTIONPF ||
|
|
||||||
vector == RISCV_IRQ_LOADPF ||
|
|
||||||
vector == RISCV_IRQ_STOREPF ||
|
|
||||||
vector == RISCV_IRQ_RESERVED)
|
|
||||||
{
|
|
||||||
riscv_exception(irq, regs, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((vector & RISCV_IRQ_BIT) != 0)
|
if ((vector & RISCV_IRQ_BIT) != 0)
|
||||||
{
|
{
|
||||||
irq += MPFS_IRQ_ASYNC;
|
irq += MPFS_IRQ_ASYNC;
|
||||||
|
@ -84,9 +84,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
/* Clear MSOFT for CPU0 */
|
/* Clear MSOFT for CPU0 */
|
||||||
|
@ -58,11 +58,6 @@ void *riscv_dispatch_irq(uintptr_t vector, uintptr_t *regs)
|
|||||||
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
int irq = (vector >> RV_IRQ_MASK) | (vector & 0xf);
|
||||||
uintptr_t *mepc = regs;
|
uintptr_t *mepc = regs;
|
||||||
|
|
||||||
if (vector < RISCV_IRQ_ECALLM)
|
|
||||||
{
|
|
||||||
riscv_exception(irq, regs, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Firstly, check if the irq is machine external interrupt */
|
/* Firstly, check if the irq is machine external interrupt */
|
||||||
|
|
||||||
if (RISCV_IRQ_MEXT == irq)
|
if (RISCV_IRQ_MEXT == irq)
|
||||||
|
@ -26,7 +26,7 @@ HEAD_ASRC = rv32m1_head.S
|
|||||||
CMN_ASRCS = riscv_vectors.S
|
CMN_ASRCS = riscv_vectors.S
|
||||||
|
|
||||||
# Specify C code within the common directory to be included
|
# Specify C code within the common directory to be included
|
||||||
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_doirq.c
|
CMN_CSRCS += riscv_initialize.c riscv_swint.c riscv_doirq.c riscv_exception.c
|
||||||
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
CMN_CSRCS += riscv_allocateheap.c riscv_createstack.c riscv_exit.c
|
||||||
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
CMN_CSRCS += riscv_assert.c riscv_blocktask.c riscv_copystate.c riscv_initialstate.c
|
||||||
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c
|
CMN_CSRCS += riscv_interruptcontext.c riscv_modifyreg32.c riscv_puts.c
|
||||||
|
@ -119,9 +119,9 @@ void up_irqinitialize(void)
|
|||||||
|
|
||||||
CURRENT_REGS = NULL;
|
CURRENT_REGS = NULL;
|
||||||
|
|
||||||
/* Attach the ecall interrupt handler */
|
/* Attach the common interrupt handler */
|
||||||
|
|
||||||
irq_attach(RISCV_IRQ_ECALLM, riscv_swint, NULL);
|
riscv_exception_attach();
|
||||||
|
|
||||||
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
#ifndef CONFIG_SUPPRESS_INTERRUPTS
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user