2005-04-17 05:20:36 +07:00
|
|
|
/*
|
2008-08-05 22:14:15 +07:00
|
|
|
* arch/arm/mach-sa1100/include/mach/uncompress.h
|
2005-04-17 05:20:36 +07:00
|
|
|
*
|
2009-09-14 14:25:28 +07:00
|
|
|
* (C) 1999 Nicolas Pitre <nico@fluxnic.net>
|
2005-04-17 05:20:36 +07:00
|
|
|
*
|
|
|
|
* Reorganised to be machine independent.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "hardware.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The following code assumes the serial port has already been
|
|
|
|
* initialized by the bootloader. We search for the first enabled
|
|
|
|
* port in the most probable order. If you didn't setup a port in
|
|
|
|
* your bootloader then nothing will appear (which might be desired).
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define UART(x) (*(volatile unsigned long *)(serial_port + (x)))
|
|
|
|
|
2006-03-28 16:24:33 +07:00
|
|
|
static void putc(int c)
|
2005-04-17 05:20:36 +07:00
|
|
|
{
|
|
|
|
unsigned long serial_port;
|
|
|
|
|
|
|
|
do {
|
|
|
|
serial_port = _Ser3UTCR0;
|
|
|
|
if (UART(UTCR3) & UTCR3_TXE) break;
|
|
|
|
serial_port = _Ser1UTCR0;
|
|
|
|
if (UART(UTCR3) & UTCR3_TXE) break;
|
|
|
|
serial_port = _Ser2UTCR0;
|
|
|
|
if (UART(UTCR3) & UTCR3_TXE) break;
|
|
|
|
return;
|
|
|
|
} while (0);
|
|
|
|
|
2006-03-28 16:24:33 +07:00
|
|
|
/* wait for space in the UART's transmitter */
|
|
|
|
while (!(UART(UTSR1) & UTSR1_TNF))
|
|
|
|
barrier();
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2006-03-28 16:24:33 +07:00
|
|
|
/* send the character out. */
|
|
|
|
UART(UTDR) = c;
|
|
|
|
}
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2006-03-28 16:24:33 +07:00
|
|
|
static inline void flush(void)
|
|
|
|
{
|
2005-04-17 05:20:36 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Nothing to do for these
|
|
|
|
*/
|
|
|
|
#define arch_decomp_setup()
|
|
|
|
#define arch_decomp_wdog()
|