/* SPDX-License-Identifier: GPL-2.0-or-later */ /* * Copyright 2025 ROHM Semiconductors. * * Author: Matti Vaittinen */ #ifndef _MFD_BD72720_H #define _MFD_BD72720_H #include enum { BD72720_BUCK1, BD72720_BUCK2, BD72720_BUCK3, BD72720_BUCK4, BD72720_BUCK5, BD72720_BUCK6, BD72720_BUCK7, BD72720_BUCK8, BD72720_BUCK9, BD72720_BUCK10, BD72720_BUCK11, BD72720_LDO1, BD72720_LDO2, BD72720_LDO3, BD72720_LDO4, BD72720_LDO5, BD72720_LDO6, BD72720_LDO7, BD72720_LDO8, BD72720_LDO9, BD72720_LDO10, BD72720_LDO11, BD72720_REGULATOR_AMOUNT, }; /* BD72720 interrupts */ #define BD72720_INT_LONGPUSH_MASK BIT(0) #define BD72720_INT_MIDPUSH_MASK BIT(1) #define BD72720_INT_SHORTPUSH_MASK BIT(2) #define BD72720_INT_PUSH_MASK BIT(3) #define BD72720_INT_HALL_DET_MASK BIT(4) #define BD72720_INT_HALL_TGL_MASK BIT(5) #define BD72720_INT_WDOG_MASK BIT(6) #define BD72720_INT_SWRESET_MASK BIT(7) #define BD72720_INT_SEQ_DONE_MASK BIT(0) #define BD72720_INT_PGFAULT_MASK BIT(4) #define BD72720_INT_BUCK1_DVS_MASK BIT(0) #define BD72720_INT_BUCK2_DVS_MASK BIT(1) #define BD72720_INT_BUCK3_DVS_MASK BIT(2) #define BD72720_INT_BUCK4_DVS_MASK BIT(3) #define BD72720_INT_BUCK5_DVS_MASK BIT(4) #define BD72720_INT_BUCK6_DVS_MASK BIT(5) #define BD72720_INT_BUCK7_DVS_MASK BIT(6) #define BD72720_INT_BUCK8_DVS_MASK BIT(7) #define BD72720_INT_BUCK9_DVS_MASK BIT(0) #define BD72720_INT_BUCK10_DVS_MASK BIT(1) #define BD72720_INT_LDO1_DVS_MASK BIT(4) #define BD72720_INT_LDO2_DVS_MASK BIT(5) #define BD72720_INT_LDO3_DVS_MASK BIT(6) #define BD72720_INT_LDO4_DVS_MASK BIT(7) #define BD72720_INT_VBUS_RMV_MASK BIT(0) #define BD72720_INT_VBUS_DET_MASK BIT(1) #define BD72720_INT_VBUS_MON_RES_MASK BIT(2) #define BD72720_INT_VBUS_MON_DET_MASK BIT(3) #define BD72720_INT_VSYS_MON_RES_MASK BIT(0) #define BD72720_INT_VSYS_MON_DET_MASK BIT(1) #define BD72720_INT_VSYS_UV_RES_MASK BIT(2) #define BD72720_INT_VSYS_UV_DET_MASK BIT(3) #define BD72720_INT_VSYS_LO_RES_MASK BIT(4) #define BD72720_INT_VSYS_LO_DET_MASK BIT(5) #define BD72720_INT_VSYS_OV_RES_MASK BIT(6) #define BD72720_INT_VSYS_OV_DET_MASK BIT(7) #define BD72720_INT_BAT_ILIM_MASK BIT(0) #define BD72720_INT_CHG_DONE_MASK BIT(1) #define BD72720_INT_EXTEMP_TOUT_MASK BIT(2) #define BD72720_INT_CHG_WDT_EXP_MASK BIT(3) #define BD72720_INT_BAT_MNT_OUT_MASK BIT(4) #define BD72720_INT_BAT_MNT_IN_MASK BIT(5) #define BD72720_INT_CHG_TRNS_MASK BIT(7) #define BD72720_INT_VBAT_MON_RES_MASK BIT(0) #define BD72720_INT_VBAT_MON_DET_MASK BIT(1) #define BD72720_INT_VBAT_SHT_RES_MASK BIT(2) #define BD72720_INT_VBAT_SHT_DET_MASK BIT(3) #define BD72720_INT_VBAT_LO_RES_MASK BIT(4) #define BD72720_INT_VBAT_LO_DET_MASK BIT(5) #define BD72720_INT_VBAT_OV_RES_MASK BIT(6) #define BD72720_INT_VBAT_OV_DET_MASK BIT(7) #define BD72720_INT_BAT_RMV_MASK BIT(0) #define BD72720_INT_BAT_DET_MASK BIT(1) #define BD72720_INT_DBAT_DET_MASK BIT(2) #define BD72720_INT_BAT_TEMP_TRNS_MASK BIT(3) #define BD72720_INT_LOBTMP_RES_MASK BIT(4) #define BD72720_INT_LOBTMP_DET_MASK BIT(5) #define BD72720_INT_OVBTMP_RES_MASK BIT(6) #define BD72720_INT_OVBTMP_DET_MASK BIT(7) #define BD72720_INT_OCUR1_RES_MASK BIT(0) #define BD72720_INT_OCUR1_DET_MASK BIT(1) #define BD72720_INT_OCUR2_RES_MASK BIT(2) #define BD72720_INT_OCUR2_DET_MASK BIT(3) #define BD72720_INT_OCUR3_RES_MASK BIT(4) #define BD72720_INT_OCUR3_DET_MASK BIT(5) #define BD72720_INT_CC_MON1_DET_MASK BIT(0) #define BD72720_INT_CC_MON2_DET_MASK BIT(1) #define BD72720_INT_CC_MON3_DET_MASK BIT(2) #define BD72720_INT_GPIO1_IN_MASK BIT(4) #define BD72720_INT_GPIO2_IN_MASK BIT(5) #define BD72720_INT_VF125_RES_MASK BIT(0) #define BD72720_INT_VF125_DET_MASK BIT(1) #define BD72720_INT_VF_RES_MASK BIT(2) #define BD72720_INT_VF_DET_MASK BIT(3) #define BD72720_INT_RTC0_MASK BIT(4) #define BD72720_INT_RTC1_MASK BIT(5) #define BD72720_INT_RTC2_MASK BIT(6) enum { /* * The IRQs excluding GPIO1 and GPIO2 are ordered in a same way as the * respective IRQ bits in status and mask registers are ordered. * * The BD72720_INT_GPIO1_IN and BD72720_INT_GPIO2_IN are IRQs which can * be used by other devices. Let's have GPIO1 and GPIO2 as first IRQs * here so we can use the regmap-IRQ with standard device tree xlate * while devices connected to the BD72720 IRQ input pins can refer to * the first two interrupt numbers in their device tree. If we placed * BD72720_INT_GPIO1_IN and BD72720_INT_GPIO2_IN after the CC_MON_DET * interrupts (like they are in the registers), the devices using * BD72720 as an IRQ parent should refer the interrupts starting with * an offset which might not be trivial to understand. */ BD72720_INT_GPIO1_IN, BD72720_INT_GPIO2_IN, BD72720_INT_LONGPUSH, BD72720_INT_MIDPUSH, BD72720_INT_SHORTPUSH, BD72720_INT_PUSH, BD72720_INT_HALL_DET, BD72720_INT_HALL_TGL, BD72720_INT_WDOG, BD72720_INT_SWRESET, BD72720_INT_SEQ_DONE, BD72720_INT_PGFAULT, BD72720_INT_BUCK1_DVS, BD72720_INT_BUCK2_DVS, BD72720_INT_BUCK3_DVS, BD72720_INT_BUCK4_DVS, BD72720_INT_BUCK5_DVS, BD72720_INT_BUCK6_DVS, BD72720_INT_BUCK7_DVS, BD72720_INT_BUCK8_DVS, BD72720_INT_BUCK9_DVS, BD72720_INT_BUCK10_DVS, BD72720_INT_LDO1_DVS, BD72720_INT_LDO2_DVS, BD72720_INT_LDO3_DVS, BD72720_INT_LDO4_DVS, BD72720_INT_VBUS_RMV, BD72720_INT_VBUS_DET, BD72720_INT_VBUS_MON_RES, BD72720_INT_VBUS_MON_DET, BD72720_INT_VSYS_MON_RES, BD72720_INT_VSYS_MON_DET, BD72720_INT_VSYS_UV_RES, BD72720_INT_VSYS_UV_DET, BD72720_INT_VSYS_LO_RES, BD72720_INT_VSYS_LO_DET, BD72720_INT_VSYS_OV_RES, BD72720_INT_VSYS_OV_DET, BD72720_INT_BAT_ILIM, BD72720_INT_CHG_DONE, BD72720_INT_EXTEMP_TOUT, BD72720_INT_CHG_WDT_EXP, BD72720_INT_BAT_MNT_OUT, BD72720_INT_BAT_MNT_IN, BD72720_INT_CHG_TRNS, BD72720_INT_VBAT_MON_RES, BD72720_INT_VBAT_MON_DET, BD72720_INT_VBAT_SHT_RES, BD72720_INT_VBAT_SHT_DET, BD72720_INT_VBAT_LO_RES, BD72720_INT_VBAT_LO_DET, BD72720_INT_VBAT_OV_RES, BD72720_INT_VBAT_OV_DET, BD72720_INT_BAT_RMV, BD72720_INT_BAT_DET, BD72720_INT_DBAT_DET, BD72720_INT_BAT_TEMP_TRNS, BD72720_INT_LOBTMP_RES, BD72720_INT_LOBTMP_DET, BD72720_INT_OVBTMP_RES, BD72720_INT_OVBTMP_DET, BD72720_INT_OCUR1_RES, BD72720_INT_OCUR1_DET, BD72720_INT_OCUR2_RES, BD72720_INT_OCUR2_DET, BD72720_INT_OCUR3_RES, BD72720_INT_OCUR3_DET, BD72720_INT_CC_MON1_DET, BD72720_INT_CC_MON2_DET, BD72720_INT_CC_MON3_DET, BD72720_INT_VF125_RES, BD72720_INT_VF125_DET, BD72720_INT_VF_RES, BD72720_INT_VF_DET, BD72720_INT_RTC0, BD72720_INT_RTC1, BD72720_INT_RTC2, }; /* * BD72720 Registers: * The BD72720 has two sets of registers behind two different I2C slave * addresses. "Common" registers being behind 0x4b, the charger registers * being behind 0x4c. */ /* Registers behind I2C slave 0x4b */ enum { BD72720_REG_PRODUCT_ID, BD72720_REG_MANUFACTURER_ID, BD72720_REG_PMIC_REV_NUM, BD72720_REG_NVM_REV_NUM, BD72720_REG_BOOTSRC = 0x10, BD72720_REG_RESETSRC_1, BD72720_REG_RESETSRC_2, BD72720_REG_RESETSRC_3, BD72720_REG_RESETSRC_4, BD72720_REG_RESETSRC_5, BD72720_REG_RESETSRC_6, BD72720_REG_RESETSRC_7, BD72720_REG_POWER_STATE, BD72720_REG_PS_CFG, BD72720_REG_PS_CTRL_1, BD72720_REG_PS_CTRL_2, BD72720_REG_RCVCFG, BD72720_REG_RCVNUM, BD72720_REG_CRDCFG, BD72720_REG_REX_CTRL, BD72720_REG_BUCK1_ON, BD72720_REG_BUCK1_MODE, /* Deep idle vsel */ BD72720_REG_BUCK1_VSEL_DI, /* Idle vsel */ BD72720_REG_BUCK1_VSEL_I, /* Suspend vsel */ BD72720_REG_BUCK1_VSEL_S, /* Run boot vsel */ BD72720_REG_BUCK1_VSEL_RB, /* Run0 ... run3 vsel */ BD72720_REG_BUCK1_VSEL_RB0, BD72720_REG_BUCK1_VSEL_RB1, BD72720_REG_BUCK1_VSEL_RB2, BD72720_REG_BUCK1_VSEL_RB3, BD72720_REG_BUCK2_ON, BD72720_REG_BUCK2_MODE, BD72720_REG_BUCK2_VSEL_DI, BD72720_REG_BUCK2_VSEL_I, BD72720_REG_BUCK2_VSEL_S, /* Run vsel */ BD72720_REG_BUCK2_VSEL_R, BD72720_REG_BUCK3_ON, BD72720_REG_BUCK3_MODE, BD72720_REG_BUCK3_VSEL_DI, BD72720_REG_BUCK3_VSEL_I, BD72720_REG_BUCK3_VSEL_S, BD72720_REG_BUCK3_VSEL_R, BD72720_REG_BUCK4_ON, BD72720_REG_BUCK4_MODE, BD72720_REG_BUCK4_VSEL_DI, BD72720_REG_BUCK4_VSEL_I, BD72720_REG_BUCK4_VSEL_S, BD72720_REG_BUCK4_VSEL_R, BD72720_REG_BUCK5_ON, BD72720_REG_BUCK5_MODE, BD72720_REG_BUCK5_VSEL, BD72720_REG_BUCK6_ON, BD72720_REG_BUCK6_MODE, BD72720_REG_BUCK6_VSEL, BD72720_REG_BUCK7_ON, BD72720_REG_BUCK7_MODE, BD72720_REG_BUCK7_VSEL, BD72720_REG_BUCK8_ON, BD72720_REG_BUCK8_MODE, BD72720_REG_BUCK8_VSEL, BD72720_REG_BUCK9_ON, BD72720_REG_BUCK9_MODE, BD72720_REG_BUCK9_VSEL, BD72720_REG_BUCK10_ON, BD72720_REG_BUCK10_MODE, BD72720_REG_BUCK10_VSEL, BD72720_REG_LDO1_ON, BD72720_REG_LDO1_MODE1, BD72720_REG_LDO1_MODE2, BD72720_REG_LDO1_VSEL_DI, BD72720_REG_LDO1_VSEL_I, BD72720_REG_LDO1_VSEL_S, BD72720_REG_LDO1_VSEL_RB, BD72720_REG_LDO1_VSEL_R0, BD72720_REG_LDO1_VSEL_R1, BD72720_REG_LDO1_VSEL_R2, BD72720_REG_LDO1_VSEL_R3, BD72720_REG_LDO2_ON, BD72720_REG_LDO2_MODE, BD72720_REG_LDO2_VSEL_DI, BD72720_REG_LDO2_VSEL_I, BD72720_REG_LDO2_VSEL_S, BD72720_REG_LDO2_VSEL_R, BD72720_REG_LDO3_ON, BD72720_REG_LDO3_MODE, BD72720_REG_LDO3_VSEL_DI, BD72720_REG_LDO3_VSEL_I, BD72720_REG_LDO3_VSEL_S, BD72720_REG_LDO3_VSEL_R, BD72720_REG_LDO4_ON, BD72720_REG_LDO4_MODE, BD72720_REG_LDO4_VSEL_DI, BD72720_REG_LDO4_VSEL_I, BD72720_REG_LDO4_VSEL_S, BD72720_REG_LDO4_VSEL_R, BD72720_REG_LDO5_ON, BD72720_REG_LDO5_MODE, BD72720_REG_LDO5_VSEL, BD72720_REG_LDO6_ON, BD72720_REG_LDO6_MODE, BD72720_REG_LDO6_VSEL, BD72720_REG_LDO7_ON, BD72720_REG_LDO7_MODE, BD72720_REG_LDO7_VSEL, BD72720_REG_LDO8_ON, BD72720_REG_LDO8_MODE, BD72720_REG_LDO8_VSEL, BD72720_REG_LDO9_ON, BD72720_REG_LDO9_MODE, BD72720_REG_LDO9_VSEL, BD72720_REG_LDO10_ON, BD72720_REG_LDO10_MODE, BD72720_REG_LDO10_VSEL, BD72720_REG_LDO11_ON, BD72720_REG_LDO11_MODE, BD72720_REG_LDO11_VSEL, BD72720_REG_GPIO1_ON = 0x8b, BD72720_REG_GPIO2_ON, BD72720_REG_GPIO3_ON, BD72720_REG_GPIO4_ON, BD72720_REG_GPIO5_ON, BD72720_REG_GPIO1_CTRL, BD72720_REG_GPIO2_CTRL, #define BD72720_GPIO_IRQ_TYPE_MASK GENMASK(6, 4) #define BD72720_GPIO_IRQ_TYPE_FALLING 0x0 #define BD72720_GPIO_IRQ_TYPE_RISING 0x1 #define BD72720_GPIO_IRQ_TYPE_BOTH 0x2 #define BD72720_GPIO_IRQ_TYPE_HIGH 0x3 #define BD72720_GPIO_IRQ_TYPE_LOW 0x4 BD72720_REG_GPIO3_CTRL, BD72720_REG_GPIO4_CTRL, BD72720_REG_GPIO5_CTRL, #define BD72720_GPIO_DRIVE_MASK BIT(1) #define BD72720_GPIO_HIGH BIT(0) BD72720_REG_EPDEN_CTRL, BD72720_REG_GATECNT_CTRL, BD72720_REG_LED_CTRL, BD72720_REG_PWRON_CFG1, BD72720_REG_PWRON_CFG2, BD72720_REG_OUT32K, BD72720_REG_CONF, BD72720_REG_HALL_STAT, BD72720_REG_RTC_SEC = 0xa0, #define BD72720_REG_RTC_START BD72720_REG_RTC_SEC BD72720_REG_RTC_MIN, BD72720_REG_RTC_HOUR, BD72720_REG_RTC_WEEK, BD72720_REG_RTC_DAY, BD72720_REG_RTC_MON, BD72720_REG_RTC_YEAR, BD72720_REG_RTC_ALM0_SEC, #define BD72720_REG_RTC_ALM_START BD72720_REG_RTC_ALM0_SEC BD72720_REG_RTC_ALM0_MIN, BD72720_REG_RTC_ALM0_HOUR, BD72720_REG_RTC_ALM0_WEEK, BD72720_REG_RTC_ALM0_MON, BD72720_REG_RTC_ALM0_YEAR, BD72720_REG_RTC_ALM1_SEC, BD72720_REG_RTC_ALM1_MIN, BD72720_REG_RTC_ALM1_HOUR, BD72720_REG_RTC_ALM1_WEEK, BD72720_REG_RTC_ALM1_MON, BD72720_REG_RTC_ALM1_YEAR, BD72720_REG_RTC_ALM0_EN, BD72720_REG_RTC_ALM1_EN, BD72720_REG_RTC_ALM2, BD72720_REG_INT_LVL1_EN = 0xc0, #define BD72720_MASK_LVL1_EN_ALL GENMASK(7, 0) BD72720_REG_INT_PS1_EN, BD72720_REG_INT_PS2_EN, BD72720_REG_INT_DVS1_EN, BD72720_REG_INT_DVS2_EN, BD72720_REG_INT_VBUS_EN, BD72720_REG_INT_VSYS_EN, BD72720_REG_INT_CHG_EN, BD72720_REG_INT_BAT1_EN, BD72720_REG_INT_BAT2_EN, BD72720_REG_INT_IBAT_EN, BD72720_REG_INT_ETC1_EN, BD72720_REG_INT_ETC2_EN, /* * The _STAT registers inform IRQ line state, and are used to ack IRQ. * The _SRC registers below indicate current state of the function * connected to the line. */ BD72720_REG_INT_LVL1_STAT, BD72720_REG_INT_PS1_STAT, BD72720_REG_INT_PS2_STAT, BD72720_REG_INT_DVS1_STAT, BD72720_REG_INT_DVS2_STAT, BD72720_REG_INT_VBUS_STAT, BD72720_REG_INT_VSYS_STAT, BD72720_REG_INT_CHG_STAT, BD72720_REG_INT_BAT1_STAT, BD72720_REG_INT_BAT2_STAT, BD72720_REG_INT_IBAT_STAT, BD72720_REG_INT_ETC1_STAT, BD72720_REG_INT_ETC2_STAT, BD72720_REG_INT_LVL1_SRC, BD72720_REG_INT_PS1_SRC, BD72720_REG_INT_PS2_SRC, BD72720_REG_INT_DVS1_SRC, BD72720_REG_INT_DVS2_SRC, BD72720_REG_INT_VBUS_SRC, #define BD72720_MASK_DCIN_DET BIT(1) BD72720_REG_INT_VSYS_SRC, BD72720_REG_INT_CHG_SRC, BD72720_REG_INT_BAT1_SRC, BD72720_REG_INT_BAT2_SRC, BD72720_REG_INT_IBAT_SRC, BD72720_REG_INT_ETC1_SRC, BD72720_REG_INT_ETC2_SRC, }; /* Register masks */ #define BD72720_MASK_DEEP_IDLE_EN BIT(0) #define BD72720_MASK_IDLE_EN BIT(1) #define BD72720_MASK_SUSPEND_EN BIT(2) #define BD72720_MASK_RUN_B_EN BIT(3) #define BD72720_MASK_RUN_0_EN BIT(4) #define BD72720_MASK_RUN_1_EN BIT(5) #define BD72720_MASK_RUN_2_EN BIT(6) #define BD72720_MASK_RUN_3_EN BIT(7) #define BD72720_MASK_RAMP_UP_DELAY GENMASK(7, 6) #define BD72720_MASK_BUCK_VSEL GENMASK(7, 0) #define BD72720_MASK_LDO12346_VSEL GENMASK(6, 0) #define BD72720_MASK_LDO_VSEL GENMASK(7, 0) #define BD72720_I2C4C_ADDR_OFFSET 0x100 /* Registers behind I2C slave 0x4c */ enum { BD72720_REG_CHG_STATE = BD72720_I2C4C_ADDR_OFFSET, BD72720_REG_CHG_LAST_STATE, BD72720_REG_CHG_VBUS_STAT, BD72720_REG_CHG_VSYS_STAT, BD72720_REG_CHG_BAT_TEMP_STAT, BD72720_REG_CHG_WDT_STAT, BD72720_REG_CHG_ILIM_STAT, BD72720_REG_CHG_CHG_STAT, BD72720_REG_CHG_EN, BD72720_REG_CHG_INIT, BD72720_REG_CHG_CTRL, BD72720_REG_CHG_SET_1, BD72720_REG_CHG_SET_2, BD72720_REG_CHG_SET_3, BD72720_REG_CHG_VPRE, BD72720_REG_CHG_VBAT_1, BD72720_REG_CHG_VBAT_2, BD72720_REG_CHG_VBAT_3, BD72720_REG_CHG_VBAT_4, BD72720_REG_CHG_BAT_SET_1, BD72720_REG_CHG_BAT_SET_2, BD72720_REG_CHG_BAT_SET_3, BD72720_REG_CHG_IPRE, BD72720_REG_CHG_IFST_TERM, BD72720_REG_CHG_VSYS_REG, BD72720_REG_CHG_VBUS_SET, BD72720_REG_CHG_WDT_PRE, BD72720_REG_CHG_WDT_FST, BD72720_REG_CHG_LED_CTRL, BD72720_REG_CHG_CFG_1, BD72720_REG_CHG_IFST_1, BD72720_REG_CHG_IFST_2, BD72720_REG_CHG_IFST_3, BD72720_REG_CHG_IFST_4, BD72720_REG_CHG_S_CFG_1, BD72720_REG_CHG_S_CFG_2, BD72720_REG_RS_VBUS, BD72720_REG_RS_IBUS, BD72720_REG_RS_VSYS, BD72720_REG_VSYS_STATE_STAT, /* 0x27 + offset*/ BD72720_REG_VM_VBAT_U = BD72720_I2C4C_ADDR_OFFSET + 0x30, BD72720_REG_VM_VBAT_L, BD72720_REG_VM_OCV_PRE_U, BD72720_REG_VM_OCV_PRE_L, BD72720_REG_VM_OCV_PST_U, BD72720_REG_VM_OCV_PST_L, BD72720_REG_VM_OCV_PWRON_U, BD72720_REG_VM_OCV_PWRON_L, BD72720_REG_VM_DVBAT_IMP_U, BD72720_REG_VM_DVBAT_IMP_L, BD72720_REG_VM_SA_VBAT_U, BD72720_REG_VM_SA_VBAT_L, BD72720_REG_VM_SA_VBAT_MIN_U, BD72720_REG_VM_SA_VBAT_MIN_L, BD72720_REG_VM_SA_VBAT_MAX_U, BD72720_REG_VM_SA_VBAT_MAX_L, BD72720_REG_REX_SA_VBAT_U, BD72720_REG_REX_SA_VBAT_L, BD72720_REG_VM_VSYS_U, BD72720_REG_VM_VSYS_L, BD72720_REG_VM_SA_VSYS_U, BD72720_REG_VM_SA_VSYS_L, BD72720_REG_VM_SA_VSYS_MIN_U, BD72720_REG_VM_SA_VSYS_MIN_L, BD72720_REG_VM_SA_VSYS_MAX_U, BD72720_REG_VM_SA_VSYS_MAX_L, BD72720_REG_VM_SA2_VSYS_U, BD72720_REG_VM_SA2_VSYS_L, BD72720_REG_VM_VBUS_U, #define BD72720_MASK_VDCIN_U GENMASK(3, 0) BD72720_REG_VM_VBUS_L, BD72720_REG_VM_BATID_U, BD72720_REG_VM_BATID_L, BD72720_REG_VM_BATID_NOLOAD_U, BD72720_REG_VM_BATID_NOLOAD_L, BD72720_REG_VM_BATID_OFS_U, BD72720_REG_VM_BATID_OFS_L, BD72720_REG_VM_VTH_U, BD72720_REG_VM_VTH_L, BD72720_REG_VM_VTH_CORR_U, BD72720_REG_VM_VTH_CORR_L, BD72720_REG_VM_BTMP_U, BD72720_REG_VM_BTMP_L, BD72720_REG_VM_BTMP_IMP_U, BD72720_REG_VM_BTMP_IMP_L, BD72720_REG_VM_VF_U, BD72720_REG_VM_VF_L, BD72720_REG_VM_BATID_TH_U, BD72720_REG_VM_BATID_TH_L, BD72720_REG_VM_BTMP_OV_THR, BD72720_REG_VM_BTMP_OV_DUR, BD72720_REG_VM_BTMP_LO_THR, BD72720_REG_VM_BTMP_LO_DUR, BD72720_REG_ALM_VBAT_TH_U, BD72720_REG_ALM_VBAT_TH_L, BD72720_REG_ALM_VSYS_TH, BD72720_REG_ALM_VBUS_TH, BD72720_REG_ALM_VF_TH, BD72720_REG_VSYS_MAX, BD72720_REG_VSYS_MIN, BD72720_REG_VM_VSYS_SA_MINMAX_CTRL, BD72720_REG_VM_SA_CFG, /* 0x6c + offset*/ BD72720_REG_CC_CURCD_U = BD72720_I2C4C_ADDR_OFFSET + 0x70, BD72720_REG_CC_CURCD_L, BD72720_REG_CC_CURCD_IMP_U, BD72720_REG_CC_CURCD_IMP_L, BD72720_REG_CC_SA_CURCD_U, BD72720_REG_CC_SA_CURCD_L, BD72720_REG_CC_OCUR_MON, BD72720_REG_CC_CCNTD_3, BD72720_REG_CC_CCNTD_2, BD72720_REG_CC_CCNTD_1, BD72720_REG_CC_CCNTD_0, BD72720_REG_REX_CCNTD_3, BD72720_REG_REX_CCNTD_2, BD72720_REG_REX_CCNTD_1, BD72720_REG_REX_CCNTD_0, BD72720_REG_FULL_CCNTD_3, BD72720_REG_FULL_CCNTD_2, BD72720_REG_FULL_CCNTD_1, BD72720_REG_FULL_CCNTD_0, BD72720_REG_CCNTD_CHG_3, BD72720_REG_CCNTD_CHG_2, BD72720_REG_CC_STAT, BD72720_REG_CC_CTRL, BD72720_REG_CC_OCUR_THR_1, BD72720_REG_CC_OCUR_THR_2, BD72720_REG_CC_OCUR_THR_3, BD72720_REG_REX_CURCD_TH, BD72720_REG_CC_BATCAP1_TH_U, BD72720_REG_CC_BATCAP1_TH_L, BD72720_REG_CC_BATCAP2_TH_U, BD72720_REG_CC_BATCAP2_TH_L, BD72720_REG_CC_BATCAP3_TH_U, BD72720_REG_CC_BATCAP3_TH_L, BD72720_REG_CC_CCNTD_CTRL, BD72720_REG_CC_SA_CFG, /* 0x92 + offset*/ BD72720_REG_IMPCHK_CTRL = BD72720_I2C4C_ADDR_OFFSET + 0xa0, }; #endif /* __LINUX_MFD_BD72720_H */