|
@@ -0,0 +1,57 @@
|
|
|
|
+/*
|
|
|
|
+ * linux/arch/arm/kernel/early_printk.c
|
|
|
|
+ *
|
|
|
|
+ * Copyright (C) 2009 Sascha Hauer <s.hauer@pengutronix.de>
|
|
|
|
+ *
|
|
|
|
+ * This program is free software; you can redistribute it and/or modify
|
|
|
|
+ * it under the terms of the GNU General Public License version 2 as
|
|
|
|
+ * published by the Free Software Foundation.
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+#include <linux/kernel.h>
|
|
|
|
+#include <linux/console.h>
|
|
|
|
+#include <linux/init.h>
|
|
|
|
+
|
|
|
|
+extern void printch(int);
|
|
|
|
+
|
|
|
|
+static void early_write(const char *s, unsigned n)
|
|
|
|
+{
|
|
|
|
+ while (n-- > 0) {
|
|
|
|
+ if (*s == '\n')
|
|
|
|
+ printch('\r');
|
|
|
|
+ printch(*s);
|
|
|
|
+ s++;
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static void early_console_write(struct console *con, const char *s, unsigned n)
|
|
|
|
+{
|
|
|
|
+ early_write(s, n);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static struct console early_console = {
|
|
|
|
+ .name = "earlycon",
|
|
|
|
+ .write = early_console_write,
|
|
|
|
+ .flags = CON_PRINTBUFFER | CON_BOOT,
|
|
|
|
+ .index = -1,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+asmlinkage void early_printk(const char *fmt, ...)
|
|
|
|
+{
|
|
|
|
+ char buf[512];
|
|
|
|
+ int n;
|
|
|
|
+ va_list ap;
|
|
|
|
+
|
|
|
|
+ va_start(ap, fmt);
|
|
|
|
+ n = vscnprintf(buf, sizeof(buf), fmt, ap);
|
|
|
|
+ early_write(buf, n);
|
|
|
|
+ va_end(ap);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static int __init setup_early_printk(char *buf)
|
|
|
|
+{
|
|
|
|
+ register_console(&early_console);
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+early_param("earlyprintk", setup_early_printk);
|