Kernel: Move __assertion_failed to aarch64/Panic.cpp

This is for an upcoming change to add the Kernel namespace to the
init.cpp file.
This commit is contained in:
Timon Kruiper 2022-05-12 22:53:44 +02:00 committed by Linus Groh
parent d451bdec6f
commit 9282e0db16
Notes: sideshowbarker 2024-07-17 10:55:53 +09:00
2 changed files with 13 additions and 15 deletions

View File

@ -10,14 +10,23 @@
// FIXME: Merge the code in this file with Kernel/Panic.cpp once the proper abstractions are in place.
namespace Kernel {
// Note: This is required here, since __assertion_failed should be out of the Kernel namespace,
// but the PANIC macro uses functions that require the Kernel namespace.
using namespace Kernel;
void __panic(char const* file, unsigned int line, char const* function)
[[noreturn]] void __assertion_failed(char const* msg, char const* file, unsigned line, char const* func)
{
critical_dmesgln("ASSERTION FAILED: {}", msg);
critical_dmesgln("{}:{} in {}", file, line, func);
// Used for printing a nice backtrace!
PANIC("Aborted");
}
void Kernel::__panic(char const* file, unsigned int line, char const* function)
{
critical_dmesgln("at {}:{} in {}", file, line, function);
dump_backtrace(PrintToScreen::Yes);
Processor::halt();
}
}

View File

@ -103,17 +103,6 @@ void __stack_chk_fail()
Kernel::Processor::halt();
}
using namespace Kernel;
[[noreturn]] void __assertion_failed(char const* msg, char const* file, unsigned line, char const* func)
{
critical_dmesgln("ASSERTION FAILED: {}", msg);
critical_dmesgln("{}:{} in {}", file, line, func);
// Used for printing a nice backtrace!
PANIC("Aborted");
}
extern "C" void exception_common(TrapFrame const* const trap_frame)
{
constexpr bool print_stack_frame = true;