-#include <arch/x86/interrupts.h>
-#include <klibc/stdio.h>
+#include <klibc/strfmt.h>
#include <lunaix/spike.h>
+#include <lunaix/pcontext.h>
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);
// 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);
- DO_SPIN // never reach
+ spin(); // never reach
}
-void
+void noret
panick(const char* msg)
{
- asm("int %0" ::"i"(LUNAIX_SYS_PANIC), "D"(msg));
- DO_SPIN
+ cpu_trap_panic(msg);
+ spin();
}
void
{
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));
- DO_SPIN
+ spin();
}