2021-02-14 09:01:52 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
|
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2021-02-14 09:01:52 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <AK/Format.h>
|
2021-10-14 00:07:37 +01:00
|
|
|
#include <Kernel/Arch/Processor.h>
|
2021-10-01 09:58:50 +03:00
|
|
|
#include <Kernel/Arch/x86/IO.h>
|
2021-07-26 00:10:41 +04:30
|
|
|
#include <Kernel/CommandLine.h>
|
2021-02-14 09:01:52 +01:00
|
|
|
#include <Kernel/KSyms.h>
|
|
|
|
#include <Kernel/Panic.h>
|
2021-09-07 00:17:45 -07:00
|
|
|
#include <Kernel/Thread.h>
|
2021-02-14 09:01:52 +01:00
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
2021-07-26 21:34:43 +03:00
|
|
|
[[noreturn]] static void __shutdown()
|
2021-07-26 00:10:41 +04:30
|
|
|
{
|
2021-07-26 21:34:43 +03:00
|
|
|
// Note: This will invoke QEMU Shutdown, but for other platforms (or emulators),
|
|
|
|
// this has no effect on the system, so we still need to halt afterwards.
|
|
|
|
// We also try the Bochs/Old QEMU shutdown method, if the first didn't work.
|
|
|
|
IO::out16(0x604, 0x2000);
|
|
|
|
IO::out16(0xb004, 0x2000);
|
|
|
|
Processor::halt();
|
2021-07-26 00:10:41 +04:30
|
|
|
}
|
|
|
|
|
2021-02-14 09:01:52 +01:00
|
|
|
void __panic(const char* file, unsigned int line, const char* function)
|
|
|
|
{
|
2021-09-07 00:17:45 -07:00
|
|
|
// Avoid lock ranking checks on crashing paths, just try to get some debugging messages out.
|
|
|
|
auto thread = Thread::current();
|
|
|
|
if (thread)
|
|
|
|
thread->set_crashing();
|
|
|
|
|
2021-04-16 22:58:51 +03:00
|
|
|
critical_dmesgln("at {}:{} in {}", file, line, function);
|
2021-08-04 16:52:14 +01:00
|
|
|
dump_backtrace(PrintToScreen::Yes);
|
2021-07-26 00:10:41 +04:30
|
|
|
if (kernel_command_line().boot_mode() == BootMode::SelfTest)
|
2021-07-26 21:34:43 +03:00
|
|
|
__shutdown();
|
2021-07-26 00:10:41 +04:30
|
|
|
else
|
|
|
|
Processor::halt();
|
2021-02-14 09:01:52 +01:00
|
|
|
}
|
|
|
|
}
|