blob: 269147f3836f50985809c3ab5b9a3f81a944e2f4 [file] [log] [blame]
Russell Kinga09e64f2008-08-05 16:14:15 +01001/*
2 * arch/arm/plat-omap/include/mach/control.h
3 *
4 * OMAP2/3 System Control Module definitions
5 *
Tony Lindgren646e3ed2008-10-06 15:49:36 +03006 * Copyright (C) 2007-2008 Texas Instruments, Inc.
7 * Copyright (C) 2007-2008 Nokia Corporation
Russell Kinga09e64f2008-08-05 16:14:15 +01008 *
9 * Written by Paul Walmsley
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation.
14 */
15
Tony Lindgren646e3ed2008-10-06 15:49:36 +030016#ifndef __ASM_ARCH_CONTROL_H
17#define __ASM_ARCH_CONTROL_H
18
Russell Kinga09e64f2008-08-05 16:14:15 +010019#include <mach/io.h>
20
Tony Lindgren646e3ed2008-10-06 15:49:36 +030021#ifndef __ASSEMBLY__
Russell Kinga09e64f2008-08-05 16:14:15 +010022#define OMAP242X_CTRL_REGADDR(reg) \
Russell Kinge8a91c92008-09-01 22:07:37 +010023 IO_ADDRESS(OMAP242X_CTRL_BASE + (reg))
Russell Kinga09e64f2008-08-05 16:14:15 +010024#define OMAP243X_CTRL_REGADDR(reg) \
Russell Kinge8a91c92008-09-01 22:07:37 +010025 IO_ADDRESS(OMAP243X_CTRL_BASE + (reg))
Russell Kinga09e64f2008-08-05 16:14:15 +010026#define OMAP343X_CTRL_REGADDR(reg) \
Russell Kinge8a91c92008-09-01 22:07:37 +010027 IO_ADDRESS(OMAP343X_CTRL_BASE + (reg))
Tony Lindgren646e3ed2008-10-06 15:49:36 +030028#else
29#define OMAP242X_CTRL_REGADDR(reg) IO_ADDRESS(OMAP242X_CTRL_BASE + (reg))
30#define OMAP243X_CTRL_REGADDR(reg) IO_ADDRESS(OMAP243X_CTRL_BASE + (reg))
31#define OMAP343X_CTRL_REGADDR(reg) IO_ADDRESS(OMAP343X_CTRL_BASE + (reg))
32#endif /* __ASSEMBLY__ */
Russell Kinga09e64f2008-08-05 16:14:15 +010033
34/*
35 * As elsewhere, the "OMAP2_" prefix indicates that the macro is valid for
36 * OMAP24XX and OMAP34XX.
37 */
38
39/* Control submodule offsets */
40
41#define OMAP2_CONTROL_INTERFACE 0x000
42#define OMAP2_CONTROL_PADCONFS 0x030
43#define OMAP2_CONTROL_GENERAL 0x270
44#define OMAP343X_CONTROL_MEM_WKUP 0x600
45#define OMAP343X_CONTROL_PADCONFS_WKUP 0xa00
46#define OMAP343X_CONTROL_GENERAL_WKUP 0xa60
47
48/* Control register offsets - read/write with omap_ctrl_{read,write}{bwl}() */
49
50#define OMAP2_CONTROL_SYSCONFIG (OMAP2_CONTROL_INTERFACE + 0x10)
51
52/* CONTROL_GENERAL register offsets common to OMAP2 & 3 */
53#define OMAP2_CONTROL_DEVCONF0 (OMAP2_CONTROL_GENERAL + 0x0004)
54#define OMAP2_CONTROL_MSUSPENDMUX_0 (OMAP2_CONTROL_GENERAL + 0x0020)
55#define OMAP2_CONTROL_MSUSPENDMUX_1 (OMAP2_CONTROL_GENERAL + 0x0024)
56#define OMAP2_CONTROL_MSUSPENDMUX_2 (OMAP2_CONTROL_GENERAL + 0x0028)
57#define OMAP2_CONTROL_MSUSPENDMUX_3 (OMAP2_CONTROL_GENERAL + 0x002c)
58#define OMAP2_CONTROL_MSUSPENDMUX_4 (OMAP2_CONTROL_GENERAL + 0x0030)
59#define OMAP2_CONTROL_MSUSPENDMUX_5 (OMAP2_CONTROL_GENERAL + 0x0034)
60#define OMAP2_CONTROL_SEC_CTRL (OMAP2_CONTROL_GENERAL + 0x0040)
61#define OMAP2_CONTROL_RPUB_KEY_H_0 (OMAP2_CONTROL_GENERAL + 0x0090)
62#define OMAP2_CONTROL_RPUB_KEY_H_1 (OMAP2_CONTROL_GENERAL + 0x0094)
63#define OMAP2_CONTROL_RPUB_KEY_H_2 (OMAP2_CONTROL_GENERAL + 0x0098)
64#define OMAP2_CONTROL_RPUB_KEY_H_3 (OMAP2_CONTROL_GENERAL + 0x009c)
65
66/* 242x-only CONTROL_GENERAL register offsets */
67#define OMAP242X_CONTROL_DEVCONF OMAP2_CONTROL_DEVCONF0 /* match TRM */
68#define OMAP242X_CONTROL_OCM_RAM_PERM (OMAP2_CONTROL_GENERAL + 0x0068)
69
70/* 243x-only CONTROL_GENERAL register offsets */
71/* CONTROL_IVA2_BOOT{ADDR,MOD} are at the same place on 343x - noted below */
72#define OMAP243X_CONTROL_DEVCONF1 (OMAP2_CONTROL_GENERAL + 0x0078)
73#define OMAP243X_CONTROL_CSIRXFE (OMAP2_CONTROL_GENERAL + 0x007c)
74#define OMAP243X_CONTROL_IVA2_BOOTADDR (OMAP2_CONTROL_GENERAL + 0x0190)
75#define OMAP243X_CONTROL_IVA2_BOOTMOD (OMAP2_CONTROL_GENERAL + 0x0194)
76#define OMAP243X_CONTROL_IVA2_GEMCFG (OMAP2_CONTROL_GENERAL + 0x0198)
Tony Lindgren90c62bf2008-12-10 17:37:17 -080077#define OMAP243X_CONTROL_PBIAS_LITE (OMAP2_CONTROL_GENERAL + 0x0230)
Russell Kinga09e64f2008-08-05 16:14:15 +010078
79/* 24xx-only CONTROL_GENERAL register offsets */
80#define OMAP24XX_CONTROL_DEBOBS (OMAP2_CONTROL_GENERAL + 0x0000)
81#define OMAP24XX_CONTROL_EMU_SUPPORT (OMAP2_CONTROL_GENERAL + 0x0008)
82#define OMAP24XX_CONTROL_SEC_TEST (OMAP2_CONTROL_GENERAL + 0x0044)
83#define OMAP24XX_CONTROL_PSA_CTRL (OMAP2_CONTROL_GENERAL + 0x0048)
84#define OMAP24XX_CONTROL_PSA_CMD (OMAP2_CONTROL_GENERAL + 0x004c)
85#define OMAP24XX_CONTROL_PSA_VALUE (OMAP2_CONTROL_GENERAL + 0x0050)
86#define OMAP24XX_CONTROL_SEC_EMU (OMAP2_CONTROL_GENERAL + 0x0060)
87#define OMAP24XX_CONTROL_SEC_TAP (OMAP2_CONTROL_GENERAL + 0x0064)
88#define OMAP24XX_CONTROL_OCM_PUB_RAM_ADD (OMAP2_CONTROL_GENERAL + 0x006c)
89#define OMAP24XX_CONTROL_EXT_SEC_RAM_START_ADD (OMAP2_CONTROL_GENERAL + 0x0070)
90#define OMAP24XX_CONTROL_EXT_SEC_RAM_STOP_ADD (OMAP2_CONTROL_GENERAL + 0x0074)
91#define OMAP24XX_CONTROL_SEC_STATUS (OMAP2_CONTROL_GENERAL + 0x0080)
92#define OMAP24XX_CONTROL_SEC_ERR_STATUS (OMAP2_CONTROL_GENERAL + 0x0084)
93#define OMAP24XX_CONTROL_STATUS (OMAP2_CONTROL_GENERAL + 0x0088)
94#define OMAP24XX_CONTROL_GENERAL_PURPOSE_STATUS (OMAP2_CONTROL_GENERAL + 0x008c)
95#define OMAP24XX_CONTROL_RAND_KEY_0 (OMAP2_CONTROL_GENERAL + 0x00a0)
96#define OMAP24XX_CONTROL_RAND_KEY_1 (OMAP2_CONTROL_GENERAL + 0x00a4)
97#define OMAP24XX_CONTROL_RAND_KEY_2 (OMAP2_CONTROL_GENERAL + 0x00a8)
98#define OMAP24XX_CONTROL_RAND_KEY_3 (OMAP2_CONTROL_GENERAL + 0x00ac)
99#define OMAP24XX_CONTROL_CUST_KEY_0 (OMAP2_CONTROL_GENERAL + 0x00b0)
100#define OMAP24XX_CONTROL_CUST_KEY_1 (OMAP2_CONTROL_GENERAL + 0x00b4)
101#define OMAP24XX_CONTROL_TEST_KEY_0 (OMAP2_CONTROL_GENERAL + 0x00c0)
102#define OMAP24XX_CONTROL_TEST_KEY_1 (OMAP2_CONTROL_GENERAL + 0x00c4)
103#define OMAP24XX_CONTROL_TEST_KEY_2 (OMAP2_CONTROL_GENERAL + 0x00c8)
104#define OMAP24XX_CONTROL_TEST_KEY_3 (OMAP2_CONTROL_GENERAL + 0x00cc)
105#define OMAP24XX_CONTROL_TEST_KEY_4 (OMAP2_CONTROL_GENERAL + 0x00d0)
106#define OMAP24XX_CONTROL_TEST_KEY_5 (OMAP2_CONTROL_GENERAL + 0x00d4)
107#define OMAP24XX_CONTROL_TEST_KEY_6 (OMAP2_CONTROL_GENERAL + 0x00d8)
108#define OMAP24XX_CONTROL_TEST_KEY_7 (OMAP2_CONTROL_GENERAL + 0x00dc)
109#define OMAP24XX_CONTROL_TEST_KEY_8 (OMAP2_CONTROL_GENERAL + 0x00e0)
110#define OMAP24XX_CONTROL_TEST_KEY_9 (OMAP2_CONTROL_GENERAL + 0x00e4)
111
112/* 34xx-only CONTROL_GENERAL register offsets */
113#define OMAP343X_CONTROL_PADCONF_OFF (OMAP2_CONTROL_GENERAL + 0x0000)
114#define OMAP343X_CONTROL_MEM_DFTRW0 (OMAP2_CONTROL_GENERAL + 0x0008)
115#define OMAP343X_CONTROL_MEM_DFTRW1 (OMAP2_CONTROL_GENERAL + 0x000c)
116#define OMAP343X_CONTROL_DEVCONF1 (OMAP2_CONTROL_GENERAL + 0x0068)
117#define OMAP343X_CONTROL_CSIRXFE (OMAP2_CONTROL_GENERAL + 0x006c)
118#define OMAP343X_CONTROL_SEC_STATUS (OMAP2_CONTROL_GENERAL + 0x0070)
119#define OMAP343X_CONTROL_SEC_ERR_STATUS (OMAP2_CONTROL_GENERAL + 0x0074)
120#define OMAP343X_CONTROL_SEC_ERR_STATUS_DEBUG (OMAP2_CONTROL_GENERAL + 0x0078)
121#define OMAP343X_CONTROL_STATUS (OMAP2_CONTROL_GENERAL + 0x0080)
122#define OMAP343X_CONTROL_GENERAL_PURPOSE_STATUS (OMAP2_CONTROL_GENERAL + 0x0084)
123#define OMAP343X_CONTROL_RPUB_KEY_H_4 (OMAP2_CONTROL_GENERAL + 0x00a0)
124#define OMAP343X_CONTROL_RAND_KEY_0 (OMAP2_CONTROL_GENERAL + 0x00a8)
125#define OMAP343X_CONTROL_RAND_KEY_1 (OMAP2_CONTROL_GENERAL + 0x00ac)
126#define OMAP343X_CONTROL_RAND_KEY_2 (OMAP2_CONTROL_GENERAL + 0x00b0)
127#define OMAP343X_CONTROL_RAND_KEY_3 (OMAP2_CONTROL_GENERAL + 0x00b4)
128#define OMAP343X_CONTROL_TEST_KEY_0 (OMAP2_CONTROL_GENERAL + 0x00c8)
129#define OMAP343X_CONTROL_TEST_KEY_1 (OMAP2_CONTROL_GENERAL + 0x00cc)
130#define OMAP343X_CONTROL_TEST_KEY_2 (OMAP2_CONTROL_GENERAL + 0x00d0)
131#define OMAP343X_CONTROL_TEST_KEY_3 (OMAP2_CONTROL_GENERAL + 0x00d4)
132#define OMAP343X_CONTROL_TEST_KEY_4 (OMAP2_CONTROL_GENERAL + 0x00d8)
133#define OMAP343X_CONTROL_TEST_KEY_5 (OMAP2_CONTROL_GENERAL + 0x00dc)
134#define OMAP343X_CONTROL_TEST_KEY_6 (OMAP2_CONTROL_GENERAL + 0x00e0)
135#define OMAP343X_CONTROL_TEST_KEY_7 (OMAP2_CONTROL_GENERAL + 0x00e4)
136#define OMAP343X_CONTROL_TEST_KEY_8 (OMAP2_CONTROL_GENERAL + 0x00e8)
137#define OMAP343X_CONTROL_TEST_KEY_9 (OMAP2_CONTROL_GENERAL + 0x00ec)
138#define OMAP343X_CONTROL_TEST_KEY_10 (OMAP2_CONTROL_GENERAL + 0x00f0)
139#define OMAP343X_CONTROL_TEST_KEY_11 (OMAP2_CONTROL_GENERAL + 0x00f4)
140#define OMAP343X_CONTROL_TEST_KEY_12 (OMAP2_CONTROL_GENERAL + 0x00f8)
141#define OMAP343X_CONTROL_TEST_KEY_13 (OMAP2_CONTROL_GENERAL + 0x00fc)
142#define OMAP343X_CONTROL_IVA2_BOOTADDR (OMAP2_CONTROL_GENERAL + 0x0190)
143#define OMAP343X_CONTROL_IVA2_BOOTMOD (OMAP2_CONTROL_GENERAL + 0x0194)
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800144#define OMAP343X_CONTROL_PBIAS_LITE (OMAP2_CONTROL_GENERAL + 0x02b0)
Tony Lindgren646e3ed2008-10-06 15:49:36 +0300145#define OMAP343X_CONTROL_TEMP_SENSOR (OMAP2_CONTROL_GENERAL + 0x02b4)
Russell Kinga09e64f2008-08-05 16:14:15 +0100146
147/*
148 * REVISIT: This list of registers is not comprehensive - there are more
149 * that should be added.
150 */
151
152/*
153 * Control module register bit defines - these should eventually go into
154 * their own regbits file. Some of these will be complicated, depending
155 * on the device type (general-purpose, emulator, test, secure, bad, other)
156 * and the security mode (secure, non-secure, don't care)
157 */
158/* CONTROL_DEVCONF0 bits */
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800159#define OMAP2_MMCSDIO1ADPCLKISEL (1 << 24) /* MMC1 loop back clock */
Russell Kinga09e64f2008-08-05 16:14:15 +0100160#define OMAP24XX_USBSTANDBYCTRL (1 << 15)
161#define OMAP2_MCBSP2_CLKS_MASK (1 << 6)
162#define OMAP2_MCBSP1_CLKS_MASK (1 << 2)
163
164/* CONTROL_DEVCONF1 bits */
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800165#define OMAP243X_MMC1_ACTIVE_OVERWRITE (1 << 31)
166#define OMAP2_MMCSDIO2ADPCLKISEL (1 << 6) /* MMC2 loop back clock */
Russell Kinga09e64f2008-08-05 16:14:15 +0100167#define OMAP2_MCBSP5_CLKS_MASK (1 << 4) /* > 242x */
168#define OMAP2_MCBSP4_CLKS_MASK (1 << 2) /* > 242x */
169#define OMAP2_MCBSP3_CLKS_MASK (1 << 0) /* > 242x */
170
171/* CONTROL_STATUS bits */
172#define OMAP2_DEVICETYPE_MASK (0x7 << 8)
173#define OMAP2_SYSBOOT_5_MASK (1 << 5)
174#define OMAP2_SYSBOOT_4_MASK (1 << 4)
175#define OMAP2_SYSBOOT_3_MASK (1 << 3)
176#define OMAP2_SYSBOOT_2_MASK (1 << 2)
177#define OMAP2_SYSBOOT_1_MASK (1 << 1)
178#define OMAP2_SYSBOOT_0_MASK (1 << 0)
179
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800180/* CONTROL_PBIAS_LITE bits */
181#define OMAP343X_PBIASLITESUPPLY_HIGH1 (1 << 15)
182#define OMAP343X_PBIASLITEVMODEERROR1 (1 << 11)
183#define OMAP343X_PBIASSPEEDCTRL1 (1 << 10)
184#define OMAP343X_PBIASLITEPWRDNZ1 (1 << 9)
185#define OMAP343X_PBIASLITEVMODE1 (1 << 8)
186#define OMAP343X_PBIASLITESUPPLY_HIGH0 (1 << 7)
187#define OMAP343X_PBIASLITEVMODEERROR0 (1 << 3)
188#define OMAP2_PBIASSPEEDCTRL0 (1 << 2)
189#define OMAP2_PBIASLITEPWRDNZ0 (1 << 1)
190#define OMAP2_PBIASLITEVMODE0 (1 << 0)
191
Russell Kinga09e64f2008-08-05 16:14:15 +0100192#ifndef __ASSEMBLY__
193#if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3)
194extern void __iomem *omap_ctrl_base_get(void);
195extern u8 omap_ctrl_readb(u16 offset);
196extern u16 omap_ctrl_readw(u16 offset);
197extern u32 omap_ctrl_readl(u16 offset);
198extern void omap_ctrl_writeb(u8 val, u16 offset);
199extern void omap_ctrl_writew(u16 val, u16 offset);
200extern void omap_ctrl_writel(u32 val, u16 offset);
201#else
202#define omap_ctrl_base_get() 0
203#define omap_ctrl_readb(x) 0
204#define omap_ctrl_readw(x) 0
205#define omap_ctrl_readl(x) 0
206#define omap_ctrl_writeb(x, y) WARN_ON(1)
207#define omap_ctrl_writew(x, y) WARN_ON(1)
208#define omap_ctrl_writel(x, y) WARN_ON(1)
209#endif
210#endif /* __ASSEMBLY__ */
211
212#endif /* __ASM_ARCH_CONTROL_H */
213