aboutsummaryrefslogtreecommitdiff
path: root/src/exc.c
blob: 657ddb89b75c87a5a1d24babc0463a6425262905 (plain) (blame)
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);
}