|  | /* | 
|  | *  8250/16550-type serial ports prom_putchar() | 
|  | * | 
|  | *  Copyright (C) 2010  Yoichi Yuasa <yuasa@linux-mips.org> | 
|  | * | 
|  | *  This program is free software; you can redistribute it and/or modify | 
|  | *  it under the terms of the GNU General Public License as published by | 
|  | *  the Free Software Foundation; either version 2 of the License, or | 
|  | *  (at your option) any later version. | 
|  | * | 
|  | *  This program is distributed in the hope that it will be useful, | 
|  | *  but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | *  GNU General Public License for more details. | 
|  | * | 
|  | *  You should have received a copy of the GNU General Public License | 
|  | *  along with this program; if not, write to the Free Software | 
|  | *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | 
|  | */ | 
|  | #include <linux/io.h> | 
|  | #include <linux/serial_core.h> | 
|  | #include <linux/serial_reg.h> | 
|  |  | 
|  | static void __iomem *serial8250_base; | 
|  | static unsigned int serial8250_reg_shift; | 
|  | static unsigned int serial8250_tx_timeout; | 
|  |  | 
|  | void setup_8250_early_printk_port(unsigned long base, unsigned int reg_shift, | 
|  | unsigned int timeout) | 
|  | { | 
|  | serial8250_base = (void __iomem *)base; | 
|  | serial8250_reg_shift = reg_shift; | 
|  | serial8250_tx_timeout = timeout; | 
|  | } | 
|  |  | 
|  | static inline u8 serial_in(int offset) | 
|  | { | 
|  | return readb(serial8250_base + (offset << serial8250_reg_shift)); | 
|  | } | 
|  |  | 
|  | static inline void serial_out(int offset, char value) | 
|  | { | 
|  | writeb(value, serial8250_base + (offset << serial8250_reg_shift)); | 
|  | } | 
|  |  | 
|  | void prom_putchar(char c) | 
|  | { | 
|  | unsigned int timeout; | 
|  | int status, bits; | 
|  |  | 
|  | if (!serial8250_base) | 
|  | return; | 
|  |  | 
|  | timeout = serial8250_tx_timeout; | 
|  | bits = UART_LSR_TEMT | UART_LSR_THRE; | 
|  |  | 
|  | do { | 
|  | status = serial_in(UART_LSR); | 
|  |  | 
|  | if (--timeout == 0) | 
|  | break; | 
|  | } while ((status & bits) != bits); | 
|  |  | 
|  | if (timeout) | 
|  | serial_out(UART_TX, c); | 
|  | } |