mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 11:02:33 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/Format.h>
 | |
| #include <Kernel/Arch/Processor.h>
 | |
| #if ARCH(X86_64)
 | |
| #    include <Kernel/Arch/x86_64/Shutdown.h>
 | |
| #endif
 | |
| #include <Kernel/CommandLine.h>
 | |
| #include <Kernel/KSyms.h>
 | |
| #include <Kernel/Panic.h>
 | |
| #include <Kernel/Thread.h>
 | |
| 
 | |
| namespace Kernel {
 | |
| 
 | |
| [[noreturn]] static void __shutdown()
 | |
| {
 | |
| #if ARCH(X86_64)
 | |
|     qemu_shutdown();
 | |
|     virtualbox_shutdown();
 | |
| #endif
 | |
|     // Note: If we failed to invoke platform shutdown, we need to halt afterwards
 | |
|     // to ensure no further execution on any CPU still happens.
 | |
|     Processor::halt();
 | |
| }
 | |
| 
 | |
| void __panic(char const* file, unsigned int line, char const* function)
 | |
| {
 | |
|     // Avoid lock ranking checks on crashing paths, just try to get some debugging messages out.
 | |
|     auto* thread = Thread::current();
 | |
|     if (thread)
 | |
|         thread->set_crashing();
 | |
| 
 | |
|     critical_dmesgln("at {}:{} in {}", file, line, function);
 | |
|     dump_backtrace(PrintToScreen::Yes);
 | |
|     if (!CommandLine::was_initialized())
 | |
|         Processor::halt();
 | |
|     switch (kernel_command_line().panic_mode()) {
 | |
|     case PanicMode::Shutdown:
 | |
|         __shutdown();
 | |
|     case PanicMode::Halt:
 | |
|         [[fallthrough]];
 | |
|     default:
 | |
|         Processor::halt();
 | |
|     }
 | |
| }
 | |
| }
 | 
