xref: /OK3568_Linux_fs/kernel/include/linux/soc/samsung/exynos-regs-pmu.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright (c) 2010-2015 Samsung Electronics Co., Ltd.
4*4882a593Smuzhiyun  *		http://www.samsung.com
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * Exynos - Power management unit definition
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  * Notice:
9*4882a593Smuzhiyun  * This is not a list of all Exynos Power Management Unit SFRs.
10*4882a593Smuzhiyun  * There are too many of them, not mentioning subtle differences
11*4882a593Smuzhiyun  * between SoCs. For now, put here only the used registers.
12*4882a593Smuzhiyun  */
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun #ifndef __LINUX_SOC_EXYNOS_REGS_PMU_H
15*4882a593Smuzhiyun #define __LINUX_SOC_EXYNOS_REGS_PMU_H __FILE__
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #define S5P_CENTRAL_SEQ_CONFIGURATION		0x0200
18*4882a593Smuzhiyun 
19*4882a593Smuzhiyun #define S5P_CENTRAL_LOWPWR_CFG			(1 << 16)
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun #define S5P_CENTRAL_SEQ_OPTION			0x0208
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFI0			(1 << 16)
24*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFI1			(1 << 17)
25*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFI2			(1 << 19)
26*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFI3			(1 << 20)
27*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFE0			(1 << 24)
28*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFE1			(1 << 25)
29*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFE2			(1 << 27)
30*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFE3			(1 << 28)
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #define S5P_USE_STANDBY_WFI_ALL \
33*4882a593Smuzhiyun 	(S5P_USE_STANDBY_WFI0 | S5P_USE_STANDBY_WFI1 | \
34*4882a593Smuzhiyun 	 S5P_USE_STANDBY_WFI2 | S5P_USE_STANDBY_WFI3 | \
35*4882a593Smuzhiyun 	 S5P_USE_STANDBY_WFE0 | S5P_USE_STANDBY_WFE1 | \
36*4882a593Smuzhiyun 	 S5P_USE_STANDBY_WFE2 | S5P_USE_STANDBY_WFE3)
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun #define S5P_USE_DELAYED_RESET_ASSERTION		BIT(12)
39*4882a593Smuzhiyun 
40*4882a593Smuzhiyun #define EXYNOS_CORE_PO_RESET(n)			((1 << 4) << n)
41*4882a593Smuzhiyun #define EXYNOS_WAKEUP_FROM_LOWPWR		(1 << 28)
42*4882a593Smuzhiyun #define EXYNOS_SWRESET				0x0400
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun #define S5P_WAKEUP_STAT				0x0600
45*4882a593Smuzhiyun /* Value for EXYNOS_EINT_WAKEUP_MASK disabling all external wakeup interrupts */
46*4882a593Smuzhiyun #define EXYNOS_EINT_WAKEUP_MASK_DISABLED	0xffffffff
47*4882a593Smuzhiyun #define EXYNOS_EINT_WAKEUP_MASK			0x0604
48*4882a593Smuzhiyun #define S5P_WAKEUP_MASK				0x0608
49*4882a593Smuzhiyun #define S5P_WAKEUP_MASK2				0x0614
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun /* MIPI_PHYn_CONTROL, valid for Exynos3250, Exynos4, Exynos5250 and Exynos5433 */
52*4882a593Smuzhiyun #define EXYNOS4_MIPI_PHY_CONTROL(n)		(0x0710 + (n) * 4)
53*4882a593Smuzhiyun /* Phy enable bit, common for all phy registers, not only MIPI */
54*4882a593Smuzhiyun #define EXYNOS4_PHY_ENABLE			(1 << 0)
55*4882a593Smuzhiyun #define EXYNOS4_MIPI_PHY_SRESETN		(1 << 1)
56*4882a593Smuzhiyun #define EXYNOS4_MIPI_PHY_MRESETN		(1 << 2)
57*4882a593Smuzhiyun #define EXYNOS4_MIPI_PHY_RESET_MASK		(3 << 1)
58*4882a593Smuzhiyun 
59*4882a593Smuzhiyun #define S5P_INFORM0				0x0800
60*4882a593Smuzhiyun #define S5P_INFORM1				0x0804
61*4882a593Smuzhiyun #define S5P_INFORM5				0x0814
62*4882a593Smuzhiyun #define S5P_INFORM6				0x0818
63*4882a593Smuzhiyun #define S5P_INFORM7				0x081C
64*4882a593Smuzhiyun #define S5P_PMU_SPARE2				0x0908
65*4882a593Smuzhiyun #define S5P_PMU_SPARE3				0x090C
66*4882a593Smuzhiyun 
67*4882a593Smuzhiyun #define EXYNOS_IROM_DATA2			0x0988
68*4882a593Smuzhiyun #define S5P_ARM_CORE0_LOWPWR			0x1000
69*4882a593Smuzhiyun #define S5P_DIS_IRQ_CORE0			0x1004
70*4882a593Smuzhiyun #define S5P_DIS_IRQ_CENTRAL0			0x1008
71*4882a593Smuzhiyun #define S5P_ARM_CORE1_LOWPWR			0x1010
72*4882a593Smuzhiyun #define S5P_DIS_IRQ_CORE1			0x1014
73*4882a593Smuzhiyun #define S5P_DIS_IRQ_CENTRAL1			0x1018
74*4882a593Smuzhiyun #define S5P_ARM_COMMON_LOWPWR			0x1080
75*4882a593Smuzhiyun #define S5P_L2_0_LOWPWR				0x10C0
76*4882a593Smuzhiyun #define S5P_L2_1_LOWPWR				0x10C4
77*4882a593Smuzhiyun #define S5P_CMU_ACLKSTOP_LOWPWR			0x1100
78*4882a593Smuzhiyun #define S5P_CMU_SCLKSTOP_LOWPWR			0x1104
79*4882a593Smuzhiyun #define S5P_CMU_RESET_LOWPWR			0x110C
80*4882a593Smuzhiyun #define S5P_APLL_SYSCLK_LOWPWR			0x1120
81*4882a593Smuzhiyun #define S5P_MPLL_SYSCLK_LOWPWR			0x1124
82*4882a593Smuzhiyun #define S5P_VPLL_SYSCLK_LOWPWR			0x1128
83*4882a593Smuzhiyun #define S5P_EPLL_SYSCLK_LOWPWR			0x112C
84*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_GPS_ALIVE_LOWPWR	0x1138
85*4882a593Smuzhiyun #define S5P_CMU_RESET_GPSALIVE_LOWPWR		0x113C
86*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_CAM_LOWPWR		0x1140
87*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_TV_LOWPWR		0x1144
88*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_MFC_LOWPWR		0x1148
89*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_G3D_LOWPWR		0x114C
90*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_LCD0_LOWPWR		0x1150
91*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_MAUDIO_LOWPWR		0x1158
92*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_GPS_LOWPWR		0x115C
93*4882a593Smuzhiyun #define S5P_CMU_RESET_CAM_LOWPWR		0x1160
94*4882a593Smuzhiyun #define S5P_CMU_RESET_TV_LOWPWR			0x1164
95*4882a593Smuzhiyun #define S5P_CMU_RESET_MFC_LOWPWR		0x1168
96*4882a593Smuzhiyun #define S5P_CMU_RESET_G3D_LOWPWR		0x116C
97*4882a593Smuzhiyun #define S5P_CMU_RESET_LCD0_LOWPWR		0x1170
98*4882a593Smuzhiyun #define S5P_CMU_RESET_MAUDIO_LOWPWR		0x1178
99*4882a593Smuzhiyun #define S5P_CMU_RESET_GPS_LOWPWR		0x117C
100*4882a593Smuzhiyun #define S5P_TOP_BUS_LOWPWR			0x1180
101*4882a593Smuzhiyun #define S5P_TOP_RETENTION_LOWPWR		0x1184
102*4882a593Smuzhiyun #define S5P_TOP_PWR_LOWPWR			0x1188
103*4882a593Smuzhiyun #define S5P_LOGIC_RESET_LOWPWR			0x11A0
104*4882a593Smuzhiyun #define S5P_ONENAND_MEM_LOWPWR			0x11C0
105*4882a593Smuzhiyun #define S5P_G2D_ACP_MEM_LOWPWR			0x11C8
106*4882a593Smuzhiyun #define S5P_USBOTG_MEM_LOWPWR			0x11CC
107*4882a593Smuzhiyun #define S5P_HSMMC_MEM_LOWPWR			0x11D0
108*4882a593Smuzhiyun #define S5P_CSSYS_MEM_LOWPWR			0x11D4
109*4882a593Smuzhiyun #define S5P_SECSS_MEM_LOWPWR			0x11D8
110*4882a593Smuzhiyun #define S5P_PAD_RETENTION_DRAM_LOWPWR		0x1200
111*4882a593Smuzhiyun #define S5P_PAD_RETENTION_MAUDIO_LOWPWR		0x1204
112*4882a593Smuzhiyun #define S5P_PAD_RETENTION_GPIO_LOWPWR		0x1220
113*4882a593Smuzhiyun #define S5P_PAD_RETENTION_UART_LOWPWR		0x1224
114*4882a593Smuzhiyun #define S5P_PAD_RETENTION_MMCA_LOWPWR		0x1228
115*4882a593Smuzhiyun #define S5P_PAD_RETENTION_MMCB_LOWPWR		0x122C
116*4882a593Smuzhiyun #define S5P_PAD_RETENTION_EBIA_LOWPWR		0x1230
117*4882a593Smuzhiyun #define S5P_PAD_RETENTION_EBIB_LOWPWR		0x1234
118*4882a593Smuzhiyun #define S5P_PAD_RETENTION_ISOLATION_LOWPWR	0x1240
119*4882a593Smuzhiyun #define S5P_PAD_RETENTION_ALV_SEL_LOWPWR	0x1260
120*4882a593Smuzhiyun #define S5P_XUSBXTI_LOWPWR			0x1280
121*4882a593Smuzhiyun #define S5P_XXTI_LOWPWR				0x1284
122*4882a593Smuzhiyun #define S5P_EXT_REGULATOR_LOWPWR		0x12C0
123*4882a593Smuzhiyun #define S5P_GPIO_MODE_LOWPWR			0x1300
124*4882a593Smuzhiyun #define S5P_GPIO_MODE_MAUDIO_LOWPWR		0x1340
125*4882a593Smuzhiyun #define S5P_CAM_LOWPWR				0x1380
126*4882a593Smuzhiyun #define S5P_TV_LOWPWR				0x1384
127*4882a593Smuzhiyun #define S5P_MFC_LOWPWR				0x1388
128*4882a593Smuzhiyun #define S5P_G3D_LOWPWR				0x138C
129*4882a593Smuzhiyun #define S5P_LCD0_LOWPWR				0x1390
130*4882a593Smuzhiyun #define S5P_MAUDIO_LOWPWR			0x1398
131*4882a593Smuzhiyun #define S5P_GPS_LOWPWR				0x139C
132*4882a593Smuzhiyun #define S5P_GPS_ALIVE_LOWPWR			0x13A0
133*4882a593Smuzhiyun 
134*4882a593Smuzhiyun #define EXYNOS_ARM_CORE0_CONFIGURATION		0x2000
135*4882a593Smuzhiyun #define EXYNOS_ARM_CORE_CONFIGURATION(_nr)	\
136*4882a593Smuzhiyun 			(EXYNOS_ARM_CORE0_CONFIGURATION + (0x80 * (_nr)))
137*4882a593Smuzhiyun #define EXYNOS_ARM_CORE_STATUS(_nr)		\
138*4882a593Smuzhiyun 			(EXYNOS_ARM_CORE_CONFIGURATION(_nr) + 0x4)
139*4882a593Smuzhiyun #define EXYNOS_ARM_CORE_OPTION(_nr)		\
140*4882a593Smuzhiyun 			(EXYNOS_ARM_CORE_CONFIGURATION(_nr) + 0x8)
141*4882a593Smuzhiyun 
142*4882a593Smuzhiyun #define EXYNOS_ARM_COMMON_CONFIGURATION		0x2500
143*4882a593Smuzhiyun #define EXYNOS_COMMON_CONFIGURATION(_nr)	\
144*4882a593Smuzhiyun 			(EXYNOS_ARM_COMMON_CONFIGURATION + (0x80 * (_nr)))
145*4882a593Smuzhiyun #define EXYNOS_COMMON_STATUS(_nr)		\
146*4882a593Smuzhiyun 			(EXYNOS_COMMON_CONFIGURATION(_nr) + 0x4)
147*4882a593Smuzhiyun #define EXYNOS_COMMON_OPTION(_nr)		\
148*4882a593Smuzhiyun 			(EXYNOS_COMMON_CONFIGURATION(_nr) + 0x8)
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun #define EXYNOS_ARM_L2_CONFIGURATION		0x2600
151*4882a593Smuzhiyun #define EXYNOS_L2_CONFIGURATION(_nr)		\
152*4882a593Smuzhiyun 			(EXYNOS_ARM_L2_CONFIGURATION + ((_nr) * 0x80))
153*4882a593Smuzhiyun #define EXYNOS_L2_STATUS(_nr)			\
154*4882a593Smuzhiyun 			(EXYNOS_L2_CONFIGURATION(_nr) + 0x4)
155*4882a593Smuzhiyun #define EXYNOS_L2_OPTION(_nr)			\
156*4882a593Smuzhiyun 			(EXYNOS_L2_CONFIGURATION(_nr) + 0x8)
157*4882a593Smuzhiyun 
158*4882a593Smuzhiyun #define EXYNOS_L2_USE_RETENTION			BIT(4)
159*4882a593Smuzhiyun 
160*4882a593Smuzhiyun #define S5P_PAD_RET_MAUDIO_OPTION		0x3028
161*4882a593Smuzhiyun #define S5P_PAD_RET_MMC2_OPTION			0x30c8
162*4882a593Smuzhiyun #define S5P_PAD_RET_GPIO_OPTION			0x3108
163*4882a593Smuzhiyun #define S5P_PAD_RET_UART_OPTION			0x3128
164*4882a593Smuzhiyun #define S5P_PAD_RET_MMCA_OPTION			0x3148
165*4882a593Smuzhiyun #define S5P_PAD_RET_MMCB_OPTION			0x3168
166*4882a593Smuzhiyun #define S5P_PAD_RET_EBIA_OPTION			0x3188
167*4882a593Smuzhiyun #define S5P_PAD_RET_EBIB_OPTION			0x31A8
168*4882a593Smuzhiyun #define S5P_PAD_RET_SPI_OPTION			0x31c8
169*4882a593Smuzhiyun 
170*4882a593Smuzhiyun #define S5P_PS_HOLD_CONTROL			0x330C
171*4882a593Smuzhiyun #define S5P_PS_HOLD_EN				(1 << 31)
172*4882a593Smuzhiyun #define S5P_PS_HOLD_OUTPUT_HIGH			(3 << 8)
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun #define S5P_CAM_OPTION				0x3C08
175*4882a593Smuzhiyun #define S5P_MFC_OPTION				0x3C48
176*4882a593Smuzhiyun #define S5P_G3D_OPTION				0x3C68
177*4882a593Smuzhiyun #define S5P_LCD0_OPTION				0x3C88
178*4882a593Smuzhiyun #define S5P_LCD1_OPTION				0x3CA8
179*4882a593Smuzhiyun #define S5P_ISP_OPTION				S5P_LCD1_OPTION
180*4882a593Smuzhiyun 
181*4882a593Smuzhiyun #define S5P_CORE_LOCAL_PWR_EN			0x3
182*4882a593Smuzhiyun #define S5P_CORE_WAKEUP_FROM_LOCAL_CFG		(0x3 << 8)
183*4882a593Smuzhiyun #define S5P_CORE_AUTOWAKEUP_EN			(1 << 31)
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun /* Only for S5Pv210 */
186*4882a593Smuzhiyun #define S5PV210_EINT_WAKEUP_MASK	0xC004
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun /* Only for Exynos4210 */
189*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_LCD1_LOWPWR	0x1154
190*4882a593Smuzhiyun #define S5P_CMU_RESET_LCD1_LOWPWR	0x1174
191*4882a593Smuzhiyun #define S5P_MODIMIF_MEM_LOWPWR		0x11C4
192*4882a593Smuzhiyun #define S5P_PCIE_MEM_LOWPWR		0x11E0
193*4882a593Smuzhiyun #define S5P_SATA_MEM_LOWPWR		0x11E4
194*4882a593Smuzhiyun #define S5P_LCD1_LOWPWR			0x1394
195*4882a593Smuzhiyun 
196*4882a593Smuzhiyun /* Only for Exynos4x12 */
197*4882a593Smuzhiyun #define S5P_ISP_ARM_LOWPWR			0x1050
198*4882a593Smuzhiyun #define S5P_DIS_IRQ_ISP_ARM_LOCAL_LOWPWR	0x1054
199*4882a593Smuzhiyun #define S5P_DIS_IRQ_ISP_ARM_CENTRAL_LOWPWR	0x1058
200*4882a593Smuzhiyun #define S5P_CMU_ACLKSTOP_COREBLK_LOWPWR		0x1110
201*4882a593Smuzhiyun #define S5P_CMU_SCLKSTOP_COREBLK_LOWPWR		0x1114
202*4882a593Smuzhiyun #define S5P_CMU_RESET_COREBLK_LOWPWR		0x111C
203*4882a593Smuzhiyun #define S5P_MPLLUSER_SYSCLK_LOWPWR		0x1130
204*4882a593Smuzhiyun #define S5P_CMU_CLKSTOP_ISP_LOWPWR		0x1154
205*4882a593Smuzhiyun #define S5P_CMU_RESET_ISP_LOWPWR		0x1174
206*4882a593Smuzhiyun #define S5P_TOP_BUS_COREBLK_LOWPWR		0x1190
207*4882a593Smuzhiyun #define S5P_TOP_RETENTION_COREBLK_LOWPWR	0x1194
208*4882a593Smuzhiyun #define S5P_TOP_PWR_COREBLK_LOWPWR		0x1198
209*4882a593Smuzhiyun #define S5P_OSCCLK_GATE_LOWPWR			0x11A4
210*4882a593Smuzhiyun #define S5P_LOGIC_RESET_COREBLK_LOWPWR		0x11B0
211*4882a593Smuzhiyun #define S5P_OSCCLK_GATE_COREBLK_LOWPWR		0x11B4
212*4882a593Smuzhiyun #define S5P_HSI_MEM_LOWPWR			0x11C4
213*4882a593Smuzhiyun #define S5P_ROTATOR_MEM_LOWPWR			0x11DC
214*4882a593Smuzhiyun #define S5P_PAD_RETENTION_GPIO_COREBLK_LOWPWR	0x123C
215*4882a593Smuzhiyun #define S5P_PAD_ISOLATION_COREBLK_LOWPWR	0x1250
216*4882a593Smuzhiyun #define S5P_GPIO_MODE_COREBLK_LOWPWR		0x1320
217*4882a593Smuzhiyun #define S5P_TOP_ASB_RESET_LOWPWR		0x1344
218*4882a593Smuzhiyun #define S5P_TOP_ASB_ISOLATION_LOWPWR		0x1348
219*4882a593Smuzhiyun #define S5P_ISP_LOWPWR				0x1394
220*4882a593Smuzhiyun #define S5P_DRAM_FREQ_DOWN_LOWPWR		0x13B0
221*4882a593Smuzhiyun #define S5P_DDRPHY_DLLOFF_LOWPWR		0x13B4
222*4882a593Smuzhiyun #define S5P_CMU_SYSCLK_ISP_LOWPWR		0x13B8
223*4882a593Smuzhiyun #define S5P_CMU_SYSCLK_GPS_LOWPWR		0x13BC
224*4882a593Smuzhiyun #define S5P_LPDDR_PHY_DLL_LOCK_LOWPWR		0x13C0
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun #define S5P_ARM_L2_0_OPTION			0x2608
227*4882a593Smuzhiyun #define S5P_ARM_L2_1_OPTION			0x2628
228*4882a593Smuzhiyun #define S5P_ONENAND_MEM_OPTION			0x2E08
229*4882a593Smuzhiyun #define S5P_HSI_MEM_OPTION			0x2E28
230*4882a593Smuzhiyun #define S5P_G2D_ACP_MEM_OPTION			0x2E48
231*4882a593Smuzhiyun #define S5P_USBOTG_MEM_OPTION			0x2E68
232*4882a593Smuzhiyun #define S5P_HSMMC_MEM_OPTION			0x2E88
233*4882a593Smuzhiyun #define S5P_CSSYS_MEM_OPTION			0x2EA8
234*4882a593Smuzhiyun #define S5P_SECSS_MEM_OPTION			0x2EC8
235*4882a593Smuzhiyun #define S5P_ROTATOR_MEM_OPTION			0x2F48
236*4882a593Smuzhiyun 
237*4882a593Smuzhiyun /* Only for Exynos4412 */
238*4882a593Smuzhiyun #define S5P_ARM_CORE2_LOWPWR			0x1020
239*4882a593Smuzhiyun #define S5P_DIS_IRQ_CORE2			0x1024
240*4882a593Smuzhiyun #define S5P_DIS_IRQ_CENTRAL2			0x1028
241*4882a593Smuzhiyun #define S5P_ARM_CORE3_LOWPWR			0x1030
242*4882a593Smuzhiyun #define S5P_DIS_IRQ_CORE3			0x1034
243*4882a593Smuzhiyun #define S5P_DIS_IRQ_CENTRAL3			0x1038
244*4882a593Smuzhiyun 
245*4882a593Smuzhiyun /* Only for Exynos3XXX */
246*4882a593Smuzhiyun #define EXYNOS3_ARM_CORE0_SYS_PWR_REG			0x1000
247*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ARM_CORE0_LOCAL_SYS_PWR_REG	0x1004
248*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ARM_CORE0_CENTRAL_SYS_PWR_REG	0x1008
249*4882a593Smuzhiyun #define EXYNOS3_ARM_CORE1_SYS_PWR_REG			0x1010
250*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ARM_CORE1_LOCAL_SYS_PWR_REG	0x1014
251*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ARM_CORE1_CENTRAL_SYS_PWR_REG	0x1018
252*4882a593Smuzhiyun #define EXYNOS3_ISP_ARM_SYS_PWR_REG			0x1050
253*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ISP_ARM_LOCAL_SYS_PWR_REG	0x1054
254*4882a593Smuzhiyun #define EXYNOS3_DIS_IRQ_ISP_ARM_CENTRAL_SYS_PWR_REG	0x1058
255*4882a593Smuzhiyun #define EXYNOS3_ARM_COMMON_SYS_PWR_REG			0x1080
256*4882a593Smuzhiyun #define EXYNOS3_ARM_L2_SYS_PWR_REG			0x10C0
257*4882a593Smuzhiyun #define EXYNOS3_CMU_ACLKSTOP_SYS_PWR_REG		0x1100
258*4882a593Smuzhiyun #define EXYNOS3_CMU_SCLKSTOP_SYS_PWR_REG		0x1104
259*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_SYS_PWR_REG			0x110C
260*4882a593Smuzhiyun #define EXYNOS3_CMU_ACLKSTOP_COREBLK_SYS_PWR_REG	0x1110
261*4882a593Smuzhiyun #define EXYNOS3_CMU_SCLKSTOP_COREBLK_SYS_PWR_REG	0x1114
262*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_COREBLK_SYS_PWR_REG		0x111C
263*4882a593Smuzhiyun #define EXYNOS3_APLL_SYSCLK_SYS_PWR_REG			0x1120
264*4882a593Smuzhiyun #define EXYNOS3_MPLL_SYSCLK_SYS_PWR_REG			0x1124
265*4882a593Smuzhiyun #define EXYNOS3_VPLL_SYSCLK_SYS_PWR_REG			0x1128
266*4882a593Smuzhiyun #define EXYNOS3_EPLL_SYSCLK_SYS_PWR_REG			0x112C
267*4882a593Smuzhiyun #define EXYNOS3_MPLLUSER_SYSCLK_SYS_PWR_REG		0x1130
268*4882a593Smuzhiyun #define EXYNOS3_BPLLUSER_SYSCLK_SYS_PWR_REG		0x1134
269*4882a593Smuzhiyun #define EXYNOS3_EPLLUSER_SYSCLK_SYS_PWR_REG		0x1138
270*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_CAM_SYS_PWR_REG		0x1140
271*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_MFC_SYS_PWR_REG		0x1148
272*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_G3D_SYS_PWR_REG		0x114C
273*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_LCD0_SYS_PWR_REG		0x1150
274*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_ISP_SYS_PWR_REG		0x1154
275*4882a593Smuzhiyun #define EXYNOS3_CMU_CLKSTOP_MAUDIO_SYS_PWR_REG		0x1158
276*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_CAM_SYS_PWR_REG		0x1160
277*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_MFC_SYS_PWR_REG		0x1168
278*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_G3D_SYS_PWR_REG		0x116C
279*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_LCD0_SYS_PWR_REG		0x1170
280*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_ISP_SYS_PWR_REG		0x1174
281*4882a593Smuzhiyun #define EXYNOS3_CMU_RESET_MAUDIO_SYS_PWR_REG		0x1178
282*4882a593Smuzhiyun #define EXYNOS3_TOP_BUS_SYS_PWR_REG			0x1180
283*4882a593Smuzhiyun #define EXYNOS3_TOP_RETENTION_SYS_PWR_REG		0x1184
284*4882a593Smuzhiyun #define EXYNOS3_TOP_PWR_SYS_PWR_REG			0x1188
285*4882a593Smuzhiyun #define EXYNOS3_TOP_BUS_COREBLK_SYS_PWR_REG		0x1190
286*4882a593Smuzhiyun #define EXYNOS3_TOP_RETENTION_COREBLK_SYS_PWR_REG	0x1194
287*4882a593Smuzhiyun #define EXYNOS3_TOP_PWR_COREBLK_SYS_PWR_REG		0x1198
288*4882a593Smuzhiyun #define EXYNOS3_LOGIC_RESET_SYS_PWR_REG			0x11A0
289*4882a593Smuzhiyun #define EXYNOS3_OSCCLK_GATE_SYS_PWR_REG			0x11A4
290*4882a593Smuzhiyun #define EXYNOS3_LOGIC_RESET_COREBLK_SYS_PWR_REG		0x11B0
291*4882a593Smuzhiyun #define EXYNOS3_OSCCLK_GATE_COREBLK_SYS_PWR_REG		0x11B4
292*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_DRAM_SYS_PWR_REG		0x1200
293*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_MAUDIO_SYS_PWR_REG	0x1204
294*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_SPI_SYS_PWR_REG		0x1208
295*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_MMC2_SYS_PWR_REG		0x1218
296*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_GPIO_SYS_PWR_REG		0x1220
297*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_UART_SYS_PWR_REG		0x1224
298*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_MMC0_SYS_PWR_REG		0x1228
299*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_MMC1_SYS_PWR_REG		0x122C
300*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_EBIA_SYS_PWR_REG		0x1230
301*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_EBIB_SYS_PWR_REG		0x1234
302*4882a593Smuzhiyun #define EXYNOS3_PAD_RETENTION_JTAG_SYS_PWR_REG		0x1238
303*4882a593Smuzhiyun #define EXYNOS3_PAD_ISOLATION_SYS_PWR_REG		0x1240
304*4882a593Smuzhiyun #define EXYNOS3_PAD_ALV_SEL_SYS_PWR_REG			0x1260
305*4882a593Smuzhiyun #define EXYNOS3_XUSBXTI_SYS_PWR_REG			0x1280
306*4882a593Smuzhiyun #define EXYNOS3_XXTI_SYS_PWR_REG			0x1284
307*4882a593Smuzhiyun #define EXYNOS3_EXT_REGULATOR_SYS_PWR_REG		0x12C0
308*4882a593Smuzhiyun #define EXYNOS3_EXT_REGULATOR_COREBLK_SYS_PWR_REG	0x12C4
309*4882a593Smuzhiyun #define EXYNOS3_GPIO_MODE_SYS_PWR_REG			0x1300
310*4882a593Smuzhiyun #define EXYNOS3_GPIO_MODE_MAUDIO_SYS_PWR_REG		0x1340
311*4882a593Smuzhiyun #define EXYNOS3_TOP_ASB_RESET_SYS_PWR_REG		0x1344
312*4882a593Smuzhiyun #define EXYNOS3_TOP_ASB_ISOLATION_SYS_PWR_REG		0x1348
313*4882a593Smuzhiyun #define EXYNOS3_TOP_ASB_RESET_COREBLK_SYS_PWR_REG	0x1350
314*4882a593Smuzhiyun #define EXYNOS3_TOP_ASB_ISOLATION_COREBLK_SYS_PWR_REG	0x1354
315*4882a593Smuzhiyun #define EXYNOS3_CAM_SYS_PWR_REG				0x1380
316*4882a593Smuzhiyun #define EXYNOS3_MFC_SYS_PWR_REG				0x1388
317*4882a593Smuzhiyun #define EXYNOS3_G3D_SYS_PWR_REG				0x138C
318*4882a593Smuzhiyun #define EXYNOS3_LCD0_SYS_PWR_REG			0x1390
319*4882a593Smuzhiyun #define EXYNOS3_ISP_SYS_PWR_REG				0x1394
320*4882a593Smuzhiyun #define EXYNOS3_MAUDIO_SYS_PWR_REG			0x1398
321*4882a593Smuzhiyun #define EXYNOS3_DRAM_FREQ_DOWN_SYS_PWR_REG		0x13B0
322*4882a593Smuzhiyun #define EXYNOS3_DDRPHY_DLLOFF_SYS_PWR_REG		0x13B4
323*4882a593Smuzhiyun #define EXYNOS3_CMU_SYSCLK_ISP_SYS_PWR_REG		0x13B8
324*4882a593Smuzhiyun #define EXYNOS3_LPDDR_PHY_DLL_LOCK_SYS_PWR_REG		0x13C0
325*4882a593Smuzhiyun #define EXYNOS3_BPLL_SYSCLK_SYS_PWR_REG			0x13C4
326*4882a593Smuzhiyun #define EXYNOS3_UPLL_SYSCLK_SYS_PWR_REG			0x13C8
327*4882a593Smuzhiyun 
328*4882a593Smuzhiyun #define EXYNOS3_ARM_CORE0_OPTION			0x2008
329*4882a593Smuzhiyun #define EXYNOS3_ARM_CORE_OPTION(_nr)	\
330*4882a593Smuzhiyun 			(EXYNOS3_ARM_CORE0_OPTION + ((_nr) * 0x80))
331*4882a593Smuzhiyun 
332*4882a593Smuzhiyun #define EXYNOS3_ARM_COMMON_OPTION			0x2408
333*4882a593Smuzhiyun #define EXYNOS3_ARM_L2_OPTION				0x2608
334*4882a593Smuzhiyun #define EXYNOS3_TOP_PWR_OPTION				0x2C48
335*4882a593Smuzhiyun #define EXYNOS3_CORE_TOP_PWR_OPTION			0x2CA8
336*4882a593Smuzhiyun #define EXYNOS3_XUSBXTI_DURATION			0x341C
337*4882a593Smuzhiyun #define EXYNOS3_XXTI_DURATION				0x343C
338*4882a593Smuzhiyun #define EXYNOS3_EXT_REGULATOR_DURATION			0x361C
339*4882a593Smuzhiyun #define EXYNOS3_EXT_REGULATOR_COREBLK_DURATION		0x363C
340*4882a593Smuzhiyun #define XUSBXTI_DURATION				0x00000BB8
341*4882a593Smuzhiyun #define XXTI_DURATION					XUSBXTI_DURATION
342*4882a593Smuzhiyun #define EXT_REGULATOR_DURATION				0x00001D4C
343*4882a593Smuzhiyun #define EXT_REGULATOR_COREBLK_DURATION			EXT_REGULATOR_DURATION
344*4882a593Smuzhiyun 
345*4882a593Smuzhiyun /* for XXX_OPTION */
346*4882a593Smuzhiyun #define EXYNOS3_OPTION_USE_SC_COUNTER			(1 << 0)
347*4882a593Smuzhiyun #define EXYNOS3_OPTION_USE_SC_FEEDBACK			(1 << 1)
348*4882a593Smuzhiyun #define EXYNOS3_OPTION_SKIP_DEACTIVATE_ACEACP_IN_PWDN	(1 << 7)
349*4882a593Smuzhiyun 
350*4882a593Smuzhiyun /* For Exynos5 */
351*4882a593Smuzhiyun 
352*4882a593Smuzhiyun #define EXYNOS5_AUTO_WDTRESET_DISABLE				0x0408
353*4882a593Smuzhiyun #define EXYNOS5_MASK_WDTRESET_REQUEST				0x040C
354*4882a593Smuzhiyun #define EXYNOS5_USBDRD_PHY_CONTROL				0x0704
355*4882a593Smuzhiyun #define EXYNOS5_DPTX_PHY_CONTROL				0x0720
356*4882a593Smuzhiyun 
357*4882a593Smuzhiyun #define EXYNOS5_USE_RETENTION			BIT(4)
358*4882a593Smuzhiyun #define EXYNOS5_SYS_WDTRESET					(1 << 20)
359*4882a593Smuzhiyun 
360*4882a593Smuzhiyun #define EXYNOS5_ARM_CORE0_SYS_PWR_REG				0x1000
361*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ARM_CORE0_LOCAL_SYS_PWR_REG		0x1004
362*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ARM_CORE0_CENTRAL_SYS_PWR_REG		0x1008
363*4882a593Smuzhiyun #define EXYNOS5_ARM_CORE1_SYS_PWR_REG				0x1010
364*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ARM_CORE1_LOCAL_SYS_PWR_REG		0x1014
365*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ARM_CORE1_CENTRAL_SYS_PWR_REG		0x1018
366*4882a593Smuzhiyun #define EXYNOS5_FSYS_ARM_SYS_PWR_REG				0x1040
367*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_FSYS_ARM_CENTRAL_SYS_PWR_REG		0x1048
368*4882a593Smuzhiyun #define EXYNOS5_ISP_ARM_SYS_PWR_REG				0x1050
369*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ISP_ARM_LOCAL_SYS_PWR_REG		0x1054
370*4882a593Smuzhiyun #define EXYNOS5_DIS_IRQ_ISP_ARM_CENTRAL_SYS_PWR_REG		0x1058
371*4882a593Smuzhiyun #define EXYNOS5_ARM_COMMON_SYS_PWR_REG				0x1080
372*4882a593Smuzhiyun #define EXYNOS5_ARM_L2_SYS_PWR_REG				0x10C0
373*4882a593Smuzhiyun #define EXYNOS5_CMU_ACLKSTOP_SYS_PWR_REG			0x1100
374*4882a593Smuzhiyun #define EXYNOS5_CMU_SCLKSTOP_SYS_PWR_REG			0x1104
375*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_SYS_PWR_REG				0x110C
376*4882a593Smuzhiyun #define EXYNOS5_CMU_ACLKSTOP_SYSMEM_SYS_PWR_REG			0x1120
377*4882a593Smuzhiyun #define EXYNOS5_CMU_SCLKSTOP_SYSMEM_SYS_PWR_REG			0x1124
378*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_SYSMEM_SYS_PWR_REG			0x112C
379*4882a593Smuzhiyun #define EXYNOS5_DRAM_FREQ_DOWN_SYS_PWR_REG			0x1130
380*4882a593Smuzhiyun #define EXYNOS5_DDRPHY_DLLOFF_SYS_PWR_REG			0x1134
381*4882a593Smuzhiyun #define EXYNOS5_DDRPHY_DLLLOCK_SYS_PWR_REG			0x1138
382*4882a593Smuzhiyun #define EXYNOS5_APLL_SYSCLK_SYS_PWR_REG				0x1140
383*4882a593Smuzhiyun #define EXYNOS5_MPLL_SYSCLK_SYS_PWR_REG				0x1144
384*4882a593Smuzhiyun #define EXYNOS5_VPLL_SYSCLK_SYS_PWR_REG				0x1148
385*4882a593Smuzhiyun #define EXYNOS5_EPLL_SYSCLK_SYS_PWR_REG				0x114C
386*4882a593Smuzhiyun #define EXYNOS5_BPLL_SYSCLK_SYS_PWR_REG				0x1150
387*4882a593Smuzhiyun #define EXYNOS5_CPLL_SYSCLK_SYS_PWR_REG				0x1154
388*4882a593Smuzhiyun #define EXYNOS5_MPLLUSER_SYSCLK_SYS_PWR_REG			0x1164
389*4882a593Smuzhiyun #define EXYNOS5_BPLLUSER_SYSCLK_SYS_PWR_REG			0x1170
390*4882a593Smuzhiyun #define EXYNOS5_TOP_BUS_SYS_PWR_REG				0x1180
391*4882a593Smuzhiyun #define EXYNOS5_TOP_RETENTION_SYS_PWR_REG			0x1184
392*4882a593Smuzhiyun #define EXYNOS5_TOP_PWR_SYS_PWR_REG				0x1188
393*4882a593Smuzhiyun #define EXYNOS5_TOP_BUS_SYSMEM_SYS_PWR_REG			0x1190
394*4882a593Smuzhiyun #define EXYNOS5_TOP_RETENTION_SYSMEM_SYS_PWR_REG		0x1194
395*4882a593Smuzhiyun #define EXYNOS5_TOP_PWR_SYSMEM_SYS_PWR_REG			0x1198
396*4882a593Smuzhiyun #define EXYNOS5_LOGIC_RESET_SYS_PWR_REG				0x11A0
397*4882a593Smuzhiyun #define EXYNOS5_OSCCLK_GATE_SYS_PWR_REG				0x11A4
398*4882a593Smuzhiyun #define EXYNOS5_LOGIC_RESET_SYSMEM_SYS_PWR_REG			0x11B0
399*4882a593Smuzhiyun #define EXYNOS5_OSCCLK_GATE_SYSMEM_SYS_PWR_REG			0x11B4
400*4882a593Smuzhiyun #define EXYNOS5_USBOTG_MEM_SYS_PWR_REG				0x11C0
401*4882a593Smuzhiyun #define EXYNOS5_G2D_MEM_SYS_PWR_REG				0x11C8
402*4882a593Smuzhiyun #define EXYNOS5_USBDRD_MEM_SYS_PWR_REG				0x11CC
403*4882a593Smuzhiyun #define EXYNOS5_SDMMC_MEM_SYS_PWR_REG				0x11D0
404*4882a593Smuzhiyun #define EXYNOS5_CSSYS_MEM_SYS_PWR_REG				0x11D4
405*4882a593Smuzhiyun #define EXYNOS5_SECSS_MEM_SYS_PWR_REG				0x11D8
406*4882a593Smuzhiyun #define EXYNOS5_ROTATOR_MEM_SYS_PWR_REG				0x11DC
407*4882a593Smuzhiyun #define EXYNOS5_INTRAM_MEM_SYS_PWR_REG				0x11E0
408*4882a593Smuzhiyun #define EXYNOS5_INTROM_MEM_SYS_PWR_REG				0x11E4
409*4882a593Smuzhiyun #define EXYNOS5_JPEG_MEM_SYS_PWR_REG				0x11E8
410*4882a593Smuzhiyun #define EXYNOS5_HSI_MEM_SYS_PWR_REG				0x11EC
411*4882a593Smuzhiyun #define EXYNOS5_MCUIOP_MEM_SYS_PWR_REG				0x11F4
412*4882a593Smuzhiyun #define EXYNOS5_SATA_MEM_SYS_PWR_REG				0x11FC
413*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_DRAM_SYS_PWR_REG			0x1200
414*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_MAU_SYS_PWR_REG			0x1204
415*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_GPIO_SYS_PWR_REG			0x1220
416*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_UART_SYS_PWR_REG			0x1224
417*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_MMCA_SYS_PWR_REG			0x1228
418*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_MMCB_SYS_PWR_REG			0x122C
419*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_EBIA_SYS_PWR_REG			0x1230
420*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_EBIB_SYS_PWR_REG			0x1234
421*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_SPI_SYS_PWR_REG			0x1238
422*4882a593Smuzhiyun #define EXYNOS5_PAD_RETENTION_GPIO_SYSMEM_SYS_PWR_REG		0x123C
423*4882a593Smuzhiyun #define EXYNOS5_PAD_ISOLATION_SYS_PWR_REG			0x1240
424*4882a593Smuzhiyun #define EXYNOS5_PAD_ISOLATION_SYSMEM_SYS_PWR_REG		0x1250
425*4882a593Smuzhiyun #define EXYNOS5_PAD_ALV_SEL_SYS_PWR_REG				0x1260
426*4882a593Smuzhiyun #define EXYNOS5_XUSBXTI_SYS_PWR_REG				0x1280
427*4882a593Smuzhiyun #define EXYNOS5_XXTI_SYS_PWR_REG				0x1284
428*4882a593Smuzhiyun #define EXYNOS5_EXT_REGULATOR_SYS_PWR_REG			0x12C0
429*4882a593Smuzhiyun #define EXYNOS5_GPIO_MODE_SYS_PWR_REG				0x1300
430*4882a593Smuzhiyun #define EXYNOS5_GPIO_MODE_SYSMEM_SYS_PWR_REG			0x1320
431*4882a593Smuzhiyun #define EXYNOS5_GPIO_MODE_MAU_SYS_PWR_REG			0x1340
432*4882a593Smuzhiyun #define EXYNOS5_TOP_ASB_RESET_SYS_PWR_REG			0x1344
433*4882a593Smuzhiyun #define EXYNOS5_TOP_ASB_ISOLATION_SYS_PWR_REG			0x1348
434*4882a593Smuzhiyun #define EXYNOS5_GSCL_SYS_PWR_REG				0x1400
435*4882a593Smuzhiyun #define EXYNOS5_ISP_SYS_PWR_REG					0x1404
436*4882a593Smuzhiyun #define EXYNOS5_MFC_SYS_PWR_REG					0x1408
437*4882a593Smuzhiyun #define EXYNOS5_G3D_SYS_PWR_REG					0x140C
438*4882a593Smuzhiyun #define EXYNOS5_DISP1_SYS_PWR_REG				0x1414
439*4882a593Smuzhiyun #define EXYNOS5_MAU_SYS_PWR_REG					0x1418
440*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_GSCL_SYS_PWR_REG			0x1480
441*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_ISP_SYS_PWR_REG			0x1484
442*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_MFC_SYS_PWR_REG			0x1488
443*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_G3D_SYS_PWR_REG			0x148C
444*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_DISP1_SYS_PWR_REG			0x1494
445*4882a593Smuzhiyun #define EXYNOS5_CMU_CLKSTOP_MAU_SYS_PWR_REG			0x1498
446*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_GSCL_SYS_PWR_REG			0x14C0
447*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_ISP_SYS_PWR_REG			0x14C4
448*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_MFC_SYS_PWR_REG			0x14C8
449*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_G3D_SYS_PWR_REG			0x14CC
450*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_DISP1_SYS_PWR_REG			0x14D4
451*4882a593Smuzhiyun #define EXYNOS5_CMU_SYSCLK_MAU_SYS_PWR_REG			0x14D8
452*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_GSCL_SYS_PWR_REG			0x1580
453*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_ISP_SYS_PWR_REG			0x1584
454*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_MFC_SYS_PWR_REG			0x1588
455*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_G3D_SYS_PWR_REG			0x158C
456*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_DISP1_SYS_PWR_REG			0x1594
457*4882a593Smuzhiyun #define EXYNOS5_CMU_RESET_MAU_SYS_PWR_REG			0x1598
458*4882a593Smuzhiyun 
459*4882a593Smuzhiyun #define EXYNOS5_ARM_CORE0_OPTION				0x2008
460*4882a593Smuzhiyun #define EXYNOS5_ARM_CORE1_OPTION				0x2088
461*4882a593Smuzhiyun #define EXYNOS5_FSYS_ARM_OPTION					0x2208
462*4882a593Smuzhiyun #define EXYNOS5_ISP_ARM_OPTION					0x2288
463*4882a593Smuzhiyun #define EXYNOS5_ARM_COMMON_OPTION				0x2408
464*4882a593Smuzhiyun #define EXYNOS5_ARM_L2_OPTION					0x2608
465*4882a593Smuzhiyun #define EXYNOS5_TOP_PWR_OPTION					0x2C48
466*4882a593Smuzhiyun #define EXYNOS5_TOP_PWR_SYSMEM_OPTION				0x2CC8
467*4882a593Smuzhiyun #define EXYNOS5_JPEG_MEM_OPTION					0x2F48
468*4882a593Smuzhiyun #define EXYNOS5_GSCL_OPTION					0x4008
469*4882a593Smuzhiyun #define EXYNOS5_ISP_OPTION					0x4028
470*4882a593Smuzhiyun #define EXYNOS5_MFC_OPTION					0x4048
471*4882a593Smuzhiyun #define EXYNOS5_G3D_OPTION					0x4068
472*4882a593Smuzhiyun #define EXYNOS5_DISP1_OPTION					0x40A8
473*4882a593Smuzhiyun #define EXYNOS5_MAU_OPTION					0x40C8
474*4882a593Smuzhiyun 
475*4882a593Smuzhiyun #define EXYNOS5_USE_SC_FEEDBACK					(1 << 1)
476*4882a593Smuzhiyun #define EXYNOS5_USE_SC_COUNTER					(1 << 0)
477*4882a593Smuzhiyun 
478*4882a593Smuzhiyun #define EXYNOS5_SKIP_DEACTIVATE_ACEACP_IN_PWDN			(1 << 7)
479*4882a593Smuzhiyun 
480*4882a593Smuzhiyun #define EXYNOS5_OPTION_USE_STANDBYWFE				(1 << 24)
481*4882a593Smuzhiyun #define EXYNOS5_OPTION_USE_STANDBYWFI				(1 << 16)
482*4882a593Smuzhiyun 
483*4882a593Smuzhiyun #define EXYNOS5_OPTION_USE_RETENTION				(1 << 4)
484*4882a593Smuzhiyun 
485*4882a593Smuzhiyun #define EXYNOS5420_SWRESET_KFC_SEL				0x3
486*4882a593Smuzhiyun 
487*4882a593Smuzhiyun /* Only for Exynos5420 */
488*4882a593Smuzhiyun #define EXYNOS5420_L2RSTDISABLE_VALUE				BIT(3)
489*4882a593Smuzhiyun 
490*4882a593Smuzhiyun #define EXYNOS5420_LPI_MASK					0x0004
491*4882a593Smuzhiyun #define EXYNOS5420_LPI_MASK1					0x0008
492*4882a593Smuzhiyun #define EXYNOS5420_UFS						BIT(8)
493*4882a593Smuzhiyun #define EXYNOS5420_ATB_KFC					BIT(13)
494*4882a593Smuzhiyun #define EXYNOS5420_ATB_ISP_ARM					BIT(19)
495*4882a593Smuzhiyun #define EXYNOS5420_EMULATION					BIT(31)
496*4882a593Smuzhiyun 
497*4882a593Smuzhiyun #define EXYNOS5420_ARM_INTR_SPREAD_ENABLE			0x0100
498*4882a593Smuzhiyun #define EXYNOS5420_ARM_INTR_SPREAD_USE_STANDBYWFI		0x0104
499*4882a593Smuzhiyun #define EXYNOS5420_UP_SCHEDULER					0x0120
500*4882a593Smuzhiyun #define SPREAD_ENABLE						0xF
501*4882a593Smuzhiyun #define SPREAD_USE_STANDWFI					0xF
502*4882a593Smuzhiyun 
503*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE_RESET0				BIT(8)
504*4882a593Smuzhiyun #define EXYNOS5420_KFC_ETM_RESET0				BIT(20)
505*4882a593Smuzhiyun 
506*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE_RESET(_nr)				\
507*4882a593Smuzhiyun 	((EXYNOS5420_KFC_CORE_RESET0 | EXYNOS5420_KFC_ETM_RESET0) << (_nr))
508*4882a593Smuzhiyun 
509*4882a593Smuzhiyun #define EXYNOS5420_USBDRD1_PHY_CONTROL				0x0708
510*4882a593Smuzhiyun #define EXYNOS5420_MIPI_PHY_CONTROL(n)				(0x0714 + (n) * 4)
511*4882a593Smuzhiyun #define EXYNOS5420_DPTX_PHY_CONTROL				0x0728
512*4882a593Smuzhiyun #define EXYNOS5420_ARM_CORE2_SYS_PWR_REG			0x1020
513*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ARM_CORE2_LOCAL_SYS_PWR_REG		0x1024
514*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ARM_CORE2_CENTRAL_SYS_PWR_REG	0x1028
515*4882a593Smuzhiyun #define EXYNOS5420_ARM_CORE3_SYS_PWR_REG			0x1030
516*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ARM_CORE3_LOCAL_SYS_PWR_REG		0x1034
517*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ARM_CORE3_CENTRAL_SYS_PWR_REG	0x1038
518*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE0_SYS_PWR_REG			0x1040
519*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE0_LOCAL_SYS_PWR_REG		0x1044
520*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE0_CENTRAL_SYS_PWR_REG	0x1048
521*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE1_SYS_PWR_REG			0x1050
522*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE1_LOCAL_SYS_PWR_REG		0x1054
523*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE1_CENTRAL_SYS_PWR_REG	0x1058
524*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE2_SYS_PWR_REG			0x1060
525*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE2_LOCAL_SYS_PWR_REG		0x1064
526*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE2_CENTRAL_SYS_PWR_REG	0x1068
527*4882a593Smuzhiyun #define EXYNOS5420_KFC_CORE3_SYS_PWR_REG			0x1070
528*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE3_LOCAL_SYS_PWR_REG		0x1074
529*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_KFC_CORE3_CENTRAL_SYS_PWR_REG	0x1078
530*4882a593Smuzhiyun #define EXYNOS5420_ISP_ARM_SYS_PWR_REG				0x1090
531*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ISP_ARM_LOCAL_SYS_PWR_REG		0x1094
532*4882a593Smuzhiyun #define EXYNOS5420_DIS_IRQ_ISP_ARM_CENTRAL_SYS_PWR_REG		0x1098
533*4882a593Smuzhiyun #define EXYNOS5420_ARM_COMMON_SYS_PWR_REG			0x10A0
534*4882a593Smuzhiyun #define EXYNOS5420_KFC_COMMON_SYS_PWR_REG			0x10B0
535*4882a593Smuzhiyun #define EXYNOS5420_KFC_L2_SYS_PWR_REG				0x10D0
536*4882a593Smuzhiyun #define EXYNOS5420_DPLL_SYSCLK_SYS_PWR_REG			0x1158
537*4882a593Smuzhiyun #define EXYNOS5420_IPLL_SYSCLK_SYS_PWR_REG			0x115C
538*4882a593Smuzhiyun #define EXYNOS5420_KPLL_SYSCLK_SYS_PWR_REG			0x1160
539*4882a593Smuzhiyun #define EXYNOS5420_RPLL_SYSCLK_SYS_PWR_REG                      0x1174
540*4882a593Smuzhiyun #define EXYNOS5420_SPLL_SYSCLK_SYS_PWR_REG                      0x1178
541*4882a593Smuzhiyun #define EXYNOS5420_INTRAM_MEM_SYS_PWR_REG                       0x11B8
542*4882a593Smuzhiyun #define EXYNOS5420_INTROM_MEM_SYS_PWR_REG                       0x11BC
543*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_JTAG_SYS_PWR_REG		0x1208
544*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_DRAM_SYS_PWR_REG		0x1210
545*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_UART_SYS_PWR_REG		0x1214
546*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_MMC0_SYS_PWR_REG		0x1218
547*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_MMC1_SYS_PWR_REG		0x121C
548*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_MMC2_SYS_PWR_REG		0x1220
549*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_HSI_SYS_PWR_REG		0x1224
550*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_EBIA_SYS_PWR_REG		0x1228
551*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_EBIB_SYS_PWR_REG		0x122C
552*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_SPI_SYS_PWR_REG		0x1230
553*4882a593Smuzhiyun #define EXYNOS5420_PAD_RETENTION_DRAM_COREBLK_SYS_PWR_REG	0x1234
554*4882a593Smuzhiyun #define EXYNOS5420_DISP1_SYS_PWR_REG				0x1410
555*4882a593Smuzhiyun #define EXYNOS5420_MAU_SYS_PWR_REG				0x1414
556*4882a593Smuzhiyun #define EXYNOS5420_G2D_SYS_PWR_REG				0x1418
557*4882a593Smuzhiyun #define EXYNOS5420_MSC_SYS_PWR_REG				0x141C
558*4882a593Smuzhiyun #define EXYNOS5420_FSYS_SYS_PWR_REG				0x1420
559*4882a593Smuzhiyun #define EXYNOS5420_FSYS2_SYS_PWR_REG				0x1424
560*4882a593Smuzhiyun #define EXYNOS5420_PSGEN_SYS_PWR_REG				0x1428
561*4882a593Smuzhiyun #define EXYNOS5420_PERIC_SYS_PWR_REG				0x142C
562*4882a593Smuzhiyun #define EXYNOS5420_WCORE_SYS_PWR_REG				0x1430
563*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_DISP1_SYS_PWR_REG		0x1490
564*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_MAU_SYS_PWR_REG			0x1494
565*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_G2D_SYS_PWR_REG			0x1498
566*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_MSC_SYS_PWR_REG			0x149C
567*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_FSYS_SYS_PWR_REG			0x14A0
568*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_FSYS2_SYS_PWR_REG		0x14A4
569*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_PSGEN_SYS_PWR_REG		0x14A8
570*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_PERIC_SYS_PWR_REG		0x14AC
571*4882a593Smuzhiyun #define EXYNOS5420_CMU_CLKSTOP_WCORE_SYS_PWR_REG		0x14B0
572*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_TOPPWR_SYS_PWR_REG		0x14BC
573*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_DISP1_SYS_PWR_REG			0x14D0
574*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_MAU_SYS_PWR_REG			0x14D4
575*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_G2D_SYS_PWR_REG			0x14D8
576*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_MSC_SYS_PWR_REG			0x14DC
577*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_FSYS_SYS_PWR_REG			0x14E0
578*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_FSYS2_SYS_PWR_REG			0x14E4
579*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_PSGEN_SYS_PWR_REG			0x14E8
580*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_PERIC_SYS_PWR_REG			0x14EC
581*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_WCORE_SYS_PWR_REG			0x14F0
582*4882a593Smuzhiyun #define EXYNOS5420_CMU_SYSCLK_SYSMEM_TOPPWR_SYS_PWR_REG		0x14F4
583*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_FSYS2_SYS_PWR_REG			0x1570
584*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_PSGEN_SYS_PWR_REG			0x1574
585*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_PERIC_SYS_PWR_REG			0x1578
586*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_WCORE_SYS_PWR_REG			0x157C
587*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_DISP1_SYS_PWR_REG			0x1590
588*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_MAU_SYS_PWR_REG			0x1594
589*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_G2D_SYS_PWR_REG			0x1598
590*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_MSC_SYS_PWR_REG			0x159C
591*4882a593Smuzhiyun #define EXYNOS5420_CMU_RESET_FSYS_SYS_PWR_REG			0x15A0
592*4882a593Smuzhiyun #define EXYNOS5420_SFR_AXI_CGDIS1				0x15E4
593*4882a593Smuzhiyun #define EXYNOS5420_ARM_COMMON_OPTION				0x2508
594*4882a593Smuzhiyun #define EXYNOS5420_KFC_COMMON_OPTION				0x2588
595*4882a593Smuzhiyun #define EXYNOS5420_LOGIC_RESET_DURATION3			0x2D1C
596*4882a593Smuzhiyun 
597*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_GPIO_OPTION				0x30C8
598*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_UART_OPTION				0x30E8
599*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_MMCA_OPTION				0x3108
600*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_MMCB_OPTION				0x3128
601*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_MMCC_OPTION				0x3148
602*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_HSI_OPTION				0x3168
603*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_SPI_OPTION				0x31C8
604*4882a593Smuzhiyun #define EXYNOS5420_PAD_RET_DRAM_COREBLK_OPTION			0x31E8
605*4882a593Smuzhiyun #define EXYNOS_PAD_RET_DRAM_OPTION				0x3008
606*4882a593Smuzhiyun #define EXYNOS_PAD_RET_MAUDIO_OPTION				0x3028
607*4882a593Smuzhiyun #define EXYNOS_PAD_RET_JTAG_OPTION				0x3048
608*4882a593Smuzhiyun #define EXYNOS_PAD_RET_EBIA_OPTION				0x3188
609*4882a593Smuzhiyun #define EXYNOS_PAD_RET_EBIB_OPTION				0x31A8
610*4882a593Smuzhiyun 
611*4882a593Smuzhiyun #define EXYNOS5420_FSYS2_OPTION					0x4168
612*4882a593Smuzhiyun #define EXYNOS5420_PSGEN_OPTION					0x4188
613*4882a593Smuzhiyun 
614*4882a593Smuzhiyun /* For EXYNOS_CENTRAL_SEQ_OPTION */
615*4882a593Smuzhiyun #define EXYNOS5_USE_STANDBYWFI_ARM_CORE0			BIT(16)
616*4882a593Smuzhiyun #define EXYNOS5_USE_STANDBYWFI_ARM_CORE1			BUT(17)
617*4882a593Smuzhiyun #define EXYNOS5_USE_STANDBYWFE_ARM_CORE0			BIT(24)
618*4882a593Smuzhiyun #define EXYNOS5_USE_STANDBYWFE_ARM_CORE1			BIT(25)
619*4882a593Smuzhiyun 
620*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFI0				BIT(4)
621*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFI1				BIT(5)
622*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFI2				BIT(6)
623*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFI3				BIT(7)
624*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFI0				BIT(8)
625*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFI1				BIT(9)
626*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFI2				BIT(10)
627*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFI3				BIT(11)
628*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFE0				BIT(16)
629*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFE1				BIT(17)
630*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFE2				BIT(18)
631*4882a593Smuzhiyun #define EXYNOS5420_ARM_USE_STANDBY_WFE3				BIT(19)
632*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFE0				BIT(20)
633*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFE1				BIT(21)
634*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFE2				BIT(22)
635*4882a593Smuzhiyun #define EXYNOS5420_KFC_USE_STANDBY_WFE3				BIT(23)
636*4882a593Smuzhiyun 
637*4882a593Smuzhiyun #define DUR_WAIT_RESET				0xF
638*4882a593Smuzhiyun 
639*4882a593Smuzhiyun #define EXYNOS5420_USE_STANDBY_WFI_ALL	(EXYNOS5420_ARM_USE_STANDBY_WFI0    \
640*4882a593Smuzhiyun 					 | EXYNOS5420_ARM_USE_STANDBY_WFI1  \
641*4882a593Smuzhiyun 					 | EXYNOS5420_ARM_USE_STANDBY_WFI2  \
642*4882a593Smuzhiyun 					 | EXYNOS5420_ARM_USE_STANDBY_WFI3  \
643*4882a593Smuzhiyun 					 | EXYNOS5420_KFC_USE_STANDBY_WFI0  \
644*4882a593Smuzhiyun 					 | EXYNOS5420_KFC_USE_STANDBY_WFI1  \
645*4882a593Smuzhiyun 					 | EXYNOS5420_KFC_USE_STANDBY_WFI2  \
646*4882a593Smuzhiyun 					 | EXYNOS5420_KFC_USE_STANDBY_WFI3)
647*4882a593Smuzhiyun 
648*4882a593Smuzhiyun /* For Exynos5433 */
649*4882a593Smuzhiyun #define EXYNOS5433_EINT_WAKEUP_MASK				(0x060C)
650*4882a593Smuzhiyun #define EXYNOS5433_USBHOST30_PHY_CONTROL			(0x0728)
651*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_AUD_OPTION			(0x3028)
652*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_MMC2_OPTION			(0x30C8)
653*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_TOP_OPTION			(0x3108)
654*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_UART_OPTION			(0x3128)
655*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_MMC0_OPTION			(0x3148)
656*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_MMC1_OPTION			(0x3168)
657*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_EBIA_OPTION			(0x3188)
658*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_EBIB_OPTION			(0x31A8)
659*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_SPI_OPTION			(0x31C8)
660*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_MIF_OPTION			(0x31E8)
661*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_USBXTI_OPTION			(0x3228)
662*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_BOOTLDO_OPTION			(0x3248)
663*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_UFS_OPTION			(0x3268)
664*4882a593Smuzhiyun #define EXYNOS5433_PAD_RETENTION_FSYSGENIO_OPTION		(0x32A8)
665*4882a593Smuzhiyun 
666*4882a593Smuzhiyun #endif /* __LINUX_SOC_EXYNOS_REGS_PMU_H */
667