mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 08:48:48 +00:00
b632a30e8b
With ARCH_HAS_DECOMP_WDOG removed from arch/arm/boot/compressed/decompress.c, all the arch_decomp_wdog() definition at platform level is unneeded. Remmove it. Signed-off-by: Shawn Guo <shawn.guo@linaro.org> Acked-by: Nicolas Pitre <nico@linaro.org> Acked-by: Jason Cooper <jason@lakedaemon.net>
104 lines
2.4 KiB
C
104 lines
2.4 KiB
C
/*
|
|
* Serial port stubs for kernel decompress status messages
|
|
*
|
|
* Initially based on:
|
|
* arch/arm/plat-omap/include/mach/uncompress.h
|
|
*
|
|
* Original copyrights follow.
|
|
*
|
|
* Copyright (C) 2000 RidgeRun, Inc.
|
|
* Author: Greg Lonnon <glonnon@ridgerun.com>
|
|
*
|
|
* Rewritten by:
|
|
* Author: <source@mvista.com>
|
|
* 2004 (c) MontaVista Software, 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>
|
|
|
|
#include <asm/mach-types.h>
|
|
|
|
#include <mach/serial.h>
|
|
|
|
#define IOMEM(x) ((void __force __iomem *)(x))
|
|
|
|
u32 *uart;
|
|
|
|
/* PORT_16C550A, in polled non-fifo mode */
|
|
static void putc(char c)
|
|
{
|
|
if (!uart)
|
|
return;
|
|
|
|
while (!(uart[UART_LSR] & UART_LSR_THRE))
|
|
barrier();
|
|
uart[UART_TX] = c;
|
|
}
|
|
|
|
static inline void flush(void)
|
|
{
|
|
if (!uart)
|
|
return;
|
|
|
|
while (!(uart[UART_LSR] & UART_LSR_THRE))
|
|
barrier();
|
|
}
|
|
|
|
static inline void set_uart_info(u32 phys)
|
|
{
|
|
uart = (u32 *)phys;
|
|
}
|
|
|
|
#define _DEBUG_LL_ENTRY(machine, phys) \
|
|
{ \
|
|
if (machine_is_##machine()) { \
|
|
set_uart_info(phys); \
|
|
break; \
|
|
} \
|
|
}
|
|
|
|
#define DEBUG_LL_DAVINCI(machine, port) \
|
|
_DEBUG_LL_ENTRY(machine, DAVINCI_UART##port##_BASE)
|
|
|
|
#define DEBUG_LL_DA8XX(machine, port) \
|
|
_DEBUG_LL_ENTRY(machine, DA8XX_UART##port##_BASE)
|
|
|
|
#define DEBUG_LL_TNETV107X(machine, port) \
|
|
_DEBUG_LL_ENTRY(machine, TNETV107X_UART##port##_BASE)
|
|
|
|
static inline void __arch_decomp_setup(unsigned long arch_id)
|
|
{
|
|
/*
|
|
* Initialize the port based on the machine ID from the bootloader.
|
|
* Note that we're using macros here instead of switch statement
|
|
* as machine_is functions are optimized out for the boards that
|
|
* are not selected.
|
|
*/
|
|
do {
|
|
/* Davinci boards */
|
|
DEBUG_LL_DAVINCI(davinci_evm, 0);
|
|
DEBUG_LL_DAVINCI(sffsdr, 0);
|
|
DEBUG_LL_DAVINCI(neuros_osd2, 0);
|
|
DEBUG_LL_DAVINCI(davinci_dm355_evm, 0);
|
|
DEBUG_LL_DAVINCI(dm355_leopard, 0);
|
|
DEBUG_LL_DAVINCI(davinci_dm6467_evm, 0);
|
|
DEBUG_LL_DAVINCI(davinci_dm365_evm, 0);
|
|
|
|
/* DA8xx boards */
|
|
DEBUG_LL_DA8XX(davinci_da830_evm, 2);
|
|
DEBUG_LL_DA8XX(davinci_da850_evm, 2);
|
|
DEBUG_LL_DA8XX(mityomapl138, 1);
|
|
DEBUG_LL_DA8XX(omapl138_hawkboard, 2);
|
|
|
|
/* TNETV107x boards */
|
|
DEBUG_LL_TNETV107X(tnetv107x, 1);
|
|
} while (0);
|
|
}
|
|
|
|
#define arch_decomp_setup() __arch_decomp_setup(arch_id)
|