blob: 512dce061967ce33d4ef4ca53dbb68d084298400 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Rick Chen6eedd922017-12-26 13:55:49 +08002/*
3 * Copyright (c) 2016-17 Microsemi Corporation.
4 * Padmarao Begari, Microsemi Corporation <padmarao.begari@microsemi.com>
5 *
6 * Copyright (C) 2017 Andes Technology Corporation
7 * Rick Chen, Andes Technology Corporation <rick@andestech.com>
Rick Chen6eedd922017-12-26 13:55:49 +08008 */
9
10#include <common.h>
Simon Glassf11478f2019-12-28 10:45:07 -070011#include <hang.h>
Simon Glass9b61c7c2019-11-14 12:57:41 -070012#include <irq_func.h>
Rick Chen6eedd922017-12-26 13:55:49 +080013#include <asm/ptrace.h>
14#include <asm/system.h>
15#include <asm/encoding.h>
16
Bin Mengbcc6c742018-12-12 06:12:44 -080017static void _exit_trap(ulong code, ulong epc, struct pt_regs *regs)
18{
19 static const char * const exception_code[] = {
20 "Instruction address misaligned",
21 "Instruction access fault",
22 "Illegal instruction",
23 "Breakpoint",
24 "Load address misaligned",
25 "Load access fault",
26 "Store/AMO address misaligned",
27 "Store/AMO access fault",
28 "Environment call from U-mode",
29 "Environment call from S-mode",
30 "Reserved",
31 "Environment call from M-mode",
32 "Instruction page fault",
33 "Load page fault",
34 "Reserved",
35 "Store/AMO page fault",
36 };
37
38 if (code < ARRAY_SIZE(exception_code)) {
39 printf("exception code: %ld , %s , epc %lx , ra %lx\n",
40 code, exception_code[code], epc, regs->ra);
41 } else {
Lukas Auer8318e892019-01-04 01:37:28 +010042 printf("reserved exception code: %ld , epc %lx , ra %lx\n",
43 code, epc, regs->ra);
Bin Mengbcc6c742018-12-12 06:12:44 -080044 }
45
46 hang();
47}
Rick Chen6eedd922017-12-26 13:55:49 +080048
49int interrupt_init(void)
50{
51 return 0;
52}
53
54/*
55 * enable interrupts
56 */
57void enable_interrupts(void)
58{
59}
60
61/*
62 * disable interrupts
63 */
64int disable_interrupts(void)
65{
66 return 0;
67}
68
Anup Patel89b39342018-12-03 10:57:40 +053069ulong handle_trap(ulong cause, ulong epc, struct pt_regs *regs)
Rick Chen6eedd922017-12-26 13:55:49 +080070{
Anup Patel89b39342018-12-03 10:57:40 +053071 ulong is_irq, irq;
72
73 is_irq = (cause & MCAUSE_INT);
74 irq = (cause & ~MCAUSE_INT);
Rick Chen6eedd922017-12-26 13:55:49 +080075
Anup Patel89b39342018-12-03 10:57:40 +053076 if (is_irq) {
77 switch (irq) {
78 case IRQ_M_EXT:
79 case IRQ_S_EXT:
80 external_interrupt(0); /* handle external interrupt */
81 break;
82 case IRQ_M_TIMER:
83 case IRQ_S_TIMER:
84 timer_interrupt(0); /* handle timer interrupt */
85 break;
86 default:
87 _exit_trap(cause, epc, regs);
88 break;
89 };
90 } else {
91 _exit_trap(cause, epc, regs);
92 }
Rick Chen6eedd922017-12-26 13:55:49 +080093
94 return epc;
95}
96
97/*
98 *Entry Point for PLIC Interrupt Handler
99 */
100__attribute__((weak)) void external_interrupt(struct pt_regs *regs)
101{
102}
103
104__attribute__((weak)) void timer_interrupt(struct pt_regs *regs)
105{
106}