mirror of
https://github.com/EnderIce2/Fennix.git
synced 2025-05-25 22:14:34 +00:00
139 lines
4.0 KiB
C++
139 lines
4.0 KiB
C++
#include <debug.h>
|
|
|
|
#include <uart.hpp>
|
|
#include <printf.h>
|
|
#include <lock.hpp>
|
|
|
|
NewLock(DebuggerLock);
|
|
|
|
using namespace UniversalAsynchronousReceiverTransmitter;
|
|
|
|
static inline NIF void uart_wrapper(char c, void *unused)
|
|
{
|
|
UART(COM1).Write(c);
|
|
UNUSED(unused);
|
|
}
|
|
|
|
static inline NIF void WritePrefix(DebugLevel Level, const char *File, int Line, const char *Function)
|
|
{
|
|
const char *DbgLvlString;
|
|
switch (Level)
|
|
{
|
|
case DebugLevelError:
|
|
DbgLvlString = "ERROR";
|
|
break;
|
|
case DebugLevelWarning:
|
|
DbgLvlString = "WARN ";
|
|
break;
|
|
case DebugLevelInfo:
|
|
DbgLvlString = "INFO ";
|
|
break;
|
|
case DebugLevelDebug:
|
|
DbgLvlString = "DEBUG";
|
|
break;
|
|
case DebugLevelTrace:
|
|
DbgLvlString = "TRACE";
|
|
break;
|
|
case DebugLevelFixme:
|
|
DbgLvlString = "FIXME";
|
|
break;
|
|
case DebugLevelUbsan:
|
|
{
|
|
DbgLvlString = "UBSAN";
|
|
fctprintf(uart_wrapper, nullptr, "%s|%s: ", DbgLvlString, Function);
|
|
return;
|
|
}
|
|
default:
|
|
DbgLvlString = "UNKNW";
|
|
break;
|
|
}
|
|
fctprintf(uart_wrapper, nullptr, "%s|%s->%s:%d: ", DbgLvlString, File, Function, Line);
|
|
}
|
|
|
|
namespace SysDbg
|
|
{
|
|
NIF void Write(DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
}
|
|
|
|
NIF void WriteLine(DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
uart_wrapper('\n', nullptr);
|
|
}
|
|
|
|
NIF void LockedWrite(DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
SmartTimeoutLock(DebuggerLock, 1000);
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
}
|
|
|
|
NIF void LockedWriteLine(DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
SmartTimeoutLock(DebuggerLock, 1000);
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
uart_wrapper('\n', nullptr);
|
|
}
|
|
}
|
|
|
|
// C compatibility
|
|
extern "C" NIF void SysDbgWrite(enum DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
}
|
|
|
|
// C compatibility
|
|
extern "C" NIF void SysDbgWriteLine(enum DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
uart_wrapper('\n', nullptr);
|
|
}
|
|
|
|
// C compatibility
|
|
extern "C" NIF void SysDbgLockedWrite(enum DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
SmartTimeoutLock(DebuggerLock, 1000);
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
}
|
|
|
|
// C compatibility
|
|
extern "C" NIF void SysDbgLockedWriteLine(enum DebugLevel Level, const char *File, int Line, const char *Function, const char *Format, ...)
|
|
{
|
|
SmartTimeoutLock(DebuggerLock, 1000);
|
|
WritePrefix(Level, File, Line, Function);
|
|
va_list args;
|
|
va_start(args, Format);
|
|
vfctprintf(uart_wrapper, nullptr, Format, args);
|
|
va_end(args);
|
|
uart_wrapper('\n', nullptr);
|
|
}
|