| /** |
| * @file bd71837.h ROHM BD71837MWV header file |
| * |
| * Copyright 2017 |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License as published by the |
| * Free Software Foundation; either version 2 of the License, or (at your |
| * option) any later version. |
| * |
| * @author cpham2403@gmail.com |
| */ |
| |
| #ifndef __LINUX_MFD_BD71837_H |
| #define __LINUX_MFD_BD71837_H |
| |
| #include <linux/regmap.h> |
| |
| enum { |
| BD71837_BUCK1 = 0, |
| BD71837_BUCK2, |
| BD71837_BUCK3, |
| BD71837_BUCK4, |
| BD71837_BUCK5, |
| BD71837_BUCK6, |
| BD71837_BUCK7, |
| BD71837_BUCK8, |
| // General Purpose |
| BD71837_LDO1, |
| BD71837_LDO2, |
| BD71837_LDO3, |
| BD71837_LDO4, |
| BD71837_LDO5, |
| BD71837_LDO6, |
| BD71837_LDO7, |
| BD71837_REGULATOR_CNT, |
| }; |
| |
| #define BD71837_SUPPLY_STATE_ENABLED 0x1 |
| |
| #define BD71837_BUCK1_VOLTAGE_NUM 0x40 |
| #define BD71837_BUCK2_VOLTAGE_NUM 0x40 |
| #define BD71837_BUCK3_VOLTAGE_NUM 0x40 |
| #define BD71837_BUCK4_VOLTAGE_NUM 0x40 |
| |
| #define BD71837_BUCK5_VOLTAGE_NUM 0x08 |
| #define BD71837_BUCK6_VOLTAGE_NUM 0x04 |
| #define BD71837_BUCK7_VOLTAGE_NUM 0x08 |
| #define BD71837_BUCK8_VOLTAGE_NUM 0x40 |
| |
| #define BD71837_LDO1_VOLTAGE_NUM 0x04 |
| #define BD71837_LDO2_VOLTAGE_NUM 0x02 |
| #define BD71837_LDO3_VOLTAGE_NUM 0x10 |
| #define BD71837_LDO4_VOLTAGE_NUM 0x10 |
| #define BD71837_LDO5_VOLTAGE_NUM 0x10 |
| #define BD71837_LDO6_VOLTAGE_NUM 0x10 |
| #define BD71837_LDO7_VOLTAGE_NUM 0x10 |
| |
| enum { |
| BD71837_REG_REV = 0x00, |
| BD71837_REG_SWRESET = 0x01, |
| BD71837_REG_I2C_DEV = 0x02, |
| BD71837_REG_PWRCTRL0 = 0x03, |
| BD71837_REG_PWRCTRL1 = 0x04, |
| BD71837_REG_BUCK1_CTRL = 0x05, |
| BD71837_REG_BUCK2_CTRL = 0x06, |
| BD71837_REG_BUCK3_CTRL = 0x07, |
| BD71837_REG_BUCK4_CTRL = 0x08, |
| BD71837_REG_BUCK5_CTRL = 0x09, |
| BD71837_REG_BUCK6_CTRL = 0x0A, |
| BD71837_REG_BUCK7_CTRL = 0x0B, |
| BD71837_REG_BUCK8_CTRL = 0x0C, |
| BD71837_REG_BUCK1_VOLT_RUN = 0x0D, |
| BD71837_REG_BUCK1_VOLT_IDLE = 0x0E, |
| BD71837_REG_BUCK1_VOLT_SUSP = 0x0F, |
| BD71837_REG_BUCK2_VOLT_RUN = 0x10, |
| BD71837_REG_BUCK2_VOLT_IDLE = 0x11, |
| BD71837_REG_BUCK3_VOLT_RUN = 0x12, |
| BD71837_REG_BUCK4_VOLT_RUN = 0x13, |
| BD71837_REG_BUCK5_VOLT = 0x14, |
| BD71837_REG_BUCK6_VOLT = 0x15, |
| BD71837_REG_BUCK7_VOLT = 0x16, |
| BD71837_REG_BUCK8_VOLT = 0x17, |
| BD71837_REG_LDO1_VOLT = 0x18, |
| BD71837_REG_LDO2_VOLT = 0x19, |
| BD71837_REG_LDO3_VOLT = 0x1A, |
| BD71837_REG_LDO4_VOLT = 0x1B, |
| BD71837_REG_LDO5_VOLT = 0x1C, |
| BD71837_REG_LDO6_VOLT = 0x1D, |
| BD71837_REG_LDO7_VOLT = 0x1E, |
| BD71837_REG_TRANS_COND0 = 0x1F, |
| BD71837_REG_TRANS_COND1 = 0x20, |
| BD71837_REG_VRFAULTEN = 0x21, |
| BD71837_REG_MVRFLTMASK0 = 0x22, |
| BD71837_REG_MVRFLTMASK1 = 0x23, |
| BD71837_REG_MVRFLTMASK2 = 0x24, |
| BD71837_REG_RCVCFG = 0x25, |
| BD71837_REG_RCVNUM = 0x26, |
| BD71837_REG_PWRONCONFIG0 = 0x27, |
| BD71837_REG_PWRONCONFIG1 = 0x28, |
| BD71837_REG_RESETSRC = 0x29, |
| BD71837_REG_MIRQ = 0x2A, |
| BD71837_REG_IRQ = 0x2B, |
| BD71837_REG_IN_MON = 0x2C, |
| BD71837_REG_POW_STATE = 0x2D, |
| BD71837_REG_OUT32K = 0x2E, |
| BD71837_REG_REGLOCK = 0x2F, |
| BD71837_REG_OTPVER = 0xFF, |
| BD71837_MAX_REGISTER = 0x100, |
| }; |
| |
| /* BD71837_REG_BUCK1_CTRL bits */ |
| #define BUCK1_RAMPRATE_MASK 0xC0 |
| #define BUCK1_RAMPRATE_10P00MV 0x0 |
| #define BUCK1_RAMPRATE_5P00MV 0x1 |
| #define BUCK1_RAMPRATE_2P50MV 0x2 |
| #define BUCK1_RAMPRATE_1P25MV 0x3 |
| #define BUCK1_SEL 0x02 |
| #define BUCK1_EN 0x01 |
| |
| /* BD71837_REG_BUCK2_CTRL bits */ |
| #define BUCK2_RAMPRATE_MASK 0xC0 |
| #define BUCK2_RAMPRATE_10P00MV 0x0 |
| #define BUCK2_RAMPRATE_5P00MV 0x1 |
| #define BUCK2_RAMPRATE_2P50MV 0x2 |
| #define BUCK2_RAMPRATE_1P25MV 0x3 |
| #define BUCK2_SEL 0x02 |
| #define BUCK2_EN 0x01 |
| |
| /* BD71837_REG_BUCK3_CTRL bits */ |
| #define BUCK3_RAMPRATE_MASK 0xC0 |
| #define BUCK3_RAMPRATE_10P00MV 0x0 |
| #define BUCK3_RAMPRATE_5P00MV 0x1 |
| #define BUCK3_RAMPRATE_2P50MV 0x2 |
| #define BUCK3_RAMPRATE_1P25MV 0x3 |
| #define BUCK3_SEL 0x02 |
| #define BUCK3_EN 0x01 |
| |
| /* BD71837_REG_BUCK4_CTRL bits */ |
| #define BUCK4_RAMPRATE_MASK 0xC0 |
| #define BUCK4_RAMPRATE_10P00MV 0x0 |
| #define BUCK4_RAMPRATE_5P00MV 0x1 |
| #define BUCK4_RAMPRATE_2P50MV 0x2 |
| #define BUCK4_RAMPRATE_1P25MV 0x3 |
| #define BUCK4_SEL 0x02 |
| #define BUCK4_EN 0x01 |
| |
| /* BD71837_REG_BUCK5_CTRL bits */ |
| #define BUCK5_SEL 0x02 |
| #define BUCK5_EN 0x01 |
| |
| /* BD71837_REG_BUCK6_CTRL bits */ |
| #define BUCK6_SEL 0x02 |
| #define BUCK6_EN 0x01 |
| |
| /* BD71837_REG_BUCK7_CTRL bits */ |
| #define BUCK7_SEL 0x02 |
| #define BUCK7_EN 0x01 |
| |
| /* BD71837_REG_BUCK8_CTRL bits */ |
| #define BUCK8_SEL 0x02 |
| #define BUCK8_EN 0x01 |
| |
| /* BD71837_REG_BUCK1_VOLT_RUN bits */ |
| #define BUCK1_RUN_MASK 0x3F |
| #define BUCK1_RUN_DEFAULT 0x14 |
| |
| /* BD71837_REG_BUCK1_VOLT_SUSP bits */ |
| #define BUCK1_SUSP_MASK 0x3F |
| #define BUCK1_SUSP_DEFAULT 0x14 |
| |
| /* BD71837_REG_BUCK1_VOLT_IDLE bits */ |
| #define BUCK1_IDLE_MASK 0x3F |
| #define BUCK1_IDLE_DEFAULT 0x14 |
| |
| /* BD71837_REG_BUCK2_VOLT_RUN bits */ |
| #define BUCK2_RUN_MASK 0x3F |
| #define BUCK2_RUN_DEFAULT 0x1E |
| |
| /* BD71837_REG_BUCK2_VOLT_IDLE bits */ |
| #define BUCK2_IDLE_MASK 0x3F |
| #define BUCK2_IDLE_DEFAULT 0x14 |
| |
| /* BD71837_REG_BUCK3_VOLT_RUN bits */ |
| #define BUCK3_RUN_MASK 0x3F |
| #define BUCK3_RUN_DEFAULT 0x1E |
| |
| /* BD71837_REG_BUCK4_VOLT_RUN bits */ |
| #define BUCK4_RUN_MASK 0x3F |
| #define BUCK4_RUN_DEFAULT 0x1E |
| |
| /* BD71837_REG_BUCK5_VOLT bits */ |
| #define BUCK5_MASK 0x07 |
| #define BUCK5_DEFAULT 0x02 |
| |
| /* BD71837_REG_BUCK6_VOLT bits */ |
| #define BUCK6_MASK 0x03 |
| #define BUCK6_DEFAULT 0x03 |
| |
| /* BD71837_REG_BUCK7_VOLT bits */ |
| #define BUCK7_MASK 0x07 |
| #define BUCK7_DEFAULT 0x03 |
| |
| /* BD71837_REG_BUCK8_VOLT bits */ |
| #define BUCK8_MASK 0x3F |
| #define BUCK8_DEFAULT 0x1E |
| |
| /* BD71837_REG_IRQ bits */ |
| #define IRQ_SWRST 0x40 |
| #define IRQ_PWRON_S 0x20 |
| #define IRQ_PWRON_L 0x10 |
| #define IRQ_PWRON 0x08 |
| #define IRQ_WDOG 0x04 |
| #define IRQ_ON_REQ 0x02 |
| #define IRQ_STBY_REQ 0x01 |
| |
| /* BD71837_REG_OUT32K bits */ |
| #define OUT32K_EN 0x01 |
| |
| /* BD71837 interrupt masks */ |
| enum { |
| BD71837_INT_MASK = 0x7F, |
| }; |
| /* BD71837 interrupt irqs */ |
| enum { |
| BD71837_IRQ = 0x0, |
| }; |
| |
| /* BD71837_REG_LDO1_VOLT bits */ |
| #define LDO1_SEL 0x80 |
| #define LDO1_EN 0x40 |
| #define LDO1_MASK 0x03 |
| |
| /* BD71837_REG_LDO2_VOLT bits */ |
| #define LDO2_SEL 0x80 |
| #define LDO2_EN 0x40 |
| |
| /* BD71837_REG_LDO3_VOLT bits */ |
| #define LDO3_SEL 0x80 |
| #define LDO3_EN 0x40 |
| #define LDO3_MASK 0x0F |
| |
| /* BD71837_REG_LDO4_VOLT bits */ |
| #define LDO4_SEL 0x80 |
| #define LDO4_EN 0x40 |
| #define LDO4_MASK 0x0F |
| |
| /* BD71837_REG_LDO5_VOLT bits */ |
| #define LDO5_EN 0x40 |
| #define LDO5_MASK 0x0F |
| |
| /* BD71837_REG_LDO6_VOLT bits */ |
| #define LDO6_EN 0x40 |
| #define LDO6_MASK 0x0F |
| |
| /* BD71837_REG_LDO7_VOLT bits */ |
| #define LDO7_EN 0x40 |
| #define LDO7_MASK 0x0F |
| |
| /** @brief charge state enumuration */ |
| enum CHG_STATE { |
| CHG_STATE_SUSPEND = 0x0, /**< suspend state */ |
| CHG_STATE_TRICKLE_CHARGE, /**< trickle charge state */ |
| CHG_STATE_PRE_CHARGE, /**< precharge state */ |
| CHG_STATE_FAST_CHARGE, /**< fast charge state */ |
| CHG_STATE_TOP_OFF, /**< top off state */ |
| CHG_STATE_DONE, /**< charge complete */ |
| }; |
| |
| struct bd71837; |
| |
| /** |
| * @brief Board platform data may be used to initialize regulators. |
| */ |
| |
| struct bd71837_board { |
| struct regulator_init_data *init_data[BD71837_REGULATOR_CNT]; |
| /**< regulator initialize data */ |
| int gpio_intr; /**< gpio connected to bd71837 INTB */ |
| int irq_base; /**< bd71837 sub irqs base # */ |
| }; |
| |
| /** |
| * @brief bd71837 sub-driver chip access routines |
| */ |
| |
| struct bd71837 { |
| struct device *dev; |
| struct i2c_client *i2c_client; |
| struct regmap *regmap; |
| struct mutex io_mutex; |
| unsigned int id; |
| |
| /* IRQ Handling */ |
| int chip_irq; /**< bd71837 irq to host cpu */ |
| struct regmap_irq_chip_data *irq_data; |
| |
| /* Client devices */ |
| struct bd71837_pmic *pmic; /**< client device regulator */ |
| struct bd71837_power *power; /**< client device battery */ |
| |
| struct bd71837_board *of_plat_data; |
| /**< Device node parsed board data */ |
| }; |
| |
| static inline int bd71837_chip_id(struct bd71837 *bd71837) |
| { |
| return bd71837->id; |
| } |
| |
| |
| /** |
| * @brief bd71837_reg_read |
| * read single register's value of bd71837 |
| * @param bd71837 device to read |
| * @param reg register address |
| * @return register value if success |
| * error number if fail |
| */ |
| static inline int bd71837_reg_read(struct bd71837 *bd71837, u8 reg) |
| { |
| int r, val; |
| |
| r = regmap_read(bd71837->regmap, reg, &val); |
| if (r < 0) { |
| return r; |
| } |
| return val; |
| } |
| |
| /** |
| * @brief bd71837_reg_write |
| * write single register of bd71837 |
| * @param bd71837 device to write |
| * @param reg register address |
| * @param val value to write |
| * @retval 0 if success |
| * @retval negative error number if fail |
| */ |
| |
| static inline int bd71837_reg_write(struct bd71837 *bd71837, u8 reg, |
| unsigned int val) |
| { |
| return regmap_write(bd71837->regmap, reg, val); |
| } |
| |
| /** |
| * @brief bd71837_set_bits |
| * set bits in one register of bd71837 |
| * @param bd71837 device to read |
| * @param reg register address |
| * @param mask mask bits |
| * @retval 0 if success |
| * @retval negative error number if fail |
| */ |
| static inline int bd71837_set_bits(struct bd71837 *bd71837, u8 reg, u8 mask) |
| { |
| return regmap_update_bits(bd71837->regmap, reg, mask, mask); |
| } |
| |
| /** |
| * @brief bd71837_clear_bits |
| * clear bits in one register of bd71837 |
| * @param bd71837 device to read |
| * @param reg register address |
| * @param mask mask bits |
| * @retval 0 if success |
| * @retval negative error number if fail |
| */ |
| |
| static inline int bd71837_clear_bits(struct bd71837 *bd71837, u8 reg, |
| u8 mask) |
| { |
| return regmap_update_bits(bd71837->regmap, reg, mask, 0); |
| } |
| |
| /** |
| * @brief bd71837_update_bits |
| * update bits in one register of bd71837 |
| * @param bd71837 device to read |
| * @param reg register address |
| * @param mask mask bits |
| * @param val value to update |
| * @retval 0 if success |
| * @retval negative error number if fail |
| */ |
| |
| static inline int bd71837_update_bits(struct bd71837 *bd71837, u8 reg, |
| u8 mask, u8 val) |
| { |
| return regmap_update_bits(bd71837->regmap, reg, mask, val); |
| } |
| |
| /** |
| * @brief bd71837 platform data type |
| */ |
| struct bd71837_gpo_plat_data { |
| u32 drv; ///< gpo output drv |
| int gpio_base; ///< base gpio number in system |
| }; |
| |
| u8 ext_bd71837_reg_read8(u8 reg); |
| int ext_bd71837_reg_write8(int reg, u8 val); |
| |
| #define BD71837_DBG0 0x0001 |
| #define BD71837_DBG1 0x0002 |
| #define BD71837_DBG2 0x0004 |
| #define BD71837_DBG3 0x0008 |
| |
| extern unsigned int bd71837_debug_mask; |
| #define bd71837_debug(debug, fmt, arg...) do { if (debug & bd71837_debug_mask) printk("BD71837:" fmt, ##arg); } while (0) |
| |
| #endif /* __LINUX_MFD_BD71837_H */ |