From 600dd0bb30d9d8d5c7645156c1c50ad68ec1b334 Mon Sep 17 00:00:00 2001 From: dzwdz Date: Tue, 3 May 2022 19:02:56 +0200 Subject: kernel: stacktraces on panic() --- src/kernel/arch/i386/debug.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 src/kernel/arch/i386/debug.c (limited to 'src/kernel/arch/i386') diff --git a/src/kernel/arch/i386/debug.c b/src/kernel/arch/i386/debug.c new file mode 100644 index 0000000..b1920db --- /dev/null +++ b/src/kernel/arch/i386/debug.c @@ -0,0 +1,18 @@ +#include + +void *debug_caller(size_t depth) { + void **ebp; + asm("mov %%ebp, %0" + : "=r" (ebp)); + while (depth--) { + if (!ebp) return NULL; + ebp = *ebp; + } + return ebp[1]; +} + +void debug_stacktrace(void) { + for (size_t i = 0; i < 16; i++) { + kprintf(" k/%08x\n", (uintptr_t)debug_caller(i)); + } +} -- cgit v1.2.3