mirror of
https://github.com/justinian/jsix.git
synced 2025-12-10 08:24:32 -08:00
Move more logging infrastructure into kutil
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
LOG(apic, info);
|
LOG(apic, info);
|
||||||
LOG(device, info);
|
LOG(device, info);
|
||||||
LOG(paging, debug);
|
LOG(paging, info);
|
||||||
LOG(driver, info);
|
LOG(driver, info);
|
||||||
LOG(memory, debug);
|
LOG(memory, debug);
|
||||||
LOG(fs, info);
|
LOG(fs, info);
|
||||||
@@ -1,20 +1,12 @@
|
|||||||
#include "kutil/constexpr_hash.h"
|
|
||||||
#include "kutil/memory.h"
|
#include "kutil/memory.h"
|
||||||
#include "console.h"
|
#include "console.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "scheduler.h"
|
#include "scheduler.h"
|
||||||
|
|
||||||
namespace logs {
|
|
||||||
|
|
||||||
static uint8_t log_buffer[0x10000];
|
static uint8_t log_buffer[0x10000];
|
||||||
static log::logger g_logger(log_buffer, sizeof(log_buffer));
|
static log::logger g_logger(log_buffer, sizeof(log_buffer));
|
||||||
|
|
||||||
#define LOG(name, lvl) \
|
|
||||||
log::area_t name = #name ## _h; \
|
|
||||||
const char * name ## _name = #name;
|
|
||||||
#include "log_areas.inc"
|
|
||||||
#undef LOG
|
|
||||||
|
|
||||||
static const uint8_t level_colors[] = {0x07, 0x07, 0x0f, 0x0b, 0x09};
|
static const uint8_t level_colors[] = {0x07, 0x07, 0x0f, 0x0b, 0x09};
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -36,7 +28,7 @@ logger_task()
|
|||||||
auto *ent = reinterpret_cast<log::logger::entry *>(buffer);
|
auto *ent = reinterpret_cast<log::logger::entry *>(buffer);
|
||||||
auto *cons = console::get();
|
auto *cons = console::get();
|
||||||
|
|
||||||
//g_logger.set_immediate(nullptr);
|
g_logger.set_immediate(nullptr);
|
||||||
log::info(logs::task, "Starting kernel logger task");
|
log::info(logs::task, "Starting kernel logger task");
|
||||||
|
|
||||||
scheduler &s = scheduler::get();
|
scheduler &s = scheduler::get();
|
||||||
@@ -56,15 +48,8 @@ logger_task()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void init()
|
void logger_init()
|
||||||
{
|
{
|
||||||
new (&g_logger) log::logger(log_buffer, sizeof(log_buffer));
|
new (&g_logger) log::logger(log_buffer, sizeof(log_buffer));
|
||||||
g_logger.set_immediate(output_log);
|
g_logger.set_immediate(output_log);
|
||||||
|
|
||||||
#define LOG(name, lvl) \
|
|
||||||
g_logger.register_area(name, name ## _name, log::level ::lvl);
|
|
||||||
#include "log_areas.inc"
|
|
||||||
#undef LOG
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace logs
|
|
||||||
|
|||||||
@@ -3,15 +3,7 @@
|
|||||||
#include "kutil/logger.h"
|
#include "kutil/logger.h"
|
||||||
|
|
||||||
namespace log = kutil::log;
|
namespace log = kutil::log;
|
||||||
|
namespace logs = kutil::logs;
|
||||||
|
|
||||||
namespace logs {
|
void logger_init();
|
||||||
|
|
||||||
#define LOG(name, lvl) extern log::area_t name;
|
|
||||||
#include "log_areas.inc"
|
|
||||||
#undef LOG
|
|
||||||
|
|
||||||
void init();
|
|
||||||
void logger_task();
|
void logger_task();
|
||||||
|
|
||||||
} // namespace logs
|
|
||||||
|
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ init_console()
|
|||||||
cons->set_color(0x08, 0x00);
|
cons->set_color(0x08, 0x00);
|
||||||
cons->puts(GIT_VERSION " booting...\n");
|
cons->puts(GIT_VERSION " booting...\n");
|
||||||
|
|
||||||
logs::init();
|
logger_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -132,7 +132,7 @@ kernel_main(kernel_args *header)
|
|||||||
syscall_enable();
|
syscall_enable();
|
||||||
scheduler *sched = new (&scheduler::get()) scheduler(devices->get_lapic());
|
scheduler *sched = new (&scheduler::get()) scheduler(devices->get_lapic());
|
||||||
|
|
||||||
sched->create_kernel_task(-1, logs::logger_task);
|
sched->create_kernel_task(-1, logger_task);
|
||||||
|
|
||||||
for (auto &f : ird.files()) {
|
for (auto &f : ird.files()) {
|
||||||
if (f.executable())
|
if (f.executable())
|
||||||
|
|||||||
@@ -108,4 +108,11 @@ void error(area_t area, const char *fmt, ...);
|
|||||||
void fatal(area_t area, const char *fmt, ...);
|
void fatal(area_t area, const char *fmt, ...);
|
||||||
|
|
||||||
} // namespace log
|
} // namespace log
|
||||||
|
|
||||||
|
namespace logs {
|
||||||
|
#define LOG(name, lvl) extern log::area_t name;
|
||||||
|
#include "log_areas.inc"
|
||||||
|
#undef LOG
|
||||||
|
} // namespace logs
|
||||||
|
|
||||||
} // namespace kutil
|
} // namespace kutil
|
||||||
|
|||||||
@@ -1,9 +1,18 @@
|
|||||||
#include "kutil/assert.h"
|
#include "kutil/assert.h"
|
||||||
|
#include "kutil/constexpr_hash.h"
|
||||||
#include "kutil/logger.h"
|
#include "kutil/logger.h"
|
||||||
#include "kutil/memory.h"
|
#include "kutil/memory.h"
|
||||||
#include "kutil/printf.h"
|
#include "kutil/printf.h"
|
||||||
|
|
||||||
namespace kutil {
|
namespace kutil {
|
||||||
|
namespace logs {
|
||||||
|
#define LOG(name, lvl) \
|
||||||
|
log::area_t name = #name ## _h; \
|
||||||
|
const char * name ## _name = #name;
|
||||||
|
#include "log_areas.inc"
|
||||||
|
#undef LOG
|
||||||
|
}
|
||||||
|
|
||||||
namespace log {
|
namespace log {
|
||||||
|
|
||||||
using kutil::memset;
|
using kutil::memset;
|
||||||
@@ -30,6 +39,11 @@ logger::logger(uint8_t *buffer, size_t size) :
|
|||||||
memset(&m_levels, 0, sizeof(m_levels));
|
memset(&m_levels, 0, sizeof(m_levels));
|
||||||
memset(&m_names, 0, sizeof(m_names));
|
memset(&m_names, 0, sizeof(m_names));
|
||||||
s_log = this;
|
s_log = this;
|
||||||
|
|
||||||
|
#define LOG(name, lvl) \
|
||||||
|
register_area(logs::name, logs::name ## _name, log::level::lvl);
|
||||||
|
#include "log_areas.inc"
|
||||||
|
#undef LOG
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
Reference in New Issue
Block a user