diff options
author | Andreas Kling <kling@serenityos.org> | 2021-02-14 09:01:52 +0100 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2021-02-14 09:36:58 +0100 |
commit | c598a95b1c3b66cf1029eac2bcd88288c1fdb05f (patch) | |
tree | 5f7439e065146786075ce863b089be60083889a4 /Kernel | |
parent | ca35776e782a87981676906d99ff25d110077a3f (diff) | |
download | serenity-c598a95b1c3b66cf1029eac2bcd88288c1fdb05f.zip |
Kernel: Add a PANIC() function
Let's be a little more expressive when inducing a kernel panic. :^)
PANIC(...) passes any arguments you give it to dmesgln(), then prints
a backtrace and hangs the machine.
Diffstat (limited to 'Kernel')
-rw-r--r-- | Kernel/CMakeLists.txt | 1 | ||||
-rw-r--r-- | Kernel/Panic.cpp | 41 | ||||
-rw-r--r-- | Kernel/Panic.h | 40 |
3 files changed, 82 insertions, 0 deletions
diff --git a/Kernel/CMakeLists.txt b/Kernel/CMakeLists.txt index 26458c32a6..5059dde24b 100644 --- a/Kernel/CMakeLists.txt +++ b/Kernel/CMakeLists.txt @@ -101,6 +101,7 @@ set(KERNEL_SOURCES PCI/IOAccess.cpp PCI/Initializer.cpp PCI/MMIOAccess.cpp + Panic.cpp PerformanceEventBuffer.cpp Process.cpp ProcessGroup.cpp diff --git a/Kernel/Panic.cpp b/Kernel/Panic.cpp new file mode 100644 index 0000000000..eccb7412f1 --- /dev/null +++ b/Kernel/Panic.cpp @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2021, Andreas Kling <kling@serenityos.org> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include <AK/Format.h> +#include <Kernel/Arch/i386/CPU.h> +#include <Kernel/KSyms.h> +#include <Kernel/Panic.h> + +namespace Kernel { + +void __panic(const char* file, unsigned int line, const char* function) +{ + dmesgln("at {}:{} in {}", file, line, function); + dump_backtrace(); + Processor::halt(); +} + +} diff --git a/Kernel/Panic.h b/Kernel/Panic.h new file mode 100644 index 0000000000..b2b325bc05 --- /dev/null +++ b/Kernel/Panic.h @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2021, Andreas Kling <kling@serenityos.org> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER + * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#pragma once + +namespace Kernel { + +[[noreturn]] void __panic(const char* file, unsigned int line, const char* function); + +#define PANIC(...) \ + do { \ + dmesgln("KERNEL PANIC! :^("); \ + dmesgln(__VA_ARGS__); \ + __panic(__FILE__, __LINE__, __PRETTY_FUNCTION__); \ + } while (0) + +} |