|  | /* | 
|  | *  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); |