/******************************************************************************* Copyright(C) Jonas 'Sortie' Termansen 2011, 2013. This file is part of Sortix. Sortix is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Sortix is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Sortix. If not, see . panic.cpp Displays an error whenever something critical happens. *******************************************************************************/ #include #include #include #include #include #include namespace Sortix { #if defined(PANIC_SHORT) const bool longpanic = false; #else const bool longpanic = true; #endif static bool panicing = false; static bool doublepanic = false; static void PanicLogoLong() { Log::Print("\e[m\e[31;40m\e[2J\e[H"); Log::Print(" _ \n"); Log::Print(" / \\ \n"); Log::Print(" /\\ /\\ / \\ \n"); Log::Print(" / \\ / \\ | | \n"); Log::Print(" / \\/ \\ | | \n"); Log::Print(" | X X \\_______________________ / | \n"); Log::Print(" | | \n"); Log::Print(" | _________ / \n"); Log::Print(" \\ / \n"); Log::Print(" ------ --------------- ---/ \n"); Log::Print(" / \\ / \\ \n"); Log::Print(" / \\ / \\ \n"); Log::Print(" / \\ / \\ \n"); Log::Print(" /_____________\\ /____________\\ \n"); Log::Print(" \n"); Log::Print(" \n"); Log::Print(" RED MAXSI OF DEATH \n"); Log::Print(" \n"); Log::Print("A critical error occured within the kernel of the operating system and it has\n"); Log::Print("forcefully shut down as a last resort.\n"); Log::Print("\n"); Log::Print("Technical information:\n"); } static void PanicLogoShort() { Log::Print("\e[m\e[31m\e[0J"); Log::Print("RED MAXSI OF DEATH\n"); } void PanicInit() { Interrupt::Disable(); // Handle the case where the panic code caused another system crash. if ( panicing ) { Log::PrintF("Panic while panicing:\n"); doublepanic = true; return; } panicing = true; // Render a notice that the system has crashed and forcefully shut down. longpanic ? PanicLogoLong() : PanicLogoShort(); } static void PanicCalltrace() { Log::Print("\n"); Calltrace::Perform(); } static void PanicHooks() { if ( doublepanic ) return; if ( ENABLE_CALLTRACE ) PanicCalltrace(); } extern "C" __attribute__((noreturn)) void Panic(const char* error) { PanicInit(); Log::Print(error); PanicHooks(); HaltKernel(); } extern "C" __attribute__((noreturn)) void PanicF(const char* format, ...) { PanicInit(); va_list list; va_start(list, format); Log::PrintFV(format, list); va_end(list); PanicHooks(); HaltKernel(); } } // namespace Sortix