X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/4f966b9a6710d138d6e921bf2a1e40f2abc76f9a..270869139db617e29a35bb9ded41087bb702f9ac:/lunaix-os/includes/lunaix/syslog.h?ds=sidebyside diff --git a/lunaix-os/includes/lunaix/syslog.h b/lunaix-os/includes/lunaix/syslog.h index 464a133..3b827f6 100644 --- a/lunaix-os/includes/lunaix/syslog.h +++ b/lunaix-os/includes/lunaix/syslog.h @@ -1,37 +1,49 @@ #ifndef __LUNAIX_SYSLOG_H #define __LUNAIX_SYSLOG_H +#include +#include #include -#define _LEVEL_INFO "0" -#define _LEVEL_WARN "1" -#define _LEVEL_ERROR "2" -#define _LEVEL_DEBUG "3" +#define KLOG_DEBUG 0 +#define KLOG_INFO 1 +#define KLOG_WARN 2 +#define KLOG_ERROR 3 +#define KLOG_FATAL 4 -#define KINFO "\x1b" _LEVEL_INFO -#define KWARN "\x1b" _LEVEL_WARN -#define KERROR "\x1b" _LEVEL_ERROR -#define KDEBUG "\x1b" _LEVEL_DEBUG +#define KMSG_LVLSTART '\x1b' +#define KMSG_LOGLEVEL(c) ((c) - '0') + +#define KDEBUG "\x1b" stringify__(KLOG_DEBUG) +#define KINFO "\x1b" stringify__(KLOG_INFO) +#define KWARN "\x1b" stringify__(KLOG_WARN) +#define KERROR "\x1b" stringify__(KLOG_ERROR) +#define KFATAL "\x1b" stringify__(KLOG_FATAL) #define LOG_MODULE(module) \ static void kprintf(const char* fmt, ...) \ { \ va_list args; \ va_start(args, fmt); \ - __kprintf(module, fmt, args); \ + kprintf_m(module, fmt, args); \ va_end(args); \ } -void -__kprintf(const char* component, const char* fmt, va_list args); +#define printk(fmt, ...) kprintf_v(__FILE__, fmt, ##__VA_ARGS__) -void -kprint_hex(const void* buffer, unsigned int size); +#define DEBUG(fmt, ...) kprintf(KDEBUG fmt, ##__VA_ARGS__) +#define INFO(fmt, ...) kprintf(KINFO fmt, ##__VA_ARGS__) +#define WARN(fmt, ...) kprintf(KWARN fmt, ##__VA_ARGS__) +#define ERROR(fmt, ...) kprintf(KERROR fmt, ##__VA_ARGS__) +#define FATAL(fmt, ...) \ + ({ \ + kprintf(KFATAL fmt, ##__VA_ARGS__); \ + fail(fmt); \ + }) void -kprint_panic(const char* fmt, ...); +kprintf_m(const char* component, const char* fmt, va_list args); void -kprint_dbg(const char* fmt, ...); - +kprintf_v(const char* component, const char* fmt, ...); #endif /* __LUNAIX_SYSLOG_H */