2007-05-01 02:37:19 +08:00
|
|
|
/*
|
|
|
|
* Serial port stubs for kernel decompress status messages
|
|
|
|
*
|
|
|
|
* Author: Anant Gole
|
|
|
|
* (C) Copyright (C) 2006, Texas Instruments, Inc
|
|
|
|
*
|
|
|
|
* This file is licensed under the terms of the GNU General Public License
|
|
|
|
* version 2. This program is licensed "as is" without any warranty of any
|
|
|
|
* kind, whether express or implied.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/serial_reg.h>
|
2008-08-05 23:14:15 +08:00
|
|
|
#include <mach/serial.h>
|
2007-05-01 02:37:19 +08:00
|
|
|
|
2009-02-19 05:00:36 +08:00
|
|
|
#include <asm/mach-types.h>
|
|
|
|
|
|
|
|
extern unsigned int __machine_arch_type;
|
|
|
|
|
|
|
|
static u32 *uart;
|
|
|
|
|
|
|
|
static u32 *get_uart_base(void)
|
|
|
|
{
|
2009-07-16 18:42:18 +08:00
|
|
|
if (__machine_arch_type == MACH_TYPE_DAVINCI_DA830_EVM ||
|
|
|
|
__machine_arch_type == MACH_TYPE_DAVINCI_DA850_EVM)
|
2009-06-04 09:41:53 +08:00
|
|
|
return (u32 *)DA8XX_UART2_BASE;
|
|
|
|
else
|
|
|
|
return (u32 *)DAVINCI_UART0_BASE;
|
2009-02-19 05:00:36 +08:00
|
|
|
}
|
|
|
|
|
2007-05-01 02:37:19 +08:00
|
|
|
/* PORT_16C550A, in polled non-fifo mode */
|
|
|
|
|
|
|
|
static void putc(char c)
|
|
|
|
{
|
2009-02-19 05:00:36 +08:00
|
|
|
if (!uart)
|
|
|
|
uart = get_uart_base();
|
2007-05-01 02:37:19 +08:00
|
|
|
|
|
|
|
while (!(uart[UART_LSR] & UART_LSR_THRE))
|
|
|
|
barrier();
|
|
|
|
uart[UART_TX] = c;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void flush(void)
|
|
|
|
{
|
2009-02-19 05:00:36 +08:00
|
|
|
if (!uart)
|
|
|
|
uart = get_uart_base();
|
|
|
|
|
2007-05-01 02:37:19 +08:00
|
|
|
while (!(uart[UART_LSR] & UART_LSR_THRE))
|
|
|
|
barrier();
|
|
|
|
}
|
|
|
|
|
|
|
|
#define arch_decomp_setup()
|
|
|
|
#define arch_decomp_wdog()
|