123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- // SPDX-License-Identifier: GPL-2.0+
- /*
- * Copyright (c) 2016-17 Microsemi Corporation.
- * Padmarao Begari, Microsemi Corporation <padmarao.begari@microsemi.com>
- *
- * Copyright (C) 2017 Andes Technology Corporation
- * Rick Chen, Andes Technology Corporation <rick@andestech.com>
- */
- #include <common.h>
- #include <asm/ptrace.h>
- #include <asm/system.h>
- #include <asm/encoding.h>
- static void _exit_trap(int code, uint epc, struct pt_regs *regs);
- int interrupt_init(void)
- {
- return 0;
- }
- /*
- * enable interrupts
- */
- void enable_interrupts(void)
- {
- }
- /*
- * disable interrupts
- */
- int disable_interrupts(void)
- {
- return 0;
- }
- uint handle_trap(uint mcause, uint epc, struct pt_regs *regs)
- {
- uint is_int;
- is_int = (mcause & MCAUSE_INT);
- if ((is_int) && ((mcause & MCAUSE_CAUSE) == IRQ_M_EXT))
- external_interrupt(0); /* handle_m_ext_interrupt */
- else if ((is_int) && ((mcause & MCAUSE_CAUSE) == IRQ_M_TIMER))
- timer_interrupt(0); /* handle_m_timer_interrupt */
- else
- _exit_trap(mcause, epc, regs);
- return epc;
- }
- /*
- *Entry Point for PLIC Interrupt Handler
- */
- __attribute__((weak)) void external_interrupt(struct pt_regs *regs)
- {
- }
- __attribute__((weak)) void timer_interrupt(struct pt_regs *regs)
- {
- }
- static void _exit_trap(int code, uint epc, struct pt_regs *regs)
- {
- static const char * const exception_code[] = {
- "Instruction address misaligned",
- "Instruction access fault",
- "Illegal instruction",
- "Breakpoint",
- "Load address misaligned"
- };
- printf("exception code: %d , %s , epc %08x , ra %08lx\n",
- code, exception_code[code], epc, regs->ra);
- }
|