xref: /rk3399_rockchip-uboot/include/power/max8997_pmic.h (revision c7336815078ff3745e3130aeff35991e3e98e61e)
1*c7336815SŁukasz Majewski /*
2*c7336815SŁukasz Majewski  *  Copyright (C) 2011 Samsung Electronics
3*c7336815SŁukasz Majewski  *  Lukasz Majewski <l.majewski@samsung.com>
4*c7336815SŁukasz Majewski  *
5*c7336815SŁukasz Majewski  * See file CREDITS for list of people who contributed to this
6*c7336815SŁukasz Majewski  * project.
7*c7336815SŁukasz Majewski  *
8*c7336815SŁukasz Majewski  * This program is free software; you can redistribute it and/or
9*c7336815SŁukasz Majewski  * modify it under the terms of the GNU General Public License as
10*c7336815SŁukasz Majewski  * published by the Free Software Foundation; either version 2 of
11*c7336815SŁukasz Majewski  * the License, or (at your option) any later version.
12*c7336815SŁukasz Majewski  *
13*c7336815SŁukasz Majewski  * This program is distributed in the hope that it will be useful,
14*c7336815SŁukasz Majewski  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15*c7336815SŁukasz Majewski  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16*c7336815SŁukasz Majewski  * GNU General Public License for more details.
17*c7336815SŁukasz Majewski  *
18*c7336815SŁukasz Majewski  * You should have received a copy of the GNU General Public License
19*c7336815SŁukasz Majewski  * along with this program; if not, write to the Free Software
20*c7336815SŁukasz Majewski  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21*c7336815SŁukasz Majewski  * MA 02111-1307 USA
22*c7336815SŁukasz Majewski  */
23*c7336815SŁukasz Majewski 
24*c7336815SŁukasz Majewski #ifndef __MAX8997_PMIC_H_
25*c7336815SŁukasz Majewski #define __MAX8997_PMIC_H_
26*c7336815SŁukasz Majewski 
27*c7336815SŁukasz Majewski /* MAX 8997 registers */
28*c7336815SŁukasz Majewski enum {
29*c7336815SŁukasz Majewski 	MAX8997_REG_PMIC_ID0	= 0x00,
30*c7336815SŁukasz Majewski 	MAX8997_REG_PMIC_ID1	= 0x01,
31*c7336815SŁukasz Majewski 	MAX8997_REG_INTSRC	= 0x02,
32*c7336815SŁukasz Majewski 	MAX8997_REG_INT1	= 0x03,
33*c7336815SŁukasz Majewski 	MAX8997_REG_INT2	= 0x04,
34*c7336815SŁukasz Majewski 	MAX8997_REG_INT3	= 0x05,
35*c7336815SŁukasz Majewski 	MAX8997_REG_INT4	= 0x06,
36*c7336815SŁukasz Majewski 
37*c7336815SŁukasz Majewski 	MAX8997_REG_INT1MSK	= 0x08,
38*c7336815SŁukasz Majewski 	MAX8997_REG_INT2MSK	= 0x09,
39*c7336815SŁukasz Majewski 	MAX8997_REG_INT3MSK	= 0x0a,
40*c7336815SŁukasz Majewski 	MAX8997_REG_INT4MSK	= 0x0b,
41*c7336815SŁukasz Majewski 
42*c7336815SŁukasz Majewski 	MAX8997_REG_STATUS1	= 0x0d,
43*c7336815SŁukasz Majewski 	MAX8997_REG_STATUS2	= 0x0e,
44*c7336815SŁukasz Majewski 	MAX8997_REG_STATUS3	= 0x0f,
45*c7336815SŁukasz Majewski 	MAX8997_REG_STATUS4	= 0x10,
46*c7336815SŁukasz Majewski 
47*c7336815SŁukasz Majewski 	MAX8997_REG_MAINCON1	= 0x13,
48*c7336815SŁukasz Majewski 	MAX8997_REG_MAINCON2	= 0x14,
49*c7336815SŁukasz Majewski 	MAX8997_REG_BUCKRAMP	= 0x15,
50*c7336815SŁukasz Majewski 
51*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1CTRL	= 0x18,
52*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS1	= 0x19,
53*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS2	= 0x1a,
54*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS3	= 0x1b,
55*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS4	= 0x1c,
56*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS5	= 0x1d,
57*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS6	= 0x1e,
58*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS7	= 0x1f,
59*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK1DVS8	= 0x20,
60*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2CTRL	= 0x21,
61*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS1	= 0x22,
62*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS2	= 0x23,
63*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS3	= 0x24,
64*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS4	= 0x25,
65*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS5	= 0x26,
66*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS6	= 0x27,
67*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS7	= 0x28,
68*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK2DVS8	= 0x29,
69*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK3CTRL	= 0x2a,
70*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK3DVS	= 0x2b,
71*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK4CTRL	= 0x2c,
72*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK4DVS	= 0x2d,
73*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5CTRL	= 0x2e,
74*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS1	= 0x2f,
75*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS2	= 0x30,
76*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS3	= 0x31,
77*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS4	= 0x32,
78*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS5	= 0x33,
79*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS6	= 0x34,
80*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS7	= 0x35,
81*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK5DVS8	= 0x36,
82*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK6CTRL	= 0x37,
83*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK6BPSKIPCTRL	= 0x38,
84*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK7CTRL	= 0x39,
85*c7336815SŁukasz Majewski 	MAX8997_REG_BUCK7DVS	= 0x3a,
86*c7336815SŁukasz Majewski 	MAX8997_REG_LDO1CTRL	= 0x3b,
87*c7336815SŁukasz Majewski 	MAX8997_REG_LDO2CTRL	= 0x3c,
88*c7336815SŁukasz Majewski 	MAX8997_REG_LDO3CTRL	= 0x3d,
89*c7336815SŁukasz Majewski 	MAX8997_REG_LDO4CTRL	= 0x3e,
90*c7336815SŁukasz Majewski 	MAX8997_REG_LDO5CTRL	= 0x3f,
91*c7336815SŁukasz Majewski 	MAX8997_REG_LDO6CTRL	= 0x40,
92*c7336815SŁukasz Majewski 	MAX8997_REG_LDO7CTRL	= 0x41,
93*c7336815SŁukasz Majewski 	MAX8997_REG_LDO8CTRL	= 0x42,
94*c7336815SŁukasz Majewski 	MAX8997_REG_LDO9CTRL	= 0x43,
95*c7336815SŁukasz Majewski 	MAX8997_REG_LDO10CTRL	= 0x44,
96*c7336815SŁukasz Majewski 	MAX8997_REG_LDO11CTRL	= 0x45,
97*c7336815SŁukasz Majewski 	MAX8997_REG_LDO12CTRL	= 0x46,
98*c7336815SŁukasz Majewski 	MAX8997_REG_LDO13CTRL	= 0x47,
99*c7336815SŁukasz Majewski 	MAX8997_REG_LDO14CTRL	= 0x48,
100*c7336815SŁukasz Majewski 	MAX8997_REG_LDO15CTRL	= 0x49,
101*c7336815SŁukasz Majewski 	MAX8997_REG_LDO16CTRL	= 0x4a,
102*c7336815SŁukasz Majewski 	MAX8997_REG_LDO17CTRL	= 0x4b,
103*c7336815SŁukasz Majewski 	MAX8997_REG_LDO18CTRL	= 0x4c,
104*c7336815SŁukasz Majewski 	MAX8997_REG_LDO21CTRL	= 0x4d,
105*c7336815SŁukasz Majewski 
106*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL1	= 0x50,
107*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL2	= 0x51,
108*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL3	= 0x52,
109*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL4	= 0x53,
110*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL5	= 0x54,
111*c7336815SŁukasz Majewski 	MAX8997_REG_MBCCTRL6	= 0x55,
112*c7336815SŁukasz Majewski 	MAX8997_REG_OTPCGHCVS	= 0x56,
113*c7336815SŁukasz Majewski 
114*c7336815SŁukasz Majewski 	MAX8997_REG_SAFEOUTCTRL = 0x5a,
115*c7336815SŁukasz Majewski 
116*c7336815SŁukasz Majewski 	MAX8997_REG_LBCNFG1	= 0x5e,
117*c7336815SŁukasz Majewski 	MAX8997_REG_LBCNFG2	= 0x5f,
118*c7336815SŁukasz Majewski 	MAX8997_REG_BBCCTRL	= 0x60,
119*c7336815SŁukasz Majewski 
120*c7336815SŁukasz Majewski 	MAX8997_REG_FLASH1_CUR	= 0x63, /* 0x63 ~ 0x6e for FLASH */
121*c7336815SŁukasz Majewski 	MAX8997_REG_FLASH2_CUR	= 0x64,
122*c7336815SŁukasz Majewski 	MAX8997_REG_MOVIE_CUR	= 0x65,
123*c7336815SŁukasz Majewski 	MAX8997_REG_GSMB_CUR	= 0x66,
124*c7336815SŁukasz Majewski 	MAX8997_REG_BOOST_CNTL	= 0x67,
125*c7336815SŁukasz Majewski 	MAX8997_REG_LEN_CNTL	= 0x68,
126*c7336815SŁukasz Majewski 	MAX8997_REG_FLASH_CNTL	= 0x69,
127*c7336815SŁukasz Majewski 	MAX8997_REG_WDT_CNTL	= 0x6a,
128*c7336815SŁukasz Majewski 	MAX8997_REG_MAXFLASH1	= 0x6b,
129*c7336815SŁukasz Majewski 	MAX8997_REG_MAXFLASH2	= 0x6c,
130*c7336815SŁukasz Majewski 	MAX8997_REG_FLASHSTATUS	= 0x6d,
131*c7336815SŁukasz Majewski 	MAX8997_REG_FLASHSTATUSMASK	= 0x6e,
132*c7336815SŁukasz Majewski 
133*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL1	= 0x70,
134*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL2	= 0x71,
135*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL3	= 0x72,
136*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL4	= 0x73,
137*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL5	= 0x74,
138*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL6	= 0x75,
139*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL7	= 0x76,
140*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL8	= 0x77,
141*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL9	= 0x78,
142*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL10	= 0x79,
143*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL11	= 0x7a,
144*c7336815SŁukasz Majewski 	MAX8997_REG_GPIOCNTL12	= 0x7b,
145*c7336815SŁukasz Majewski 
146*c7336815SŁukasz Majewski 	MAX8997_REG_LDO1CONFIG	= 0x80,
147*c7336815SŁukasz Majewski 	MAX8997_REG_LDO2CONFIG	= 0x81,
148*c7336815SŁukasz Majewski 	MAX8997_REG_LDO3CONFIG	= 0x82,
149*c7336815SŁukasz Majewski 	MAX8997_REG_LDO4CONFIG	= 0x83,
150*c7336815SŁukasz Majewski 	MAX8997_REG_LDO5CONFIG	= 0x84,
151*c7336815SŁukasz Majewski 	MAX8997_REG_LDO6CONFIG	= 0x85,
152*c7336815SŁukasz Majewski 	MAX8997_REG_LDO7CONFIG	= 0x86,
153*c7336815SŁukasz Majewski 	MAX8997_REG_LDO8CONFIG	= 0x87,
154*c7336815SŁukasz Majewski 	MAX8997_REG_LDO9CONFIG	= 0x88,
155*c7336815SŁukasz Majewski 	MAX8997_REG_LDO10CONFIG	= 0x89,
156*c7336815SŁukasz Majewski 	MAX8997_REG_LDO11CONFIG	= 0x8a,
157*c7336815SŁukasz Majewski 	MAX8997_REG_LDO12CONFIG	= 0x8b,
158*c7336815SŁukasz Majewski 	MAX8997_REG_LDO13CONFIG	= 0x8c,
159*c7336815SŁukasz Majewski 	MAX8997_REG_LDO14CONFIG	= 0x8d,
160*c7336815SŁukasz Majewski 	MAX8997_REG_LDO15CONFIG	= 0x8e,
161*c7336815SŁukasz Majewski 	MAX8997_REG_LDO16CONFIG	= 0x8f,
162*c7336815SŁukasz Majewski 	MAX8997_REG_LDO17CONFIG	= 0x90,
163*c7336815SŁukasz Majewski 	MAX8997_REG_LDO18CONFIG	= 0x91,
164*c7336815SŁukasz Majewski 	MAX8997_REG_LDO21CONFIG	= 0x92,
165*c7336815SŁukasz Majewski 
166*c7336815SŁukasz Majewski 	MAX8997_REG_DVSOKTIMER1	= 0x97,
167*c7336815SŁukasz Majewski 	MAX8997_REG_DVSOKTIMER2	= 0x98,
168*c7336815SŁukasz Majewski 	MAX8997_REG_DVSOKTIMER4	= 0x99,
169*c7336815SŁukasz Majewski 	MAX8997_REG_DVSOKTIMER5	= 0x9a,
170*c7336815SŁukasz Majewski 
171*c7336815SŁukasz Majewski 	PMIC_NUM_OF_REGS = 0x9b,
172*c7336815SŁukasz Majewski };
173*c7336815SŁukasz Majewski 
174*c7336815SŁukasz Majewski #define ACTDISSAFEO1 (1 << 4)
175*c7336815SŁukasz Majewski #define ACTDISSAFEO2 (1 << 5)
176*c7336815SŁukasz Majewski #define ENSAFEOUT1 (1 << 6)
177*c7336815SŁukasz Majewski #define ENSAFEOUT2 (1 << 7)
178*c7336815SŁukasz Majewski 
179*c7336815SŁukasz Majewski /* Charger */
180*c7336815SŁukasz Majewski enum {CHARGER_ENABLE, CHARGER_DISABLE};
181*c7336815SŁukasz Majewski #define DETBAT                  (1 << 2)
182*c7336815SŁukasz Majewski #define MBCICHFCSET             (1 << 4)
183*c7336815SŁukasz Majewski #define MBCHOSTEN               (1 << 6)
184*c7336815SŁukasz Majewski #define VCHGR_FC                (1 << 7)
185*c7336815SŁukasz Majewski 
186*c7336815SŁukasz Majewski #define CHARGER_MIN_CURRENT 200
187*c7336815SŁukasz Majewski #define CHARGER_MAX_CURRENT 950
188*c7336815SŁukasz Majewski #define CHARGER_CURRENT_RESOLUTION 50
189*c7336815SŁukasz Majewski 
190*c7336815SŁukasz Majewski #define MAX8997_I2C_ADDR        (0xCC >> 1)
191*c7336815SŁukasz Majewski #define MAX8997_RTC_ADDR	(0x0C >> 1)
192*c7336815SŁukasz Majewski #define MAX8997_MUIC_ADDR	(0x4A >> 1)
193*c7336815SŁukasz Majewski #define MAX8997_FG_ADDR	(0x6C >> 1)
194*c7336815SŁukasz Majewski 
195*c7336815SŁukasz Majewski enum {
196*c7336815SŁukasz Majewski 	LDO_OFF = 0,
197*c7336815SŁukasz Majewski 	LDO_ON = 1,
198*c7336815SŁukasz Majewski 
199*c7336815SŁukasz Majewski 	DIS_LDO = (0x00 << 6),
200*c7336815SŁukasz Majewski 	EN_LDO = (0x3 << 6),
201*c7336815SŁukasz Majewski };
202*c7336815SŁukasz Majewski 
203*c7336815SŁukasz Majewski #endif /* __MAX8997_PMIC_H_ */
204