blob: 838b594d4e13f546ac45d32fa84218216fea76ca [file] [log] [blame]
Tony Lindgrenc5957132008-03-18 14:53:17 +02001/*
2 * OMAP3430 Power/Reset Management register bits
3 *
4 * Copyright (C) 2007-2008 Texas Instruments, Inc.
5 * Copyright (C) 2007-2008 Nokia Corporation
6 *
7 * Written by Paul Walmsley
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License version 2 as
11 * published by the Free Software Foundation.
12 */
Paul Walmsley59fb6592010-12-21 15:30:55 -070013#ifndef __ARCH_ARM_MACH_OMAP2_PRM_REGBITS_34XX_H
14#define __ARCH_ARM_MACH_OMAP2_PRM_REGBITS_34XX_H
Tony Lindgrenc5957132008-03-18 14:53:17 +020015
Paul Walmsley59fb6592010-12-21 15:30:55 -070016
Paul Walmsley139563a2012-10-21 01:01:10 -060017#include "prm3xxx.h"
Tony Lindgrenc5957132008-03-18 14:53:17 +020018
19/* Shared register bits */
20
21/* PRM_VC_CMD_VAL_0, PRM_VC_CMD_VAL_1 shared bits */
22#define OMAP3430_ON_SHIFT 24
23#define OMAP3430_ON_MASK (0xff << 24)
24#define OMAP3430_ONLP_SHIFT 16
25#define OMAP3430_ONLP_MASK (0xff << 16)
26#define OMAP3430_RET_SHIFT 8
27#define OMAP3430_RET_MASK (0xff << 8)
28#define OMAP3430_OFF_SHIFT 0
29#define OMAP3430_OFF_MASK (0xff << 0)
30
31/* PRM_VP1_CONFIG, PRM_VP2_CONFIG shared bits */
32#define OMAP3430_ERROROFFSET_SHIFT 24
33#define OMAP3430_ERROROFFSET_MASK (0xff << 24)
34#define OMAP3430_ERRORGAIN_SHIFT 16
35#define OMAP3430_ERRORGAIN_MASK (0xff << 16)
36#define OMAP3430_INITVOLTAGE_SHIFT 8
37#define OMAP3430_INITVOLTAGE_MASK (0xff << 8)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060038#define OMAP3430_TIMEOUTEN_MASK (1 << 3)
39#define OMAP3430_INITVDD_MASK (1 << 2)
40#define OMAP3430_FORCEUPDATE_MASK (1 << 1)
41#define OMAP3430_VPENABLE_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020042
43/* PRM_VP1_VSTEPMIN, PRM_VP2_VSTEPMIN shared bits */
44#define OMAP3430_SMPSWAITTIMEMIN_SHIFT 8
45#define OMAP3430_SMPSWAITTIMEMIN_MASK (0xffff << 8)
46#define OMAP3430_VSTEPMIN_SHIFT 0
47#define OMAP3430_VSTEPMIN_MASK (0xff << 0)
48
49/* PRM_VP1_VSTEPMAX, PRM_VP2_VSTEPMAX shared bits */
50#define OMAP3430_SMPSWAITTIMEMAX_SHIFT 8
51#define OMAP3430_SMPSWAITTIMEMAX_MASK (0xffff << 8)
52#define OMAP3430_VSTEPMAX_SHIFT 0
53#define OMAP3430_VSTEPMAX_MASK (0xff << 0)
54
55/* PRM_VP1_VLIMITTO, PRM_VP2_VLIMITTO shared bits */
56#define OMAP3430_VDDMAX_SHIFT 24
57#define OMAP3430_VDDMAX_MASK (0xff << 24)
58#define OMAP3430_VDDMIN_SHIFT 16
59#define OMAP3430_VDDMIN_MASK (0xff << 16)
60#define OMAP3430_TIMEOUT_SHIFT 0
61#define OMAP3430_TIMEOUT_MASK (0xffff << 0)
62
63/* PRM_VP1_VOLTAGE, PRM_VP2_VOLTAGE shared bits */
64#define OMAP3430_VPVOLTAGE_SHIFT 0
65#define OMAP3430_VPVOLTAGE_MASK (0xff << 0)
66
67/* PRM_VP1_STATUS, PRM_VP2_STATUS shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060068#define OMAP3430_VPINIDLE_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020069
70/* PM_WKDEP_IVA2, PM_WKDEP_MPU shared bits */
Paul Walmsleyecb24aa2008-08-19 11:08:43 +030071#define OMAP3430_EN_PER_SHIFT 7
72#define OMAP3430_EN_PER_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +020073
74/* PM_PWSTCTRL_IVA2, PM_PWSTCTRL_MPU, PM_PWSTCTRL_CORE shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060075#define OMAP3430_MEMORYCHANGE_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +020076
77/* PM_PWSTST_IVA2, PM_PWSTST_CORE shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060078#define OMAP3430_LOGICSTATEST_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +020079
80/* PM_PREPWSTST_IVA2, PM_PREPWSTST_CORE shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060081#define OMAP3430_LASTLOGICSTATEENTERED_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +020082
83/*
84 * PM_PREPWSTST_IVA2, PM_PREPWSTST_MPU, PM_PREPWSTST_CORE,
85 * PM_PREPWSTST_GFX, PM_PREPWSTST_DSS, PM_PREPWSTST_CAM,
86 * PM_PREPWSTST_PER, PM_PREPWSTST_NEON shared bits
87 */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060088#define OMAP3430_LASTPOWERSTATEENTERED_SHIFT 0
89#define OMAP3430_LASTPOWERSTATEENTERED_MASK (0x3 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020090
91/* PRM_IRQSTATUS_IVA2, PRM_IRQSTATUS_MPU shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060092#define OMAP3430_WKUP_ST_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020093
94/* PRM_IRQENABLE_IVA2, PRM_IRQENABLE_MPU shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060095#define OMAP3430_WKUP_EN_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020096
97/* PM_MPUGRPSEL1_CORE, PM_IVA2GRPSEL1_CORE shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060098#define OMAP3430_GRPSEL_MMC2_MASK (1 << 25)
99#define OMAP3430_GRPSEL_MMC1_MASK (1 << 24)
100#define OMAP3430_GRPSEL_MCSPI4_MASK (1 << 21)
101#define OMAP3430_GRPSEL_MCSPI3_MASK (1 << 20)
102#define OMAP3430_GRPSEL_MCSPI2_MASK (1 << 19)
103#define OMAP3430_GRPSEL_MCSPI1_MASK (1 << 18)
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530104#define OMAP3430_GRPSEL_I2C3_SHIFT 17
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600105#define OMAP3430_GRPSEL_I2C3_MASK (1 << 17)
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530106#define OMAP3430_GRPSEL_I2C2_SHIFT 16
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600107#define OMAP3430_GRPSEL_I2C2_MASK (1 << 16)
Rajendra Nayak4fe20e92010-09-21 19:37:13 +0530108#define OMAP3430_GRPSEL_I2C1_SHIFT 15
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600109#define OMAP3430_GRPSEL_I2C1_MASK (1 << 15)
110#define OMAP3430_GRPSEL_UART2_MASK (1 << 14)
111#define OMAP3430_GRPSEL_UART1_MASK (1 << 13)
112#define OMAP3430_GRPSEL_GPT11_MASK (1 << 12)
113#define OMAP3430_GRPSEL_GPT10_MASK (1 << 11)
114#define OMAP3430_GRPSEL_MCBSP5_MASK (1 << 10)
115#define OMAP3430_GRPSEL_MCBSP1_MASK (1 << 9)
116#define OMAP3430_GRPSEL_HSOTGUSB_MASK (1 << 4)
117#define OMAP3430_GRPSEL_D2D_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200118
119/*
120 * PM_PWSTCTRL_GFX, PM_PWSTCTRL_DSS, PM_PWSTCTRL_CAM,
121 * PM_PWSTCTRL_PER shared bits
122 */
123#define OMAP3430_MEMONSTATE_SHIFT 16
124#define OMAP3430_MEMONSTATE_MASK (0x3 << 16)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600125#define OMAP3430_MEMRETSTATE_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200126
127/* PM_MPUGRPSEL_PER, PM_IVA2GRPSEL_PER shared bits */
Govindraj.Re5863682010-09-27 20:20:25 +0530128#define OMAP3630_GRPSEL_UART4_MASK (1 << 18)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600129#define OMAP3430_GRPSEL_GPIO6_MASK (1 << 17)
130#define OMAP3430_GRPSEL_GPIO5_MASK (1 << 16)
131#define OMAP3430_GRPSEL_GPIO4_MASK (1 << 15)
132#define OMAP3430_GRPSEL_GPIO3_MASK (1 << 14)
133#define OMAP3430_GRPSEL_GPIO2_MASK (1 << 13)
134#define OMAP3430_GRPSEL_UART3_MASK (1 << 11)
135#define OMAP3430_GRPSEL_GPT9_MASK (1 << 10)
136#define OMAP3430_GRPSEL_GPT8_MASK (1 << 9)
137#define OMAP3430_GRPSEL_GPT7_MASK (1 << 8)
138#define OMAP3430_GRPSEL_GPT6_MASK (1 << 7)
139#define OMAP3430_GRPSEL_GPT5_MASK (1 << 6)
140#define OMAP3430_GRPSEL_GPT4_MASK (1 << 5)
141#define OMAP3430_GRPSEL_GPT3_MASK (1 << 4)
142#define OMAP3430_GRPSEL_GPT2_MASK (1 << 3)
143#define OMAP3430_GRPSEL_MCBSP4_MASK (1 << 2)
144#define OMAP3430_GRPSEL_MCBSP3_MASK (1 << 1)
145#define OMAP3430_GRPSEL_MCBSP2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200146
147/* PM_MPUGRPSEL_WKUP, PM_IVA2GRPSEL_WKUP shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600148#define OMAP3430_GRPSEL_IO_MASK (1 << 8)
149#define OMAP3430_GRPSEL_SR2_MASK (1 << 7)
150#define OMAP3430_GRPSEL_SR1_MASK (1 << 6)
151#define OMAP3430_GRPSEL_GPIO1_MASK (1 << 3)
152#define OMAP3430_GRPSEL_GPT12_MASK (1 << 1)
153#define OMAP3430_GRPSEL_GPT1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200154
155/* Bits specific to each register */
156
157/* RM_RSTCTRL_IVA2 */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600158#define OMAP3430_RST3_IVA2_MASK (1 << 2)
159#define OMAP3430_RST2_IVA2_MASK (1 << 1)
160#define OMAP3430_RST1_IVA2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200161
162/* RM_RSTST_IVA2 specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600163#define OMAP3430_EMULATION_VSEQ_RST_MASK (1 << 13)
164#define OMAP3430_EMULATION_VHWA_RST_MASK (1 << 12)
165#define OMAP3430_EMULATION_IVA2_RST_MASK (1 << 11)
166#define OMAP3430_IVA2_SW_RST3_MASK (1 << 10)
167#define OMAP3430_IVA2_SW_RST2_MASK (1 << 9)
168#define OMAP3430_IVA2_SW_RST1_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200169
170/* PM_WKDEP_IVA2 specific bits */
171
172/* PM_PWSTCTRL_IVA2 specific bits */
173#define OMAP3430_L2FLATMEMONSTATE_SHIFT 22
174#define OMAP3430_L2FLATMEMONSTATE_MASK (0x3 << 22)
175#define OMAP3430_SHAREDL2CACHEFLATONSTATE_SHIFT 20
176#define OMAP3430_SHAREDL2CACHEFLATONSTATE_MASK (0x3 << 20)
177#define OMAP3430_L1FLATMEMONSTATE_SHIFT 18
178#define OMAP3430_L1FLATMEMONSTATE_MASK (0x3 << 18)
179#define OMAP3430_SHAREDL1CACHEFLATONSTATE_SHIFT 16
180#define OMAP3430_SHAREDL1CACHEFLATONSTATE_MASK (0x3 << 16)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600181#define OMAP3430_L2FLATMEMRETSTATE_MASK (1 << 11)
182#define OMAP3430_SHAREDL2CACHEFLATRETSTATE_MASK (1 << 10)
183#define OMAP3430_L1FLATMEMRETSTATE_MASK (1 << 9)
184#define OMAP3430_SHAREDL1CACHEFLATRETSTATE_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200185
186/* PM_PWSTST_IVA2 specific bits */
187#define OMAP3430_L2FLATMEMSTATEST_SHIFT 10
188#define OMAP3430_L2FLATMEMSTATEST_MASK (0x3 << 10)
189#define OMAP3430_SHAREDL2CACHEFLATSTATEST_SHIFT 8
190#define OMAP3430_SHAREDL2CACHEFLATSTATEST_MASK (0x3 << 8)
191#define OMAP3430_L1FLATMEMSTATEST_SHIFT 6
192#define OMAP3430_L1FLATMEMSTATEST_MASK (0x3 << 6)
193#define OMAP3430_SHAREDL1CACHEFLATSTATEST_SHIFT 4
194#define OMAP3430_SHAREDL1CACHEFLATSTATEST_MASK (0x3 << 4)
195
196/* PM_PREPWSTST_IVA2 specific bits */
197#define OMAP3430_LASTL2FLATMEMSTATEENTERED_SHIFT 10
198#define OMAP3430_LASTL2FLATMEMSTATEENTERED_MASK (0x3 << 10)
199#define OMAP3430_LASTSHAREDL2CACHEFLATSTATEENTERED_SHIFT 8
200#define OMAP3430_LASTSHAREDL2CACHEFLATSTATEENTERED_MASK (0x3 << 8)
201#define OMAP3430_LASTL1FLATMEMSTATEENTERED_SHIFT 6
202#define OMAP3430_LASTL1FLATMEMSTATEENTERED_MASK (0x3 << 6)
203#define OMAP3430_LASTSHAREDL1CACHEFLATSTATEENTERED_SHIFT 4
204#define OMAP3430_LASTSHAREDL1CACHEFLATSTATEENTERED_MASK (0x3 << 4)
205
206/* PRM_IRQSTATUS_IVA2 specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600207#define OMAP3430_PRM_IRQSTATUS_IVA2_IVA2_DPLL_ST_MASK (1 << 2)
208#define OMAP3430_FORCEWKUP_ST_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200209
210/* PRM_IRQENABLE_IVA2 specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600211#define OMAP3430_PRM_IRQENABLE_IVA2_IVA2_DPLL_RECAL_EN_MASK (1 << 2)
212#define OMAP3430_FORCEWKUP_EN_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200213
214/* PRM_REVISION specific bits */
215
216/* PRM_SYSCONFIG specific bits */
217
218/* PRM_IRQSTATUS_MPU specific bits */
219#define OMAP3430ES2_SND_PERIPH_DPLL_ST_SHIFT 25
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600220#define OMAP3430ES2_SND_PERIPH_DPLL_ST_MASK (1 << 25)
221#define OMAP3430_VC_TIMEOUTERR_ST_MASK (1 << 24)
222#define OMAP3430_VC_RAERR_ST_MASK (1 << 23)
223#define OMAP3430_VC_SAERR_ST_MASK (1 << 22)
224#define OMAP3430_VP2_TRANXDONE_ST_MASK (1 << 21)
225#define OMAP3430_VP2_EQVALUE_ST_MASK (1 << 20)
226#define OMAP3430_VP2_NOSMPSACK_ST_MASK (1 << 19)
227#define OMAP3430_VP2_MAXVDD_ST_MASK (1 << 18)
228#define OMAP3430_VP2_MINVDD_ST_MASK (1 << 17)
229#define OMAP3430_VP2_OPPCHANGEDONE_ST_MASK (1 << 16)
230#define OMAP3430_VP1_TRANXDONE_ST_MASK (1 << 15)
231#define OMAP3430_VP1_EQVALUE_ST_MASK (1 << 14)
232#define OMAP3430_VP1_NOSMPSACK_ST_MASK (1 << 13)
233#define OMAP3430_VP1_MAXVDD_ST_MASK (1 << 12)
234#define OMAP3430_VP1_MINVDD_ST_MASK (1 << 11)
235#define OMAP3430_VP1_OPPCHANGEDONE_ST_MASK (1 << 10)
236#define OMAP3430_IO_ST_MASK (1 << 9)
237#define OMAP3430_PRM_IRQSTATUS_MPU_IVA2_DPLL_ST_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200238#define OMAP3430_PRM_IRQSTATUS_MPU_IVA2_DPLL_ST_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600239#define OMAP3430_MPU_DPLL_ST_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200240#define OMAP3430_MPU_DPLL_ST_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600241#define OMAP3430_PERIPH_DPLL_ST_MASK (1 << 6)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200242#define OMAP3430_PERIPH_DPLL_ST_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600243#define OMAP3430_CORE_DPLL_ST_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200244#define OMAP3430_CORE_DPLL_ST_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600245#define OMAP3430_TRANSITION_ST_MASK (1 << 4)
246#define OMAP3430_EVGENOFF_ST_MASK (1 << 3)
247#define OMAP3430_EVGENON_ST_MASK (1 << 2)
248#define OMAP3430_FS_USB_WKUP_ST_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200249
250/* PRM_IRQENABLE_MPU specific bits */
251#define OMAP3430ES2_SND_PERIPH_DPLL_RECAL_EN_SHIFT 25
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600252#define OMAP3430ES2_SND_PERIPH_DPLL_RECAL_EN_MASK (1 << 25)
253#define OMAP3430_VC_TIMEOUTERR_EN_MASK (1 << 24)
254#define OMAP3430_VC_RAERR_EN_MASK (1 << 23)
255#define OMAP3430_VC_SAERR_EN_MASK (1 << 22)
256#define OMAP3430_VP2_TRANXDONE_EN_MASK (1 << 21)
257#define OMAP3430_VP2_EQVALUE_EN_MASK (1 << 20)
258#define OMAP3430_VP2_NOSMPSACK_EN_MASK (1 << 19)
259#define OMAP3430_VP2_MAXVDD_EN_MASK (1 << 18)
260#define OMAP3430_VP2_MINVDD_EN_MASK (1 << 17)
261#define OMAP3430_VP2_OPPCHANGEDONE_EN_MASK (1 << 16)
262#define OMAP3430_VP1_TRANXDONE_EN_MASK (1 << 15)
263#define OMAP3430_VP1_EQVALUE_EN_MASK (1 << 14)
264#define OMAP3430_VP1_NOSMPSACK_EN_MASK (1 << 13)
265#define OMAP3430_VP1_MAXVDD_EN_MASK (1 << 12)
266#define OMAP3430_VP1_MINVDD_EN_MASK (1 << 11)
267#define OMAP3430_VP1_OPPCHANGEDONE_EN_MASK (1 << 10)
268#define OMAP3430_IO_EN_MASK (1 << 9)
269#define OMAP3430_PRM_IRQENABLE_MPU_IVA2_DPLL_RECAL_EN_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200270#define OMAP3430_PRM_IRQENABLE_MPU_IVA2_DPLL_RECAL_EN_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600271#define OMAP3430_MPU_DPLL_RECAL_EN_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200272#define OMAP3430_MPU_DPLL_RECAL_EN_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600273#define OMAP3430_PERIPH_DPLL_RECAL_EN_MASK (1 << 6)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200274#define OMAP3430_PERIPH_DPLL_RECAL_EN_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600275#define OMAP3430_CORE_DPLL_RECAL_EN_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200276#define OMAP3430_CORE_DPLL_RECAL_EN_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600277#define OMAP3430_TRANSITION_EN_MASK (1 << 4)
278#define OMAP3430_EVGENOFF_EN_MASK (1 << 3)
279#define OMAP3430_EVGENON_EN_MASK (1 << 2)
280#define OMAP3430_FS_USB_WKUP_EN_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200281
282/* RM_RSTST_MPU specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600283#define OMAP3430_EMULATION_MPU_RST_MASK (1 << 11)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200284
285/* PM_WKDEP_MPU specific bits */
Paul Walmsleyecb24aa2008-08-19 11:08:43 +0300286#define OMAP3430_PM_WKDEP_MPU_EN_DSS_SHIFT 5
287#define OMAP3430_PM_WKDEP_MPU_EN_DSS_MASK (1 << 5)
288#define OMAP3430_PM_WKDEP_MPU_EN_IVA2_SHIFT 2
289#define OMAP3430_PM_WKDEP_MPU_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200290
291/* PM_EVGENCTRL_MPU */
292#define OMAP3430_OFFLOADMODE_SHIFT 3
293#define OMAP3430_OFFLOADMODE_MASK (0x3 << 3)
294#define OMAP3430_ONLOADMODE_SHIFT 1
295#define OMAP3430_ONLOADMODE_MASK (0x3 << 1)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600296#define OMAP3430_ENABLE_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200297
298/* PM_EVGENONTIM_MPU */
299#define OMAP3430_ONTIMEVAL_SHIFT 0
300#define OMAP3430_ONTIMEVAL_MASK (0xffffffff << 0)
301
302/* PM_EVGENOFFTIM_MPU */
303#define OMAP3430_OFFTIMEVAL_SHIFT 0
304#define OMAP3430_OFFTIMEVAL_MASK (0xffffffff << 0)
305
306/* PM_PWSTCTRL_MPU specific bits */
307#define OMAP3430_L2CACHEONSTATE_SHIFT 16
308#define OMAP3430_L2CACHEONSTATE_MASK (0x3 << 16)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600309#define OMAP3430_L2CACHERETSTATE_MASK (1 << 8)
310#define OMAP3430_LOGICL1CACHERETSTATE_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200311
312/* PM_PWSTST_MPU specific bits */
313#define OMAP3430_L2CACHESTATEST_SHIFT 6
314#define OMAP3430_L2CACHESTATEST_MASK (0x3 << 6)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600315#define OMAP3430_LOGICL1CACHESTATEST_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200316
317/* PM_PREPWSTST_MPU specific bits */
318#define OMAP3430_LASTL2CACHESTATEENTERED_SHIFT 6
319#define OMAP3430_LASTL2CACHESTATEENTERED_MASK (0x3 << 6)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600320#define OMAP3430_LASTLOGICL1CACHESTATEENTERED_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200321
322/* RM_RSTCTRL_CORE */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600323#define OMAP3430_RM_RSTCTRL_CORE_MODEM_SW_RSTPWRON_MASK (1 << 1)
324#define OMAP3430_RM_RSTCTRL_CORE_MODEM_SW_RST_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200325
326/* RM_RSTST_CORE specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600327#define OMAP3430_MODEM_SECURITY_VIOL_RST_MASK (1 << 10)
328#define OMAP3430_RM_RSTST_CORE_MODEM_SW_RSTPWRON_MASK (1 << 9)
329#define OMAP3430_RM_RSTST_CORE_MODEM_SW_RST_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200330
331/* PM_WKEN1_CORE specific bits */
332
333/* PM_MPUGRPSEL1_CORE specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600334#define OMAP3430_GRPSEL_FSHOSTUSB_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200335
336/* PM_IVA2GRPSEL1_CORE specific bits */
337
338/* PM_WKST1_CORE specific bits */
339
340/* PM_PWSTCTRL_CORE specific bits */
341#define OMAP3430_MEM2ONSTATE_SHIFT 18
342#define OMAP3430_MEM2ONSTATE_MASK (0x3 << 18)
343#define OMAP3430_MEM1ONSTATE_SHIFT 16
344#define OMAP3430_MEM1ONSTATE_MASK (0x3 << 16)
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600345#define OMAP3430_MEM2RETSTATE_MASK (1 << 9)
346#define OMAP3430_MEM1RETSTATE_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200347
348/* PM_PWSTST_CORE specific bits */
349#define OMAP3430_MEM2STATEST_SHIFT 6
350#define OMAP3430_MEM2STATEST_MASK (0x3 << 6)
351#define OMAP3430_MEM1STATEST_SHIFT 4
352#define OMAP3430_MEM1STATEST_MASK (0x3 << 4)
353
354/* PM_PREPWSTST_CORE specific bits */
355#define OMAP3430_LASTMEM2STATEENTERED_SHIFT 6
356#define OMAP3430_LASTMEM2STATEENTERED_MASK (0x3 << 6)
357#define OMAP3430_LASTMEM1STATEENTERED_SHIFT 4
358#define OMAP3430_LASTMEM1STATEENTERED_MASK (0x3 << 4)
359
360/* RM_RSTST_GFX specific bits */
361
362/* PM_WKDEP_GFX specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600363#define OMAP3430_PM_WKDEP_GFX_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200364
365/* PM_PWSTCTRL_GFX specific bits */
366
367/* PM_PWSTST_GFX specific bits */
368
369/* PM_PREPWSTST_GFX specific bits */
370
371/* PM_WKEN_WKUP specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600372#define OMAP3430_EN_IO_CHAIN_MASK (1 << 16)
373#define OMAP3430_EN_IO_MASK (1 << 8)
374#define OMAP3430_EN_GPIO1_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200375
376/* PM_MPUGRPSEL_WKUP specific bits */
377
378/* PM_IVA2GRPSEL_WKUP specific bits */
379
380/* PM_WKST_WKUP specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600381#define OMAP3430_ST_IO_CHAIN_MASK (1 << 16)
382#define OMAP3430_ST_IO_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200383
384/* PRM_CLKSEL */
385#define OMAP3430_SYS_CLKIN_SEL_SHIFT 0
386#define OMAP3430_SYS_CLKIN_SEL_MASK (0x7 << 0)
387
388/* PRM_CLKOUT_CTRL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600389#define OMAP3430_CLKOUT_EN_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200390#define OMAP3430_CLKOUT_EN_SHIFT 7
391
392/* RM_RSTST_DSS specific bits */
393
394/* PM_WKEN_DSS */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600395#define OMAP3430_PM_WKEN_DSS_EN_DSS_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200396
397/* PM_WKDEP_DSS specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600398#define OMAP3430_PM_WKDEP_DSS_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200399
400/* PM_PWSTCTRL_DSS specific bits */
401
402/* PM_PWSTST_DSS specific bits */
403
404/* PM_PREPWSTST_DSS specific bits */
405
406/* RM_RSTST_CAM specific bits */
407
408/* PM_WKDEP_CAM specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600409#define OMAP3430_PM_WKDEP_CAM_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200410
411/* PM_PWSTCTRL_CAM specific bits */
412
413/* PM_PWSTST_CAM specific bits */
414
415/* PM_PREPWSTST_CAM specific bits */
416
417/* PM_PWSTCTRL_USBHOST specific bits */
Kalle Jokiniemi8dbe4392009-05-16 08:28:17 -0700418#define OMAP3430ES2_SAVEANDRESTORE_SHIFT 4
Tony Lindgrenc5957132008-03-18 14:53:17 +0200419
420/* RM_RSTST_PER specific bits */
421
422/* PM_WKEN_PER specific bits */
423
424/* PM_MPUGRPSEL_PER specific bits */
425
426/* PM_IVA2GRPSEL_PER specific bits */
427
428/* PM_WKST_PER specific bits */
429
430/* PM_WKDEP_PER specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600431#define OMAP3430_PM_WKDEP_PER_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200432
433/* PM_PWSTCTRL_PER specific bits */
434
435/* PM_PWSTST_PER specific bits */
436
437/* PM_PREPWSTST_PER specific bits */
438
439/* RM_RSTST_EMU specific bits */
440
441/* PM_PWSTST_EMU specific bits */
442
443/* PRM_VC_SMPS_SA */
444#define OMAP3430_PRM_VC_SMPS_SA_SA1_SHIFT 16
445#define OMAP3430_PRM_VC_SMPS_SA_SA1_MASK (0x7f << 16)
446#define OMAP3430_PRM_VC_SMPS_SA_SA0_SHIFT 0
447#define OMAP3430_PRM_VC_SMPS_SA_SA0_MASK (0x7f << 0)
448
449/* PRM_VC_SMPS_VOL_RA */
450#define OMAP3430_VOLRA1_SHIFT 16
451#define OMAP3430_VOLRA1_MASK (0xff << 16)
452#define OMAP3430_VOLRA0_SHIFT 0
453#define OMAP3430_VOLRA0_MASK (0xff << 0)
454
455/* PRM_VC_SMPS_CMD_RA */
456#define OMAP3430_CMDRA1_SHIFT 16
457#define OMAP3430_CMDRA1_MASK (0xff << 16)
458#define OMAP3430_CMDRA0_SHIFT 0
459#define OMAP3430_CMDRA0_MASK (0xff << 0)
460
461/* PRM_VC_CMD_VAL_0 specific bits */
Jouni Hogander027d8de2008-05-16 13:58:18 +0300462#define OMAP3430_VC_CMD_ON_SHIFT 24
463#define OMAP3430_VC_CMD_ON_MASK (0xFF << 24)
464#define OMAP3430_VC_CMD_ONLP_SHIFT 16
465#define OMAP3430_VC_CMD_ONLP_MASK (0xFF << 16)
466#define OMAP3430_VC_CMD_RET_SHIFT 8
467#define OMAP3430_VC_CMD_RET_MASK (0xFF << 8)
468#define OMAP3430_VC_CMD_OFF_SHIFT 0
469#define OMAP3430_VC_CMD_OFF_MASK (0xFF << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200470
471/* PRM_VC_CMD_VAL_1 specific bits */
472
473/* PRM_VC_CH_CONF */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600474#define OMAP3430_CMD1_MASK (1 << 20)
475#define OMAP3430_RACEN1_MASK (1 << 19)
476#define OMAP3430_RAC1_MASK (1 << 18)
477#define OMAP3430_RAV1_MASK (1 << 17)
478#define OMAP3430_PRM_VC_CH_CONF_SA1_MASK (1 << 16)
479#define OMAP3430_CMD0_MASK (1 << 4)
480#define OMAP3430_RACEN0_MASK (1 << 3)
481#define OMAP3430_RAC0_MASK (1 << 2)
482#define OMAP3430_RAV0_MASK (1 << 1)
483#define OMAP3430_PRM_VC_CH_CONF_SA0_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200484
485/* PRM_VC_I2C_CFG */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600486#define OMAP3430_HSMASTER_MASK (1 << 5)
487#define OMAP3430_SREN_MASK (1 << 4)
488#define OMAP3430_HSEN_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200489#define OMAP3430_MCODE_SHIFT 0
490#define OMAP3430_MCODE_MASK (0x7 << 0)
491
492/* PRM_VC_BYPASS_VAL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600493#define OMAP3430_VALID_MASK (1 << 24)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200494#define OMAP3430_DATA_SHIFT 16
495#define OMAP3430_DATA_MASK (0xff << 16)
496#define OMAP3430_REGADDR_SHIFT 8
497#define OMAP3430_REGADDR_MASK (0xff << 8)
498#define OMAP3430_SLAVEADDR_SHIFT 0
499#define OMAP3430_SLAVEADDR_MASK (0x7f << 0)
500
501/* PRM_RSTCTRL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600502#define OMAP3430_RST_DPLL3_MASK (1 << 2)
503#define OMAP3430_RST_GS_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200504
505/* PRM_RSTTIME */
506#define OMAP3430_RSTTIME2_SHIFT 8
507#define OMAP3430_RSTTIME2_MASK (0x1f << 8)
508#define OMAP3430_RSTTIME1_SHIFT 0
509#define OMAP3430_RSTTIME1_MASK (0xff << 0)
510
511/* PRM_RSTST */
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600512#define OMAP3430_ICECRUSHER_RST_SHIFT 10
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600513#define OMAP3430_ICECRUSHER_RST_MASK (1 << 10)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600514#define OMAP3430_ICEPICK_RST_SHIFT 9
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600515#define OMAP3430_ICEPICK_RST_MASK (1 << 9)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600516#define OMAP3430_VDD2_VOLTAGE_MANAGER_RST_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600517#define OMAP3430_VDD2_VOLTAGE_MANAGER_RST_MASK (1 << 8)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600518#define OMAP3430_VDD1_VOLTAGE_MANAGER_RST_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600519#define OMAP3430_VDD1_VOLTAGE_MANAGER_RST_MASK (1 << 7)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600520#define OMAP3430_EXTERNAL_WARM_RST_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600521#define OMAP3430_EXTERNAL_WARM_RST_MASK (1 << 6)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600522#define OMAP3430_SECURE_WD_RST_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600523#define OMAP3430_SECURE_WD_RST_MASK (1 << 5)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600524#define OMAP3430_MPU_WD_RST_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600525#define OMAP3430_MPU_WD_RST_MASK (1 << 4)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600526#define OMAP3430_SECURITY_VIOL_RST_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600527#define OMAP3430_SECURITY_VIOL_RST_MASK (1 << 3)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600528#define OMAP3430_GLOBAL_SW_RST_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600529#define OMAP3430_GLOBAL_SW_RST_MASK (1 << 1)
Paul Walmsley2bb2a5d2012-10-21 01:01:13 -0600530#define OMAP3430_GLOBAL_COLD_RST_SHIFT 0
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600531#define OMAP3430_GLOBAL_COLD_RST_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200532
533/* PRM_VOLTCTRL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600534#define OMAP3430_SEL_VMODE_MASK (1 << 4)
535#define OMAP3430_SEL_OFF_MASK (1 << 3)
536#define OMAP3430_AUTO_OFF_MASK (1 << 2)
537#define OMAP3430_AUTO_RET_MASK (1 << 1)
538#define OMAP3430_AUTO_SLEEP_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200539
540/* PRM_SRAM_PCHARGE */
541#define OMAP3430_PCHARGE_TIME_SHIFT 0
542#define OMAP3430_PCHARGE_TIME_MASK (0xff << 0)
543
544/* PRM_CLKSRC_CTRL */
545#define OMAP3430_SYSCLKDIV_SHIFT 6
546#define OMAP3430_SYSCLKDIV_MASK (0x3 << 6)
547#define OMAP3430_AUTOEXTCLKMODE_SHIFT 3
548#define OMAP3430_AUTOEXTCLKMODE_MASK (0x3 << 3)
549#define OMAP3430_SYSCLKSEL_SHIFT 0
550#define OMAP3430_SYSCLKSEL_MASK (0x3 << 0)
551
552/* PRM_VOLTSETUP1 */
553#define OMAP3430_SETUP_TIME2_SHIFT 16
554#define OMAP3430_SETUP_TIME2_MASK (0xffff << 16)
555#define OMAP3430_SETUP_TIME1_SHIFT 0
556#define OMAP3430_SETUP_TIME1_MASK (0xffff << 0)
557
558/* PRM_VOLTOFFSET */
559#define OMAP3430_OFFSET_TIME_SHIFT 0
560#define OMAP3430_OFFSET_TIME_MASK (0xffff << 0)
561
562/* PRM_CLKSETUP */
563#define OMAP3430_SETUP_TIME_SHIFT 0
564#define OMAP3430_SETUP_TIME_MASK (0xffff << 0)
565
566/* PRM_POLCTRL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600567#define OMAP3430_OFFMODE_POL_MASK (1 << 3)
568#define OMAP3430_CLKOUT_POL_MASK (1 << 2)
569#define OMAP3430_CLKREQ_POL_MASK (1 << 1)
570#define OMAP3430_EXTVOL_POL_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200571
572/* PRM_VOLTSETUP2 */
573#define OMAP3430_OFFMODESETUPTIME_SHIFT 0
574#define OMAP3430_OFFMODESETUPTIME_MASK (0xffff << 0)
575
576/* PRM_VP1_CONFIG specific bits */
577
578/* PRM_VP1_VSTEPMIN specific bits */
579
580/* PRM_VP1_VSTEPMAX specific bits */
581
582/* PRM_VP1_VLIMITTO specific bits */
583
584/* PRM_VP1_VOLTAGE specific bits */
585
586/* PRM_VP1_STATUS specific bits */
587
588/* PRM_VP2_CONFIG specific bits */
589
590/* PRM_VP2_VSTEPMIN specific bits */
591
592/* PRM_VP2_VSTEPMAX specific bits */
593
594/* PRM_VP2_VLIMITTO specific bits */
595
596/* PRM_VP2_VOLTAGE specific bits */
597
598/* PRM_VP2_STATUS specific bits */
599
600/* RM_RSTST_NEON specific bits */
601
602/* PM_WKDEP_NEON specific bits */
603
604/* PM_PWSTCTRL_NEON specific bits */
605
606/* PM_PWSTST_NEON specific bits */
607
608/* PM_PREPWSTST_NEON specific bits */
609
610#endif