]> git.karo-electronics.de Git - mv-sheeva.git/blob - arch/mips/lemote/lm2e/early_printk.c
811c7dec1edd9de80cac25ed0583d4758beb1663
[mv-sheeva.git] / arch / mips / lemote / lm2e / early_printk.c
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
22 static inline unsigned int serial_in(phys_addr_t base, int offset)
23 {
24         return readb(PORT(base, offset));
25 }
26
27 static inline void serial_out(phys_addr_t base, int offset, int value)
28 {
29         writeb(value, PORT(base, offset));
30 }
31
32 void 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 }