| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267 | 
							- #ifndef __ARCH_ARM_MACH_OMAP2_CM_REGBITS_24XX_H
 
- #define __ARCH_ARM_MACH_OMAP2_CM_REGBITS_24XX_H
 
- /*
 
-  * OMAP24XX Clock Management register bits
 
-  *
 
-  * Copyright (C) 2007 Texas Instruments, Inc.
 
-  * Copyright (C) 2007 Nokia Corporation
 
-  *
 
-  * Written by Paul Walmsley
 
-  *
 
-  * This program is free software; you can redistribute it and/or modify
 
-  * it under the terms of the GNU General Public License version 2 as
 
-  * published by the Free Software Foundation.
 
-  */
 
- /* Bits shared between registers */
 
- /* CM_FCLKEN1_CORE and CM_ICLKEN1_CORE shared bits */
 
- #define OMAP24XX_EN_CAM_SHIFT				31
 
- #define OMAP24XX_EN_CAM_MASK				(1 << 31)
 
- #define OMAP24XX_EN_WDT4_SHIFT				29
 
- #define OMAP24XX_EN_WDT4_MASK				(1 << 29)
 
- #define OMAP2420_EN_WDT3_SHIFT				28
 
- #define OMAP2420_EN_WDT3_MASK				(1 << 28)
 
- #define OMAP24XX_EN_MSPRO_SHIFT				27
 
- #define OMAP24XX_EN_MSPRO_MASK				(1 << 27)
 
- #define OMAP24XX_EN_FAC_SHIFT				25
 
- #define OMAP24XX_EN_FAC_MASK				(1 << 25)
 
- #define OMAP2420_EN_EAC_SHIFT				24
 
- #define OMAP2420_EN_EAC_MASK				(1 << 24)
 
- #define OMAP24XX_EN_HDQ_SHIFT				23
 
- #define OMAP24XX_EN_HDQ_MASK				(1 << 23)
 
- #define OMAP2420_EN_I2C2_SHIFT				20
 
- #define OMAP2420_EN_I2C2_MASK				(1 << 20)
 
- #define OMAP2420_EN_I2C1_SHIFT				19
 
- #define OMAP2420_EN_I2C1_MASK				(1 << 19)
 
- /* CM_FCLKEN2_CORE and CM_ICLKEN2_CORE shared bits */
 
- #define OMAP2430_EN_MCBSP5_SHIFT			5
 
- #define OMAP2430_EN_MCBSP5_MASK				(1 << 5)
 
- #define OMAP2430_EN_MCBSP4_SHIFT			4
 
- #define OMAP2430_EN_MCBSP4_MASK				(1 << 4)
 
- #define OMAP2430_EN_MCBSP3_SHIFT			3
 
- #define OMAP2430_EN_MCBSP3_MASK				(1 << 3)
 
- #define OMAP24XX_EN_SSI_SHIFT				1
 
- #define OMAP24XX_EN_SSI_MASK				(1 << 1)
 
- /* CM_FCLKEN_WKUP and CM_ICLKEN_WKUP shared bits */
 
- #define OMAP24XX_EN_MPU_WDT_SHIFT			3
 
- #define OMAP24XX_EN_MPU_WDT_MASK			(1 << 3)
 
- /* Bits specific to each register */
 
- /* CM_IDLEST_MPU */
 
- /* 2430 only */
 
- #define OMAP2430_ST_MPU_MASK				(1 << 0)
 
- /* CM_CLKSEL_MPU */
 
- #define OMAP24XX_CLKSEL_MPU_SHIFT			0
 
- #define OMAP24XX_CLKSEL_MPU_MASK			(0x1f << 0)
 
- #define OMAP24XX_CLKSEL_MPU_WIDTH			5
 
- /* CM_CLKSTCTRL_MPU */
 
- #define OMAP24XX_AUTOSTATE_MPU_SHIFT			0
 
- #define OMAP24XX_AUTOSTATE_MPU_MASK			(1 << 0)
 
- /* CM_FCLKEN1_CORE specific bits*/
 
- #define OMAP24XX_EN_TV_SHIFT				2
 
- #define OMAP24XX_EN_TV_MASK				(1 << 2)
 
- #define OMAP24XX_EN_DSS2_SHIFT				1
 
- #define OMAP24XX_EN_DSS2_MASK				(1 << 1)
 
- #define OMAP24XX_EN_DSS1_SHIFT				0
 
- #define OMAP24XX_EN_DSS1_MASK				(1 << 0)
 
- /* CM_FCLKEN2_CORE specific bits */
 
- #define OMAP2430_EN_I2CHS2_SHIFT			20
 
- #define OMAP2430_EN_I2CHS2_MASK				(1 << 20)
 
- #define OMAP2430_EN_I2CHS1_SHIFT			19
 
- #define OMAP2430_EN_I2CHS1_MASK				(1 << 19)
 
- #define OMAP2430_EN_MMCHSDB2_SHIFT			17
 
- #define OMAP2430_EN_MMCHSDB2_MASK			(1 << 17)
 
- #define OMAP2430_EN_MMCHSDB1_SHIFT			16
 
- #define OMAP2430_EN_MMCHSDB1_MASK			(1 << 16)
 
- /* CM_ICLKEN1_CORE specific bits */
 
- #define OMAP24XX_EN_MAILBOXES_SHIFT			30
 
- #define OMAP24XX_EN_MAILBOXES_MASK			(1 << 30)
 
- #define OMAP24XX_EN_DSS_SHIFT				0
 
- #define OMAP24XX_EN_DSS_MASK				(1 << 0)
 
- /* CM_ICLKEN2_CORE specific bits */
 
- /* CM_ICLKEN3_CORE */
 
- /* 2430 only */
 
- #define OMAP2430_EN_SDRC_SHIFT				2
 
- #define OMAP2430_EN_SDRC_MASK				(1 << 2)
 
- /* CM_ICLKEN4_CORE */
 
- #define OMAP24XX_EN_PKA_SHIFT				4
 
- #define OMAP24XX_EN_PKA_MASK				(1 << 4)
 
- #define OMAP24XX_EN_AES_SHIFT				3
 
- #define OMAP24XX_EN_AES_MASK				(1 << 3)
 
- #define OMAP24XX_EN_RNG_SHIFT				2
 
- #define OMAP24XX_EN_RNG_MASK				(1 << 2)
 
- #define OMAP24XX_EN_SHA_SHIFT				1
 
- #define OMAP24XX_EN_SHA_MASK				(1 << 1)
 
- #define OMAP24XX_EN_DES_SHIFT				0
 
- #define OMAP24XX_EN_DES_MASK				(1 << 0)
 
- /* CM_IDLEST1_CORE specific bits */
 
- #define OMAP24XX_ST_MAILBOXES_SHIFT			30
 
- #define OMAP24XX_ST_MAILBOXES_MASK			(1 << 30)
 
- #define OMAP24XX_ST_WDT4_SHIFT				29
 
- #define OMAP24XX_ST_WDT4_MASK				(1 << 29)
 
- #define OMAP2420_ST_WDT3_SHIFT				28
 
- #define OMAP2420_ST_WDT3_MASK				(1 << 28)
 
- #define OMAP24XX_ST_MSPRO_SHIFT				27
 
- #define OMAP24XX_ST_MSPRO_MASK				(1 << 27)
 
- #define OMAP24XX_ST_FAC_SHIFT				25
 
- #define OMAP24XX_ST_FAC_MASK				(1 << 25)
 
- #define OMAP2420_ST_EAC_SHIFT				24
 
- #define OMAP2420_ST_EAC_MASK				(1 << 24)
 
- #define OMAP24XX_ST_HDQ_SHIFT				23
 
- #define OMAP24XX_ST_HDQ_MASK				(1 << 23)
 
- #define OMAP2420_ST_I2C2_SHIFT				20
 
- #define OMAP2420_ST_I2C2_MASK				(1 << 20)
 
- #define OMAP2430_ST_I2CHS1_SHIFT			19
 
- #define OMAP2430_ST_I2CHS1_MASK				(1 << 19)
 
- #define OMAP2420_ST_I2C1_SHIFT				19
 
- #define OMAP2420_ST_I2C1_MASK				(1 << 19)
 
- #define OMAP2430_ST_I2CHS2_SHIFT			20
 
- #define OMAP2430_ST_I2CHS2_MASK				(1 << 20)
 
- #define OMAP24XX_ST_MCBSP2_SHIFT			16
 
- #define OMAP24XX_ST_MCBSP2_MASK				(1 << 16)
 
- #define OMAP24XX_ST_MCBSP1_SHIFT			15
 
- #define OMAP24XX_ST_MCBSP1_MASK				(1 << 15)
 
- #define OMAP24XX_ST_DSS_SHIFT				0
 
- #define OMAP24XX_ST_DSS_MASK				(1 << 0)
 
- /* CM_IDLEST2_CORE */
 
- #define OMAP2430_ST_MCBSP5_SHIFT			5
 
- #define OMAP2430_ST_MCBSP5_MASK				(1 << 5)
 
- #define OMAP2430_ST_MCBSP4_SHIFT			4
 
- #define OMAP2430_ST_MCBSP4_MASK				(1 << 4)
 
- #define OMAP2430_ST_MCBSP3_SHIFT			3
 
- #define OMAP2430_ST_MCBSP3_MASK				(1 << 3)
 
- #define OMAP24XX_ST_SSI_SHIFT				1
 
- #define OMAP24XX_ST_SSI_MASK				(1 << 1)
 
- /* CM_IDLEST3_CORE */
 
- /* 2430 only */
 
- #define OMAP2430_ST_SDRC_MASK				(1 << 2)
 
- /* CM_IDLEST4_CORE */
 
- #define OMAP24XX_ST_PKA_SHIFT				4
 
- #define OMAP24XX_ST_PKA_MASK				(1 << 4)
 
- #define OMAP24XX_ST_AES_SHIFT				3
 
- #define OMAP24XX_ST_AES_MASK				(1 << 3)
 
- #define OMAP24XX_ST_RNG_SHIFT				2
 
- #define OMAP24XX_ST_RNG_MASK				(1 << 2)
 
- #define OMAP24XX_ST_SHA_SHIFT				1
 
- #define OMAP24XX_ST_SHA_MASK				(1 << 1)
 
- #define OMAP24XX_ST_DES_SHIFT				0
 
- #define OMAP24XX_ST_DES_MASK				(1 << 0)
 
- /* CM_AUTOIDLE1_CORE */
 
- #define OMAP24XX_AUTO_CAM_MASK				(1 << 31)
 
- #define OMAP24XX_AUTO_MAILBOXES_MASK			(1 << 30)
 
- #define OMAP24XX_AUTO_WDT4_MASK				(1 << 29)
 
- #define OMAP2420_AUTO_WDT3_MASK				(1 << 28)
 
- #define OMAP24XX_AUTO_MSPRO_MASK			(1 << 27)
 
- #define OMAP2420_AUTO_MMC_MASK				(1 << 26)
 
- #define OMAP24XX_AUTO_FAC_MASK				(1 << 25)
 
- #define OMAP2420_AUTO_EAC_MASK				(1 << 24)
 
- #define OMAP24XX_AUTO_HDQ_MASK				(1 << 23)
 
- #define OMAP24XX_AUTO_UART2_MASK			(1 << 22)
 
- #define OMAP24XX_AUTO_UART1_MASK			(1 << 21)
 
- #define OMAP24XX_AUTO_I2C2_MASK				(1 << 20)
 
- #define OMAP24XX_AUTO_I2C1_MASK				(1 << 19)
 
- #define OMAP24XX_AUTO_MCSPI2_MASK			(1 << 18)
 
- #define OMAP24XX_AUTO_MCSPI1_MASK			(1 << 17)
 
- #define OMAP24XX_AUTO_MCBSP2_MASK			(1 << 16)
 
- #define OMAP24XX_AUTO_MCBSP1_MASK			(1 << 15)
 
- #define OMAP24XX_AUTO_GPT12_MASK			(1 << 14)
 
- #define OMAP24XX_AUTO_GPT11_MASK			(1 << 13)
 
- #define OMAP24XX_AUTO_GPT10_MASK			(1 << 12)
 
- #define OMAP24XX_AUTO_GPT9_MASK				(1 << 11)
 
- #define OMAP24XX_AUTO_GPT8_MASK				(1 << 10)
 
- #define OMAP24XX_AUTO_GPT7_MASK				(1 << 9)
 
- #define OMAP24XX_AUTO_GPT6_MASK				(1 << 8)
 
- #define OMAP24XX_AUTO_GPT5_MASK				(1 << 7)
 
- #define OMAP24XX_AUTO_GPT4_MASK				(1 << 6)
 
- #define OMAP24XX_AUTO_GPT3_MASK				(1 << 5)
 
- #define OMAP24XX_AUTO_GPT2_MASK				(1 << 4)
 
- #define OMAP2420_AUTO_VLYNQ_MASK			(1 << 3)
 
- #define OMAP24XX_AUTO_DSS_MASK				(1 << 0)
 
- /* CM_AUTOIDLE2_CORE */
 
- #define OMAP2430_AUTO_MDM_INTC_MASK			(1 << 11)
 
- #define OMAP2430_AUTO_GPIO5_MASK			(1 << 10)
 
- #define OMAP2430_AUTO_MCSPI3_MASK			(1 << 9)
 
- #define OMAP2430_AUTO_MMCHS2_MASK			(1 << 8)
 
- #define OMAP2430_AUTO_MMCHS1_MASK			(1 << 7)
 
- #define OMAP2430_AUTO_USBHS_MASK			(1 << 6)
 
- #define OMAP2430_AUTO_MCBSP5_MASK			(1 << 5)
 
- #define OMAP2430_AUTO_MCBSP4_MASK			(1 << 4)
 
- #define OMAP2430_AUTO_MCBSP3_MASK			(1 << 3)
 
- #define OMAP24XX_AUTO_UART3_MASK			(1 << 2)
 
- #define OMAP24XX_AUTO_SSI_MASK				(1 << 1)
 
- #define OMAP24XX_AUTO_USB_MASK				(1 << 0)
 
- /* CM_AUTOIDLE3_CORE */
 
- #define OMAP24XX_AUTO_SDRC_SHIFT			2
 
- #define OMAP24XX_AUTO_SDRC_MASK				(1 << 2)
 
- #define OMAP24XX_AUTO_GPMC_SHIFT			1
 
- #define OMAP24XX_AUTO_GPMC_MASK				(1 << 1)
 
- #define OMAP24XX_AUTO_SDMA_SHIFT			0
 
- #define OMAP24XX_AUTO_SDMA_MASK				(1 << 0)
 
- /* CM_AUTOIDLE4_CORE */
 
- #define OMAP24XX_AUTO_PKA_MASK				(1 << 4)
 
- #define OMAP24XX_AUTO_AES_MASK				(1 << 3)
 
- #define OMAP24XX_AUTO_RNG_MASK				(1 << 2)
 
- #define OMAP24XX_AUTO_SHA_MASK				(1 << 1)
 
- #define OMAP24XX_AUTO_DES_MASK				(1 << 0)
 
- /* CM_CLKSEL1_CORE */
 
- #define OMAP24XX_CLKSEL_USB_SHIFT			25
 
- #define OMAP24XX_CLKSEL_USB_MASK			(0x7 << 25)
 
- #define OMAP24XX_CLKSEL_SSI_SHIFT			20
 
- #define OMAP24XX_CLKSEL_SSI_MASK			(0x1f << 20)
 
- #define OMAP2420_CLKSEL_VLYNQ_SHIFT			15
 
- #define OMAP2420_CLKSEL_VLYNQ_MASK			(0x1f << 15)
 
- #define OMAP24XX_CLKSEL_DSS2_SHIFT			13
 
- #define OMAP24XX_CLKSEL_DSS2_MASK			(0x1 << 13)
 
- #define OMAP24XX_CLKSEL_DSS1_SHIFT			8
 
- #define OMAP24XX_CLKSEL_DSS1_MASK			(0x1f << 8)
 
- #define OMAP24XX_CLKSEL_L4_SHIFT			5
 
- #define OMAP24XX_CLKSEL_L4_MASK				(0x3 << 5)
 
- #define OMAP24XX_CLKSEL_L4_WIDTH			2
 
- #define OMAP24XX_CLKSEL_L3_SHIFT			0
 
- #define OMAP24XX_CLKSEL_L3_MASK				(0x1f << 0)
 
- #define OMAP24XX_CLKSEL_L3_WIDTH			5
 
- /* CM_CLKSEL2_CORE */
 
- #define OMAP24XX_CLKSEL_GPT12_SHIFT			22
 
- #define OMAP24XX_CLKSEL_GPT12_MASK			(0x3 << 22)
 
- #define OMAP24XX_CLKSEL_GPT11_SHIFT			20
 
- #define OMAP24XX_CLKSEL_GPT11_MASK			(0x3 << 20)
 
- #define OMAP24XX_CLKSEL_GPT10_SHIFT			18
 
- #define OMAP24XX_CLKSEL_GPT10_MASK			(0x3 << 18)
 
- #define OMAP24XX_CLKSEL_GPT9_SHIFT			16
 
- #define OMAP24XX_CLKSEL_GPT9_MASK			(0x3 << 16)
 
- #define OMAP24XX_CLKSEL_GPT8_SHIFT			14
 
- #define OMAP24XX_CLKSEL_GPT8_MASK			(0x3 << 14)
 
- #define OMAP24XX_CLKSEL_GPT7_SHIFT			12
 
- #define OMAP24XX_CLKSEL_GPT7_MASK			(0x3 << 12)
 
- #define OMAP24XX_CLKSEL_GPT6_SHIFT			10
 
- #define OMAP24XX_CLKSEL_GPT6_MASK			(0x3 << 10)
 
- #define OMAP24XX_CLKSEL_GPT5_SHIFT			8
 
- #define OMAP24XX_CLKSEL_GPT5_MASK			(0x3 << 8)
 
- #define OMAP24XX_CLKSEL_GPT4_SHIFT			6
 
- #define OMAP24XX_CLKSEL_GPT4_MASK			(0x3 << 6)
 
- #define OMAP24XX_CLKSEL_GPT3_SHIFT			4
 
- #define OMAP24XX_CLKSEL_GPT3_MASK			(0x3 << 4)
 
- #define OMAP24XX_CLKSEL_GPT2_SHIFT			2
 
 
  |