5069185fc1
Add support for the BQ25980, BQ25975 and BQ25960 family of flash chargers. Signed-off-by: Dan Murphy <dmurphy@ti.com> Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
179 lines
5.5 KiB
C
179 lines
5.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/* Copyright (C) 2020 Texas Instruments Incorporated - http://www.ti.com/ */
|
|
|
|
#ifndef BQ25980_CHARGER_H
|
|
#define BQ25980_CHARGER_H
|
|
|
|
#define BQ25980_MANUFACTURER "Texas Instruments"
|
|
|
|
#define BQ25980_BATOVP 0x0
|
|
#define BQ25980_BATOVP_ALM 0x1
|
|
#define BQ25980_BATOCP 0x2
|
|
#define BQ25980_BATOCP_ALM 0x3
|
|
#define BQ25980_BATUCP_ALM 0x4
|
|
#define BQ25980_CHRGR_CTRL_1 0x5
|
|
#define BQ25980_BUSOVP 0x6
|
|
#define BQ25980_BUSOVP_ALM 0x7
|
|
#define BQ25980_BUSOCP 0x8
|
|
#define BQ25980_BUSOCP_ALM 0x9
|
|
#define BQ25980_TEMP_CONTROL 0xA
|
|
#define BQ25980_TDIE_ALM 0xB
|
|
#define BQ25980_TSBUS_FLT 0xC
|
|
#define BQ25980_TSBAT_FLG 0xD
|
|
#define BQ25980_VAC_CONTROL 0xE
|
|
#define BQ25980_CHRGR_CTRL_2 0xF
|
|
#define BQ25980_CHRGR_CTRL_3 0x10
|
|
#define BQ25980_CHRGR_CTRL_4 0x11
|
|
#define BQ25980_CHRGR_CTRL_5 0x12
|
|
#define BQ25980_STAT1 0x13
|
|
#define BQ25980_STAT2 0x14
|
|
#define BQ25980_STAT3 0x15
|
|
#define BQ25980_STAT4 0x16
|
|
#define BQ25980_STAT5 0x17
|
|
#define BQ25980_FLAG1 0x18
|
|
#define BQ25980_FLAG2 0x19
|
|
#define BQ25980_FLAG3 0x1A
|
|
#define BQ25980_FLAG4 0x1B
|
|
#define BQ25980_FLAG5 0x1C
|
|
#define BQ25980_MASK1 0x1D
|
|
#define BQ25980_MASK2 0x1E
|
|
#define BQ25980_MASK3 0x1F
|
|
#define BQ25980_MASK4 0x20
|
|
#define BQ25980_MASK5 0x21
|
|
#define BQ25980_DEVICE_INFO 0x22
|
|
#define BQ25980_ADC_CONTROL1 0x23
|
|
#define BQ25980_ADC_CONTROL2 0x24
|
|
#define BQ25980_IBUS_ADC_MSB 0x25
|
|
#define BQ25980_IBUS_ADC_LSB 0x26
|
|
#define BQ25980_VBUS_ADC_MSB 0x27
|
|
#define BQ25980_VBUS_ADC_LSB 0x28
|
|
#define BQ25980_VAC1_ADC_MSB 0x29
|
|
#define BQ25980_VAC1_ADC_LSB 0x2A
|
|
#define BQ25980_VAC2_ADC_MSB 0x2B
|
|
#define BQ25980_VAC2_ADC_LSB 0x2C
|
|
#define BQ25980_VOUT_ADC_MSB 0x2D
|
|
#define BQ25980_VOUT_ADC_LSB 0x2E
|
|
#define BQ25980_VBAT_ADC_MSB 0x2F
|
|
#define BQ25980_VBAT_ADC_LSB 0x30
|
|
#define BQ25980_IBAT_ADC_MSB 0x31
|
|
#define BQ25980_IBAT_ADC_LSB 0x32
|
|
#define BQ25980_TSBUS_ADC_MSB 0x33
|
|
#define BQ25980_TSBUS_ADC_LSB 0x34
|
|
#define BQ25980_TSBAT_ADC_MSB 0x35
|
|
#define BQ25980_TSBAT_ADC_LSB 0x36
|
|
#define BQ25980_TDIE_ADC_MSB 0x37
|
|
#define BQ25980_TDIE_ADC_LSB 0x38
|
|
#define BQ25980_DEGLITCH_TIME 0x39
|
|
#define BQ25980_CHRGR_CTRL_6 0x3A
|
|
|
|
#define BQ25980_BUSOCP_STEP_uA 250000
|
|
#define BQ25980_BUSOCP_OFFSET_uA 1000000
|
|
|
|
#define BQ25980_BUSOCP_DFLT_uA 4250000
|
|
#define BQ25975_BUSOCP_DFLT_uA 4250000
|
|
#define BQ25960_BUSOCP_DFLT_uA 3250000
|
|
|
|
#define BQ25980_BUSOCP_MIN_uA 1000000
|
|
|
|
#define BQ25980_BUSOCP_SC_MAX_uA 5750000
|
|
#define BQ25975_BUSOCP_SC_MAX_uA 5750000
|
|
#define BQ25960_BUSOCP_SC_MAX_uA 3750000
|
|
|
|
#define BQ25980_BUSOCP_BYP_MAX_uA 8500000
|
|
#define BQ25975_BUSOCP_BYP_MAX_uA 8500000
|
|
#define BQ25960_BUSOCP_BYP_MAX_uA 5750000
|
|
|
|
#define BQ25980_BUSOVP_SC_STEP_uV 100000
|
|
#define BQ25975_BUSOVP_SC_STEP_uV 50000
|
|
#define BQ25960_BUSOVP_SC_STEP_uV 50000
|
|
#define BQ25980_BUSOVP_SC_OFFSET_uV 14000000
|
|
#define BQ25975_BUSOVP_SC_OFFSET_uV 7000000
|
|
#define BQ25960_BUSOVP_SC_OFFSET_uV 7000000
|
|
|
|
#define BQ25980_BUSOVP_BYP_STEP_uV 50000
|
|
#define BQ25975_BUSOVP_BYP_STEP_uV 25000
|
|
#define BQ25960_BUSOVP_BYP_STEP_uV 25000
|
|
#define BQ25980_BUSOVP_BYP_OFFSET_uV 7000000
|
|
#define BQ25975_BUSOVP_BYP_OFFSET_uV 3500000
|
|
#define BQ25960_BUSOVP_BYP_OFFSET_uV 3500000
|
|
|
|
#define BQ25980_BUSOVP_DFLT_uV 17800000
|
|
#define BQ25980_BUSOVP_BYPASS_DFLT_uV 8900000
|
|
#define BQ25975_BUSOVP_DFLT_uV 8900000
|
|
#define BQ25975_BUSOVP_BYPASS_DFLT_uV 4450000
|
|
#define BQ25960_BUSOVP_DFLT_uV 8900000
|
|
|
|
#define BQ25980_BUSOVP_SC_MIN_uV 14000000
|
|
#define BQ25975_BUSOVP_SC_MIN_uV 7000000
|
|
#define BQ25960_BUSOVP_SC_MIN_uV 7000000
|
|
#define BQ25980_BUSOVP_BYP_MIN_uV 7000000
|
|
#define BQ25975_BUSOVP_BYP_MIN_uV 3500000
|
|
#define BQ25960_BUSOVP_BYP_MIN_uV 3500000
|
|
|
|
#define BQ25980_BUSOVP_SC_MAX_uV 22000000
|
|
#define BQ25975_BUSOVP_SC_MAX_uV 12750000
|
|
#define BQ25960_BUSOVP_SC_MAX_uV 12750000
|
|
|
|
#define BQ25980_BUSOVP_BYP_MAX_uV 12750000
|
|
#define BQ25975_BUSOVP_BYP_MAX_uV 6500000
|
|
#define BQ25960_BUSOVP_BYP_MAX_uV 6500000
|
|
|
|
#define BQ25980_BATOVP_STEP_uV 20000
|
|
#define BQ25975_BATOVP_STEP_uV 10000
|
|
#define BQ25960_BATOVP_STEP_uV 10000
|
|
|
|
#define BQ25980_BATOVP_OFFSET_uV 7000000
|
|
#define BQ25975_BATOVP_OFFSET_uV 3500000
|
|
#define BQ25960_BATOVP_OFFSET_uV 3500000
|
|
|
|
#define BQ25980_BATOVP_DFLT_uV 14000000
|
|
#define BQ25975_BATOVP_DFLT_uV 8900000
|
|
#define BQ25960_BATOVP_DFLT_uV 8900000
|
|
|
|
#define BQ25980_BATOVP_MIN_uV 7000000
|
|
#define BQ25975_BATOVP_MIN_uV 3500000
|
|
#define BQ25960_BATOVP_MIN_uV 3500000
|
|
|
|
#define BQ25980_BATOVP_MAX_uV 9540000
|
|
#define BQ25975_BATOVP_MAX_uV 4770000
|
|
#define BQ25960_BATOVP_MAX_uV 4770000
|
|
|
|
#define BQ25980_BATOCP_STEP_uA 100000
|
|
|
|
#define BQ25980_BATOCP_MASK GENMASK(6, 0)
|
|
|
|
#define BQ25980_BATOCP_DFLT_uA 8100000
|
|
#define BQ25960_BATOCP_DFLT_uA 6100000
|
|
|
|
#define BQ25980_BATOCP_MIN_uA 2000000
|
|
|
|
#define BQ25980_BATOCP_MAX_uA 11000000
|
|
#define BQ25975_BATOCP_MAX_uA 11000000
|
|
#define BQ25960_BATOCP_MAX_uA 7000000
|
|
|
|
#define BQ25980_ENABLE_HIZ 0xff
|
|
#define BQ25980_DISABLE_HIZ 0x0
|
|
#define BQ25980_EN_BYPASS BIT(3)
|
|
#define BQ25980_STAT1_OVP_MASK (BIT(6) | BIT(5) | BIT(0))
|
|
#define BQ25980_STAT3_OVP_MASK (BIT(7) | BIT(6))
|
|
#define BQ25980_STAT1_OCP_MASK BIT(3)
|
|
#define BQ25980_STAT2_OCP_MASK (BIT(6) | BIT(1))
|
|
#define BQ25980_STAT4_TFLT_MASK GENMASK(5, 1)
|
|
#define BQ25980_WD_STAT BIT(0)
|
|
#define BQ25980_PRESENT_MASK GENMASK(4, 2)
|
|
#define BQ25980_CHG_EN BIT(4)
|
|
#define BQ25980_EN_HIZ BIT(6)
|
|
#define BQ25980_ADC_EN BIT(7)
|
|
|
|
#define BQ25980_ADC_VOLT_STEP_uV 1000
|
|
#define BQ25980_ADC_CURR_STEP_uA 1000
|
|
#define BQ25980_ADC_POLARITY_BIT BIT(7)
|
|
|
|
#define BQ25980_WATCHDOG_MASK GENMASK(4, 3)
|
|
#define BQ25980_WATCHDOG_DIS BIT(2)
|
|
#define BQ25980_WATCHDOG_MAX 300000
|
|
#define BQ25980_WATCHDOG_MIN 0
|
|
#define BQ25980_NUM_WD_VAL 4
|
|
|
|
#endif /* BQ25980_CHARGER_H */
|