65e866a974
Currently, there is one set of platform_device and platform_data structures for all DaVinci SoCs. The differences in the data between the various SoCs is handled by davinci_serial_init() by checking the SoC type. However, as new SoCs appear, this routine will become more & more cluttered. To clean up the routine and make it easier to add support for new SoCs, move the platform_device and platform_data structures into the SoC-specific code and use the SoC infrastructure to provide access to the data. In the process, fix a bug where the wrong irq is used for uart2 of the dm646x. Signed-off-by: Mark A. Greer <mgreer@mvista.com> Signed-off-by: Kevin Hilman <khilman@deeprootsystems.com>
35 lines
1,005 B
C
35 lines
1,005 B
C
/*
|
|
* DaVinci serial device definitions
|
|
*
|
|
* Author: Kevin Hilman, MontaVista Software, Inc. <source@mvista.com>
|
|
*
|
|
* 2007 (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.
|
|
*/
|
|
#ifndef __ASM_ARCH_SERIAL_H
|
|
#define __ASM_ARCH_SERIAL_H
|
|
|
|
#include <mach/io.h>
|
|
|
|
#define DAVINCI_MAX_NR_UARTS 3
|
|
#define DAVINCI_UART0_BASE (IO_PHYS + 0x20000)
|
|
#define DAVINCI_UART1_BASE (IO_PHYS + 0x20400)
|
|
#define DAVINCI_UART2_BASE (IO_PHYS + 0x20800)
|
|
|
|
#define DM355_UART2_BASE (IO_PHYS + 0x206000)
|
|
|
|
/* DaVinci UART register offsets */
|
|
#define UART_DAVINCI_PWREMU 0x0c
|
|
#define UART_DM646X_SCR 0x10
|
|
#define UART_DM646X_SCR_TX_WATERMARK 0x08
|
|
|
|
struct davinci_uart_config {
|
|
/* Bit field of UARTs present; bit 0 --> UART1 */
|
|
unsigned int enabled_uarts;
|
|
};
|
|
|
|
extern int davinci_serial_init(struct davinci_uart_config *);
|
|
|
|
#endif /* __ASM_ARCH_SERIAL_H */
|