2011-12-15 03:47:30 +04:00
|
|
|
/* vim: tabstop=4 shiftwidth=4 noexpandtab
|
|
|
|
*
|
|
|
|
* Kernel Logging Facility
|
|
|
|
*
|
|
|
|
* Maintains a log in-memory as well as to serial (unless
|
|
|
|
* told not to).
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <system.h>
|
|
|
|
#include <list.h>
|
|
|
|
#include <logging.h>
|
2011-12-15 05:19:51 +04:00
|
|
|
#include <va_list.h>
|
2011-12-15 03:47:30 +04:00
|
|
|
|
|
|
|
static list_t * log_buffer;
|
|
|
|
|
|
|
|
static char * messages[] = {
|
|
|
|
"info",
|
|
|
|
"note",
|
|
|
|
"warn",
|
|
|
|
"err ",
|
|
|
|
"crit"
|
|
|
|
};
|
|
|
|
|
|
|
|
void logging_install() {
|
|
|
|
log_buffer = list_create();
|
2011-12-15 05:06:11 +04:00
|
|
|
LOG(INFO, "Kernel log initialized");
|
2011-12-15 03:47:30 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
void debug_print_log_entry(log_entry_t * l) {
|
2011-12-15 05:43:14 +04:00
|
|
|
int i;
|
|
|
|
i = kprintf("[%s] %s ",
|
2011-12-15 03:47:30 +04:00
|
|
|
messages[l->type],
|
2011-12-15 05:43:14 +04:00
|
|
|
l->module);
|
|
|
|
while (i < 40) {
|
|
|
|
kprintf(" ");
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
i = kprintf("line %d", l->line);
|
|
|
|
while (i < 10) {
|
|
|
|
kprintf(" ");
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
kprintf("%s\n", l->text);
|
2011-12-15 03:47:30 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
void debug_print_log() {
|
|
|
|
foreach(entry, log_buffer) {
|
|
|
|
debug_print_log_entry((log_entry_t *)entry->value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void klog(log_type_t type, char *module, unsigned int line, const char *fmt, ...) {
|
|
|
|
if (!log_buffer) return;
|
|
|
|
log_entry_t * l = malloc(sizeof(log_entry_t));
|
|
|
|
l->type = type;
|
|
|
|
l->module = module;
|
|
|
|
l->line = line;
|
|
|
|
l->text = malloc(sizeof(char) * 1024);
|
2011-12-15 05:19:51 +04:00
|
|
|
va_list args;
|
|
|
|
va_start(args, fmt);
|
|
|
|
vasprintf(l->text, fmt, args);
|
|
|
|
va_end(args);
|
2011-12-15 03:47:30 +04:00
|
|
|
list_insert(log_buffer, l);
|
|
|
|
}
|