Move more logging infrastructure into kutil

This commit is contained in:
Justin C. Miller
2019-04-06 11:46:53 -07:00
parent 863555ec6b
commit e050d6f151
6 changed files with 28 additions and 30 deletions

View File

@@ -1,20 +1,12 @@
#include "kutil/constexpr_hash.h"
#include "kutil/memory.h"
#include "console.h"
#include "log.h"
#include "scheduler.h"
namespace logs {
static uint8_t log_buffer[0x10000];
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 void
@@ -36,7 +28,7 @@ logger_task()
auto *ent = reinterpret_cast<log::logger::entry *>(buffer);
auto *cons = console::get();
//g_logger.set_immediate(nullptr);
g_logger.set_immediate(nullptr);
log::info(logs::task, "Starting kernel logger task");
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));
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