xref: /OK3568_Linux_fs/u-boot/arch/arm/include/asm/arch-mxs/regs-power-mx23.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Freescale i.MX23 Power Controller Register Definitions
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Copyright (C) 2012 Marek Vasut <marex@denx.de>
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0+
7*4882a593Smuzhiyun  */
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #ifndef __MX23_REGS_POWER_H__
10*4882a593Smuzhiyun #define __MX23_REGS_POWER_H__
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun #include <asm/mach-imx/regs-common.h>
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun #ifndef	__ASSEMBLY__
15*4882a593Smuzhiyun struct mxs_power_regs {
16*4882a593Smuzhiyun 	mxs_reg_32(hw_power_ctrl)
17*4882a593Smuzhiyun 	mxs_reg_32(hw_power_5vctrl)
18*4882a593Smuzhiyun 	mxs_reg_32(hw_power_minpwr)
19*4882a593Smuzhiyun 	mxs_reg_32(hw_power_charge)
20*4882a593Smuzhiyun 	uint32_t	hw_power_vdddctrl;
21*4882a593Smuzhiyun 	uint32_t	reserved_vddd[3];
22*4882a593Smuzhiyun 	uint32_t	hw_power_vddactrl;
23*4882a593Smuzhiyun 	uint32_t	reserved_vdda[3];
24*4882a593Smuzhiyun 	uint32_t	hw_power_vddioctrl;
25*4882a593Smuzhiyun 	uint32_t	reserved_vddio[3];
26*4882a593Smuzhiyun 	uint32_t	hw_power_vddmemctrl;
27*4882a593Smuzhiyun 	uint32_t	reserved_vddmem[3];
28*4882a593Smuzhiyun 	uint32_t	hw_power_dcdc4p2;
29*4882a593Smuzhiyun 	uint32_t	reserved_dcdc4p2[3];
30*4882a593Smuzhiyun 	uint32_t	hw_power_misc;
31*4882a593Smuzhiyun 	uint32_t	reserved_misc[3];
32*4882a593Smuzhiyun 	uint32_t	hw_power_dclimits;
33*4882a593Smuzhiyun 	uint32_t	reserved_dclimits[3];
34*4882a593Smuzhiyun 	mxs_reg_32(hw_power_loopctrl)
35*4882a593Smuzhiyun 	uint32_t	hw_power_sts;
36*4882a593Smuzhiyun 	uint32_t	reserved_sts[3];
37*4882a593Smuzhiyun 	mxs_reg_32(hw_power_speed)
38*4882a593Smuzhiyun 	uint32_t	hw_power_battmonitor;
39*4882a593Smuzhiyun 	uint32_t	reserved_battmonitor[3];
40*4882a593Smuzhiyun 
41*4882a593Smuzhiyun 	uint32_t	reserved1[4];
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun 	mxs_reg_32(hw_power_reset)
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun 	uint32_t	reserved2[4];
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun 	mxs_reg_32(hw_power_special)
48*4882a593Smuzhiyun 	mxs_reg_32(hw_power_version)
49*4882a593Smuzhiyun };
50*4882a593Smuzhiyun #endif
51*4882a593Smuzhiyun 
52*4882a593Smuzhiyun #define	POWER_CTRL_CLKGATE				(1 << 30)
53*4882a593Smuzhiyun #define	POWER_CTRL_PSWITCH_MID_TRAN			(1 << 27)
54*4882a593Smuzhiyun #define	POWER_CTRL_DCDC4P2_BO_IRQ			(1 << 24)
55*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_DCDC4P2_BO			(1 << 23)
56*4882a593Smuzhiyun #define	POWER_CTRL_VDD5V_DROOP_IRQ			(1 << 22)
57*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VDD5V_DROOP			(1 << 21)
58*4882a593Smuzhiyun #define	POWER_CTRL_PSWITCH_IRQ				(1 << 20)
59*4882a593Smuzhiyun #define	POWER_CTRL_PSWITCH_IRQ_SRC			(1 << 19)
60*4882a593Smuzhiyun #define	POWER_CTRL_POLARITY_PSWITCH			(1 << 18)
61*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_PSWITCH			(1 << 17)
62*4882a593Smuzhiyun #define	POWER_CTRL_POLARITY_DC_OK			(1 << 16)
63*4882a593Smuzhiyun #define	POWER_CTRL_DC_OK_IRQ				(1 << 15)
64*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_DC_OK				(1 << 14)
65*4882a593Smuzhiyun #define	POWER_CTRL_BATT_BO_IRQ				(1 << 13)
66*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_BATT_BO			(1 << 12)
67*4882a593Smuzhiyun #define	POWER_CTRL_VDDIO_BO_IRQ				(1 << 11)
68*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VDDIO_BO			(1 << 10)
69*4882a593Smuzhiyun #define	POWER_CTRL_VDDA_BO_IRQ				(1 << 9)
70*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VDDA_BO			(1 << 8)
71*4882a593Smuzhiyun #define	POWER_CTRL_VDDD_BO_IRQ				(1 << 7)
72*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VDDD_BO			(1 << 6)
73*4882a593Smuzhiyun #define	POWER_CTRL_POLARITY_VBUSVALID			(1 << 5)
74*4882a593Smuzhiyun #define	POWER_CTRL_VBUS_VALID_IRQ			(1 << 4)
75*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VBUS_VALID			(1 << 3)
76*4882a593Smuzhiyun #define	POWER_CTRL_POLARITY_VDD5V_GT_VDDIO		(1 << 2)
77*4882a593Smuzhiyun #define	POWER_CTRL_VDD5V_GT_VDDIO_IRQ			(1 << 1)
78*4882a593Smuzhiyun #define	POWER_CTRL_ENIRQ_VDD5V_GT_VDDIO			(1 << 0)
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_MASK		(0x3 << 28)
81*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_OFFSET		28
82*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_4V3			(0x0 << 28)
83*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_4V4			(0x1 << 28)
84*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_4V5			(0x2 << 28)
85*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSDROOP_TRSH_4V7			(0x3 << 28)
86*4882a593Smuzhiyun #define	POWER_5VCTRL_HEADROOM_ADJ_MASK			(0x7 << 24)
87*4882a593Smuzhiyun #define	POWER_5VCTRL_HEADROOM_ADJ_OFFSET		24
88*4882a593Smuzhiyun #define	POWER_5VCTRL_PWD_CHARGE_4P2_MASK		(0x1 << 20)
89*4882a593Smuzhiyun #define	POWER_5VCTRL_PWD_CHARGE_4P2_OFFSET		20
90*4882a593Smuzhiyun #define	POWER_5VCTRL_CHARGE_4P2_ILIMIT_MASK		(0x3f << 12)
91*4882a593Smuzhiyun #define	POWER_5VCTRL_CHARGE_4P2_ILIMIT_OFFSET		12
92*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_MASK		(0x7 << 8)
93*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_OFFSET		8
94*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_2V9			(0x0 << 8)
95*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V0			(0x1 << 8)
96*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V1			(0x2 << 8)
97*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V2			(0x3 << 8)
98*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V3			(0x4 << 8)
99*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V4			(0x5 << 8)
100*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V5			(0x6 << 8)
101*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TRSH_4V6			(0x7 << 8)
102*4882a593Smuzhiyun #define	POWER_5VCTRL_PWDN_5VBRNOUT			(1 << 7)
103*4882a593Smuzhiyun #define	POWER_5VCTRL_ENABLE_LINREG_ILIMIT		(1 << 6)
104*4882a593Smuzhiyun #define	POWER_5VCTRL_DCDC_XFER				(1 << 5)
105*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_5VDETECT			(1 << 4)
106*4882a593Smuzhiyun #define	POWER_5VCTRL_VBUSVALID_TO_B			(1 << 3)
107*4882a593Smuzhiyun #define	POWER_5VCTRL_ILIMIT_EQ_ZERO			(1 << 2)
108*4882a593Smuzhiyun #define	POWER_5VCTRL_PWRUP_VBUS_CMPS			(1 << 1)
109*4882a593Smuzhiyun #define	POWER_5VCTRL_ENABLE_DCDC			(1 << 0)
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun #define	POWER_MINPWR_LOWPWR_4P2				(1 << 14)
112*4882a593Smuzhiyun #define	POWER_MINPWR_VDAC_DUMP_CTRL			(1 << 13)
113*4882a593Smuzhiyun #define	POWER_MINPWR_PWD_BO				(1 << 12)
114*4882a593Smuzhiyun #define	POWER_MINPWR_USE_VDDXTAL_VBG			(1 << 11)
115*4882a593Smuzhiyun #define	POWER_MINPWR_PWD_ANA_CMPS			(1 << 10)
116*4882a593Smuzhiyun #define	POWER_MINPWR_ENABLE_OSC				(1 << 9)
117*4882a593Smuzhiyun #define	POWER_MINPWR_SELECT_OSC				(1 << 8)
118*4882a593Smuzhiyun #define	POWER_MINPWR_VBG_OFF				(1 << 7)
119*4882a593Smuzhiyun #define	POWER_MINPWR_DOUBLE_FETS			(1 << 6)
120*4882a593Smuzhiyun #define	POWER_MINPWR_HALFFETS				(1 << 5)
121*4882a593Smuzhiyun #define	POWER_MINPWR_LESSANA_I				(1 << 4)
122*4882a593Smuzhiyun #define	POWER_MINPWR_PWD_XTAL24				(1 << 3)
123*4882a593Smuzhiyun #define	POWER_MINPWR_DC_STOPCLK				(1 << 2)
124*4882a593Smuzhiyun #define	POWER_MINPWR_EN_DC_PFM				(1 << 1)
125*4882a593Smuzhiyun #define	POWER_MINPWR_DC_HALFCLK				(1 << 0)
126*4882a593Smuzhiyun 
127*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_MASK			(0x7 << 24)
128*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_OFFSET			24
129*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_M025P			(0x1 << 24)
130*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_P050P			(0x2 << 24)
131*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_M075P			(0x3 << 24)
132*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_P025P			(0x4 << 24)
133*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_M050P			(0x5 << 24)
134*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_P075P			(0x6 << 24)
135*4882a593Smuzhiyun #define	POWER_CHARGE_ADJ_VOLT_M100P			(0x7 << 24)
136*4882a593Smuzhiyun #define	POWER_CHARGE_ENABLE_LOAD			(1 << 22)
137*4882a593Smuzhiyun #define	POWER_CHARGE_ENABLE_CHARGER_RESISTORS		(1 << 21)
138*4882a593Smuzhiyun #define	POWER_CHARGE_ENABLE_FAULT_DETECT		(1 << 20)
139*4882a593Smuzhiyun #define	POWER_CHARGE_CHRG_STS_OFF			(1 << 19)
140*4882a593Smuzhiyun #define	POWER_CHARGE_USE_EXTERN_R			(1 << 17)
141*4882a593Smuzhiyun #define	POWER_CHARGE_PWD_BATTCHRG			(1 << 16)
142*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_MASK			(0xf << 8)
143*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_OFFSET			8
144*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_10MA			(0x1 << 8)
145*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_20MA			(0x2 << 8)
146*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_50MA			(0x4 << 8)
147*4882a593Smuzhiyun #define	POWER_CHARGE_STOP_ILIMIT_100MA			(0x8 << 8)
148*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_MASK			0x3f
149*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_OFFSET			0
150*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_10MA			0x01
151*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_20MA			0x02
152*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_50MA			0x04
153*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_100MA			0x08
154*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_200MA			0x10
155*4882a593Smuzhiyun #define	POWER_CHARGE_BATTCHRG_I_400MA			0x20
156*4882a593Smuzhiyun 
157*4882a593Smuzhiyun #define	POWER_VDDDCTRL_ADJTN_MASK			(0xf << 28)
158*4882a593Smuzhiyun #define	POWER_VDDDCTRL_ADJTN_OFFSET			28
159*4882a593Smuzhiyun #define	POWER_VDDDCTRL_PWDN_BRNOUT			(1 << 23)
160*4882a593Smuzhiyun #define	POWER_VDDDCTRL_DISABLE_STEPPING			(1 << 22)
161*4882a593Smuzhiyun #define	POWER_VDDDCTRL_ENABLE_LINREG			(1 << 21)
162*4882a593Smuzhiyun #define	POWER_VDDDCTRL_DISABLE_FET			(1 << 20)
163*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_MASK		(0x3 << 16)
164*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_OFFSET		16
165*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_0STEPS		(0x0 << 16)
166*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_1STEPS_ABOVE	(0x1 << 16)
167*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_1STEPS_BELOW	(0x2 << 16)
168*4882a593Smuzhiyun #define	POWER_VDDDCTRL_LINREG_OFFSET_2STEPS_BELOW	(0x3 << 16)
169*4882a593Smuzhiyun #define	POWER_VDDDCTRL_BO_OFFSET_MASK			(0x7 << 8)
170*4882a593Smuzhiyun #define	POWER_VDDDCTRL_BO_OFFSET_OFFSET			8
171*4882a593Smuzhiyun #define	POWER_VDDDCTRL_TRG_MASK				0x1f
172*4882a593Smuzhiyun #define	POWER_VDDDCTRL_TRG_OFFSET			0
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun #define	POWER_VDDACTRL_PWDN_BRNOUT			(1 << 19)
175*4882a593Smuzhiyun #define	POWER_VDDACTRL_DISABLE_STEPPING			(1 << 18)
176*4882a593Smuzhiyun #define	POWER_VDDACTRL_ENABLE_LINREG			(1 << 17)
177*4882a593Smuzhiyun #define	POWER_VDDACTRL_DISABLE_FET			(1 << 16)
178*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_MASK		(0x3 << 12)
179*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_OFFSET		12
180*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_0STEPS		(0x0 << 12)
181*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_1STEPS_ABOVE	(0x1 << 12)
182*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_1STEPS_BELOW	(0x2 << 12)
183*4882a593Smuzhiyun #define	POWER_VDDACTRL_LINREG_OFFSET_2STEPS_BELOW	(0x3 << 12)
184*4882a593Smuzhiyun #define	POWER_VDDACTRL_BO_OFFSET_MASK			(0x7 << 8)
185*4882a593Smuzhiyun #define	POWER_VDDACTRL_BO_OFFSET_OFFSET			8
186*4882a593Smuzhiyun #define	POWER_VDDACTRL_TRG_MASK				0x1f
187*4882a593Smuzhiyun #define	POWER_VDDACTRL_TRG_OFFSET			0
188*4882a593Smuzhiyun 
189*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_ADJTN_MASK			(0xf << 20)
190*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_ADJTN_OFFSET			20
191*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_PWDN_BRNOUT			(1 << 18)
192*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_DISABLE_STEPPING		(1 << 17)
193*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_DISABLE_FET			(1 << 16)
194*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_MASK		(0x3 << 12)
195*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_OFFSET		12
196*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_0STEPS		(0x0 << 12)
197*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_1STEPS_ABOVE	(0x1 << 12)
198*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_1STEPS_BELOW	(0x2 << 12)
199*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_LINREG_OFFSET_2STEPS_BELOW	(0x3 << 12)
200*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_BO_OFFSET_MASK			(0x7 << 8)
201*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_BO_OFFSET_OFFSET		8
202*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_TRG_MASK			0x1f
203*4882a593Smuzhiyun #define	POWER_VDDIOCTRL_TRG_OFFSET			0
204*4882a593Smuzhiyun 
205*4882a593Smuzhiyun #define	POWER_VDDMEMCTRL_PULLDOWN_ACTIVE		(1 << 10)
206*4882a593Smuzhiyun #define	POWER_VDDMEMCTRL_ENABLE_ILIMIT			(1 << 9)
207*4882a593Smuzhiyun #define	POWER_VDDMEMCTRL_ENABLE_LINREG			(1 << 8)
208*4882a593Smuzhiyun #define	POWER_VDDMEMCTRL_TRG_MASK			0x1f
209*4882a593Smuzhiyun #define	POWER_VDDMEMCTRL_TRG_OFFSET			0
210*4882a593Smuzhiyun 
211*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_MASK			(0xf << 28)
212*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_OFFSET		28
213*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_200MV		(0x3 << 30)
214*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_100MV		(0x2 << 30)
215*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_50MV			(0x1 << 30)
216*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_25MV			(0x0 << 30)
217*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_SRC_4P2		(0x0 << 28)
218*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_SRC_4P2_LT_BATT	(0x1 << 28)
219*4882a593Smuzhiyun #define	POWER_DCDC4P2_DROPOUT_CTRL_SRC_SEL		(0x2 << 28)
220*4882a593Smuzhiyun #define	POWER_DCDC4P2_ISTEAL_THRESH_MASK		(0x3 << 24)
221*4882a593Smuzhiyun #define	POWER_DCDC4P2_ISTEAL_THRESH_OFFSET		24
222*4882a593Smuzhiyun #define	POWER_DCDC4P2_ENABLE_4P2			(1 << 23)
223*4882a593Smuzhiyun #define	POWER_DCDC4P2_ENABLE_DCDC			(1 << 22)
224*4882a593Smuzhiyun #define	POWER_DCDC4P2_HYST_DIR				(1 << 21)
225*4882a593Smuzhiyun #define	POWER_DCDC4P2_HYST_THRESH			(1 << 20)
226*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_MASK				(0x7 << 16)
227*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_OFFSET			16
228*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_4V2				(0x0 << 16)
229*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_4V1				(0x1 << 16)
230*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_4V0				(0x2 << 16)
231*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_3V9				(0x3 << 16)
232*4882a593Smuzhiyun #define	POWER_DCDC4P2_TRG_BATT				(0x4 << 16)
233*4882a593Smuzhiyun #define	POWER_DCDC4P2_BO_MASK				(0x1f << 8)
234*4882a593Smuzhiyun #define	POWER_DCDC4P2_BO_OFFSET				8
235*4882a593Smuzhiyun #define	POWER_DCDC4P2_CMPTRIP_MASK			0x1f
236*4882a593Smuzhiyun #define	POWER_DCDC4P2_CMPTRIP_OFFSET			0
237*4882a593Smuzhiyun 
238*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_MASK				(0x7 << 4)
239*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_OFFSET			4
240*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_20MHZ			(0x1 << 4)
241*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_24MHZ			(0x2 << 4)
242*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_19MHZ			(0x3 << 4)
243*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_14MHZ			(0x4 << 4)
244*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_18MHZ			(0x5 << 4)
245*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_21MHZ			(0x6 << 4)
246*4882a593Smuzhiyun #define	POWER_MISC_FREQSEL_17MHZ			(0x7 << 4)
247*4882a593Smuzhiyun #define	POWER_MISC_DISABLE_FET_BO_LOGIC			(1 << 3)
248*4882a593Smuzhiyun #define	POWER_MISC_DELAY_TIMING				(1 << 2)
249*4882a593Smuzhiyun #define	POWER_MISC_TEST					(1 << 1)
250*4882a593Smuzhiyun #define	POWER_MISC_SEL_PLLCLK				(1 << 0)
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun #define	POWER_DCLIMITS_POSLIMIT_BUCK_MASK		(0x7f << 8)
253*4882a593Smuzhiyun #define	POWER_DCLIMITS_POSLIMIT_BUCK_OFFSET		8
254*4882a593Smuzhiyun #define	POWER_DCLIMITS_NEGLIMIT_MASK			0x7f
255*4882a593Smuzhiyun #define	POWER_DCLIMITS_NEGLIMIT_OFFSET			0
256*4882a593Smuzhiyun 
257*4882a593Smuzhiyun #define	POWER_LOOPCTRL_TOGGLE_DIF			(1 << 20)
258*4882a593Smuzhiyun #define	POWER_LOOPCTRL_HYST_SIGN			(1 << 19)
259*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_CM_HYST			(1 << 18)
260*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_DF_HYST			(1 << 17)
261*4882a593Smuzhiyun #define	POWER_LOOPCTRL_CM_HYST_THRESH			(1 << 16)
262*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DF_HYST_THRESH			(1 << 15)
263*4882a593Smuzhiyun #define	POWER_LOOPCTRL_RCSCALE_THRESH			(1 << 14)
264*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_MASK			(0x3 << 12)
265*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_OFFSET		12
266*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_DIS			(0x0 << 12)
267*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_2X			(0x1 << 12)
268*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_4X			(0x2 << 12)
269*4882a593Smuzhiyun #define	POWER_LOOPCTRL_EN_RCSCALE_8X			(0x3 << 12)
270*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_FF_MASK			(0x7 << 8)
271*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_FF_OFFSET			8
272*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_R_MASK			(0xf << 4)
273*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_R_OFFSET			4
274*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_MASK			0x3
275*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_OFFSET			0
276*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_MAX				0x0
277*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_2X				0x1
278*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_4X				0x2
279*4882a593Smuzhiyun #define	POWER_LOOPCTRL_DC_C_MIN				0x3
280*4882a593Smuzhiyun 
281*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_MASK			(0x3f << 24)
282*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_OFFSET			24
283*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_5V			(0x20 << 24)
284*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_RTC			(0x10 << 24)
285*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_PSWITCH_HIGH		(0x02 << 24)
286*4882a593Smuzhiyun #define	POWER_STS_PWRUP_SOURCE_PSWITCH_MID		(0x01 << 24)
287*4882a593Smuzhiyun #define	POWER_STS_PSWITCH_MASK				(0x3 << 20)
288*4882a593Smuzhiyun #define	POWER_STS_PSWITCH_OFFSET			20
289*4882a593Smuzhiyun #define	POWER_STS_AVALID0_STATUS			(1 << 17)
290*4882a593Smuzhiyun #define	POWER_STS_BVALID0_STATUS			(1 << 16)
291*4882a593Smuzhiyun #define	POWER_STS_VBUSVALID0_STATUS			(1 << 15)
292*4882a593Smuzhiyun #define	POWER_STS_SESSEND0_STATUS			(1 << 14)
293*4882a593Smuzhiyun #define	POWER_STS_BATT_BO				(1 << 13)
294*4882a593Smuzhiyun #define	POWER_STS_VDD5V_FAULT				(1 << 12)
295*4882a593Smuzhiyun #define	POWER_STS_CHRGSTS				(1 << 11)
296*4882a593Smuzhiyun #define	POWER_STS_DCDC_4P2_BO				(1 << 10)
297*4882a593Smuzhiyun #define	POWER_STS_DC_OK					(1 << 9)
298*4882a593Smuzhiyun #define	POWER_STS_VDDIO_BO				(1 << 8)
299*4882a593Smuzhiyun #define	POWER_STS_VDDA_BO				(1 << 7)
300*4882a593Smuzhiyun #define	POWER_STS_VDDD_BO				(1 << 6)
301*4882a593Smuzhiyun #define	POWER_STS_VDD5V_GT_VDDIO			(1 << 5)
302*4882a593Smuzhiyun #define	POWER_STS_VDD5V_DROOP				(1 << 4)
303*4882a593Smuzhiyun #define	POWER_STS_AVALID0				(1 << 3)
304*4882a593Smuzhiyun #define	POWER_STS_BVALID0				(1 << 2)
305*4882a593Smuzhiyun #define	POWER_STS_VBUSVALID0				(1 << 1)
306*4882a593Smuzhiyun #define	POWER_STS_SESSEND0				(1 << 0)
307*4882a593Smuzhiyun 
308*4882a593Smuzhiyun #define	POWER_SPEED_STATUS_MASK				(0xff << 16)
309*4882a593Smuzhiyun #define	POWER_SPEED_STATUS_OFFSET			16
310*4882a593Smuzhiyun #define	POWER_SPEED_CTRL_MASK				0x3
311*4882a593Smuzhiyun #define	POWER_SPEED_CTRL_OFFSET				0
312*4882a593Smuzhiyun #define	POWER_SPEED_CTRL_SS_OFF				0x0
313*4882a593Smuzhiyun #define	POWER_SPEED_CTRL_SS_ON				0x1
314*4882a593Smuzhiyun #define	POWER_SPEED_CTRL_SS_ENABLE			0x3
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun #define	POWER_BATTMONITOR_BATT_VAL_MASK			(0x3ff << 16)
317*4882a593Smuzhiyun #define	POWER_BATTMONITOR_BATT_VAL_OFFSET		16
318*4882a593Smuzhiyun #define	POWER_BATTMONITOR_EN_BATADJ			(1 << 10)
319*4882a593Smuzhiyun #define	POWER_BATTMONITOR_PWDN_BATTBRNOUT		(1 << 9)
320*4882a593Smuzhiyun #define	POWER_BATTMONITOR_BRWNOUT_PWD			(1 << 8)
321*4882a593Smuzhiyun #define	POWER_BATTMONITOR_BRWNOUT_LVL_MASK		0x1f
322*4882a593Smuzhiyun #define	POWER_BATTMONITOR_BRWNOUT_LVL_OFFSET		0
323*4882a593Smuzhiyun 
324*4882a593Smuzhiyun #define	POWER_RESET_UNLOCK_MASK				(0xffff << 16)
325*4882a593Smuzhiyun #define	POWER_RESET_UNLOCK_OFFSET			16
326*4882a593Smuzhiyun #define	POWER_RESET_UNLOCK_KEY				(0x3e77 << 16)
327*4882a593Smuzhiyun #define	POWER_RESET_PWD_OFF				(1 << 1)
328*4882a593Smuzhiyun #define	POWER_RESET_PWD					(1 << 0)
329*4882a593Smuzhiyun 
330*4882a593Smuzhiyun #define	POWER_DEBUG_VBUSVALIDPIOLOCK			(1 << 3)
331*4882a593Smuzhiyun #define	POWER_DEBUG_AVALIDPIOLOCK			(1 << 2)
332*4882a593Smuzhiyun #define	POWER_DEBUG_BVALIDPIOLOCK			(1 << 1)
333*4882a593Smuzhiyun #define	POWER_DEBUG_SESSENDPIOLOCK			(1 << 0)
334*4882a593Smuzhiyun 
335*4882a593Smuzhiyun #define	POWER_SPECIAL_TEST_MASK				0xffffffff
336*4882a593Smuzhiyun #define	POWER_SPECIAL_TEST_OFFSET			0
337*4882a593Smuzhiyun 
338*4882a593Smuzhiyun #define	POWER_VERSION_MAJOR_MASK			(0xff << 24)
339*4882a593Smuzhiyun #define	POWER_VERSION_MAJOR_OFFSET			24
340*4882a593Smuzhiyun #define	POWER_VERSION_MINOR_MASK			(0xff << 16)
341*4882a593Smuzhiyun #define	POWER_VERSION_MINOR_OFFSET			16
342*4882a593Smuzhiyun #define	POWER_VERSION_STEP_MASK				0xffff
343*4882a593Smuzhiyun #define	POWER_VERSION_STEP_OFFSET			0
344*4882a593Smuzhiyun 
345*4882a593Smuzhiyun #endif	/* __MX23_REGS_POWER_H__ */
346