mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 13:57:34 +00:00
Kernel: Colorize debugger output from the kernel.
This makes it easy to distinguish kernel/userspace dbgprintf()'s. :^)
This commit is contained in:
parent
db2980c848
commit
639478391b
1 changed files with 21 additions and 0 deletions
|
@ -6,6 +6,22 @@
|
||||||
#include <Kernel/kstdio.h>
|
#include <Kernel/kstdio.h>
|
||||||
#include <LibC/stdarg.h>
|
#include <LibC/stdarg.h>
|
||||||
|
|
||||||
|
static void color_on()
|
||||||
|
{
|
||||||
|
IO::out8(0xe9, 0x1b);
|
||||||
|
IO::out8(0xe9, '[');
|
||||||
|
IO::out8(0xe9, '3');
|
||||||
|
IO::out8(0xe9, '6');
|
||||||
|
IO::out8(0xe9, 'm');
|
||||||
|
}
|
||||||
|
|
||||||
|
static void color_off()
|
||||||
|
{
|
||||||
|
IO::out8(0xe9, 0x1b);
|
||||||
|
IO::out8(0xe9, '[');
|
||||||
|
IO::out8(0xe9, '0');
|
||||||
|
IO::out8(0xe9, 'm');
|
||||||
|
}
|
||||||
static void console_putch(char*&, char ch)
|
static void console_putch(char*&, char ch)
|
||||||
{
|
{
|
||||||
if (!current) {
|
if (!current) {
|
||||||
|
@ -17,10 +33,12 @@ static void console_putch(char*&, char ch)
|
||||||
|
|
||||||
int kprintf(const char* fmt, ...)
|
int kprintf(const char* fmt, ...)
|
||||||
{
|
{
|
||||||
|
color_on();
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
int ret = printf_internal(console_putch, nullptr, fmt, ap);
|
int ret = printf_internal(console_putch, nullptr, fmt, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
|
color_off();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,11 +62,14 @@ static void debugger_putch(char*&, char ch)
|
||||||
IO::out8(0xe9, ch);
|
IO::out8(0xe9, ch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
extern "C" int dbgprintf(const char* fmt, ...)
|
extern "C" int dbgprintf(const char* fmt, ...)
|
||||||
{
|
{
|
||||||
|
color_on();
|
||||||
va_list ap;
|
va_list ap;
|
||||||
va_start(ap, fmt);
|
va_start(ap, fmt);
|
||||||
int ret = printf_internal(debugger_putch, nullptr, fmt, ap);
|
int ret = printf_internal(debugger_putch, nullptr, fmt, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
|
color_off();
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue