aboutsummaryrefslogtreecommitdiffstats
path: root/src/interrupt.zig
blob: 2fe16714179f4e96fe1a3d44102313d64b5cda3f (plain)
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
const vector_table_type = [256] *const fn () void;
var vector_table: vector_table_type = undefined;
var vtor: **volatile vector_table_type = @ptrFromInt(0xE000ED08);

pub const vector = enum(u8) {
    NMI = 2,
    HardFault,
    MemManage,
    BusFault,
    UsageFault,
    rsvd7,
    rsvd8,
    rsvd9,
    rsvd10,
    SVCall,
    DebugMonitor,
    rsvd13,
    PendSV,
    SysTick,
};

pub fn initialize() void {
    register(.NMI, nmi);
    register(.HardFault, hardfault);
    register(.MemManage, memmanage);
    register(.BusFault, busfault);
    register(.UsageFault, usagefault);

    vtor.* = &vector_table;
}

pub fn register(index: vector, handler: *const fn () void) void {
    vector_table[@intFromEnum(index)] = handler;
}

fn nmi() void { while (true) {} }
fn hardfault() void { while (true) {} }
fn memmanage() void { while (true) {} }
fn busfault() void { while (true) {} }
fn usagefault() void { while (true) {} }