- // Here we load the buffer's address into %edi ("D" constraint)
- // 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)
- );
-
- spin(); // never reach
-}
-
-void panick(const char* msg) {
- asm(
- "int %0"
- ::"i"(LUNAIX_SYS_PANIC), "D"(msg)
- );
- spin();
+void noret
+__assert_fail(const char* expr, const char* file, unsigned int line)
+{
+ // Don't do another trap, print it right-away, allow
+ // the stack context being preserved
+ cpu_disable_interrupt();
+ ERROR("assertion fail (%s:%u)\n\t%s", file, line, expr);
+
+ failsafe_diagnostic();