mirror of
https://github.com/justinian/jsix.git
synced 2025-12-10 08:24:32 -08:00
Add immediate log output for early kernel
This commit is contained in:
@@ -16,29 +16,22 @@ static log::logger g_logger(log_buffer, sizeof(log_buffer));
|
|||||||
|
|
||||||
static const uint8_t level_colors[] = {0x07, 0x07, 0x0f, 0x0b, 0x09};
|
static const uint8_t level_colors[] = {0x07, 0x07, 0x0f, 0x0b, 0x09};
|
||||||
|
|
||||||
void
|
static void
|
||||||
output_logs()
|
output_log(log::area_t area, log::level severity, const char *message)
|
||||||
{
|
{
|
||||||
uint8_t buffer[257];
|
|
||||||
auto *ent = reinterpret_cast<log::logger::entry *>(buffer);
|
|
||||||
auto *cons = console::get();
|
auto *cons = console::get();
|
||||||
|
cons->set_color(level_colors[static_cast<int>(severity)]);
|
||||||
while (true) {
|
cons->printf("%9s %8s: %s\n",
|
||||||
if(g_logger.get_entry(buffer, sizeof(buffer))) {
|
g_logger.area_name(area),
|
||||||
buffer[ent->bytes] = 0;
|
g_logger.level_name(severity),
|
||||||
cons->set_color(level_colors[static_cast<int>(ent->severity)]);
|
message);
|
||||||
cons->printf("%9s %8s: %s\n",
|
cons->set_color();
|
||||||
g_logger.area_name(ent->area),
|
|
||||||
g_logger.level_name(ent->severity),
|
|
||||||
ent->message);
|
|
||||||
cons->set_color();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void init()
|
void 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);
|
||||||
|
|
||||||
#define LOG(name, lvl) \
|
#define LOG(name, lvl) \
|
||||||
g_logger.register_area(name, name ## _name, log::level ::lvl);
|
g_logger.register_area(name, name ## _name, log::level ::lvl);
|
||||||
|
|||||||
@@ -11,7 +11,6 @@ namespace logs {
|
|||||||
#undef LOG
|
#undef LOG
|
||||||
|
|
||||||
void init();
|
void init();
|
||||||
void output_logs();
|
|
||||||
|
|
||||||
} // namespace logs
|
} // namespace logs
|
||||||
|
|
||||||
|
|||||||
@@ -138,5 +138,4 @@ kernel_main(kernel_args *header)
|
|||||||
}
|
}
|
||||||
|
|
||||||
sched->start();
|
sched->start();
|
||||||
logs::output_logs();
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,6 +30,12 @@ public:
|
|||||||
/// \arg verbosity What level of logs to print for this area
|
/// \arg verbosity What level of logs to print for this area
|
||||||
void register_area(area_t area, const char *name, level verbosity);
|
void register_area(area_t area, const char *name, level verbosity);
|
||||||
|
|
||||||
|
/// Callback type for immediate-mode logging
|
||||||
|
typedef void (*immediate)(area_t, level, const char *);
|
||||||
|
|
||||||
|
/// Register an immediate-mode log callback
|
||||||
|
inline void set_immediate(immediate cb) { m_immediate = cb; }
|
||||||
|
|
||||||
/// Get the default logger.
|
/// Get the default logger.
|
||||||
inline logger & get() { return *s_log; }
|
inline logger & get() { return *s_log; }
|
||||||
|
|
||||||
@@ -85,6 +91,7 @@ private:
|
|||||||
static const unsigned num_areas = 1 << (sizeof(area_t) * 8);
|
static const unsigned num_areas = 1 << (sizeof(area_t) * 8);
|
||||||
uint8_t m_levels[num_areas / 2];
|
uint8_t m_levels[num_areas / 2];
|
||||||
const char *m_names[num_areas];
|
const char *m_names[num_areas];
|
||||||
|
immediate m_immediate;
|
||||||
|
|
||||||
uint8_t m_sequence;
|
uint8_t m_sequence;
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ const char *logger::s_level_names[] = {"", "debug", " info", " warn", "error", "
|
|||||||
|
|
||||||
logger::logger() :
|
logger::logger() :
|
||||||
m_buffer(nullptr, 0),
|
m_buffer(nullptr, 0),
|
||||||
|
m_immediate(nullptr),
|
||||||
m_sequence(0)
|
m_sequence(0)
|
||||||
{
|
{
|
||||||
memset(&m_levels, 0, sizeof(m_levels));
|
memset(&m_levels, 0, sizeof(m_levels));
|
||||||
@@ -23,6 +24,7 @@ logger::logger() :
|
|||||||
|
|
||||||
logger::logger(uint8_t *buffer, size_t size) :
|
logger::logger(uint8_t *buffer, size_t size) :
|
||||||
m_buffer(buffer, size),
|
m_buffer(buffer, size),
|
||||||
|
m_immediate(nullptr),
|
||||||
m_sequence(0)
|
m_sequence(0)
|
||||||
{
|
{
|
||||||
memset(&m_levels, 0, sizeof(m_levels));
|
memset(&m_levels, 0, sizeof(m_levels));
|
||||||
@@ -73,6 +75,12 @@ logger::output(level severity, area_t area, const char *fmt, va_list args)
|
|||||||
header->bytes +=
|
header->bytes +=
|
||||||
vsnprintf(header->message, sizeof(buffer) - sizeof(entry), fmt, args);
|
vsnprintf(header->message, sizeof(buffer) - sizeof(entry), fmt, args);
|
||||||
|
|
||||||
|
if (m_immediate) {
|
||||||
|
buffer[header->bytes] = 0;
|
||||||
|
m_immediate(area, severity, header->message);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
uint8_t *out;
|
uint8_t *out;
|
||||||
size_t n = m_buffer.reserve(header->bytes, reinterpret_cast<void**>(&out));
|
size_t n = m_buffer.reserve(header->bytes, reinterpret_cast<void**>(&out));
|
||||||
if (n < sizeof(entry)) {
|
if (n < sizeof(entry)) {
|
||||||
|
|||||||
Reference in New Issue
Block a user