aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mips/lemote/lm2e
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mips/lemote/lm2e')
-rw-r--r--arch/mips/lemote/lm2e/Makefile5
-rw-r--r--arch/mips/lemote/lm2e/early_printk.c41
2 files changed, 46 insertions, 0 deletions
diff --git a/arch/mips/lemote/lm2e/Makefile b/arch/mips/lemote/lm2e/Makefile
index b0c03390241d..f19173252d6a 100644
--- a/arch/mips/lemote/lm2e/Makefile
+++ b/arch/mips/lemote/lm2e/Makefile
@@ -4,4 +4,9 @@
4 4
5obj-y += setup.o prom.o reset.o irq.o pci.o bonito-irq.o mem.o 5obj-y += setup.o prom.o reset.o irq.o pci.o bonito-irq.o mem.o
6 6
7#
8# Early printk support
9#
10obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
11
7EXTRA_CFLAGS += -Werror 12EXTRA_CFLAGS += -Werror
diff --git a/arch/mips/lemote/lm2e/early_printk.c b/arch/mips/lemote/lm2e/early_printk.c
new file mode 100644
index 000000000000..811c7dec1edd
--- /dev/null
+++ b/arch/mips/lemote/lm2e/early_printk.c
@@ -0,0 +1,41 @@
1/* early printk support
2 *
3 * Copyright (c) 2009 Philippe Vachon <philippe@cowpig.ca>
4 * Copyright (C) 2009 Lemote Inc. & Insititute of Computing Technology
5 * Author: Wu Zhangjin, wuzj@lemote.com
6 *
7 * This program is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by the
9 * Free Software Foundation; either version 2 of the License, or (at your
10 * option) any later version.
11 */
12#include <linux/io.h>
13#include <linux/init.h>
14#include <linux/serial_reg.h>
15
16#include <asm/mips-boards/bonito64.h>
17
18#define UART_BASE (BONITO_PCIIO_BASE + 0x3f8)
19
20#define PORT(base, offset) (u8 *)(base + offset)
21
22static inline unsigned int serial_in(phys_addr_t base, int offset)
23{
24 return readb(PORT(base, offset));
25}
26
27static inline void serial_out(phys_addr_t base, int offset, int value)
28{
29 writeb(value, PORT(base, offset));
30}
31
32void prom_putchar(char c)
33{
34 phys_addr_t uart_base =
35 (phys_addr_t) ioremap_nocache(UART_BASE, 8);
36
37 while ((serial_in(uart_base, UART_LSR) & UART_LSR_THRE) == 0)
38 ;
39
40 serial_out(uart_base, UART_TX, c);
41}