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