blob: 4f959a7d881c82712557f58f2f0115d358af868a [file] [log] [blame]
Tony Lindgrenc5957132008-03-18 14:53:17 +02001#ifndef __ARCH_ARM_MACH_OMAP2_CM_REGBITS_34XX_H
2#define __ARCH_ARM_MACH_OMAP2_CM_REGBITS_34XX_H
3
4/*
5 * OMAP3430 Clock Management register bits
6 *
7 * Copyright (C) 2007-2008 Texas Instruments, Inc.
8 * Copyright (C) 2007-2008 Nokia Corporation
9 *
10 * Written by Paul Walmsley
11 *
12 * This program is free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License version 2 as
14 * published by the Free Software Foundation.
15 */
16
17#include "cm.h"
18
19/* Bits shared between registers */
20
21/* CM_FCLKEN1_CORE and CM_ICLKEN1_CORE shared bits */
22#define OMAP3430ES2_EN_MMC3_MASK (1 << 30)
23#define OMAP3430ES2_EN_MMC3_SHIFT 30
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060024#define OMAP3430_EN_MSPRO_MASK (1 << 23)
Tony Lindgrenc5957132008-03-18 14:53:17 +020025#define OMAP3430_EN_MSPRO_SHIFT 23
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060026#define OMAP3430_EN_HDQ_MASK (1 << 22)
Tony Lindgrenc5957132008-03-18 14:53:17 +020027#define OMAP3430_EN_HDQ_SHIFT 22
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060028#define OMAP3430ES1_EN_FSHOSTUSB_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +020029#define OMAP3430ES1_EN_FSHOSTUSB_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060030#define OMAP3430ES1_EN_D2D_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +020031#define OMAP3430ES1_EN_D2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060032#define OMAP3430_EN_SSI_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020033#define OMAP3430_EN_SSI_SHIFT 0
34
35/* CM_FCLKEN3_CORE and CM_ICLKEN3_CORE shared bits */
36#define OMAP3430ES2_EN_USBTLL_SHIFT 2
37#define OMAP3430ES2_EN_USBTLL_MASK (1 << 2)
38
39/* CM_FCLKEN_WKUP and CM_ICLKEN_WKUP shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060040#define OMAP3430_EN_WDT2_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +020041#define OMAP3430_EN_WDT2_SHIFT 5
42
43/* CM_ICLKEN_CAM, CM_FCLKEN_CAM shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060044#define OMAP3430_EN_CAM_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020045#define OMAP3430_EN_CAM_SHIFT 0
46
47/* CM_FCLKEN_PER, CM_ICLKEN_PER shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060048#define OMAP3430_EN_WDT3_MASK (1 << 12)
Tony Lindgrenc5957132008-03-18 14:53:17 +020049#define OMAP3430_EN_WDT3_SHIFT 12
50
51/* CM_CLKSEL2_EMU, CM_CLKSEL3_EMU shared bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060052#define OMAP3430_OVERRIDE_ENABLE_MASK (1 << 19)
Tony Lindgrenc5957132008-03-18 14:53:17 +020053
54
55/* Bits specific to each register */
56
57/* CM_FCLKEN_IVA2 */
Kevin Hilmandfa6d6f2010-02-24 12:05:48 -070058#define OMAP3430_CM_FCLKEN_IVA2_EN_IVA2_MASK (1 << 0)
Hiroshi DOYU31c203d2008-04-01 10:11:22 +030059#define OMAP3430_CM_FCLKEN_IVA2_EN_IVA2_SHIFT 0
Tony Lindgrenc5957132008-03-18 14:53:17 +020060
61/* CM_CLKEN_PLL_IVA2 */
62#define OMAP3430_IVA2_DPLL_RAMPTIME_SHIFT 8
63#define OMAP3430_IVA2_DPLL_RAMPTIME_MASK (0x3 << 8)
64#define OMAP3430_IVA2_DPLL_FREQSEL_SHIFT 4
65#define OMAP3430_IVA2_DPLL_FREQSEL_MASK (0xf << 4)
66#define OMAP3430_EN_IVA2_DPLL_DRIFTGUARD_SHIFT 3
67#define OMAP3430_EN_IVA2_DPLL_DRIFTGUARD_MASK (1 << 3)
68#define OMAP3430_EN_IVA2_DPLL_SHIFT 0
69#define OMAP3430_EN_IVA2_DPLL_MASK (0x7 << 0)
70
71/* CM_IDLEST_IVA2 */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -060072#define OMAP3430_ST_IVA2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020073
74/* CM_IDLEST_PLL_IVA2 */
Paul Walmsley542313c2008-07-03 12:24:45 +030075#define OMAP3430_ST_IVA2_CLK_SHIFT 0
76#define OMAP3430_ST_IVA2_CLK_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +020077
78/* CM_AUTOIDLE_PLL_IVA2 */
79#define OMAP3430_AUTO_IVA2_DPLL_SHIFT 0
80#define OMAP3430_AUTO_IVA2_DPLL_MASK (0x7 << 0)
81
82/* CM_CLKSEL1_PLL_IVA2 */
83#define OMAP3430_IVA2_CLK_SRC_SHIFT 19
84#define OMAP3430_IVA2_CLK_SRC_MASK (0x3 << 19)
85#define OMAP3430_IVA2_DPLL_MULT_SHIFT 8
86#define OMAP3430_IVA2_DPLL_MULT_MASK (0x7ff << 8)
87#define OMAP3430_IVA2_DPLL_DIV_SHIFT 0
88#define OMAP3430_IVA2_DPLL_DIV_MASK (0x7f << 0)
89
90/* CM_CLKSEL2_PLL_IVA2 */
91#define OMAP3430_IVA2_DPLL_CLKOUT_DIV_SHIFT 0
92#define OMAP3430_IVA2_DPLL_CLKOUT_DIV_MASK (0x1f << 0)
93
94/* CM_CLKSTCTRL_IVA2 */
95#define OMAP3430_CLKTRCTRL_IVA2_SHIFT 0
96#define OMAP3430_CLKTRCTRL_IVA2_MASK (0x3 << 0)
97
98/* CM_CLKSTST_IVA2 */
Paul Walmsley801954d2008-08-19 11:08:44 +030099#define OMAP3430_CLKACTIVITY_IVA2_SHIFT 0
100#define OMAP3430_CLKACTIVITY_IVA2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200101
102/* CM_REVISION specific bits */
103
104/* CM_SYSCONFIG specific bits */
105
106/* CM_CLKEN_PLL_MPU */
107#define OMAP3430_MPU_DPLL_RAMPTIME_SHIFT 8
108#define OMAP3430_MPU_DPLL_RAMPTIME_MASK (0x3 << 8)
109#define OMAP3430_MPU_DPLL_FREQSEL_SHIFT 4
110#define OMAP3430_MPU_DPLL_FREQSEL_MASK (0xf << 4)
111#define OMAP3430_EN_MPU_DPLL_DRIFTGUARD_SHIFT 3
112#define OMAP3430_EN_MPU_DPLL_DRIFTGUARD_MASK (1 << 3)
113#define OMAP3430_EN_MPU_DPLL_SHIFT 0
114#define OMAP3430_EN_MPU_DPLL_MASK (0x7 << 0)
115
116/* CM_IDLEST_MPU */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600117#define OMAP3430_ST_MPU_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200118
119/* CM_IDLEST_PLL_MPU */
Paul Walmsley542313c2008-07-03 12:24:45 +0300120#define OMAP3430_ST_MPU_CLK_SHIFT 0
Roman Tereshonkov3760d312008-03-13 21:35:09 +0200121#define OMAP3430_ST_MPU_CLK_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200122
123/* CM_AUTOIDLE_PLL_MPU */
124#define OMAP3430_AUTO_MPU_DPLL_SHIFT 0
125#define OMAP3430_AUTO_MPU_DPLL_MASK (0x7 << 0)
126
127/* CM_CLKSEL1_PLL_MPU */
128#define OMAP3430_MPU_CLK_SRC_SHIFT 19
129#define OMAP3430_MPU_CLK_SRC_MASK (0x3 << 19)
130#define OMAP3430_MPU_DPLL_MULT_SHIFT 8
131#define OMAP3430_MPU_DPLL_MULT_MASK (0x7ff << 8)
132#define OMAP3430_MPU_DPLL_DIV_SHIFT 0
133#define OMAP3430_MPU_DPLL_DIV_MASK (0x7f << 0)
134
135/* CM_CLKSEL2_PLL_MPU */
136#define OMAP3430_MPU_DPLL_CLKOUT_DIV_SHIFT 0
137#define OMAP3430_MPU_DPLL_CLKOUT_DIV_MASK (0x1f << 0)
138
139/* CM_CLKSTCTRL_MPU */
140#define OMAP3430_CLKTRCTRL_MPU_SHIFT 0
141#define OMAP3430_CLKTRCTRL_MPU_MASK (0x3 << 0)
142
143/* CM_CLKSTST_MPU */
Paul Walmsley801954d2008-08-19 11:08:44 +0300144#define OMAP3430_CLKACTIVITY_MPU_SHIFT 0
145#define OMAP3430_CLKACTIVITY_MPU_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200146
147/* CM_FCLKEN1_CORE specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600148#define OMAP3430_EN_MODEM_MASK (1 << 31)
Kevin Hilman8111b222009-04-28 15:27:44 -0700149#define OMAP3430_EN_MODEM_SHIFT 31
Tony Lindgrenc5957132008-03-18 14:53:17 +0200150
151/* CM_ICLKEN1_CORE specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600152#define OMAP3430_EN_ICR_MASK (1 << 29)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200153#define OMAP3430_EN_ICR_SHIFT 29
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600154#define OMAP3430_EN_AES2_MASK (1 << 28)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200155#define OMAP3430_EN_AES2_SHIFT 28
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600156#define OMAP3430_EN_SHA12_MASK (1 << 27)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200157#define OMAP3430_EN_SHA12_SHIFT 27
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600158#define OMAP3430_EN_DES2_MASK (1 << 26)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200159#define OMAP3430_EN_DES2_SHIFT 26
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600160#define OMAP3430ES1_EN_FAC_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200161#define OMAP3430ES1_EN_FAC_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600162#define OMAP3430_EN_MAILBOXES_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200163#define OMAP3430_EN_MAILBOXES_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600164#define OMAP3430_EN_OMAPCTRL_MASK (1 << 6)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200165#define OMAP3430_EN_OMAPCTRL_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600166#define OMAP3430_EN_SAD2D_MASK (1 << 3)
Kevin Hilman8111b222009-04-28 15:27:44 -0700167#define OMAP3430_EN_SAD2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600168#define OMAP3430_EN_SDRC_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200169#define OMAP3430_EN_SDRC_SHIFT 1
170
Ranjith Lohithakshan3cc4a2f2010-02-24 12:05:55 -0700171/* AM35XX specific CM_ICLKEN1_CORE bits */
172#define AM35XX_EN_IPSS_MASK (1 << 4)
173#define AM35XX_EN_IPSS_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600174#define AM35XX_EN_UART4_MASK (1 << 23)
Ranjith Lohithakshan3cc4a2f2010-02-24 12:05:55 -0700175#define AM35XX_EN_UART4_SHIFT 23
176
Tony Lindgrenc5957132008-03-18 14:53:17 +0200177/* CM_ICLKEN2_CORE */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600178#define OMAP3430_EN_PKA_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200179#define OMAP3430_EN_PKA_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600180#define OMAP3430_EN_AES1_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200181#define OMAP3430_EN_AES1_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600182#define OMAP3430_EN_RNG_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200183#define OMAP3430_EN_RNG_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600184#define OMAP3430_EN_SHA11_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200185#define OMAP3430_EN_SHA11_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600186#define OMAP3430_EN_DES1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200187#define OMAP3430_EN_DES1_SHIFT 0
188
Kevin Hilman8111b222009-04-28 15:27:44 -0700189/* CM_ICLKEN3_CORE */
190#define OMAP3430_EN_MAD2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600191#define OMAP3430_EN_MAD2D_MASK (1 << 3)
Kevin Hilman8111b222009-04-28 15:27:44 -0700192
Tony Lindgrenc5957132008-03-18 14:53:17 +0200193/* CM_FCLKEN3_CORE specific bits */
194#define OMAP3430ES2_EN_TS_SHIFT 1
195#define OMAP3430ES2_EN_TS_MASK (1 << 1)
196#define OMAP3430ES2_EN_CPEFUSE_SHIFT 0
197#define OMAP3430ES2_EN_CPEFUSE_MASK (1 << 0)
198
199/* CM_IDLEST1_CORE specific bits */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700200#define OMAP3430ES2_ST_MMC3_SHIFT 30
201#define OMAP3430ES2_ST_MMC3_MASK (1 << 30)
202#define OMAP3430_ST_ICR_SHIFT 29
203#define OMAP3430_ST_ICR_MASK (1 << 29)
204#define OMAP3430_ST_AES2_SHIFT 28
205#define OMAP3430_ST_AES2_MASK (1 << 28)
206#define OMAP3430_ST_SHA12_SHIFT 27
207#define OMAP3430_ST_SHA12_MASK (1 << 27)
208#define OMAP3430_ST_DES2_SHIFT 26
209#define OMAP3430_ST_DES2_MASK (1 << 26)
210#define OMAP3430_ST_MSPRO_SHIFT 23
211#define OMAP3430_ST_MSPRO_MASK (1 << 23)
212#define OMAP3430_ST_HDQ_SHIFT 22
213#define OMAP3430_ST_HDQ_MASK (1 << 22)
214#define OMAP3430ES1_ST_FAC_SHIFT 8
215#define OMAP3430ES1_ST_FAC_MASK (1 << 8)
216#define OMAP3430ES2_ST_SSI_IDLE_SHIFT 8
217#define OMAP3430ES2_ST_SSI_IDLE_MASK (1 << 8)
218#define OMAP3430_ST_MAILBOXES_SHIFT 7
219#define OMAP3430_ST_MAILBOXES_MASK (1 << 7)
220#define OMAP3430_ST_OMAPCTRL_SHIFT 6
221#define OMAP3430_ST_OMAPCTRL_MASK (1 << 6)
222#define OMAP3430_ST_SDMA_SHIFT 2
223#define OMAP3430_ST_SDMA_MASK (1 << 2)
224#define OMAP3430_ST_SDRC_SHIFT 1
225#define OMAP3430_ST_SDRC_MASK (1 << 1)
226#define OMAP3430_ST_SSI_STDBY_SHIFT 0
227#define OMAP3430_ST_SSI_STDBY_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200228
Ranjith Lohithakshan3cc4a2f2010-02-24 12:05:55 -0700229/* AM35xx specific CM_IDLEST1_CORE bits */
230#define AM35XX_ST_IPSS_SHIFT 5
231#define AM35XX_ST_IPSS_MASK (1 << 5)
232
Tony Lindgrenc5957132008-03-18 14:53:17 +0200233/* CM_IDLEST2_CORE */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700234#define OMAP3430_ST_PKA_SHIFT 4
235#define OMAP3430_ST_PKA_MASK (1 << 4)
236#define OMAP3430_ST_AES1_SHIFT 3
237#define OMAP3430_ST_AES1_MASK (1 << 3)
238#define OMAP3430_ST_RNG_SHIFT 2
239#define OMAP3430_ST_RNG_MASK (1 << 2)
240#define OMAP3430_ST_SHA11_SHIFT 1
241#define OMAP3430_ST_SHA11_MASK (1 << 1)
242#define OMAP3430_ST_DES1_SHIFT 0
243#define OMAP3430_ST_DES1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200244
245/* CM_IDLEST3_CORE */
246#define OMAP3430ES2_ST_USBTLL_SHIFT 2
247#define OMAP3430ES2_ST_USBTLL_MASK (1 << 2)
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700248#define OMAP3430ES2_ST_CPEFUSE_SHIFT 0
249#define OMAP3430ES2_ST_CPEFUSE_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200250
251/* CM_AUTOIDLE1_CORE */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600252#define OMAP3430_AUTO_MODEM_MASK (1 << 31)
Kevin Hilman8111b222009-04-28 15:27:44 -0700253#define OMAP3430_AUTO_MODEM_SHIFT 31
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600254#define OMAP3430ES2_AUTO_MMC3_MASK (1 << 30)
Jouni Hogander027d8de2008-05-16 13:58:18 +0300255#define OMAP3430ES2_AUTO_MMC3_SHIFT 30
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600256#define OMAP3430ES2_AUTO_ICR_MASK (1 << 29)
Jouni Hogander027d8de2008-05-16 13:58:18 +0300257#define OMAP3430ES2_AUTO_ICR_SHIFT 29
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600258#define OMAP3430_AUTO_AES2_MASK (1 << 28)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200259#define OMAP3430_AUTO_AES2_SHIFT 28
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600260#define OMAP3430_AUTO_SHA12_MASK (1 << 27)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200261#define OMAP3430_AUTO_SHA12_SHIFT 27
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600262#define OMAP3430_AUTO_DES2_MASK (1 << 26)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200263#define OMAP3430_AUTO_DES2_SHIFT 26
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600264#define OMAP3430_AUTO_MMC2_MASK (1 << 25)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200265#define OMAP3430_AUTO_MMC2_SHIFT 25
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600266#define OMAP3430_AUTO_MMC1_MASK (1 << 24)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200267#define OMAP3430_AUTO_MMC1_SHIFT 24
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600268#define OMAP3430_AUTO_MSPRO_MASK (1 << 23)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200269#define OMAP3430_AUTO_MSPRO_SHIFT 23
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600270#define OMAP3430_AUTO_HDQ_MASK (1 << 22)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200271#define OMAP3430_AUTO_HDQ_SHIFT 22
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600272#define OMAP3430_AUTO_MCSPI4_MASK (1 << 21)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200273#define OMAP3430_AUTO_MCSPI4_SHIFT 21
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600274#define OMAP3430_AUTO_MCSPI3_MASK (1 << 20)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200275#define OMAP3430_AUTO_MCSPI3_SHIFT 20
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600276#define OMAP3430_AUTO_MCSPI2_MASK (1 << 19)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200277#define OMAP3430_AUTO_MCSPI2_SHIFT 19
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600278#define OMAP3430_AUTO_MCSPI1_MASK (1 << 18)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200279#define OMAP3430_AUTO_MCSPI1_SHIFT 18
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600280#define OMAP3430_AUTO_I2C3_MASK (1 << 17)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200281#define OMAP3430_AUTO_I2C3_SHIFT 17
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600282#define OMAP3430_AUTO_I2C2_MASK (1 << 16)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200283#define OMAP3430_AUTO_I2C2_SHIFT 16
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600284#define OMAP3430_AUTO_I2C1_MASK (1 << 15)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200285#define OMAP3430_AUTO_I2C1_SHIFT 15
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600286#define OMAP3430_AUTO_UART2_MASK (1 << 14)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200287#define OMAP3430_AUTO_UART2_SHIFT 14
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600288#define OMAP3430_AUTO_UART1_MASK (1 << 13)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200289#define OMAP3430_AUTO_UART1_SHIFT 13
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600290#define OMAP3430_AUTO_GPT11_MASK (1 << 12)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200291#define OMAP3430_AUTO_GPT11_SHIFT 12
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600292#define OMAP3430_AUTO_GPT10_MASK (1 << 11)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200293#define OMAP3430_AUTO_GPT10_SHIFT 11
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600294#define OMAP3430_AUTO_MCBSP5_MASK (1 << 10)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200295#define OMAP3430_AUTO_MCBSP5_SHIFT 10
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600296#define OMAP3430_AUTO_MCBSP1_MASK (1 << 9)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200297#define OMAP3430_AUTO_MCBSP1_SHIFT 9
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600298#define OMAP3430ES1_AUTO_FAC_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200299#define OMAP3430ES1_AUTO_FAC_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600300#define OMAP3430_AUTO_MAILBOXES_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200301#define OMAP3430_AUTO_MAILBOXES_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600302#define OMAP3430_AUTO_OMAPCTRL_MASK (1 << 6)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200303#define OMAP3430_AUTO_OMAPCTRL_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600304#define OMAP3430ES1_AUTO_FSHOSTUSB_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200305#define OMAP3430ES1_AUTO_FSHOSTUSB_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600306#define OMAP3430_AUTO_HSOTGUSB_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200307#define OMAP3430_AUTO_HSOTGUSB_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600308#define OMAP3430ES1_AUTO_D2D_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200309#define OMAP3430ES1_AUTO_D2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600310#define OMAP3430_AUTO_SAD2D_MASK (1 << 3)
Kevin Hilman8111b222009-04-28 15:27:44 -0700311#define OMAP3430_AUTO_SAD2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600312#define OMAP3430_AUTO_SSI_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200313#define OMAP3430_AUTO_SSI_SHIFT 0
314
315/* CM_AUTOIDLE2_CORE */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600316#define OMAP3430_AUTO_PKA_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200317#define OMAP3430_AUTO_PKA_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600318#define OMAP3430_AUTO_AES1_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200319#define OMAP3430_AUTO_AES1_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600320#define OMAP3430_AUTO_RNG_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200321#define OMAP3430_AUTO_RNG_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600322#define OMAP3430_AUTO_SHA11_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200323#define OMAP3430_AUTO_SHA11_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600324#define OMAP3430_AUTO_DES1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200325#define OMAP3430_AUTO_DES1_SHIFT 0
326
327/* CM_AUTOIDLE3_CORE */
Jouni Hogander027d8de2008-05-16 13:58:18 +0300328#define OMAP3430ES2_AUTO_USBHOST (1 << 0)
329#define OMAP3430ES2_AUTO_USBHOST_SHIFT 0
330#define OMAP3430ES2_AUTO_USBTLL (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200331#define OMAP3430ES2_AUTO_USBTLL_SHIFT 2
332#define OMAP3430ES2_AUTO_USBTLL_MASK (1 << 2)
Kevin Hilman8111b222009-04-28 15:27:44 -0700333#define OMAP3430_AUTO_MAD2D_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600334#define OMAP3430_AUTO_MAD2D_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200335
336/* CM_CLKSEL_CORE */
337#define OMAP3430_CLKSEL_SSI_SHIFT 8
338#define OMAP3430_CLKSEL_SSI_MASK (0xf << 8)
339#define OMAP3430_CLKSEL_GPT11_MASK (1 << 7)
340#define OMAP3430_CLKSEL_GPT11_SHIFT 7
341#define OMAP3430_CLKSEL_GPT10_MASK (1 << 6)
342#define OMAP3430_CLKSEL_GPT10_SHIFT 6
343#define OMAP3430ES1_CLKSEL_FSHOSTUSB_SHIFT 4
344#define OMAP3430ES1_CLKSEL_FSHOSTUSB_MASK (0x3 << 4)
345#define OMAP3430_CLKSEL_L4_SHIFT 2
346#define OMAP3430_CLKSEL_L4_MASK (0x3 << 2)
347#define OMAP3430_CLKSEL_L3_SHIFT 0
348#define OMAP3430_CLKSEL_L3_MASK (0x3 << 0)
Vishwanath BS7356f0b2010-02-22 22:09:10 -0700349#define OMAP3630_CLKSEL_96M_SHIFT 12
350#define OMAP3630_CLKSEL_96M_MASK (0x3 << 12)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200351
352/* CM_CLKSTCTRL_CORE */
353#define OMAP3430ES1_CLKTRCTRL_D2D_SHIFT 4
354#define OMAP3430ES1_CLKTRCTRL_D2D_MASK (0x3 << 4)
355#define OMAP3430_CLKTRCTRL_L4_SHIFT 2
356#define OMAP3430_CLKTRCTRL_L4_MASK (0x3 << 2)
357#define OMAP3430_CLKTRCTRL_L3_SHIFT 0
358#define OMAP3430_CLKTRCTRL_L3_MASK (0x3 << 0)
359
360/* CM_CLKSTST_CORE */
Paul Walmsley801954d2008-08-19 11:08:44 +0300361#define OMAP3430ES1_CLKACTIVITY_D2D_SHIFT 2
362#define OMAP3430ES1_CLKACTIVITY_D2D_MASK (1 << 2)
363#define OMAP3430_CLKACTIVITY_L4_SHIFT 1
364#define OMAP3430_CLKACTIVITY_L4_MASK (1 << 1)
365#define OMAP3430_CLKACTIVITY_L3_SHIFT 0
366#define OMAP3430_CLKACTIVITY_L3_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200367
368/* CM_FCLKEN_GFX */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600369#define OMAP3430ES1_EN_3D_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200370#define OMAP3430ES1_EN_3D_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600371#define OMAP3430ES1_EN_2D_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200372#define OMAP3430ES1_EN_2D_SHIFT 1
373
374/* CM_ICLKEN_GFX specific bits */
375
376/* CM_IDLEST_GFX specific bits */
377
378/* CM_CLKSEL_GFX specific bits */
379
380/* CM_SLEEPDEP_GFX specific bits */
381
382/* CM_CLKSTCTRL_GFX */
383#define OMAP3430ES1_CLKTRCTRL_GFX_SHIFT 0
384#define OMAP3430ES1_CLKTRCTRL_GFX_MASK (0x3 << 0)
385
386/* CM_CLKSTST_GFX */
Paul Walmsley801954d2008-08-19 11:08:44 +0300387#define OMAP3430ES1_CLKACTIVITY_GFX_SHIFT 0
388#define OMAP3430ES1_CLKACTIVITY_GFX_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200389
390/* CM_FCLKEN_SGX */
Daniel Stone712d7c82009-01-27 19:13:05 -0700391#define OMAP3430ES2_CM_FCLKEN_SGX_EN_SGX_SHIFT 1
392#define OMAP3430ES2_CM_FCLKEN_SGX_EN_SGX_MASK (1 << 1)
393
Tero Kristob024b542010-02-24 12:05:48 -0700394/* CM_IDLEST_SGX */
395#define OMAP3430ES2_ST_SGX_SHIFT 1
396#define OMAP3430ES2_ST_SGX_MASK (1 << 1)
397
Daniel Stone712d7c82009-01-27 19:13:05 -0700398/* CM_ICLKEN_SGX */
399#define OMAP3430ES2_CM_ICLKEN_SGX_EN_SGX_SHIFT 0
400#define OMAP3430ES2_CM_ICLKEN_SGX_EN_SGX_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200401
402/* CM_CLKSEL_SGX */
403#define OMAP3430ES2_CLKSEL_SGX_SHIFT 0
404#define OMAP3430ES2_CLKSEL_SGX_MASK (0x7 << 0)
405
Paul Walmsley801954d2008-08-19 11:08:44 +0300406/* CM_CLKSTCTRL_SGX */
407#define OMAP3430ES2_CLKTRCTRL_SGX_SHIFT 0
408#define OMAP3430ES2_CLKTRCTRL_SGX_MASK (0x3 << 0)
409
410/* CM_CLKSTST_SGX */
411#define OMAP3430ES2_CLKACTIVITY_SGX_SHIFT 0
412#define OMAP3430ES2_CLKACTIVITY_SGX_MASK (1 << 0)
413
Tony Lindgrenc5957132008-03-18 14:53:17 +0200414/* CM_FCLKEN_WKUP specific bits */
415#define OMAP3430ES2_EN_USIMOCP_SHIFT 9
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700416#define OMAP3430ES2_EN_USIMOCP_MASK (1 << 9)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200417
418/* CM_ICLKEN_WKUP specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600419#define OMAP3430_EN_WDT1_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200420#define OMAP3430_EN_WDT1_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600421#define OMAP3430_EN_32KSYNC_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200422#define OMAP3430_EN_32KSYNC_SHIFT 2
423
424/* CM_IDLEST_WKUP specific bits */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700425#define OMAP3430ES2_ST_USIMOCP_SHIFT 9
426#define OMAP3430ES2_ST_USIMOCP_MASK (1 << 9)
427#define OMAP3430_ST_WDT2_SHIFT 5
428#define OMAP3430_ST_WDT2_MASK (1 << 5)
429#define OMAP3430_ST_WDT1_SHIFT 4
430#define OMAP3430_ST_WDT1_MASK (1 << 4)
431#define OMAP3430_ST_32KSYNC_SHIFT 2
432#define OMAP3430_ST_32KSYNC_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200433
434/* CM_AUTOIDLE_WKUP */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600435#define OMAP3430ES2_AUTO_USIMOCP_MASK (1 << 9)
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700436#define OMAP3430ES2_AUTO_USIMOCP_SHIFT 9
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600437#define OMAP3430_AUTO_WDT2_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200438#define OMAP3430_AUTO_WDT2_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600439#define OMAP3430_AUTO_WDT1_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200440#define OMAP3430_AUTO_WDT1_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600441#define OMAP3430_AUTO_GPIO1_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200442#define OMAP3430_AUTO_GPIO1_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600443#define OMAP3430_AUTO_32KSYNC_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200444#define OMAP3430_AUTO_32KSYNC_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600445#define OMAP3430_AUTO_GPT12_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200446#define OMAP3430_AUTO_GPT12_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600447#define OMAP3430_AUTO_GPT1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200448#define OMAP3430_AUTO_GPT1_SHIFT 0
449
450/* CM_CLKSEL_WKUP */
451#define OMAP3430ES2_CLKSEL_USIMOCP_MASK (0xf << 3)
452#define OMAP3430_CLKSEL_RM_SHIFT 1
453#define OMAP3430_CLKSEL_RM_MASK (0x3 << 1)
454#define OMAP3430_CLKSEL_GPT1_SHIFT 0
455#define OMAP3430_CLKSEL_GPT1_MASK (1 << 0)
456
457/* CM_CLKEN_PLL */
458#define OMAP3430_PWRDN_EMU_PERIPH_SHIFT 31
459#define OMAP3430_PWRDN_CAM_SHIFT 30
460#define OMAP3430_PWRDN_DSS1_SHIFT 29
461#define OMAP3430_PWRDN_TV_SHIFT 28
462#define OMAP3430_PWRDN_96M_SHIFT 27
463#define OMAP3430_PERIPH_DPLL_RAMPTIME_SHIFT 24
464#define OMAP3430_PERIPH_DPLL_RAMPTIME_MASK (0x3 << 24)
465#define OMAP3430_PERIPH_DPLL_FREQSEL_SHIFT 20
466#define OMAP3430_PERIPH_DPLL_FREQSEL_MASK (0xf << 20)
467#define OMAP3430_EN_PERIPH_DPLL_DRIFTGUARD_SHIFT 19
468#define OMAP3430_EN_PERIPH_DPLL_DRIFTGUARD_MASK (1 << 19)
469#define OMAP3430_EN_PERIPH_DPLL_SHIFT 16
470#define OMAP3430_EN_PERIPH_DPLL_MASK (0x7 << 16)
471#define OMAP3430_PWRDN_EMU_CORE_SHIFT 12
472#define OMAP3430_CORE_DPLL_RAMPTIME_SHIFT 8
473#define OMAP3430_CORE_DPLL_RAMPTIME_MASK (0x3 << 8)
474#define OMAP3430_CORE_DPLL_FREQSEL_SHIFT 4
475#define OMAP3430_CORE_DPLL_FREQSEL_MASK (0xf << 4)
476#define OMAP3430_EN_CORE_DPLL_DRIFTGUARD_SHIFT 3
477#define OMAP3430_EN_CORE_DPLL_DRIFTGUARD_MASK (1 << 3)
478#define OMAP3430_EN_CORE_DPLL_SHIFT 0
479#define OMAP3430_EN_CORE_DPLL_MASK (0x7 << 0)
480
481/* CM_CLKEN2_PLL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600482#define OMAP3430ES2_EN_PERIPH2_DPLL_LPMODE_SHIFT 10
Tony Lindgrenc5957132008-03-18 14:53:17 +0200483#define OMAP3430ES2_PERIPH2_DPLL_RAMPTIME_MASK (0x3 << 8)
484#define OMAP3430ES2_PERIPH2_DPLL_FREQSEL_SHIFT 4
485#define OMAP3430ES2_PERIPH2_DPLL_FREQSEL_MASK (0xf << 4)
486#define OMAP3430ES2_EN_PERIPH2_DPLL_DRIFTGUARD_SHIFT 3
487#define OMAP3430ES2_EN_PERIPH2_DPLL_SHIFT 0
488#define OMAP3430ES2_EN_PERIPH2_DPLL_MASK (0x7 << 0)
489
490/* CM_IDLEST_CKGEN */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600491#define OMAP3430_ST_54M_CLK_MASK (1 << 5)
492#define OMAP3430_ST_12M_CLK_MASK (1 << 4)
493#define OMAP3430_ST_48M_CLK_MASK (1 << 3)
494#define OMAP3430_ST_96M_CLK_MASK (1 << 2)
Paul Walmsley542313c2008-07-03 12:24:45 +0300495#define OMAP3430_ST_PERIPH_CLK_SHIFT 1
496#define OMAP3430_ST_PERIPH_CLK_MASK (1 << 1)
497#define OMAP3430_ST_CORE_CLK_SHIFT 0
498#define OMAP3430_ST_CORE_CLK_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200499
500/* CM_IDLEST2_CKGEN */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700501#define OMAP3430ES2_ST_USIM_CLK_SHIFT 2
502#define OMAP3430ES2_ST_USIM_CLK_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200503#define OMAP3430ES2_ST_120M_CLK_SHIFT 1
504#define OMAP3430ES2_ST_120M_CLK_MASK (1 << 1)
505#define OMAP3430ES2_ST_PERIPH2_CLK_SHIFT 0
506#define OMAP3430ES2_ST_PERIPH2_CLK_MASK (1 << 0)
507
508/* CM_AUTOIDLE_PLL */
509#define OMAP3430_AUTO_PERIPH_DPLL_SHIFT 3
510#define OMAP3430_AUTO_PERIPH_DPLL_MASK (0x7 << 3)
511#define OMAP3430_AUTO_CORE_DPLL_SHIFT 0
512#define OMAP3430_AUTO_CORE_DPLL_MASK (0x7 << 0)
513
Paul Walmsley542313c2008-07-03 12:24:45 +0300514/* CM_AUTOIDLE2_PLL */
515#define OMAP3430ES2_AUTO_PERIPH2_DPLL_SHIFT 0
516#define OMAP3430ES2_AUTO_PERIPH2_DPLL_MASK (0x7 << 0)
517
Tony Lindgrenc5957132008-03-18 14:53:17 +0200518/* CM_CLKSEL1_PLL */
519/* Note that OMAP3430_CORE_DPLL_CLKOUT_DIV_MASK was (0x3 << 27) on 3430ES1 */
520#define OMAP3430_CORE_DPLL_CLKOUT_DIV_SHIFT 27
521#define OMAP3430_CORE_DPLL_CLKOUT_DIV_MASK (0x1f << 27)
522#define OMAP3430_CORE_DPLL_MULT_SHIFT 16
523#define OMAP3430_CORE_DPLL_MULT_MASK (0x7ff << 16)
524#define OMAP3430_CORE_DPLL_DIV_SHIFT 8
525#define OMAP3430_CORE_DPLL_DIV_MASK (0x7f << 8)
Paul Walmsley9cfd9852009-01-27 19:13:02 -0700526#define OMAP3430_SOURCE_96M_SHIFT 6
527#define OMAP3430_SOURCE_96M_MASK (1 << 6)
528#define OMAP3430_SOURCE_54M_SHIFT 5
529#define OMAP3430_SOURCE_54M_MASK (1 << 5)
530#define OMAP3430_SOURCE_48M_SHIFT 3
531#define OMAP3430_SOURCE_48M_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200532
533/* CM_CLKSEL2_PLL */
534#define OMAP3430_PERIPH_DPLL_MULT_SHIFT 8
535#define OMAP3430_PERIPH_DPLL_MULT_MASK (0x7ff << 8)
Richard Woodruff358965d2010-02-22 22:09:08 -0700536#define OMAP3630_PERIPH_DPLL_MULT_MASK (0xfff << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200537#define OMAP3430_PERIPH_DPLL_DIV_SHIFT 0
538#define OMAP3430_PERIPH_DPLL_DIV_MASK (0x7f << 0)
Richard Woodruff358965d2010-02-22 22:09:08 -0700539#define OMAP3630_PERIPH_DPLL_DCO_SEL_SHIFT 21
540#define OMAP3630_PERIPH_DPLL_DCO_SEL_MASK (0x7 << 21)
541#define OMAP3630_PERIPH_DPLL_SD_DIV_SHIFT 24
542#define OMAP3630_PERIPH_DPLL_SD_DIV_MASK (0xff << 24)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200543
544/* CM_CLKSEL3_PLL */
545#define OMAP3430_DIV_96M_SHIFT 0
546#define OMAP3430_DIV_96M_MASK (0x1f << 0)
Vishwanath BS678bc9a2010-02-22 22:09:09 -0700547#define OMAP3630_DIV_96M_MASK (0x3f << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200548
549/* CM_CLKSEL4_PLL */
550#define OMAP3430ES2_PERIPH2_DPLL_MULT_SHIFT 8
551#define OMAP3430ES2_PERIPH2_DPLL_MULT_MASK (0x7ff << 8)
552#define OMAP3430ES2_PERIPH2_DPLL_DIV_SHIFT 0
553#define OMAP3430ES2_PERIPH2_DPLL_DIV_MASK (0x7f << 0)
554
555/* CM_CLKSEL5_PLL */
556#define OMAP3430ES2_DIV_120M_SHIFT 0
557#define OMAP3430ES2_DIV_120M_MASK (0x1f << 0)
558
559/* CM_CLKOUT_CTRL */
560#define OMAP3430_CLKOUT2_EN_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600561#define OMAP3430_CLKOUT2_EN_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200562#define OMAP3430_CLKOUT2_DIV_SHIFT 3
563#define OMAP3430_CLKOUT2_DIV_MASK (0x7 << 3)
564#define OMAP3430_CLKOUT2SOURCE_SHIFT 0
565#define OMAP3430_CLKOUT2SOURCE_MASK (0x3 << 0)
566
567/* CM_FCLKEN_DSS */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600568#define OMAP3430_EN_TV_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200569#define OMAP3430_EN_TV_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600570#define OMAP3430_EN_DSS2_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200571#define OMAP3430_EN_DSS2_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600572#define OMAP3430_EN_DSS1_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200573#define OMAP3430_EN_DSS1_SHIFT 0
574
575/* CM_ICLKEN_DSS */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600576#define OMAP3430_CM_ICLKEN_DSS_EN_DSS_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200577#define OMAP3430_CM_ICLKEN_DSS_EN_DSS_SHIFT 0
578
579/* CM_IDLEST_DSS */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700580#define OMAP3430ES2_ST_DSS_IDLE_SHIFT 1
581#define OMAP3430ES2_ST_DSS_IDLE_MASK (1 << 1)
582#define OMAP3430ES2_ST_DSS_STDBY_SHIFT 0
583#define OMAP3430ES2_ST_DSS_STDBY_MASK (1 << 0)
584#define OMAP3430ES1_ST_DSS_SHIFT 0
585#define OMAP3430ES1_ST_DSS_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200586
587/* CM_AUTOIDLE_DSS */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600588#define OMAP3430_AUTO_DSS_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200589#define OMAP3430_AUTO_DSS_SHIFT 0
590
591/* CM_CLKSEL_DSS */
592#define OMAP3430_CLKSEL_TV_SHIFT 8
593#define OMAP3430_CLKSEL_TV_MASK (0x1f << 8)
Vishwanath BS678bc9a2010-02-22 22:09:09 -0700594#define OMAP3630_CLKSEL_TV_MASK (0x3f << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200595#define OMAP3430_CLKSEL_DSS1_SHIFT 0
596#define OMAP3430_CLKSEL_DSS1_MASK (0x1f << 0)
Vishwanath BS678bc9a2010-02-22 22:09:09 -0700597#define OMAP3630_CLKSEL_DSS1_MASK (0x3f << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200598
599/* CM_SLEEPDEP_DSS specific bits */
600
601/* CM_CLKSTCTRL_DSS */
602#define OMAP3430_CLKTRCTRL_DSS_SHIFT 0
603#define OMAP3430_CLKTRCTRL_DSS_MASK (0x3 << 0)
604
605/* CM_CLKSTST_DSS */
Paul Walmsley801954d2008-08-19 11:08:44 +0300606#define OMAP3430_CLKACTIVITY_DSS_SHIFT 0
607#define OMAP3430_CLKACTIVITY_DSS_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200608
609/* CM_FCLKEN_CAM specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600610#define OMAP3430_EN_CSI2_MASK (1 << 1)
Sergio Aguirre6c8fe0b2009-01-27 19:13:09 -0700611#define OMAP3430_EN_CSI2_SHIFT 1
Tony Lindgrenc5957132008-03-18 14:53:17 +0200612
613/* CM_ICLKEN_CAM specific bits */
614
615/* CM_IDLEST_CAM */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600616#define OMAP3430_ST_CAM_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200617
618/* CM_AUTOIDLE_CAM */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600619#define OMAP3430_AUTO_CAM_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200620#define OMAP3430_AUTO_CAM_SHIFT 0
621
622/* CM_CLKSEL_CAM */
623#define OMAP3430_CLKSEL_CAM_SHIFT 0
624#define OMAP3430_CLKSEL_CAM_MASK (0x1f << 0)
Vishwanath BS678bc9a2010-02-22 22:09:09 -0700625#define OMAP3630_CLKSEL_CAM_MASK (0x3f << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200626
627/* CM_SLEEPDEP_CAM specific bits */
628
629/* CM_CLKSTCTRL_CAM */
630#define OMAP3430_CLKTRCTRL_CAM_SHIFT 0
631#define OMAP3430_CLKTRCTRL_CAM_MASK (0x3 << 0)
632
633/* CM_CLKSTST_CAM */
Paul Walmsley801954d2008-08-19 11:08:44 +0300634#define OMAP3430_CLKACTIVITY_CAM_SHIFT 0
635#define OMAP3430_CLKACTIVITY_CAM_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200636
637/* CM_FCLKEN_PER specific bits */
638
639/* CM_ICLKEN_PER specific bits */
640
641/* CM_IDLEST_PER */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700642#define OMAP3430_ST_WDT3_SHIFT 12
643#define OMAP3430_ST_WDT3_MASK (1 << 12)
644#define OMAP3430_ST_MCBSP4_SHIFT 2
645#define OMAP3430_ST_MCBSP4_MASK (1 << 2)
646#define OMAP3430_ST_MCBSP3_SHIFT 1
647#define OMAP3430_ST_MCBSP3_MASK (1 << 1)
648#define OMAP3430_ST_MCBSP2_SHIFT 0
649#define OMAP3430_ST_MCBSP2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200650
651/* CM_AUTOIDLE_PER */
Govindraj.Re5863682010-09-27 20:20:25 +0530652#define OMAP3630_AUTO_UART4_MASK (1 << 18)
653#define OMAP3630_AUTO_UART4_SHIFT 18
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600654#define OMAP3430_AUTO_GPIO6_MASK (1 << 17)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200655#define OMAP3430_AUTO_GPIO6_SHIFT 17
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600656#define OMAP3430_AUTO_GPIO5_MASK (1 << 16)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200657#define OMAP3430_AUTO_GPIO5_SHIFT 16
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600658#define OMAP3430_AUTO_GPIO4_MASK (1 << 15)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200659#define OMAP3430_AUTO_GPIO4_SHIFT 15
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600660#define OMAP3430_AUTO_GPIO3_MASK (1 << 14)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200661#define OMAP3430_AUTO_GPIO3_SHIFT 14
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600662#define OMAP3430_AUTO_GPIO2_MASK (1 << 13)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200663#define OMAP3430_AUTO_GPIO2_SHIFT 13
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600664#define OMAP3430_AUTO_WDT3_MASK (1 << 12)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200665#define OMAP3430_AUTO_WDT3_SHIFT 12
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600666#define OMAP3430_AUTO_UART3_MASK (1 << 11)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200667#define OMAP3430_AUTO_UART3_SHIFT 11
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600668#define OMAP3430_AUTO_GPT9_MASK (1 << 10)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200669#define OMAP3430_AUTO_GPT9_SHIFT 10
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600670#define OMAP3430_AUTO_GPT8_MASK (1 << 9)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200671#define OMAP3430_AUTO_GPT8_SHIFT 9
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600672#define OMAP3430_AUTO_GPT7_MASK (1 << 8)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200673#define OMAP3430_AUTO_GPT7_SHIFT 8
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600674#define OMAP3430_AUTO_GPT6_MASK (1 << 7)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200675#define OMAP3430_AUTO_GPT6_SHIFT 7
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600676#define OMAP3430_AUTO_GPT5_MASK (1 << 6)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200677#define OMAP3430_AUTO_GPT5_SHIFT 6
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600678#define OMAP3430_AUTO_GPT4_MASK (1 << 5)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200679#define OMAP3430_AUTO_GPT4_SHIFT 5
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600680#define OMAP3430_AUTO_GPT3_MASK (1 << 4)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200681#define OMAP3430_AUTO_GPT3_SHIFT 4
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600682#define OMAP3430_AUTO_GPT2_MASK (1 << 3)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200683#define OMAP3430_AUTO_GPT2_SHIFT 3
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600684#define OMAP3430_AUTO_MCBSP4_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200685#define OMAP3430_AUTO_MCBSP4_SHIFT 2
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600686#define OMAP3430_AUTO_MCBSP3_MASK (1 << 1)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200687#define OMAP3430_AUTO_MCBSP3_SHIFT 1
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600688#define OMAP3430_AUTO_MCBSP2_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200689#define OMAP3430_AUTO_MCBSP2_SHIFT 0
690
691/* CM_CLKSEL_PER */
692#define OMAP3430_CLKSEL_GPT9_MASK (1 << 7)
693#define OMAP3430_CLKSEL_GPT9_SHIFT 7
694#define OMAP3430_CLKSEL_GPT8_MASK (1 << 6)
695#define OMAP3430_CLKSEL_GPT8_SHIFT 6
696#define OMAP3430_CLKSEL_GPT7_MASK (1 << 5)
697#define OMAP3430_CLKSEL_GPT7_SHIFT 5
698#define OMAP3430_CLKSEL_GPT6_MASK (1 << 4)
699#define OMAP3430_CLKSEL_GPT6_SHIFT 4
700#define OMAP3430_CLKSEL_GPT5_MASK (1 << 3)
701#define OMAP3430_CLKSEL_GPT5_SHIFT 3
702#define OMAP3430_CLKSEL_GPT4_MASK (1 << 2)
703#define OMAP3430_CLKSEL_GPT4_SHIFT 2
704#define OMAP3430_CLKSEL_GPT3_MASK (1 << 1)
705#define OMAP3430_CLKSEL_GPT3_SHIFT 1
706#define OMAP3430_CLKSEL_GPT2_MASK (1 << 0)
707#define OMAP3430_CLKSEL_GPT2_SHIFT 0
708
709/* CM_SLEEPDEP_PER specific bits */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600710#define OMAP3430_CM_SLEEPDEP_PER_EN_IVA2_MASK (1 << 2)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200711
712/* CM_CLKSTCTRL_PER */
713#define OMAP3430_CLKTRCTRL_PER_SHIFT 0
714#define OMAP3430_CLKTRCTRL_PER_MASK (0x3 << 0)
715
716/* CM_CLKSTST_PER */
Paul Walmsley801954d2008-08-19 11:08:44 +0300717#define OMAP3430_CLKACTIVITY_PER_SHIFT 0
718#define OMAP3430_CLKACTIVITY_PER_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200719
720/* CM_CLKSEL1_EMU */
721#define OMAP3430_DIV_DPLL4_SHIFT 24
722#define OMAP3430_DIV_DPLL4_MASK (0x1f << 24)
Vishwanath BS678bc9a2010-02-22 22:09:09 -0700723#define OMAP3630_DIV_DPLL4_MASK (0x3f << 24)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200724#define OMAP3430_DIV_DPLL3_SHIFT 16
725#define OMAP3430_DIV_DPLL3_MASK (0x1f << 16)
726#define OMAP3430_CLKSEL_TRACECLK_SHIFT 11
727#define OMAP3430_CLKSEL_TRACECLK_MASK (0x7 << 11)
728#define OMAP3430_CLKSEL_PCLK_SHIFT 8
729#define OMAP3430_CLKSEL_PCLK_MASK (0x7 << 8)
730#define OMAP3430_CLKSEL_PCLKX2_SHIFT 6
731#define OMAP3430_CLKSEL_PCLKX2_MASK (0x3 << 6)
732#define OMAP3430_CLKSEL_ATCLK_SHIFT 4
733#define OMAP3430_CLKSEL_ATCLK_MASK (0x3 << 4)
734#define OMAP3430_TRACE_MUX_CTRL_SHIFT 2
735#define OMAP3430_TRACE_MUX_CTRL_MASK (0x3 << 2)
736#define OMAP3430_MUX_CTRL_SHIFT 0
737#define OMAP3430_MUX_CTRL_MASK (0x3 << 0)
738
739/* CM_CLKSTCTRL_EMU */
740#define OMAP3430_CLKTRCTRL_EMU_SHIFT 0
741#define OMAP3430_CLKTRCTRL_EMU_MASK (0x3 << 0)
742
743/* CM_CLKSTST_EMU */
Paul Walmsley801954d2008-08-19 11:08:44 +0300744#define OMAP3430_CLKACTIVITY_EMU_SHIFT 0
745#define OMAP3430_CLKACTIVITY_EMU_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200746
747/* CM_CLKSEL2_EMU specific bits */
748#define OMAP3430_CORE_DPLL_EMU_MULT_SHIFT 8
749#define OMAP3430_CORE_DPLL_EMU_MULT_MASK (0x7ff << 8)
750#define OMAP3430_CORE_DPLL_EMU_DIV_SHIFT 0
751#define OMAP3430_CORE_DPLL_EMU_DIV_MASK (0x7f << 0)
752
753/* CM_CLKSEL3_EMU specific bits */
754#define OMAP3430_PERIPH_DPLL_EMU_MULT_SHIFT 8
755#define OMAP3430_PERIPH_DPLL_EMU_MULT_MASK (0x7ff << 8)
756#define OMAP3430_PERIPH_DPLL_EMU_DIV_SHIFT 0
757#define OMAP3430_PERIPH_DPLL_EMU_DIV_MASK (0x7f << 0)
758
759/* CM_POLCTRL */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600760#define OMAP3430_CLKOUT2_POL_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200761
762/* CM_IDLEST_NEON */
Paul Walmsley2bc4ef72010-05-18 18:47:24 -0600763#define OMAP3430_ST_NEON_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200764
765/* CM_CLKSTCTRL_NEON */
766#define OMAP3430_CLKTRCTRL_NEON_SHIFT 0
767#define OMAP3430_CLKTRCTRL_NEON_MASK (0x3 << 0)
768
769/* CM_FCLKEN_USBHOST */
770#define OMAP3430ES2_EN_USBHOST2_SHIFT 1
771#define OMAP3430ES2_EN_USBHOST2_MASK (1 << 1)
772#define OMAP3430ES2_EN_USBHOST1_SHIFT 0
773#define OMAP3430ES2_EN_USBHOST1_MASK (1 << 0)
774
775/* CM_ICLKEN_USBHOST */
776#define OMAP3430ES2_EN_USBHOST_SHIFT 0
777#define OMAP3430ES2_EN_USBHOST_MASK (1 << 0)
778
779/* CM_IDLEST_USBHOST */
Paul Walmsleyda0747d2009-01-28 12:18:22 -0700780#define OMAP3430ES2_ST_USBHOST_IDLE_SHIFT 1
781#define OMAP3430ES2_ST_USBHOST_IDLE_MASK (1 << 1)
782#define OMAP3430ES2_ST_USBHOST_STDBY_SHIFT 0
783#define OMAP3430ES2_ST_USBHOST_STDBY_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200784
785/* CM_AUTOIDLE_USBHOST */
786#define OMAP3430ES2_AUTO_USBHOST_SHIFT 0
787#define OMAP3430ES2_AUTO_USBHOST_MASK (1 << 0)
788
789/* CM_SLEEPDEP_USBHOST */
790#define OMAP3430ES2_EN_MPU_SHIFT 1
791#define OMAP3430ES2_EN_MPU_MASK (1 << 1)
792#define OMAP3430ES2_EN_IVA2_SHIFT 2
793#define OMAP3430ES2_EN_IVA2_MASK (1 << 2)
794
795/* CM_CLKSTCTRL_USBHOST */
796#define OMAP3430ES2_CLKTRCTRL_USBHOST_SHIFT 0
797#define OMAP3430ES2_CLKTRCTRL_USBHOST_MASK (3 << 0)
798
Paul Walmsley801954d2008-08-19 11:08:44 +0300799/* CM_CLKSTST_USBHOST */
800#define OMAP3430ES2_CLKACTIVITY_USBHOST_SHIFT 0
801#define OMAP3430ES2_CLKACTIVITY_USBHOST_MASK (1 << 0)
Tony Lindgrenc5957132008-03-18 14:53:17 +0200802
803#endif