|
|
|
@ -30,6 +30,8 @@
|
|
|
|
|
#define PALMAS_CHIP_ID 0xC035
|
|
|
|
|
#define PALMAS_CHIP_CHARGER_ID 0xC036
|
|
|
|
|
|
|
|
|
|
#define TPS65917_RESERVED -1
|
|
|
|
|
|
|
|
|
|
#define is_palmas(a) (((a) == PALMAS_CHIP_OLD_ID) || \
|
|
|
|
|
((a) == PALMAS_CHIP_ID))
|
|
|
|
|
#define is_palmas_charger(a) ((a) == PALMAS_CHIP_CHARGER_ID)
|
|
|
|
@ -51,6 +53,8 @@ struct palmas_pmic;
|
|
|
|
|
struct palmas_gpadc;
|
|
|
|
|
struct palmas_resource;
|
|
|
|
|
struct palmas_usb;
|
|
|
|
|
struct palmas_pmic_driver_data;
|
|
|
|
|
struct palmas_pmic_platform_data;
|
|
|
|
|
|
|
|
|
|
enum palmas_usb_state {
|
|
|
|
|
PALMAS_USB_STATE_DISCONNECT,
|
|
|
|
@ -74,6 +78,8 @@ struct palmas {
|
|
|
|
|
struct mutex irq_lock;
|
|
|
|
|
struct regmap_irq_chip_data *irq_data;
|
|
|
|
|
|
|
|
|
|
struct palmas_pmic_driver_data *pmic_ddata;
|
|
|
|
|
|
|
|
|
|
/* Child Devices */
|
|
|
|
|
struct palmas_pmic *pmic;
|
|
|
|
|
struct palmas_gpadc *gpadc;
|
|
|
|
@ -86,6 +92,46 @@ struct palmas {
|
|
|
|
|
u8 pwm_muxed;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#define PALMAS_EXT_REQ (PALMAS_EXT_CONTROL_ENABLE1 | \
|
|
|
|
|
PALMAS_EXT_CONTROL_ENABLE2 | \
|
|
|
|
|
PALMAS_EXT_CONTROL_NSLEEP)
|
|
|
|
|
|
|
|
|
|
struct palmas_sleep_requestor_info {
|
|
|
|
|
int id;
|
|
|
|
|
int reg_offset;
|
|
|
|
|
int bit_pos;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct palmas_regs_info {
|
|
|
|
|
char *name;
|
|
|
|
|
char *sname;
|
|
|
|
|
u8 vsel_addr;
|
|
|
|
|
u8 ctrl_addr;
|
|
|
|
|
u8 tstep_addr;
|
|
|
|
|
int sleep_id;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct palmas_pmic_driver_data {
|
|
|
|
|
int smps_start;
|
|
|
|
|
int smps_end;
|
|
|
|
|
int ldo_begin;
|
|
|
|
|
int ldo_end;
|
|
|
|
|
int max_reg;
|
|
|
|
|
struct palmas_regs_info *palmas_regs_info;
|
|
|
|
|
struct of_regulator_match *palmas_matches;
|
|
|
|
|
struct palmas_sleep_requestor_info *sleep_req_info;
|
|
|
|
|
int (*smps_register)(struct palmas_pmic *pmic,
|
|
|
|
|
struct palmas_pmic_driver_data *ddata,
|
|
|
|
|
struct palmas_pmic_platform_data *pdata,
|
|
|
|
|
const char *pdev_name,
|
|
|
|
|
struct regulator_config config);
|
|
|
|
|
int (*ldo_register)(struct palmas_pmic *pmic,
|
|
|
|
|
struct palmas_pmic_driver_data *ddata,
|
|
|
|
|
struct palmas_pmic_platform_data *pdata,
|
|
|
|
|
const char *pdev_name,
|
|
|
|
|
struct regulator_config config);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct palmas_gpadc_platform_data {
|
|
|
|
|
/* Channel 3 current source is only enabled during conversion */
|
|
|
|
|
int ch3_current;
|
|
|
|
@ -184,6 +230,27 @@ enum palmas_regulators {
|
|
|
|
|
PALMAS_NUM_REGS,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum tps65917_regulators {
|
|
|
|
|
/* SMPS regulators */
|
|
|
|
|
TPS65917_REG_SMPS1,
|
|
|
|
|
TPS65917_REG_SMPS2,
|
|
|
|
|
TPS65917_REG_SMPS3,
|
|
|
|
|
TPS65917_REG_SMPS4,
|
|
|
|
|
TPS65917_REG_SMPS5,
|
|
|
|
|
/* LDO regulators */
|
|
|
|
|
TPS65917_REG_LDO1,
|
|
|
|
|
TPS65917_REG_LDO2,
|
|
|
|
|
TPS65917_REG_LDO3,
|
|
|
|
|
TPS65917_REG_LDO4,
|
|
|
|
|
TPS65917_REG_LDO5,
|
|
|
|
|
TPS65917_REG_REGEN1,
|
|
|
|
|
TPS65917_REG_REGEN2,
|
|
|
|
|
TPS65917_REG_REGEN3,
|
|
|
|
|
|
|
|
|
|
/* Total number of regulators */
|
|
|
|
|
TPS65917_NUM_REGS,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* External controll signal name */
|
|
|
|
|
enum {
|
|
|
|
|
PALMAS_EXT_CONTROL_ENABLE1 = 0x1,
|
|
|
|
@ -228,6 +295,24 @@ enum palmas_external_requestor_id {
|
|
|
|
|
PALMAS_EXTERNAL_REQSTR_ID_MAX,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum tps65917_external_requestor_id {
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_REGEN1,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_REGEN2,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_REGEN3,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_SMPS1,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_SMPS2,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_SMPS3,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_SMPS4,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_SMPS5,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_LDO1,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_LDO2,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_LDO3,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_LDO4,
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_LDO5,
|
|
|
|
|
/* Last entry */
|
|
|
|
|
TPS65917_EXTERNAL_REQSTR_ID_MAX,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct palmas_pmic_platform_data {
|
|
|
|
|
/* An array of pointers to regulator init data indexed by regulator
|
|
|
|
|
* ID
|
|
|
|
@ -349,6 +434,48 @@ struct palmas_gpadc_result {
|
|
|
|
|
|
|
|
|
|
#define PALMAS_MAX_CHANNELS 16
|
|
|
|
|
|
|
|
|
|
/* Define the tps65917 IRQ numbers */
|
|
|
|
|
enum tps65917_irqs {
|
|
|
|
|
/* INT1 registers */
|
|
|
|
|
TPS65917_RESERVED1,
|
|
|
|
|
TPS65917_PWRON_IRQ,
|
|
|
|
|
TPS65917_LONG_PRESS_KEY_IRQ,
|
|
|
|
|
TPS65917_RESERVED2,
|
|
|
|
|
TPS65917_PWRDOWN_IRQ,
|
|
|
|
|
TPS65917_HOTDIE_IRQ,
|
|
|
|
|
TPS65917_VSYS_MON_IRQ,
|
|
|
|
|
TPS65917_RESERVED3,
|
|
|
|
|
/* INT2 registers */
|
|
|
|
|
TPS65917_RESERVED4,
|
|
|
|
|
TPS65917_OTP_ERROR_IRQ,
|
|
|
|
|
TPS65917_WDT_IRQ,
|
|
|
|
|
TPS65917_RESERVED5,
|
|
|
|
|
TPS65917_RESET_IN_IRQ,
|
|
|
|
|
TPS65917_FSD_IRQ,
|
|
|
|
|
TPS65917_SHORT_IRQ,
|
|
|
|
|
TPS65917_RESERVED6,
|
|
|
|
|
/* INT3 registers */
|
|
|
|
|
TPS65917_GPADC_AUTO_0_IRQ,
|
|
|
|
|
TPS65917_GPADC_AUTO_1_IRQ,
|
|
|
|
|
TPS65917_GPADC_EOC_SW_IRQ,
|
|
|
|
|
TPS65917_RESREVED6,
|
|
|
|
|
TPS65917_RESERVED7,
|
|
|
|
|
TPS65917_RESERVED8,
|
|
|
|
|
TPS65917_RESERVED9,
|
|
|
|
|
TPS65917_VBUS_IRQ,
|
|
|
|
|
/* INT4 registers */
|
|
|
|
|
TPS65917_GPIO_0_IRQ,
|
|
|
|
|
TPS65917_GPIO_1_IRQ,
|
|
|
|
|
TPS65917_GPIO_2_IRQ,
|
|
|
|
|
TPS65917_GPIO_3_IRQ,
|
|
|
|
|
TPS65917_GPIO_4_IRQ,
|
|
|
|
|
TPS65917_GPIO_5_IRQ,
|
|
|
|
|
TPS65917_GPIO_6_IRQ,
|
|
|
|
|
TPS65917_RESERVED10,
|
|
|
|
|
/* Total Number IRQs */
|
|
|
|
|
TPS65917_NUM_IRQ,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Define the palmas IRQ numbers */
|
|
|
|
|
enum palmas_irqs {
|
|
|
|
|
/* INT1 registers */
|
|
|
|
@ -400,6 +527,7 @@ struct palmas_pmic {
|
|
|
|
|
|
|
|
|
|
int smps123;
|
|
|
|
|
int smps457;
|
|
|
|
|
int smps12;
|
|
|
|
|
|
|
|
|
|
int range[PALMAS_REG_SMPS10_OUT1];
|
|
|
|
|
unsigned int ramp_delay[PALMAS_REG_SMPS10_OUT1];
|
|
|
|
@ -2871,6 +2999,715 @@ enum usb_irq_events {
|
|
|
|
|
#define PALMAS_GPADC_TRIM15 0x0E
|
|
|
|
|
#define PALMAS_GPADC_TRIM16 0x0F
|
|
|
|
|
|
|
|
|
|
/* TPS65917 Interrupt registers */
|
|
|
|
|
|
|
|
|
|
/* Registers for function INTERRUPT */
|
|
|
|
|
#define TPS65917_INT1_STATUS 0x00
|
|
|
|
|
#define TPS65917_INT1_MASK 0x01
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE 0x02
|
|
|
|
|
#define TPS65917_INT2_STATUS 0x05
|
|
|
|
|
#define TPS65917_INT2_MASK 0x06
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE 0x07
|
|
|
|
|
#define TPS65917_INT3_STATUS 0x0A
|
|
|
|
|
#define TPS65917_INT3_MASK 0x0B
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE 0x0C
|
|
|
|
|
#define TPS65917_INT4_STATUS 0x0F
|
|
|
|
|
#define TPS65917_INT4_MASK 0x10
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE 0x11
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1 0x12
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2 0x13
|
|
|
|
|
#define TPS65917_INT_CTRL 0x14
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT1_STATUS */
|
|
|
|
|
#define TPS65917_INT1_STATUS_VSYS_MON 0x40
|
|
|
|
|
#define TPS65917_INT1_STATUS_VSYS_MON_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT1_STATUS_HOTDIE 0x20
|
|
|
|
|
#define TPS65917_INT1_STATUS_HOTDIE_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT1_STATUS_PWRDOWN 0x10
|
|
|
|
|
#define TPS65917_INT1_STATUS_PWRDOWN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT1_STATUS_LONG_PRESS_KEY 0x04
|
|
|
|
|
#define TPS65917_INT1_STATUS_LONG_PRESS_KEY_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT1_STATUS_PWRON 0x02
|
|
|
|
|
#define TPS65917_INT1_STATUS_PWRON_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT1_MASK */
|
|
|
|
|
#define TPS65917_INT1_MASK_VSYS_MON 0x40
|
|
|
|
|
#define TPS65917_INT1_MASK_VSYS_MON_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT1_MASK_HOTDIE 0x20
|
|
|
|
|
#define TPS65917_INT1_MASK_HOTDIE_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT1_MASK_PWRDOWN 0x10
|
|
|
|
|
#define TPS65917_INT1_MASK_PWRDOWN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT1_MASK_LONG_PRESS_KEY 0x04
|
|
|
|
|
#define TPS65917_INT1_MASK_LONG_PRESS_KEY_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT1_MASK_PWRON 0x02
|
|
|
|
|
#define TPS65917_INT1_MASK_PWRON_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT1_LINE_STATE */
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_VSYS_MON 0x40
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_VSYS_MON_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_HOTDIE 0x20
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_HOTDIE_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_PWRDOWN 0x10
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_PWRDOWN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_LONG_PRESS_KEY 0x04
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_LONG_PRESS_KEY_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_PWRON 0x02
|
|
|
|
|
#define TPS65917_INT1_LINE_STATE_PWRON_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT2_STATUS */
|
|
|
|
|
#define TPS65917_INT2_STATUS_SHORT 0x40
|
|
|
|
|
#define TPS65917_INT2_STATUS_SHORT_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT2_STATUS_FSD 0x20
|
|
|
|
|
#define TPS65917_INT2_STATUS_FSD_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT2_STATUS_RESET_IN 0x10
|
|
|
|
|
#define TPS65917_INT2_STATUS_RESET_IN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT2_STATUS_WDT 0x04
|
|
|
|
|
#define TPS65917_INT2_STATUS_WDT_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT2_STATUS_OTP_ERROR 0x02
|
|
|
|
|
#define TPS65917_INT2_STATUS_OTP_ERROR_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT2_MASK */
|
|
|
|
|
#define TPS65917_INT2_MASK_SHORT 0x40
|
|
|
|
|
#define TPS65917_INT2_MASK_SHORT_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT2_MASK_FSD 0x20
|
|
|
|
|
#define TPS65917_INT2_MASK_FSD_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT2_MASK_RESET_IN 0x10
|
|
|
|
|
#define TPS65917_INT2_MASK_RESET_IN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT2_MASK_WDT 0x04
|
|
|
|
|
#define TPS65917_INT2_MASK_WDT_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT2_MASK_OTP_ERROR_TIMER 0x02
|
|
|
|
|
#define TPS65917_INT2_MASK_OTP_ERROR_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT2_LINE_STATE */
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_SHORT 0x40
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_SHORT_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_FSD 0x20
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_FSD_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_RESET_IN 0x10
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_RESET_IN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_WDT 0x04
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_WDT_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_OTP_ERROR 0x02
|
|
|
|
|
#define TPS65917_INT2_LINE_STATE_OTP_ERROR_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT3_STATUS */
|
|
|
|
|
#define TPS65917_INT3_STATUS_VBUS 0x80
|
|
|
|
|
#define TPS65917_INT3_STATUS_VBUS_SHIFT 0x07
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_EOC_SW 0x04
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_EOC_SW_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_AUTO_1 0x02
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_AUTO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_AUTO_0 0x01
|
|
|
|
|
#define TPS65917_INT3_STATUS_GPADC_AUTO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT3_MASK */
|
|
|
|
|
#define TPS65917_INT3_MASK_VBUS 0x80
|
|
|
|
|
#define TPS65917_INT3_MASK_VBUS_SHIFT 0x07
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_EOC_SW 0x04
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_EOC_SW_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_AUTO_1 0x02
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_AUTO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_AUTO_0 0x01
|
|
|
|
|
#define TPS65917_INT3_MASK_GPADC_AUTO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT3_LINE_STATE */
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_VBUS 0x80
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_VBUS_SHIFT 0x07
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_EOC_SW 0x04
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_EOC_SW_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_AUTO_1 0x02
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_AUTO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_AUTO_0 0x01
|
|
|
|
|
#define TPS65917_INT3_LINE_STATE_GPADC_AUTO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT4_STATUS */
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_6 0x40
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_6_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_5 0x20
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_5_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_4 0x10
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_3 0x08
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_2 0x04
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_2_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_1 0x02
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_0 0x01
|
|
|
|
|
#define TPS65917_INT4_STATUS_GPIO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT4_MASK */
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_6 0x40
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_6_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_5 0x20
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_5_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_4 0x10
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_3 0x08
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_2 0x04
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_2_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_1 0x02
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_0 0x01
|
|
|
|
|
#define TPS65917_INT4_MASK_GPIO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT4_LINE_STATE */
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_6 0x40
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_6_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_5 0x20
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_5_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_4 0x10
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_3 0x08
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_2 0x04
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_2_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_1 0x02
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_1_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_0 0x01
|
|
|
|
|
#define TPS65917_INT4_LINE_STATE_GPIO_0_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT4_EDGE_DETECT1 */
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_3_RISING 0x80
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_3_RISING_SHIFT 0x07
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_3_FALLING 0x40
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_3_FALLING_SHIFT 0x06
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_2_RISING 0x20
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_2_RISING_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_2_FALLING 0x10
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_2_FALLING_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_1_RISING 0x08
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_1_RISING_SHIFT 0x03
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_1_FALLING 0x04
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_1_FALLING_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_0_RISING 0x02
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_0_RISING_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_0_FALLING 0x01
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT1_GPIO_0_FALLING_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT4_EDGE_DETECT2 */
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_6_RISING 0x20
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_6_RISING_SHIFT 0x05
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_6_FALLING 0x10
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_6_FALLING_SHIFT 0x04
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_5_RISING 0x08
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_5_RISING_SHIFT 0x03
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_5_FALLING 0x04
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_5_FALLING_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_4_RISING 0x02
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_4_RISING_SHIFT 0x01
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_4_FALLING 0x01
|
|
|
|
|
#define TPS65917_INT4_EDGE_DETECT2_GPIO_4_FALLING_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for INT_CTRL */
|
|
|
|
|
#define TPS65917_INT_CTRL_INT_PENDING 0x04
|
|
|
|
|
#define TPS65917_INT_CTRL_INT_PENDING_SHIFT 0x02
|
|
|
|
|
#define TPS65917_INT_CTRL_INT_CLEAR 0x01
|
|
|
|
|
#define TPS65917_INT_CTRL_INT_CLEAR_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* TPS65917 SMPS Registers */
|
|
|
|
|
|
|
|
|
|
/* Registers for function SMPS */
|
|
|
|
|
#define TPS65917_SMPS1_CTRL 0x00
|
|
|
|
|
#define TPS65917_SMPS1_FORCE 0x02
|
|
|
|
|
#define TPS65917_SMPS1_VOLTAGE 0x03
|
|
|
|
|
#define TPS65917_SMPS2_CTRL 0x04
|
|
|
|
|
#define TPS65917_SMPS2_FORCE 0x06
|
|
|
|
|
#define TPS65917_SMPS2_VOLTAGE 0x07
|
|
|
|
|
#define TPS65917_SMPS3_CTRL 0x0C
|
|
|
|
|
#define TPS65917_SMPS3_FORCE 0x0E
|
|
|
|
|
#define TPS65917_SMPS3_VOLTAGE 0x0F
|
|
|
|
|
#define TPS65917_SMPS4_CTRL 0x10
|
|
|
|
|
#define TPS65917_SMPS4_VOLTAGE 0x13
|
|
|
|
|
#define TPS65917_SMPS5_CTRL 0x18
|
|
|
|
|
#define TPS65917_SMPS5_VOLTAGE 0x1B
|
|
|
|
|
#define TPS65917_SMPS_CTRL 0x24
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL 0x25
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN 0x27
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS 0x28
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS 0x29
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN 0x2A
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1 0x2B
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK2 0x2C
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS1_CTRL */
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_ROOF_FLOOR_EN 0x40
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_ROOF_FLOOR_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_STATUS_MASK 0x30
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_MODE_SLEEP_MASK 0x0C
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_MODE_ACTIVE_MASK 0x03
|
|
|
|
|
#define TPS65917_SMPS1_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS1_FORCE */
|
|
|
|
|
#define TPS65917_SMPS1_FORCE_CMD 0x80
|
|
|
|
|
#define TPS65917_SMPS1_FORCE_CMD_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS1_FORCE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS1_FORCE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS1_VOLTAGE */
|
|
|
|
|
#define TPS65917_SMPS1_VOLTAGE_RANGE 0x80
|
|
|
|
|
#define TPS65917_SMPS1_VOLTAGE_RANGE_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS1_VOLTAGE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS1_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS2_CTRL */
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_ROOF_FLOOR_EN 0x40
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_ROOF_FLOOR_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_STATUS_MASK 0x30
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_MODE_SLEEP_MASK 0x0C
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_MODE_ACTIVE_MASK 0x03
|
|
|
|
|
#define TPS65917_SMPS2_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS2_FORCE */
|
|
|
|
|
#define TPS65917_SMPS2_FORCE_CMD 0x80
|
|
|
|
|
#define TPS65917_SMPS2_FORCE_CMD_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS2_FORCE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS2_FORCE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS2_VOLTAGE */
|
|
|
|
|
#define TPS65917_SMPS2_VOLTAGE_RANGE 0x80
|
|
|
|
|
#define TPS65917_SMPS2_VOLTAGE_RANGE_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS2_VOLTAGE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS2_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS3_CTRL */
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_ROOF_FLOOR_EN 0x40
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_ROOF_FLOOR_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_STATUS_MASK 0x30
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_MODE_SLEEP_MASK 0x0C
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_MODE_ACTIVE_MASK 0x03
|
|
|
|
|
#define TPS65917_SMPS3_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS3_FORCE */
|
|
|
|
|
#define TPS65917_SMPS3_FORCE_CMD 0x80
|
|
|
|
|
#define TPS65917_SMPS3_FORCE_CMD_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS3_FORCE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS3_FORCE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS3_VOLTAGE */
|
|
|
|
|
#define TPS65917_SMPS3_VOLTAGE_RANGE 0x80
|
|
|
|
|
#define TPS65917_SMPS3_VOLTAGE_RANGE_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS3_VOLTAGE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS3_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS4_CTRL */
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_ROOF_FLOOR_EN 0x40
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_ROOF_FLOOR_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_STATUS_MASK 0x30
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_MODE_SLEEP_MASK 0x0C
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_MODE_ACTIVE_MASK 0x03
|
|
|
|
|
#define TPS65917_SMPS4_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS4_VOLTAGE */
|
|
|
|
|
#define TPS65917_SMPS4_VOLTAGE_RANGE 0x80
|
|
|
|
|
#define TPS65917_SMPS4_VOLTAGE_RANGE_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS4_VOLTAGE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS4_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS5_CTRL */
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_ROOF_FLOOR_EN 0x40
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_ROOF_FLOOR_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_STATUS_MASK 0x30
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_MODE_SLEEP_MASK 0x0C
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_MODE_ACTIVE_MASK 0x03
|
|
|
|
|
#define TPS65917_SMPS5_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS5_VOLTAGE */
|
|
|
|
|
#define TPS65917_SMPS5_VOLTAGE_RANGE 0x80
|
|
|
|
|
#define TPS65917_SMPS5_VOLTAGE_RANGE_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS5_VOLTAGE_VSEL_MASK 0x7F
|
|
|
|
|
#define TPS65917_SMPS5_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_CTRL */
|
|
|
|
|
#define TPS65917_SMPS_CTRL_SMPS1_SMPS12_EN 0x10
|
|
|
|
|
#define TPS65917_SMPS_CTRL_SMPS1_SMPS12_EN_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_CTRL_SMPS12_PHASE_CTRL 0x03
|
|
|
|
|
#define TPS65917_SMPS_CTRL_SMPS12_PHASE_CTRL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_PD_CTRL */
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS4 0x10
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS2 0x02
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS1 0x01
|
|
|
|
|
#define TPS65917_SMPS_PD_CTRL_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_THERMAL_EN */
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS12 0x01
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_EN_SMPS12_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_THERMAL_STATUS */
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS12 0x01
|
|
|
|
|
#define TPS65917_SMPS_THERMAL_STATUS_SMPS12_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_SHORT_STATUS */
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS4 0x10
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS2 0x02
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS1 0x01
|
|
|
|
|
#define TPS65917_SMPS_SHORT_STATUS_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_NEGATIVE_CURRENT_LIMIT_EN */
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS4 0x10
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS2 0x02
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS1 0x01
|
|
|
|
|
#define TPS65917_SMPS_NEGATIVE_CURRENT_LIMIT_EN_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_POWERGOOD_MASK1 */
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS5 0x40
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS4 0x10
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS3 0x08
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS2 0x02
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS1 0x01
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK1_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_POWERGOOD_MASK2 */
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK2_POWERGOOD_TYPE_SELECT 0x80
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK2_POWERGOOD_TYPE_SELECT_SHIFT 0x07
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK2_OVC_ALARM_SHIFT 0x10
|
|
|
|
|
#define TPS65917_SMPS_POWERGOOD_MASK2_OVC_ALARM 0x04
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for SMPS_PLL_CTRL */
|
|
|
|
|
|
|
|
|
|
#define TPS65917_SMPS_PLL_CTRL_PLL_EN_PLL_BYPASS_SHIFT 0x08
|
|
|
|
|
#define TPS65917_SMPS_PLL_CTRL_PLL_PLL_EN_BYPASS 0x03
|
|
|
|
|
#define TPS65917_SMPS_PLL_CTRL_PLL_PLL_BYPASS_CLK_SHIFT 0x04
|
|
|
|
|
#define TPS65917_SMPS_PLL_CTRL_PLL_PLL_BYPASS_CLK 0x02
|
|
|
|
|
|
|
|
|
|
/* Registers for function LDO */
|
|
|
|
|
#define TPS65917_LDO1_CTRL 0x00
|
|
|
|
|
#define TPS65917_LDO1_VOLTAGE 0x01
|
|
|
|
|
#define TPS65917_LDO2_CTRL 0x02
|
|
|
|
|
#define TPS65917_LDO2_VOLTAGE 0x03
|
|
|
|
|
#define TPS65917_LDO3_CTRL 0x04
|
|
|
|
|
#define TPS65917_LDO3_VOLTAGE 0x05
|
|
|
|
|
#define TPS65917_LDO4_CTRL 0x0E
|
|
|
|
|
#define TPS65917_LDO4_VOLTAGE 0x0F
|
|
|
|
|
#define TPS65917_LDO5_CTRL 0x12
|
|
|
|
|
#define TPS65917_LDO5_VOLTAGE 0x13
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1 0x1B
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2 0x1C
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1 0x1D
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2 0x1E
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL3 0x2D
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS3 0x2E
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO1_CTRL */
|
|
|
|
|
#define TPS65917_LDO1_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_LDO1_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO1_CTRL_BYPASS_EN 0x40
|
|
|
|
|
#define TPS65917_LDO1_CTRL_BYPASS_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_LDO1_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_LDO1_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_LDO1_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_LDO1_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO1_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_LDO1_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO1_VOLTAGE */
|
|
|
|
|
#define TPS65917_LDO1_VOLTAGE_VSEL_MASK 0x2F
|
|
|
|
|
#define TPS65917_LDO1_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO2_CTRL */
|
|
|
|
|
#define TPS65917_LDO2_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_LDO2_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO2_CTRL_BYPASS_EN 0x40
|
|
|
|
|
#define TPS65917_LDO2_CTRL_BYPASS_EN_SHIFT 0x06
|
|
|
|
|
#define TPS65917_LDO2_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_LDO2_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_LDO2_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_LDO2_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO2_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_LDO2_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO2_VOLTAGE */
|
|
|
|
|
#define TPS65917_LDO2_VOLTAGE_VSEL_MASK 0x2F
|
|
|
|
|
#define TPS65917_LDO2_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO3_CTRL */
|
|
|
|
|
#define TPS65917_LDO3_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_LDO3_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO3_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_LDO3_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_LDO3_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_LDO3_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO3_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_LDO3_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO3_VOLTAGE */
|
|
|
|
|
#define TPS65917_LDO3_VOLTAGE_VSEL_MASK 0x2F
|
|
|
|
|
#define TPS65917_LDO3_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO4_CTRL */
|
|
|
|
|
#define TPS65917_LDO4_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_LDO4_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO4_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_LDO4_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_LDO4_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_LDO4_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO4_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_LDO4_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO4_VOLTAGE */
|
|
|
|
|
#define TPS65917_LDO4_VOLTAGE_VSEL_MASK 0x2F
|
|
|
|
|
#define TPS65917_LDO4_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO5_CTRL */
|
|
|
|
|
#define TPS65917_LDO5_CTRL_WR_S 0x80
|
|
|
|
|
#define TPS65917_LDO5_CTRL_WR_S_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO5_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_LDO5_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_LDO5_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_LDO5_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO5_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_LDO5_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO5_VOLTAGE */
|
|
|
|
|
#define TPS65917_LDO5_VOLTAGE_VSEL_MASK 0x2F
|
|
|
|
|
#define TPS65917_LDO5_VOLTAGE_VSEL_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_PD_CTRL1 */
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO4 0x80
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO4_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO2 0x02
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO1 0x01
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL1_LDO1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_PD_CTRL2 */
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDO3 0x04
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDO3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDO5 0x02
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDO5_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_PD_CTRL3 */
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDOVANA 0x80
|
|
|
|
|
#define TPS65917_LDO_PD_CTRL2_LDOVANA_SHIFT 0x07
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_SHORT_STATUS1 */
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO4 0x80
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO4_SHIFT 0x07
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO2 0x02
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO1 0x01
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS1_LDO1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_SHORT_STATUS2 */
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDO3 0x04
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDO3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDO5 0x02
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDO5_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for LDO_SHORT_STATUS2 */
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDOVANA 0x80
|
|
|
|
|
#define TPS65917_LDO_SHORT_STATUS2_LDOVANA_SHIFT 0x07
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for REGEN1_CTRL */
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_REGEN1_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for PLLEN_CTRL */
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_PLLEN_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for REGEN2_CTRL */
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_REGEN2_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for NSLEEP_RES_ASSIGN */
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_PLL_EN 0x08
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_PLL_EN_SHIFT 0x03
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN3 0x04
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN2 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN1 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN_REGEN1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for NSLEEP_SMPS_ASSIGN */
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS5 0x40
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS4 0x10
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS3 0x08
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS2 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS1 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for NSLEEP_LDO_ASSIGN1 */
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO4 0x80
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO4_SHIFT 0x07
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO2 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO1 0x01
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1_LDO1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for NSLEEP_LDO_ASSIGN2 */
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN2_LDO3 0x04
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN2_LDO3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN2_LDO5 0x02
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN2_LDO5_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE1_RES_ASSIGN */
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_PLLEN 0x08
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_PLLEN_SHIFT 0x03
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN3 0x04
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN2 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN1 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN_REGEN1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE1_SMPS_ASSIGN */
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS5 0x40
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS4 0x10
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS3 0x08
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS2 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS1 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE1_LDO_ASSIGN1 */
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO4 0x80
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO4_SHIFT 0x07
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO2 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO1 0x01
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1_LDO1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE1_LDO_ASSIGN2 */
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN2_LDO3 0x04
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN2_LDO3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN2_LDO5 0x02
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN2_LDO5_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE2_RES_ASSIGN */
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_PLLEN 0x08
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_PLLEN_SHIFT 0x03
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN3 0x04
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN2 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN1 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN_REGEN1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE2_SMPS_ASSIGN */
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS5 0x40
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS5_SHIFT 0x06
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS4 0x10
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS4_SHIFT 0x04
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS3 0x08
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS3_SHIFT 0x03
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS2 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS1 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN_SMPS1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE2_LDO_ASSIGN1 */
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO4 0x80
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO4_SHIFT 0x07
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO2 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO2_SHIFT 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO1 0x01
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1_LDO1_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for ENABLE2_LDO_ASSIGN2 */
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN2_LDO3 0x04
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN2_LDO3_SHIFT 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN2_LDO5 0x02
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN2_LDO5_SHIFT 0x01
|
|
|
|
|
|
|
|
|
|
/* Bit definitions for REGEN3_CTRL */
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_STATUS 0x10
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_STATUS_SHIFT 0x04
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_MODE_SLEEP 0x04
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_MODE_SLEEP_SHIFT 0x02
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_MODE_ACTIVE 0x01
|
|
|
|
|
#define TPS65917_REGEN3_CTRL_MODE_ACTIVE_SHIFT 0x00
|
|
|
|
|
|
|
|
|
|
/* Registers for function RESOURCE */
|
|
|
|
|
#define TPS65917_REGEN1_CTRL 0x2
|
|
|
|
|
#define TPS65917_PLLEN_CTRL 0x3
|
|
|
|
|
#define TPS65917_NSLEEP_RES_ASSIGN 0x6
|
|
|
|
|
#define TPS65917_NSLEEP_SMPS_ASSIGN 0x7
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN1 0x8
|
|
|
|
|
#define TPS65917_NSLEEP_LDO_ASSIGN2 0x9
|
|
|
|
|
#define TPS65917_ENABLE1_RES_ASSIGN 0xA
|
|
|
|
|
#define TPS65917_ENABLE1_SMPS_ASSIGN 0xB
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN1 0xC
|
|
|
|
|
#define TPS65917_ENABLE1_LDO_ASSIGN2 0xD
|
|
|
|
|
#define TPS65917_ENABLE2_RES_ASSIGN 0xE
|
|
|
|
|
#define TPS65917_ENABLE2_SMPS_ASSIGN 0xF
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN1 0x10
|
|
|
|
|
#define TPS65917_ENABLE2_LDO_ASSIGN2 0x11
|
|
|
|
|
#define TPS65917_REGEN2_CTRL 0x12
|
|
|
|
|
#define TPS65917_REGEN3_CTRL 0x13
|
|
|
|
|
|
|
|
|
|
static inline int palmas_read(struct palmas *palmas, unsigned int base,
|
|
|
|
|
unsigned int reg, unsigned int *val)
|
|
|
|
|
{
|
|
|
|
|