xref: /openbmc/u-boot/include/power/tps65218.h (revision 3483f28ebfaf968112ede2f075b9769a007cacdd)
1 /*
2  * (C) Copyright 2014
3  * Texas Instruments, <www.ti.com>
4  *
5  * SPDX-License-Identifier:	GPL-2.0+
6  */
7 
8 #ifndef __POWER_TPS65218_H__
9 #define __POWER_TPS65218_H__
10 
11 #include <linux/bitops.h>
12 
13 /* I2C chip address */
14 #define TPS65218_CHIP_PM			0x24
15 
16 /* Registers */
17 enum {
18 	TPS65218_CHIPID				= 0x00,
19 	TPS65218_INT1,
20 	TPS65218_INT2,
21 	TPS65218_INT_MASK1,
22 	TPS65218_INT_MASK2,
23 	TPS65218_STATUS,
24 	TPS65218_CONTROL,
25 	TPS65218_FLAG,
26 	TPS65218_PASSWORD			= 0x10,
27 	TPS65218_ENABLE1,
28 	TPS65218_ENABLE2,
29 	TPS65218_CONFIG1,
30 	TPS65218_CONFIG2,
31 	TPS65218_CONFIG3,
32 	TPS65218_DCDC1,
33 	TPS65218_DCDC2,
34 	TPS65218_DCDC3,
35 	TPS65218_DCDC4,
36 	TPS65218_SLEW,
37 	TPS65218_LDO1,
38 	TPS65218_SEQ1				= 0x20,
39 	TPS65218_SEQ2,
40 	TPS65218_SEQ3,
41 	TPS65218_SEQ4,
42 	TPS65218_SEQ5,
43 	TPS65218_SEQ6,
44 	TPS65218_SEQ7,
45 	TPS65218_PMIC_NUM_OF_REGS,
46 };
47 
48 #define TPS65218_PROT_LEVEL_NONE		0x00
49 #define TPS65218_PROT_LEVEL_1			0x01
50 #define TPS65218_PROT_LEVEL_2			0x02
51 
52 #define TPS65218_PASSWORD_LOCK_FOR_WRITE	0x00
53 #define TPS65218_PASSWORD_UNLOCK		0x7D
54 
55 #define TPS65218_DCDC_GO			0x80
56 
57 #define TPS65218_MASK_ALL_BITS			0xFF
58 
59 #define TPS65218_DCDC_VSEL_MASK			0x3F
60 
61 #define TPS65218_DCDC_VOLT_SEL_0950MV		0x0a
62 #define TPS65218_DCDC_VOLT_SEL_1100MV		0x19
63 #define TPS65218_DCDC_VOLT_SEL_1200MV		0x23
64 #define TPS65218_DCDC_VOLT_SEL_1260MV		0x29
65 #define TPS65218_DCDC_VOLT_SEL_1330MV		0x30
66 #define TPS65218_DCDC3_VOLT_SEL_1350MV		0x12
67 
68 #define TPS65218_CC_STAT	(BIT(0) | BIT(1))
69 #define TPS65218_STATE		(BIT(2) | BIT(3))
70 #define TPS65218_PB_STATE	BIT(4)
71 #define TPS65218_AC_STATE	BIT(5)
72 #define TPS65218_EE		BIT(6)
73 #define TPS65218_FSEAL		BIT(7)
74 
75 int tps65218_reg_read(uchar dest_reg, uchar *dest_val);
76 int tps65218_reg_write(uchar prot_level, uchar dest_reg, uchar dest_val,
77 		       uchar mask);
78 int tps65218_voltage_update(uchar dc_cntrl_reg, uchar volt_sel);
79 int tps65218_toggle_fseal(void);
80 int tps65218_lock_fseal(void);
81 int power_tps65218_init(unsigned char bus);
82 #endif	/* __POWER_TPS65218_H__ */
83