Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license version 2 as published by the free software foundation 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 59 temple place suite 330 boston ma 02111 1307 usa extracted by the scancode license scanner the SPDX license identifier GPL-2.0-only has been chosen to replace the boilerplate/reference in 136 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Alexios Zavras <alexios.zavras@intel.com> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190530000436.384967451@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
64 lines
1.3 KiB
C
64 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* arch/arm/mach-netx/include/mach/uncompress.h
|
|
*
|
|
* Copyright (C) 2005 Sascha Hauer <s.hauer@pengutronix.de>, Pengutronix
|
|
*/
|
|
|
|
/*
|
|
* 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).
|
|
*
|
|
* This does not append a newline
|
|
*/
|
|
|
|
#define REG(x) (*(volatile unsigned long *)(x))
|
|
|
|
#define UART1_BASE 0x100a00
|
|
#define UART2_BASE 0x100a80
|
|
|
|
#define UART_DR 0x0
|
|
|
|
#define UART_CR 0x14
|
|
#define CR_UART_EN (1<<0)
|
|
|
|
#define UART_FR 0x18
|
|
#define FR_BUSY (1<<3)
|
|
#define FR_TXFF (1<<5)
|
|
|
|
static inline void putc(char c)
|
|
{
|
|
unsigned long base;
|
|
|
|
if (REG(UART1_BASE + UART_CR) & CR_UART_EN)
|
|
base = UART1_BASE;
|
|
else if (REG(UART2_BASE + UART_CR) & CR_UART_EN)
|
|
base = UART2_BASE;
|
|
else
|
|
return;
|
|
|
|
while (REG(base + UART_FR) & FR_TXFF);
|
|
REG(base + UART_DR) = c;
|
|
}
|
|
|
|
static inline void flush(void)
|
|
{
|
|
unsigned long base;
|
|
|
|
if (REG(UART1_BASE + UART_CR) & CR_UART_EN)
|
|
base = UART1_BASE;
|
|
else if (REG(UART2_BASE + UART_CR) & CR_UART_EN)
|
|
base = UART2_BASE;
|
|
else
|
|
return;
|
|
|
|
while (REG(base + UART_FR) & FR_BUSY);
|
|
}
|
|
|
|
/*
|
|
* nothing to do
|
|
*/
|
|
#define arch_decomp_setup()
|