1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
#include <stdio.h>
#include "isr_vector.h"
#include "panic.h"
#include "ch573/gpio.h"
#define GPIO_PORT_A ch573_gpio__gpio_port_a
#define GPIO_PORT CH573_GPIO__GPIO_PORT_T_INTF
void delay();
IRQ(exc)
{
uint32_t mcause, mepc, mtval, *sp;
asm volatile("csrr %0, mcause" : "=r"(mcause));
asm volatile("csrr %0, mepc" : "=r"(mepc));
asm volatile("csrr %0, mtval" : "=r"(mtval));
printf("Hardware Exception Caught:\n");
printf(" mcause: 0x%08x\n", mcause);
printf(" mepc: 0x%08x\n", mepc);
printf(" mtval: 0x%08x\n", mtval);
panic(mcause);
}
IRQ(nmi)
{
uint32_t mcause, mepc, mtval, *sp;
asm volatile("csrr %0, mcause" : "=r"(mcause));
asm volatile("csrr %0, mepc" : "=r"(mepc));
asm volatile("csrr %0, mtval" : "=r"(mtval));
printf("Unhandled NMI Caught:\n");
printf(" mcause: 0x%08x\n", mcause);
printf(" mepc: 0x%08x\n", mepc);
printf(" mtval: 0x%08x\n", mtval);
panic(mcause);
}
|