0df0914d41
* 'omap-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tmlind/linux-omap-2.6: (258 commits) omap: zoom: host should not pull up wl1271's irq line arm: plat-omap: iommu: fix request_mem_region() error path OMAP2+: Common CPU DIE ID reading code reads wrong registers for OMAP4430 omap4: mux: Remove duplicate mux modes omap: iovmm: don't check 'da' to set IOVMF_DA_FIXED flag omap: iovmm: disallow mapping NULL address when IOVMF_DA_ANON is set omap2+: mux: Fix compile when CONFIG_OMAP_MUX is not selected omap4: board-omap4panda: Initialise the serial pads omap3: board-3430sdp: Initialise the serial pads omap4: board-4430sdp: Initialise the serial pads omap2+: mux: Add macro for configuring static with omap_hwmod_mux_init omap2+: mux: Remove the use of IDLE flag omap2+: Add separate list for dynamic pads to mux perf: add OMAP support for the new power events OMAP4: Add IVA OPP enteries. OMAP4: Update Voltage Rail Values for MPU, IVA and CORE OMAP4: Enable 800 MHz and 1 GHz MPU-OPP OMAP3+: OPP: Replace voltage values with Macros OMAP3: wdtimer: Fix CORE idle transition Watchdog: omap_wdt: add fine grain runtime-pm ... Fix up various conflicts in - arch/arm/mach-omap2/board-omap3evm.c - arch/arm/mach-omap2/clock3xxx_data.c - arch/arm/mach-omap2/usb-musb.c - arch/arm/plat-omap/include/plat/usb.h - drivers/usb/musb/musb_core.h
118 lines
3.4 KiB
C
118 lines
3.4 KiB
C
/*
|
|
* arch/arm/plat-omap/include/mach/serial.h
|
|
*
|
|
* Copyright (C) 2009 Texas Instruments
|
|
* Addded OMAP4 support- Santosh Shilimkar <santosh.shilimkar@ti.com>
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#ifndef __ASM_ARCH_SERIAL_H
|
|
#define __ASM_ARCH_SERIAL_H
|
|
|
|
#include <linux/init.h>
|
|
|
|
/*
|
|
* Memory entry used for the DEBUG_LL UART configuration. See also
|
|
* uncompress.h and debug-macro.S.
|
|
*
|
|
* Note that using a memory location for storing the UART configuration
|
|
* has at least two limitations:
|
|
*
|
|
* 1. Kernel uncompress code cannot overlap OMAP_UART_INFO as the
|
|
* uncompress code could then partially overwrite itself
|
|
* 2. We assume printascii is called at least once before paging_init,
|
|
* and addruart has a chance to read OMAP_UART_INFO
|
|
*/
|
|
#define OMAP_UART_INFO (PLAT_PHYS_OFFSET + 0x3ffc)
|
|
|
|
/* OMAP1 serial ports */
|
|
#define OMAP1_UART1_BASE 0xfffb0000
|
|
#define OMAP1_UART2_BASE 0xfffb0800
|
|
#define OMAP1_UART3_BASE 0xfffb9800
|
|
|
|
/* OMAP2 serial ports */
|
|
#define OMAP2_UART1_BASE 0x4806a000
|
|
#define OMAP2_UART2_BASE 0x4806c000
|
|
#define OMAP2_UART3_BASE 0x4806e000
|
|
|
|
/* OMAP3 serial ports */
|
|
#define OMAP3_UART1_BASE OMAP2_UART1_BASE
|
|
#define OMAP3_UART2_BASE OMAP2_UART2_BASE
|
|
#define OMAP3_UART3_BASE 0x49020000
|
|
#define OMAP3_UART4_BASE 0x49042000 /* Only on 36xx */
|
|
|
|
/* OMAP4 serial ports */
|
|
#define OMAP4_UART1_BASE OMAP2_UART1_BASE
|
|
#define OMAP4_UART2_BASE OMAP2_UART2_BASE
|
|
#define OMAP4_UART3_BASE 0x48020000
|
|
#define OMAP4_UART4_BASE 0x4806e000
|
|
|
|
/* TI816X serial ports */
|
|
#define TI816X_UART1_BASE 0x48020000
|
|
#define TI816X_UART2_BASE 0x48022000
|
|
#define TI816X_UART3_BASE 0x48024000
|
|
|
|
/* External port on Zoom2/3 */
|
|
#define ZOOM_UART_BASE 0x10000000
|
|
#define ZOOM_UART_VIRT 0xfa400000
|
|
|
|
#define OMAP_PORT_SHIFT 2
|
|
#define OMAP7XX_PORT_SHIFT 0
|
|
#define ZOOM_PORT_SHIFT 1
|
|
|
|
#define OMAP1510_BASE_BAUD (12000000/16)
|
|
#define OMAP16XX_BASE_BAUD (48000000/16)
|
|
#define OMAP24XX_BASE_BAUD (48000000/16)
|
|
|
|
/*
|
|
* DEBUG_LL port encoding stored into the UART1 scratchpad register by
|
|
* decomp_setup in uncompress.h
|
|
*/
|
|
#define OMAP1UART1 11
|
|
#define OMAP1UART2 12
|
|
#define OMAP1UART3 13
|
|
#define OMAP2UART1 21
|
|
#define OMAP2UART2 22
|
|
#define OMAP2UART3 23
|
|
#define OMAP3UART1 OMAP2UART1
|
|
#define OMAP3UART2 OMAP2UART2
|
|
#define OMAP3UART3 33
|
|
#define OMAP3UART4 34 /* Only on 36xx */
|
|
#define OMAP4UART1 OMAP2UART1
|
|
#define OMAP4UART2 OMAP2UART2
|
|
#define OMAP4UART3 43
|
|
#define OMAP4UART4 44
|
|
#define TI816XUART1 81
|
|
#define TI816XUART2 82
|
|
#define TI816XUART3 83
|
|
#define ZOOM_UART 95 /* Only on zoom2/3 */
|
|
|
|
/* This is only used by 8250.c for omap1510 */
|
|
#define is_omap_port(pt) ({int __ret = 0; \
|
|
if ((pt)->port.mapbase == OMAP1_UART1_BASE || \
|
|
(pt)->port.mapbase == OMAP1_UART2_BASE || \
|
|
(pt)->port.mapbase == OMAP1_UART3_BASE) \
|
|
__ret = 1; \
|
|
__ret; \
|
|
})
|
|
|
|
#ifndef __ASSEMBLER__
|
|
|
|
struct omap_board_data;
|
|
|
|
extern void omap_serial_init(void);
|
|
extern void omap_serial_init_port(struct omap_board_data *bdata);
|
|
extern int omap_uart_can_sleep(void);
|
|
extern void omap_uart_check_wakeup(void);
|
|
extern void omap_uart_prepare_suspend(void);
|
|
extern void omap_uart_prepare_idle(int num);
|
|
extern void omap_uart_resume_idle(int num);
|
|
extern void omap_uart_enable_irqs(int enable);
|
|
#endif
|
|
|
|
#endif
|