Files
osc2025/kernel/exception_handler.S
2025-04-08 06:59:50 +08:00

89 lines
1.6 KiB
ArmAsm

.section ".text.exception"
// save general registers to stack
.macro save_all
sub sp, sp, 32 * 8
stp x0, x1, [sp ,16 * 0]
stp x2, x3, [sp ,16 * 1]
stp x4, x5, [sp ,16 * 2]
stp x6, x7, [sp ,16 * 3]
stp x8, x9, [sp ,16 * 4]
stp x10, x11, [sp ,16 * 5]
stp x12, x13, [sp ,16 * 6]
stp x14, x15, [sp ,16 * 7]
stp x16, x17, [sp ,16 * 8]
stp x18, x19, [sp ,16 * 9]
stp x20, x21, [sp ,16 * 10]
stp x22, x23, [sp ,16 * 11]
stp x24, x25, [sp ,16 * 12]
stp x26, x27, [sp ,16 * 13]
stp x28, x29, [sp ,16 * 14]
str x30, [sp, 16 * 15]
.endm
// load general registers from stack
.macro load_all
ldp x0, x1, [sp ,16 * 0]
ldp x2, x3, [sp ,16 * 1]
ldp x4, x5, [sp ,16 * 2]
ldp x6, x7, [sp ,16 * 3]
ldp x8, x9, [sp ,16 * 4]
ldp x10, x11, [sp ,16 * 5]
ldp x12, x13, [sp ,16 * 6]
ldp x14, x15, [sp ,16 * 7]
ldp x16, x17, [sp ,16 * 8]
ldp x18, x19, [sp ,16 * 9]
ldp x20, x21, [sp ,16 * 10]
ldp x22, x23, [sp ,16 * 11]
ldp x24, x25, [sp ,16 * 12]
ldp x26, x27, [sp ,16 * 13]
ldp x28, x29, [sp ,16 * 14]
ldr x30, [sp, 16 * 15]
add sp, sp, 32 * 8
.endm
_null_handler:
save_all
bl not_implemented_interrupt
load_all
eret
.align 11
.global exception_vector_table
exception_vector_table:
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7
b _null_handler
.align 7