 9d6eccb9cc
			
		
	
	
	9d6eccb9cc
	
	
	
		
			
			The tnetv107x support does not compile, and seems to have been broken for a while with nobody caring to fix it. So far everyone I asked said it's probably dead and completely unused and will never again be needed in a future kernel release, so let's delete it. If someone finds a use for this code later and is able to get it to work again, we can always revert the removal. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Acked-by: Sekhar Nori <nsekhar@ti.com> Acked-by: Kevin Hilman <khilman@linaro.org>
		
			
				
	
	
		
			97 lines
		
	
	
	
		
			2.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
	
		
			2.2 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)
 | |
| 
 | |
| 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);
 | |
| 	} while (0);
 | |
| }
 | |
| 
 | |
| #define arch_decomp_setup()	__arch_decomp_setup(arch_id)
 |