X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/ea77b9c3fc7fb9bf9d7f9604fc187c8049212a2a..8c06c883e7b13c115d5ff207f79d4b68fccd5ad6:/lunaix-os/kernel/spike.c diff --git a/lunaix-os/kernel/spike.c b/lunaix-os/kernel/spike.c index 860b201..63414c2 100644 --- a/lunaix-os/kernel/spike.c +++ b/lunaix-os/kernel/spike.c @@ -1,10 +1,10 @@ -#include -#include +#include #include +#include static char buffer[1024]; -void +void noret __assert_fail(const char* expr, const char* file, unsigned int line) { ksprintf(buffer, "%s (%s:%u)", expr, file, line); @@ -13,15 +13,15 @@ __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 } -void +void noret panick(const char* msg) { - asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(msg)); + cpu_trap_panic(msg); spin(); } @@ -30,7 +30,7 @@ panickf(const char* fmt, ...) { va_list args; va_start(args, fmt); - __ksprintf_internal(buffer, fmt, 1024, args); + ksnprintfv(buffer, fmt, 1024, args); va_end(args); asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(buffer));