Add support for the tracing infastructure in coreboot.
[coreboot.git] / src / console / printk.c
index 636424c12a764c9925ad7807e0e35521c33c39c1..75490881f6cf7221aa515636a7d6bcf4287c9e7f 100644 (file)
@@ -4,39 +4,27 @@
  *  Copyright (C) 1991, 1992  Linus Torvalds
  *
  */
-//typedef void * va_list;
 
-#include <stdarg.h>
 #include <smp/spinlock.h>
+#include <console/vtxprintf.h>
 #include <console/console.h>
+#include <trace.h>
 
-/* printk's without a loglevel use this.. */
-#define DEFAULT_MESSAGE_LOGLEVEL 4 /* BIOS_WARNING */
+int console_loglevel = CONFIG_DEFAULT_CONSOLE_LOGLEVEL;
+int default_console_loglevel = CONFIG_DEFAULT_CONSOLE_LOGLEVEL;
 
-/* We show everything that is MORE important than this.. */
-#define MINIMUM_CONSOLE_LOGLEVEL 1 /* Minimum loglevel we let people use */
-
-/* Keep together for sysctl support */
-
-int console_loglevel = DEFAULT_CONSOLE_LOGLEVEL;
-int default_message_loglevel = DEFAULT_MESSAGE_LOGLEVEL;
-int minimum_console_loglevel = MINIMUM_CONSOLE_LOGLEVEL;
-int default_console_loglevel = DEFAULT_CONSOLE_LOGLEVEL;
-
-void display(char*);
-extern int vtxprintf(void (*)(unsigned char), const char *, va_list);
-
-spinlock_t console_lock = SPIN_LOCK_UNLOCKED;
+DECLARE_SPIN_LOCK(console_lock)
 
 int do_printk(int msg_level, const char *fmt, ...)
 {
        va_list args;
        int i;
 
-       if (msg_level >= console_loglevel) {
+       if (msg_level > console_loglevel) {
                return 0;
        }
 
+       DISABLE_TRACE;
        spin_lock(&console_lock);
 
        va_start(args, fmt);
@@ -46,6 +34,7 @@ int do_printk(int msg_level, const char *fmt, ...)
        console_tx_flush();
 
        spin_unlock(&console_lock);
+       ENABLE_TRACE;
 
        return i;
 }