X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/e5c3c8accffbcd77fea12ccf2b0accc70c645aaa..1fe5f5eb5378a47bf0f3451762743c162e40faad:/lunaix-os/kernel/spike.c diff --git a/lunaix-os/kernel/spike.c b/lunaix-os/kernel/spike.c index 860b201..67f9abe 100644 --- a/lunaix-os/kernel/spike.c +++ b/lunaix-os/kernel/spike.c @@ -1,6 +1,6 @@ -#include #include #include +#include static char buffer[1024]; @@ -13,16 +13,16 @@ __assert_fail(const char* expr, const char* file, unsigned int line) // This is a convention we made that the LUNAIX_SYS_PANIC syscall will // print the panic message passed via %edi. (see // kernel/asm/x86/interrupts.c) - asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(buffer)); + cpu_trap_panic(buffer); - spin(); // never reach + DO_SPIN // never reach } -void +void noret panick(const char* msg) { - asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(msg)); - spin(); + cpu_trap_panic(msg); + DO_SPIN } void @@ -34,5 +34,5 @@ panickf(const char* fmt, ...) va_end(args); asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(buffer)); - spin(); + DO_SPIN }