1*83d290c5STom Rini /* SPDX-License-Identifier: GPL-2.0+ */ 286db550bSTom Rini /* 386db550bSTom Rini * (C) Copyright 2014 486db550bSTom Rini * Texas Instruments, <www.ti.com> 586db550bSTom Rini */ 686db550bSTom Rini 786db550bSTom Rini #ifndef __POWER_TPS65218_H__ 886db550bSTom Rini #define __POWER_TPS65218_H__ 986db550bSTom Rini 109bcfca12SNikita Kiryanov #include <linux/bitops.h> 119bcfca12SNikita Kiryanov 1286db550bSTom Rini /* I2C chip address */ 1386db550bSTom Rini #define TPS65218_CHIP_PM 0x24 1486db550bSTom Rini 1586db550bSTom Rini /* Registers */ 1686db550bSTom Rini enum { 1786db550bSTom Rini TPS65218_CHIPID = 0x00, 1886db550bSTom Rini TPS65218_INT1, 1986db550bSTom Rini TPS65218_INT2, 2086db550bSTom Rini TPS65218_INT_MASK1, 2186db550bSTom Rini TPS65218_INT_MASK2, 2286db550bSTom Rini TPS65218_STATUS, 2386db550bSTom Rini TPS65218_CONTROL, 2486db550bSTom Rini TPS65218_FLAG, 2586db550bSTom Rini TPS65218_PASSWORD = 0x10, 2686db550bSTom Rini TPS65218_ENABLE1, 2786db550bSTom Rini TPS65218_ENABLE2, 2886db550bSTom Rini TPS65218_CONFIG1, 2986db550bSTom Rini TPS65218_CONFIG2, 3086db550bSTom Rini TPS65218_CONFIG3, 3186db550bSTom Rini TPS65218_DCDC1, 3286db550bSTom Rini TPS65218_DCDC2, 3386db550bSTom Rini TPS65218_DCDC3, 3486db550bSTom Rini TPS65218_DCDC4, 3586db550bSTom Rini TPS65218_SLEW, 3686db550bSTom Rini TPS65218_LDO1, 3786db550bSTom Rini TPS65218_SEQ1 = 0x20, 3886db550bSTom Rini TPS65218_SEQ2, 3986db550bSTom Rini TPS65218_SEQ3, 4086db550bSTom Rini TPS65218_SEQ4, 4186db550bSTom Rini TPS65218_SEQ5, 4286db550bSTom Rini TPS65218_SEQ6, 4386db550bSTom Rini TPS65218_SEQ7, 4486db550bSTom Rini TPS65218_PMIC_NUM_OF_REGS, 4586db550bSTom Rini }; 4686db550bSTom Rini 4786db550bSTom Rini #define TPS65218_PROT_LEVEL_NONE 0x00 4886db550bSTom Rini #define TPS65218_PROT_LEVEL_1 0x01 4986db550bSTom Rini #define TPS65218_PROT_LEVEL_2 0x02 5086db550bSTom Rini 5186db550bSTom Rini #define TPS65218_PASSWORD_LOCK_FOR_WRITE 0x00 5286db550bSTom Rini #define TPS65218_PASSWORD_UNLOCK 0x7D 5386db550bSTom Rini 5486db550bSTom Rini #define TPS65218_DCDC_GO 0x80 5586db550bSTom Rini 5686db550bSTom Rini #define TPS65218_MASK_ALL_BITS 0xFF 5786db550bSTom Rini 586183b295SKeerthy #define TPS65218_DCDC_VSEL_MASK 0x3F 596183b295SKeerthy 608465d6a7SFelipe Balbi #define TPS65218_DCDC_VOLT_SEL_0950MV 0x0a 6186db550bSTom Rini #define TPS65218_DCDC_VOLT_SEL_1100MV 0x19 628465d6a7SFelipe Balbi #define TPS65218_DCDC_VOLT_SEL_1200MV 0x23 638465d6a7SFelipe Balbi #define TPS65218_DCDC_VOLT_SEL_1260MV 0x29 6486db550bSTom Rini #define TPS65218_DCDC_VOLT_SEL_1330MV 0x30 65fc69d472SKeerthy #define TPS65218_DCDC3_VOLT_SEL_1350MV 0x12 66ebf48500SKeerthy #define TPS65218_DCDC3_VOLT_SEL_1200MV 0xC 6786db550bSTom Rini 689bcfca12SNikita Kiryanov #define TPS65218_CC_STAT (BIT(0) | BIT(1)) 699bcfca12SNikita Kiryanov #define TPS65218_STATE (BIT(2) | BIT(3)) 709bcfca12SNikita Kiryanov #define TPS65218_PB_STATE BIT(4) 719bcfca12SNikita Kiryanov #define TPS65218_AC_STATE BIT(5) 729bcfca12SNikita Kiryanov #define TPS65218_EE BIT(6) 739bcfca12SNikita Kiryanov #define TPS65218_FSEAL BIT(7) 749bcfca12SNikita Kiryanov 759bcfca12SNikita Kiryanov int tps65218_reg_read(uchar dest_reg, uchar *dest_val); 7686db550bSTom Rini int tps65218_reg_write(uchar prot_level, uchar dest_reg, uchar dest_val, 7786db550bSTom Rini uchar mask); 7886db550bSTom Rini int tps65218_voltage_update(uchar dc_cntrl_reg, uchar volt_sel); 799bcfca12SNikita Kiryanov int tps65218_toggle_fseal(void); 809bcfca12SNikita Kiryanov int tps65218_lock_fseal(void); 817aa5598aSTom Rini int power_tps65218_init(unsigned char bus); 8286db550bSTom Rini #endif /* __POWER_TPS65218_H__ */ 83