mirror of
https://github.com/Fennix-Project/Kernel.git
synced 2025-05-25 22:14:37 +00:00
97 lines
3.1 KiB
C++
97 lines
3.1 KiB
C++
#include "../crashhandler.hpp"
|
|
#include "chfcts.hpp"
|
|
|
|
#include <display.hpp>
|
|
#include <printf.h>
|
|
#include <debug.h>
|
|
#include <smp.hpp>
|
|
#include <cpu.hpp>
|
|
|
|
#if defined(__amd64__)
|
|
#include "../../Architecture/amd64/cpu/gdt.hpp"
|
|
#elif defined(__i386__)
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
|
|
#include "../../kernel.h"
|
|
|
|
namespace CrashHandler
|
|
{
|
|
struct StackFrame
|
|
{
|
|
struct StackFrame *rbp;
|
|
uint64_t rip;
|
|
};
|
|
|
|
SafeFunction void TraceFrames(CHArchTrapFrame *Frame, int Count)
|
|
{
|
|
|
|
#if defined(__amd64__)
|
|
struct StackFrame *frames = (struct StackFrame *)Frame->rbp; // (struct StackFrame *)__builtin_frame_address(0);
|
|
#elif defined(__i386__)
|
|
struct StackFrame *frames = (struct StackFrame *)Frame->ebp; // (struct StackFrame *)__builtin_frame_address(0);
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
debug("Stack tracing...");
|
|
EHPrint("\e7981FC\nStack Trace:\n");
|
|
if (!frames || !frames->rip || !frames->rbp)
|
|
{
|
|
#if defined(__amd64__)
|
|
EHPrint("\e2565CC%p", (void *)Frame->rip);
|
|
#elif defined(__i386__)
|
|
EHPrint("\e2565CC%p", (void *)Frame->eip);
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
EHPrint("\e7925CC-");
|
|
#if defined(__amd64__)
|
|
EHPrint("\eAA25CC%s", KernelSymbolTable->GetSymbolFromAddress(Frame->rip));
|
|
#elif defined(__i386__)
|
|
EHPrint("\eAA25CC%s", KernelSymbolTable->GetSymbolFromAddress(Frame->eip));
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
EHPrint("\e7981FC <- Exception");
|
|
EHPrint("\eFF0000\n< No stack trace available. >\n");
|
|
}
|
|
else
|
|
{
|
|
#if defined(__amd64__)
|
|
EHPrint("\e2565CC%p", (void *)Frame->rip);
|
|
EHPrint("\e7925CC-");
|
|
if (Frame->rip >= 0xFFFFFFFF80000000 && Frame->rip <= (uint64_t)&_kernel_end)
|
|
EHPrint("\eAA25CC%s", KernelSymbolTable->GetSymbolFromAddress(Frame->rip));
|
|
else
|
|
EHPrint("Outside Kernel");
|
|
#elif defined(__i386__)
|
|
EHPrint("\e2565CC%p", (void *)Frame->eip);
|
|
EHPrint("\e7925CC-");
|
|
if (Frame->eip >= 0xC0000000 && Frame->eip <= (uint64_t)&_kernel_end)
|
|
EHPrint("\eAA25CC%s", KernelSymbolTable->GetSymbolFromAddress(Frame->eip));
|
|
else
|
|
EHPrint("Outside Kernel");
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
EHPrint("\e7981FC <- Exception");
|
|
for (int frame = 0; frame < Count; ++frame)
|
|
{
|
|
if (!frames->rip)
|
|
break;
|
|
EHPrint("\n\e2565CC%p", (void *)frames->rip);
|
|
EHPrint("\e7925CC-");
|
|
#if defined(__amd64__)
|
|
if (frames->rip >= 0xFFFFFFFF80000000 && frames->rip <= (uint64_t)&_kernel_end)
|
|
#elif defined(__i386__)
|
|
if (frames->rip >= 0xC0000000 && frames->rip <= (uint64_t)&_kernel_end)
|
|
#elif defined(__aarch64__)
|
|
#endif
|
|
EHPrint("\e25CCC9%s", KernelSymbolTable->GetSymbolFromAddress(frames->rip));
|
|
else
|
|
EHPrint("\eFF4CA9Outside Kernel");
|
|
|
|
if (!Memory::Virtual().Check(frames->rbp))
|
|
return;
|
|
frames = frames->rbp;
|
|
}
|
|
}
|
|
}
|
|
}
|