2018-05-06 21:58:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
2014-06-05 15:15:29 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2014
|
|
|
|
* Texas Instruments, <www.ti.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __POWER_TPS65218_H__
|
|
|
|
#define __POWER_TPS65218_H__
|
|
|
|
|
2016-02-19 17:19:46 +00:00
|
|
|
#include <linux/bitops.h>
|
|
|
|
|
2014-06-05 15:15:29 +00:00
|
|
|
/* I2C chip address */
|
|
|
|
#define TPS65218_CHIP_PM 0x24
|
|
|
|
|
|
|
|
/* Registers */
|
|
|
|
enum {
|
|
|
|
TPS65218_CHIPID = 0x00,
|
|
|
|
TPS65218_INT1,
|
|
|
|
TPS65218_INT2,
|
|
|
|
TPS65218_INT_MASK1,
|
|
|
|
TPS65218_INT_MASK2,
|
|
|
|
TPS65218_STATUS,
|
|
|
|
TPS65218_CONTROL,
|
|
|
|
TPS65218_FLAG,
|
|
|
|
TPS65218_PASSWORD = 0x10,
|
|
|
|
TPS65218_ENABLE1,
|
|
|
|
TPS65218_ENABLE2,
|
|
|
|
TPS65218_CONFIG1,
|
|
|
|
TPS65218_CONFIG2,
|
|
|
|
TPS65218_CONFIG3,
|
|
|
|
TPS65218_DCDC1,
|
|
|
|
TPS65218_DCDC2,
|
|
|
|
TPS65218_DCDC3,
|
|
|
|
TPS65218_DCDC4,
|
|
|
|
TPS65218_SLEW,
|
|
|
|
TPS65218_LDO1,
|
|
|
|
TPS65218_SEQ1 = 0x20,
|
|
|
|
TPS65218_SEQ2,
|
|
|
|
TPS65218_SEQ3,
|
|
|
|
TPS65218_SEQ4,
|
|
|
|
TPS65218_SEQ5,
|
|
|
|
TPS65218_SEQ6,
|
|
|
|
TPS65218_SEQ7,
|
|
|
|
TPS65218_PMIC_NUM_OF_REGS,
|
|
|
|
};
|
|
|
|
|
|
|
|
#define TPS65218_PROT_LEVEL_NONE 0x00
|
|
|
|
#define TPS65218_PROT_LEVEL_1 0x01
|
|
|
|
#define TPS65218_PROT_LEVEL_2 0x02
|
|
|
|
|
|
|
|
#define TPS65218_PASSWORD_LOCK_FOR_WRITE 0x00
|
|
|
|
#define TPS65218_PASSWORD_UNLOCK 0x7D
|
|
|
|
|
|
|
|
#define TPS65218_DCDC_GO 0x80
|
|
|
|
|
|
|
|
#define TPS65218_MASK_ALL_BITS 0xFF
|
|
|
|
|
2017-05-24 04:49:27 +00:00
|
|
|
#define TPS65218_DCDC_VSEL_MASK 0x3F
|
|
|
|
|
2014-12-22 22:26:14 +00:00
|
|
|
#define TPS65218_DCDC_VOLT_SEL_0950MV 0x0a
|
2014-06-05 15:15:29 +00:00
|
|
|
#define TPS65218_DCDC_VOLT_SEL_1100MV 0x19
|
2014-12-22 22:26:14 +00:00
|
|
|
#define TPS65218_DCDC_VOLT_SEL_1200MV 0x23
|
|
|
|
#define TPS65218_DCDC_VOLT_SEL_1260MV 0x29
|
2014-06-05 15:15:29 +00:00
|
|
|
#define TPS65218_DCDC_VOLT_SEL_1330MV 0x30
|
2017-06-02 09:30:31 +00:00
|
|
|
#define TPS65218_DCDC3_VOLT_SEL_1350MV 0x12
|
2018-05-02 09:36:31 +00:00
|
|
|
#define TPS65218_DCDC3_VOLT_SEL_1200MV 0xC
|
2014-06-05 15:15:29 +00:00
|
|
|
|
2016-02-19 17:19:46 +00:00
|
|
|
#define TPS65218_CC_STAT (BIT(0) | BIT(1))
|
|
|
|
#define TPS65218_STATE (BIT(2) | BIT(3))
|
|
|
|
#define TPS65218_PB_STATE BIT(4)
|
|
|
|
#define TPS65218_AC_STATE BIT(5)
|
|
|
|
#define TPS65218_EE BIT(6)
|
|
|
|
#define TPS65218_FSEAL BIT(7)
|
|
|
|
|
|
|
|
int tps65218_reg_read(uchar dest_reg, uchar *dest_val);
|
2014-06-05 15:15:29 +00:00
|
|
|
int tps65218_reg_write(uchar prot_level, uchar dest_reg, uchar dest_val,
|
|
|
|
uchar mask);
|
|
|
|
int tps65218_voltage_update(uchar dc_cntrl_reg, uchar volt_sel);
|
2016-02-19 17:19:46 +00:00
|
|
|
int tps65218_toggle_fseal(void);
|
|
|
|
int tps65218_lock_fseal(void);
|
2014-06-23 20:06:29 +00:00
|
|
|
int power_tps65218_init(unsigned char bus);
|
2014-06-05 15:15:29 +00:00
|
|
|
#endif /* __POWER_TPS65218_H__ */
|