mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-03 05:26:42 +07:00
2f82af08fc
Due to problems at cam.org, my nico@cam.org email address is no longer valid. FRom now on, nico@fluxnic.net should be used instead. Signed-off-by: Nicolas Pitre <nico@fluxnic.net> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
51 lines
1.0 KiB
C
51 lines
1.0 KiB
C
/*
|
|
* arch/arm/mach-sa1100/include/mach/uncompress.h
|
|
*
|
|
* (C) 1999 Nicolas Pitre <nico@fluxnic.net>
|
|
*
|
|
* 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)))
|
|
|
|
static void putc(int c)
|
|
{
|
|
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);
|
|
|
|
/* wait for space in the UART's transmitter */
|
|
while (!(UART(UTSR1) & UTSR1_TNF))
|
|
barrier();
|
|
|
|
/* send the character out. */
|
|
UART(UTDR) = c;
|
|
}
|
|
|
|
static inline void flush(void)
|
|
{
|
|
}
|
|
|
|
/*
|
|
* Nothing to do for these
|
|
*/
|
|
#define arch_decomp_setup()
|
|
#define arch_decomp_wdog()
|