1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Driver for the TI bq24190 battery charger. 4 * 5 * Author: Mark A. Greer <mgreer@animalcreek.com> 6 */ 7 8 #include <linux/mod_devicetable.h> 9 #include <linux/module.h> 10 #include <linux/interrupt.h> 11 #include <linux/delay.h> 12 #include <linux/pm_runtime.h> 13 #include <linux/power_supply.h> 14 #include <linux/power/bq24190_charger.h> 15 #include <linux/regulator/driver.h> 16 #include <linux/regulator/machine.h> 17 #include <linux/workqueue.h> 18 #include <linux/i2c.h> 19 #include <linux/extcon-provider.h> 20 21 #define BQ24190_MANUFACTURER "Texas Instruments" 22 23 #define BQ24190_REG_ISC 0x00 /* Input Source Control */ 24 #define BQ24190_REG_ISC_EN_HIZ_MASK BIT(7) 25 #define BQ24190_REG_ISC_EN_HIZ_SHIFT 7 26 #define BQ24190_REG_ISC_VINDPM_MASK (BIT(6) | BIT(5) | BIT(4) | \ 27 BIT(3)) 28 #define BQ24190_REG_ISC_VINDPM_SHIFT 3 29 #define BQ24190_REG_ISC_IINLIM_MASK (BIT(2) | BIT(1) | BIT(0)) 30 #define BQ24190_REG_ISC_IINLIM_SHIFT 0 31 32 #define BQ24190_REG_POC 0x01 /* Power-On Configuration */ 33 #define BQ24190_REG_POC_RESET_MASK BIT(7) 34 #define BQ24190_REG_POC_RESET_SHIFT 7 35 #define BQ24190_REG_POC_WDT_RESET_MASK BIT(6) 36 #define BQ24190_REG_POC_WDT_RESET_SHIFT 6 37 #define BQ24190_REG_POC_CHG_CONFIG_MASK (BIT(5) | BIT(4)) 38 #define BQ24190_REG_POC_CHG_CONFIG_SHIFT 4 39 #define BQ24190_REG_POC_CHG_CONFIG_DISABLE 0x0 40 #define BQ24190_REG_POC_CHG_CONFIG_CHARGE 0x1 41 #define BQ24190_REG_POC_CHG_CONFIG_OTG 0x2 42 #define BQ24190_REG_POC_CHG_CONFIG_OTG_ALT 0x3 43 #define BQ24296_REG_POC_OTG_CONFIG_MASK BIT(5) 44 #define BQ24296_REG_POC_OTG_CONFIG_SHIFT 5 45 #define BQ24296_REG_POC_CHG_CONFIG_MASK BIT(4) 46 #define BQ24296_REG_POC_CHG_CONFIG_SHIFT 4 47 #define BQ24296_REG_POC_OTG_CONFIG_DISABLE 0x0 48 #define BQ24296_REG_POC_OTG_CONFIG_OTG 0x1 49 #define BQ24190_REG_POC_SYS_MIN_MASK (BIT(3) | BIT(2) | BIT(1)) 50 #define BQ24190_REG_POC_SYS_MIN_SHIFT 1 51 #define BQ24190_REG_POC_SYS_MIN_MIN 3000 52 #define BQ24190_REG_POC_SYS_MIN_MAX 3700 53 #define BQ24190_REG_POC_BOOST_LIM_MASK BIT(0) 54 #define BQ24190_REG_POC_BOOST_LIM_SHIFT 0 55 56 #define BQ24190_REG_CCC 0x02 /* Charge Current Control */ 57 #define BQ24190_REG_CCC_ICHG_MASK (BIT(7) | BIT(6) | BIT(5) | \ 58 BIT(4) | BIT(3) | BIT(2)) 59 #define BQ24190_REG_CCC_ICHG_SHIFT 2 60 #define BQ24190_REG_CCC_FORCE_20PCT_MASK BIT(0) 61 #define BQ24190_REG_CCC_FORCE_20PCT_SHIFT 0 62 63 #define BQ24190_REG_PCTCC 0x03 /* Pre-charge/Termination Current Cntl */ 64 #define BQ24190_REG_PCTCC_IPRECHG_MASK (BIT(7) | BIT(6) | BIT(5) | \ 65 BIT(4)) 66 #define BQ24190_REG_PCTCC_IPRECHG_SHIFT 4 67 #define BQ24190_REG_PCTCC_IPRECHG_MIN 128 68 #define BQ24190_REG_PCTCC_IPRECHG_MAX 2048 69 #define BQ24190_REG_PCTCC_ITERM_MASK (BIT(3) | BIT(2) | BIT(1) | \ 70 BIT(0)) 71 #define BQ24190_REG_PCTCC_ITERM_SHIFT 0 72 #define BQ24190_REG_PCTCC_ITERM_MIN 128 73 #define BQ24190_REG_PCTCC_ITERM_MAX 2048 74 75 #define BQ24190_REG_CVC 0x04 /* Charge Voltage Control */ 76 #define BQ24190_REG_CVC_VREG_MASK (BIT(7) | BIT(6) | BIT(5) | \ 77 BIT(4) | BIT(3) | BIT(2)) 78 #define BQ24190_REG_CVC_VREG_SHIFT 2 79 #define BQ24190_REG_CVC_BATLOWV_MASK BIT(1) 80 #define BQ24190_REG_CVC_BATLOWV_SHIFT 1 81 #define BQ24190_REG_CVC_VRECHG_MASK BIT(0) 82 #define BQ24190_REG_CVC_VRECHG_SHIFT 0 83 84 #define BQ24190_REG_CTTC 0x05 /* Charge Term/Timer Control */ 85 #define BQ24190_REG_CTTC_EN_TERM_MASK BIT(7) 86 #define BQ24190_REG_CTTC_EN_TERM_SHIFT 7 87 #define BQ24190_REG_CTTC_TERM_STAT_MASK BIT(6) 88 #define BQ24190_REG_CTTC_TERM_STAT_SHIFT 6 89 #define BQ24190_REG_CTTC_WATCHDOG_MASK (BIT(5) | BIT(4)) 90 #define BQ24190_REG_CTTC_WATCHDOG_SHIFT 4 91 #define BQ24190_REG_CTTC_EN_TIMER_MASK BIT(3) 92 #define BQ24190_REG_CTTC_EN_TIMER_SHIFT 3 93 #define BQ24190_REG_CTTC_CHG_TIMER_MASK (BIT(2) | BIT(1)) 94 #define BQ24190_REG_CTTC_CHG_TIMER_SHIFT 1 95 #define BQ24190_REG_CTTC_JEITA_ISET_MASK BIT(0) 96 #define BQ24190_REG_CTTC_JEITA_ISET_SHIFT 0 97 98 #define BQ24190_REG_ICTRC 0x06 /* IR Comp/Thermal Regulation Control */ 99 #define BQ24190_REG_ICTRC_BAT_COMP_MASK (BIT(7) | BIT(6) | BIT(5)) 100 #define BQ24190_REG_ICTRC_BAT_COMP_SHIFT 5 101 #define BQ24190_REG_ICTRC_VCLAMP_MASK (BIT(4) | BIT(3) | BIT(2)) 102 #define BQ24190_REG_ICTRC_VCLAMP_SHIFT 2 103 #define BQ24190_REG_ICTRC_TREG_MASK (BIT(1) | BIT(0)) 104 #define BQ24190_REG_ICTRC_TREG_SHIFT 0 105 106 #define BQ24190_REG_MOC 0x07 /* Misc. Operation Control */ 107 #define BQ24190_REG_MOC_DPDM_EN_MASK BIT(7) 108 #define BQ24190_REG_MOC_DPDM_EN_SHIFT 7 109 #define BQ24190_REG_MOC_TMR2X_EN_MASK BIT(6) 110 #define BQ24190_REG_MOC_TMR2X_EN_SHIFT 6 111 #define BQ24190_REG_MOC_BATFET_DISABLE_MASK BIT(5) 112 #define BQ24190_REG_MOC_BATFET_DISABLE_SHIFT 5 113 #define BQ24190_REG_MOC_JEITA_VSET_MASK BIT(4) 114 #define BQ24190_REG_MOC_JEITA_VSET_SHIFT 4 115 #define BQ24190_REG_MOC_INT_MASK_MASK (BIT(1) | BIT(0)) 116 #define BQ24190_REG_MOC_INT_MASK_SHIFT 0 117 118 #define BQ24190_REG_SS 0x08 /* System Status */ 119 #define BQ24190_REG_SS_VBUS_STAT_MASK (BIT(7) | BIT(6)) 120 #define BQ24190_REG_SS_VBUS_STAT_SHIFT 6 121 #define BQ24190_REG_SS_CHRG_STAT_MASK (BIT(5) | BIT(4)) 122 #define BQ24190_REG_SS_CHRG_STAT_SHIFT 4 123 #define BQ24190_REG_SS_DPM_STAT_MASK BIT(3) 124 #define BQ24190_REG_SS_DPM_STAT_SHIFT 3 125 #define BQ24190_REG_SS_PG_STAT_MASK BIT(2) 126 #define BQ24190_REG_SS_PG_STAT_SHIFT 2 127 #define BQ24190_REG_SS_THERM_STAT_MASK BIT(1) 128 #define BQ24190_REG_SS_THERM_STAT_SHIFT 1 129 #define BQ24190_REG_SS_VSYS_STAT_MASK BIT(0) 130 #define BQ24190_REG_SS_VSYS_STAT_SHIFT 0 131 132 #define BQ24190_REG_F 0x09 /* Fault */ 133 #define BQ24190_REG_F_WATCHDOG_FAULT_MASK BIT(7) 134 #define BQ24190_REG_F_WATCHDOG_FAULT_SHIFT 7 135 #define BQ24190_REG_F_BOOST_FAULT_MASK BIT(6) 136 #define BQ24190_REG_F_BOOST_FAULT_SHIFT 6 137 #define BQ24190_REG_F_CHRG_FAULT_MASK (BIT(5) | BIT(4)) 138 #define BQ24190_REG_F_CHRG_FAULT_SHIFT 4 139 #define BQ24190_REG_F_BAT_FAULT_MASK BIT(3) 140 #define BQ24190_REG_F_BAT_FAULT_SHIFT 3 141 #define BQ24190_REG_F_NTC_FAULT_MASK (BIT(2) | BIT(1) | BIT(0)) 142 #define BQ24190_REG_F_NTC_FAULT_SHIFT 0 143 #define BQ24296_REG_F_NTC_FAULT_MASK (BIT(1) | BIT(0)) 144 #define BQ24296_REG_F_NTC_FAULT_SHIFT 0 145 146 #define BQ24190_REG_VPRS 0x0A /* Vendor/Part/Revision Status */ 147 #define BQ24190_REG_VPRS_PN_MASK (BIT(5) | BIT(4) | BIT(3)) 148 #define BQ24190_REG_VPRS_PN_SHIFT 3 149 #define BQ24190_REG_VPRS_PN_24190 0x4 150 #define BQ24190_REG_VPRS_PN_24192 0x5 /* Also 24193, 24196 */ 151 #define BQ24190_REG_VPRS_PN_24192I 0x3 152 #define BQ24296_REG_VPRS_PN_MASK (BIT(7) | BIT(6) | BIT(5)) 153 #define BQ24296_REG_VPRS_PN_SHIFT 5 154 #define BQ24296_REG_VPRS_PN_24296 0x1 155 #define BQ24190_REG_VPRS_TS_PROFILE_MASK BIT(2) 156 #define BQ24190_REG_VPRS_TS_PROFILE_SHIFT 2 157 #define BQ24190_REG_VPRS_DEV_REG_MASK (BIT(1) | BIT(0)) 158 #define BQ24190_REG_VPRS_DEV_REG_SHIFT 0 159 160 /* 161 * The tables below provide a 2-way mapping for the value that goes in 162 * the register field and the real-world value that it represents. 163 * The index of the array is the value that goes in the register; the 164 * number at that index in the array is the real-world value that it 165 * represents. 166 */ 167 168 /* REG00[2:0] (IINLIM) in uAh */ 169 static const int bq24190_isc_iinlim_values[] = { 170 100000, 150000, 500000, 900000, 1200000, 1500000, 2000000, 3000000 171 }; 172 173 /* REG02[7:2] (ICHG) in uAh */ 174 static const int bq24190_ccc_ichg_values[] = { 175 512000, 576000, 640000, 704000, 768000, 832000, 896000, 960000, 176 1024000, 1088000, 1152000, 1216000, 1280000, 1344000, 1408000, 1472000, 177 1536000, 1600000, 1664000, 1728000, 1792000, 1856000, 1920000, 1984000, 178 2048000, 2112000, 2176000, 2240000, 2304000, 2368000, 2432000, 2496000, 179 2560000, 2624000, 2688000, 2752000, 2816000, 2880000, 2944000, 3008000, 180 3072000, 3136000, 3200000, 3264000, 3328000, 3392000, 3456000, 3520000, 181 3584000, 3648000, 3712000, 3776000, 3840000, 3904000, 3968000, 4032000, 182 4096000, 4160000, 4224000, 4288000, 4352000, 4416000, 4480000, 4544000 183 }; 184 185 /* ICHG higher than 3008mA is not supported in BQ24296 */ 186 #define BQ24296_CCC_ICHG_VALUES_LEN 40 187 188 /* REG04[7:2] (VREG) in uV */ 189 static const int bq24190_cvc_vreg_values[] = { 190 3504000, 3520000, 3536000, 3552000, 3568000, 3584000, 3600000, 3616000, 191 3632000, 3648000, 3664000, 3680000, 3696000, 3712000, 3728000, 3744000, 192 3760000, 3776000, 3792000, 3808000, 3824000, 3840000, 3856000, 3872000, 193 3888000, 3904000, 3920000, 3936000, 3952000, 3968000, 3984000, 4000000, 194 4016000, 4032000, 4048000, 4064000, 4080000, 4096000, 4112000, 4128000, 195 4144000, 4160000, 4176000, 4192000, 4208000, 4224000, 4240000, 4256000, 196 4272000, 4288000, 4304000, 4320000, 4336000, 4352000, 4368000, 4384000, 197 4400000 198 }; 199 200 /* REG06[1:0] (TREG) in tenths of degrees Celsius */ 201 static const int bq24190_ictrc_treg_values[] = { 202 600, 800, 1000, 1200 203 }; 204 205 enum bq24190_chip { 206 BQ24190, 207 BQ24192, 208 BQ24192i, 209 BQ24196, 210 BQ24296, 211 }; 212 213 /* 214 * The FAULT register is latched by the bq24190 (except for NTC_FAULT) 215 * so the first read after a fault returns the latched value and subsequent 216 * reads return the current value. In order to return the fault status 217 * to the user, have the interrupt handler save the reg's value and retrieve 218 * it in the appropriate health/status routine. 219 */ 220 struct bq24190_dev_info { 221 struct i2c_client *client; 222 struct device *dev; 223 struct extcon_dev *edev; 224 struct power_supply *charger; 225 struct power_supply *battery; 226 struct delayed_work input_current_limit_work; 227 char model_name[I2C_NAME_SIZE]; 228 bool initialized; 229 bool irq_event; 230 bool otg_vbus_enabled; 231 int charge_type; 232 u16 sys_min; 233 u16 iprechg; 234 u16 iterm; 235 u32 ichg; 236 u32 ichg_max; 237 u32 vreg; 238 u32 vreg_max; 239 struct mutex f_reg_lock; 240 u8 f_reg; 241 u8 ss_reg; 242 u8 watchdog; 243 const struct bq24190_chip_info *info; 244 }; 245 246 struct bq24190_chip_info { 247 int ichg_array_size; 248 #ifdef CONFIG_REGULATOR 249 const struct regulator_desc *vbus_desc; 250 #endif 251 int (*check_chip)(struct bq24190_dev_info *bdi); 252 int (*set_chg_config)(struct bq24190_dev_info *bdi, const u8 chg_config); 253 int (*set_otg_vbus)(struct bq24190_dev_info *bdi, bool enable); 254 u8 ntc_fault_mask; 255 int (*get_ntc_status)(const u8 value); 256 }; 257 258 static int bq24190_charger_set_charge_type(struct bq24190_dev_info *bdi, 259 const union power_supply_propval *val); 260 261 static const unsigned int bq24190_usb_extcon_cable[] = { 262 EXTCON_USB, 263 EXTCON_NONE, 264 }; 265 266 267 /* 268 * Return the index in 'tbl' of greatest value that is less than or equal to 269 * 'val'. The index range returned is 0 to 'tbl_size' - 1. Assumes that 270 * the values in 'tbl' are sorted from smallest to largest and 'tbl_size' 271 * is less than 2^8. 272 */ 273 static u8 bq24190_find_idx(const int tbl[], int tbl_size, int v) 274 { 275 int i; 276 277 for (i = 1; i < tbl_size; i++) 278 if (v < tbl[i]) 279 break; 280 281 return i - 1; 282 } 283 284 /* Basic driver I/O routines */ 285 286 static int bq24190_read(struct bq24190_dev_info *bdi, u8 reg, u8 *data) 287 { 288 int ret; 289 290 ret = i2c_smbus_read_byte_data(bdi->client, reg); 291 if (ret < 0) 292 return ret; 293 294 *data = ret; 295 return 0; 296 } 297 298 static int bq24190_write(struct bq24190_dev_info *bdi, u8 reg, u8 data) 299 { 300 return i2c_smbus_write_byte_data(bdi->client, reg, data); 301 } 302 303 static int bq24190_read_mask(struct bq24190_dev_info *bdi, u8 reg, 304 u8 mask, u8 shift, u8 *data) 305 { 306 u8 v; 307 int ret; 308 309 ret = bq24190_read(bdi, reg, &v); 310 if (ret < 0) 311 return ret; 312 313 v &= mask; 314 v >>= shift; 315 *data = v; 316 317 return 0; 318 } 319 320 static int bq24190_write_mask(struct bq24190_dev_info *bdi, u8 reg, 321 u8 mask, u8 shift, u8 data) 322 { 323 u8 v; 324 int ret; 325 326 ret = bq24190_read(bdi, reg, &v); 327 if (ret < 0) 328 return ret; 329 330 v &= ~mask; 331 v |= ((data << shift) & mask); 332 333 return bq24190_write(bdi, reg, v); 334 } 335 336 static int bq24190_get_field_val(struct bq24190_dev_info *bdi, 337 u8 reg, u8 mask, u8 shift, 338 const int tbl[], int tbl_size, 339 int *val) 340 { 341 u8 v; 342 int ret; 343 344 ret = bq24190_read_mask(bdi, reg, mask, shift, &v); 345 if (ret < 0) 346 return ret; 347 348 v = (v >= tbl_size) ? (tbl_size - 1) : v; 349 *val = tbl[v]; 350 351 return 0; 352 } 353 354 static int bq24190_set_field_val(struct bq24190_dev_info *bdi, 355 u8 reg, u8 mask, u8 shift, 356 const int tbl[], int tbl_size, 357 int val) 358 { 359 u8 idx; 360 361 idx = bq24190_find_idx(tbl, tbl_size, val); 362 363 return bq24190_write_mask(bdi, reg, mask, shift, idx); 364 } 365 366 #ifdef CONFIG_SYSFS 367 /* 368 * There are a numerous options that are configurable on the bq24190 369 * that go well beyond what the power_supply properties provide access to. 370 * Provide sysfs access to them so they can be examined and possibly modified 371 * on the fly. They will be provided for the charger power_supply object only 372 * and will be prefixed by 'f_' to make them easier to recognize. 373 */ 374 375 #define BQ24190_SYSFS_FIELD(_name, r, f, m, store) \ 376 { \ 377 .attr = __ATTR(f_##_name, m, bq24190_sysfs_show, store), \ 378 .reg = BQ24190_REG_##r, \ 379 .mask = BQ24190_REG_##r##_##f##_MASK, \ 380 .shift = BQ24190_REG_##r##_##f##_SHIFT, \ 381 } 382 383 #define BQ24190_SYSFS_FIELD_RW(_name, r, f) \ 384 BQ24190_SYSFS_FIELD(_name, r, f, S_IWUSR | S_IRUGO, \ 385 bq24190_sysfs_store) 386 387 #define BQ24190_SYSFS_FIELD_RO(_name, r, f) \ 388 BQ24190_SYSFS_FIELD(_name, r, f, S_IRUGO, NULL) 389 390 static ssize_t bq24190_sysfs_show(struct device *dev, 391 struct device_attribute *attr, char *buf); 392 static ssize_t bq24190_sysfs_store(struct device *dev, 393 struct device_attribute *attr, const char *buf, size_t count); 394 395 struct bq24190_sysfs_field_info { 396 struct device_attribute attr; 397 u8 reg; 398 u8 mask; 399 u8 shift; 400 }; 401 402 /* On i386 ptrace-abi.h defines SS that breaks the macro calls below. */ 403 #undef SS 404 405 static struct bq24190_sysfs_field_info bq24190_sysfs_field_tbl[] = { 406 /* sysfs name reg field in reg */ 407 BQ24190_SYSFS_FIELD_RW(en_hiz, ISC, EN_HIZ), 408 BQ24190_SYSFS_FIELD_RW(vindpm, ISC, VINDPM), 409 BQ24190_SYSFS_FIELD_RW(iinlim, ISC, IINLIM), 410 BQ24190_SYSFS_FIELD_RW(chg_config, POC, CHG_CONFIG), 411 BQ24190_SYSFS_FIELD_RW(sys_min, POC, SYS_MIN), 412 BQ24190_SYSFS_FIELD_RW(boost_lim, POC, BOOST_LIM), 413 BQ24190_SYSFS_FIELD_RW(ichg, CCC, ICHG), 414 BQ24190_SYSFS_FIELD_RW(force_20_pct, CCC, FORCE_20PCT), 415 BQ24190_SYSFS_FIELD_RW(iprechg, PCTCC, IPRECHG), 416 BQ24190_SYSFS_FIELD_RW(iterm, PCTCC, ITERM), 417 BQ24190_SYSFS_FIELD_RW(vreg, CVC, VREG), 418 BQ24190_SYSFS_FIELD_RW(batlowv, CVC, BATLOWV), 419 BQ24190_SYSFS_FIELD_RW(vrechg, CVC, VRECHG), 420 BQ24190_SYSFS_FIELD_RW(en_term, CTTC, EN_TERM), 421 BQ24190_SYSFS_FIELD_RW(term_stat, CTTC, TERM_STAT), 422 BQ24190_SYSFS_FIELD_RO(watchdog, CTTC, WATCHDOG), 423 BQ24190_SYSFS_FIELD_RW(en_timer, CTTC, EN_TIMER), 424 BQ24190_SYSFS_FIELD_RW(chg_timer, CTTC, CHG_TIMER), 425 BQ24190_SYSFS_FIELD_RW(jeta_iset, CTTC, JEITA_ISET), 426 BQ24190_SYSFS_FIELD_RW(bat_comp, ICTRC, BAT_COMP), 427 BQ24190_SYSFS_FIELD_RW(vclamp, ICTRC, VCLAMP), 428 BQ24190_SYSFS_FIELD_RW(treg, ICTRC, TREG), 429 BQ24190_SYSFS_FIELD_RW(dpdm_en, MOC, DPDM_EN), 430 BQ24190_SYSFS_FIELD_RW(tmr2x_en, MOC, TMR2X_EN), 431 BQ24190_SYSFS_FIELD_RW(batfet_disable, MOC, BATFET_DISABLE), 432 BQ24190_SYSFS_FIELD_RW(jeita_vset, MOC, JEITA_VSET), 433 BQ24190_SYSFS_FIELD_RO(int_mask, MOC, INT_MASK), 434 BQ24190_SYSFS_FIELD_RO(vbus_stat, SS, VBUS_STAT), 435 BQ24190_SYSFS_FIELD_RO(chrg_stat, SS, CHRG_STAT), 436 BQ24190_SYSFS_FIELD_RO(dpm_stat, SS, DPM_STAT), 437 BQ24190_SYSFS_FIELD_RO(pg_stat, SS, PG_STAT), 438 BQ24190_SYSFS_FIELD_RO(therm_stat, SS, THERM_STAT), 439 BQ24190_SYSFS_FIELD_RO(vsys_stat, SS, VSYS_STAT), 440 BQ24190_SYSFS_FIELD_RO(watchdog_fault, F, WATCHDOG_FAULT), 441 BQ24190_SYSFS_FIELD_RO(boost_fault, F, BOOST_FAULT), 442 BQ24190_SYSFS_FIELD_RO(chrg_fault, F, CHRG_FAULT), 443 BQ24190_SYSFS_FIELD_RO(bat_fault, F, BAT_FAULT), 444 BQ24190_SYSFS_FIELD_RO(ntc_fault, F, NTC_FAULT), 445 BQ24190_SYSFS_FIELD_RO(pn, VPRS, PN), 446 BQ24190_SYSFS_FIELD_RO(ts_profile, VPRS, TS_PROFILE), 447 BQ24190_SYSFS_FIELD_RO(dev_reg, VPRS, DEV_REG), 448 }; 449 450 static struct attribute * 451 bq24190_sysfs_attrs[ARRAY_SIZE(bq24190_sysfs_field_tbl) + 1]; 452 453 ATTRIBUTE_GROUPS(bq24190_sysfs); 454 455 static void bq24190_sysfs_init_attrs(void) 456 { 457 int i, limit = ARRAY_SIZE(bq24190_sysfs_field_tbl); 458 459 for (i = 0; i < limit; i++) 460 bq24190_sysfs_attrs[i] = &bq24190_sysfs_field_tbl[i].attr.attr; 461 462 bq24190_sysfs_attrs[limit] = NULL; /* Has additional entry for this */ 463 } 464 465 static struct bq24190_sysfs_field_info *bq24190_sysfs_field_lookup( 466 const char *name) 467 { 468 int i, limit = ARRAY_SIZE(bq24190_sysfs_field_tbl); 469 470 for (i = 0; i < limit; i++) 471 if (!strcmp(name, bq24190_sysfs_field_tbl[i].attr.attr.name)) 472 break; 473 474 if (i >= limit) 475 return NULL; 476 477 return &bq24190_sysfs_field_tbl[i]; 478 } 479 480 static ssize_t bq24190_sysfs_show(struct device *dev, 481 struct device_attribute *attr, char *buf) 482 { 483 struct power_supply *psy = dev_get_drvdata(dev); 484 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 485 struct bq24190_sysfs_field_info *info; 486 ssize_t count; 487 int ret; 488 u8 v; 489 490 info = bq24190_sysfs_field_lookup(attr->attr.name); 491 if (!info) 492 return -EINVAL; 493 494 ret = pm_runtime_resume_and_get(bdi->dev); 495 if (ret < 0) 496 return ret; 497 498 ret = bq24190_read_mask(bdi, info->reg, info->mask, info->shift, &v); 499 if (ret) 500 count = ret; 501 else 502 count = sysfs_emit(buf, "%hhx\n", v); 503 504 pm_runtime_mark_last_busy(bdi->dev); 505 pm_runtime_put_autosuspend(bdi->dev); 506 507 return count; 508 } 509 510 static ssize_t bq24190_sysfs_store(struct device *dev, 511 struct device_attribute *attr, const char *buf, size_t count) 512 { 513 struct power_supply *psy = dev_get_drvdata(dev); 514 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 515 struct bq24190_sysfs_field_info *info; 516 int ret; 517 u8 v; 518 519 info = bq24190_sysfs_field_lookup(attr->attr.name); 520 if (!info) 521 return -EINVAL; 522 523 ret = kstrtou8(buf, 0, &v); 524 if (ret < 0) 525 return ret; 526 527 ret = pm_runtime_resume_and_get(bdi->dev); 528 if (ret < 0) 529 return ret; 530 531 ret = bq24190_write_mask(bdi, info->reg, info->mask, info->shift, v); 532 if (ret) 533 count = ret; 534 535 pm_runtime_mark_last_busy(bdi->dev); 536 pm_runtime_put_autosuspend(bdi->dev); 537 538 return count; 539 } 540 #endif 541 542 static int bq24190_set_otg_vbus(struct bq24190_dev_info *bdi, bool enable) 543 { 544 union power_supply_propval val = { .intval = bdi->charge_type }; 545 int ret; 546 547 ret = pm_runtime_resume_and_get(bdi->dev); 548 if (ret < 0) { 549 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret); 550 return ret; 551 } 552 553 bdi->otg_vbus_enabled = enable; 554 if (enable) 555 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 556 BQ24190_REG_POC_CHG_CONFIG_MASK, 557 BQ24190_REG_POC_CHG_CONFIG_SHIFT, 558 BQ24190_REG_POC_CHG_CONFIG_OTG); 559 else 560 ret = bq24190_charger_set_charge_type(bdi, &val); 561 562 pm_runtime_mark_last_busy(bdi->dev); 563 pm_runtime_put_autosuspend(bdi->dev); 564 565 return ret; 566 } 567 568 static int bq24296_set_otg_vbus(struct bq24190_dev_info *bdi, bool enable) 569 { 570 union power_supply_propval val = { .intval = bdi->charge_type }; 571 int ret; 572 573 ret = pm_runtime_resume_and_get(bdi->dev); 574 if (ret < 0) { 575 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret); 576 return ret; 577 } 578 579 bdi->otg_vbus_enabled = enable; 580 if (enable) { 581 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 582 BQ24296_REG_POC_CHG_CONFIG_MASK, 583 BQ24296_REG_POC_CHG_CONFIG_SHIFT, 584 BQ24190_REG_POC_CHG_CONFIG_DISABLE); 585 586 if (ret < 0) 587 goto out; 588 589 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 590 BQ24296_REG_POC_OTG_CONFIG_MASK, 591 BQ24296_REG_POC_OTG_CONFIG_SHIFT, 592 BQ24296_REG_POC_OTG_CONFIG_OTG); 593 } else { 594 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 595 BQ24296_REG_POC_OTG_CONFIG_MASK, 596 BQ24296_REG_POC_OTG_CONFIG_SHIFT, 597 BQ24296_REG_POC_OTG_CONFIG_DISABLE); 598 if (ret < 0) 599 goto out; 600 601 ret = bq24190_charger_set_charge_type(bdi, &val); 602 } 603 604 out: 605 pm_runtime_mark_last_busy(bdi->dev); 606 pm_runtime_put_autosuspend(bdi->dev); 607 608 return ret; 609 } 610 611 #ifdef CONFIG_REGULATOR 612 static int bq24190_vbus_enable(struct regulator_dev *dev) 613 { 614 return bq24190_set_otg_vbus(rdev_get_drvdata(dev), true); 615 } 616 617 static int bq24190_vbus_disable(struct regulator_dev *dev) 618 { 619 return bq24190_set_otg_vbus(rdev_get_drvdata(dev), false); 620 } 621 622 static int bq24190_vbus_is_enabled(struct regulator_dev *dev) 623 { 624 struct bq24190_dev_info *bdi = rdev_get_drvdata(dev); 625 int ret; 626 u8 val; 627 628 ret = pm_runtime_resume_and_get(bdi->dev); 629 if (ret < 0) { 630 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret); 631 return ret; 632 } 633 634 ret = bq24190_read_mask(bdi, BQ24190_REG_POC, 635 BQ24190_REG_POC_CHG_CONFIG_MASK, 636 BQ24190_REG_POC_CHG_CONFIG_SHIFT, &val); 637 638 pm_runtime_mark_last_busy(bdi->dev); 639 pm_runtime_put_autosuspend(bdi->dev); 640 641 if (ret) 642 return ret; 643 644 bdi->otg_vbus_enabled = (val == BQ24190_REG_POC_CHG_CONFIG_OTG || 645 val == BQ24190_REG_POC_CHG_CONFIG_OTG_ALT); 646 return bdi->otg_vbus_enabled; 647 } 648 649 static int bq24296_vbus_enable(struct regulator_dev *dev) 650 { 651 return bq24296_set_otg_vbus(rdev_get_drvdata(dev), true); 652 } 653 654 static int bq24296_vbus_disable(struct regulator_dev *dev) 655 { 656 return bq24296_set_otg_vbus(rdev_get_drvdata(dev), false); 657 } 658 659 static int bq24296_vbus_is_enabled(struct regulator_dev *dev) 660 { 661 struct bq24190_dev_info *bdi = rdev_get_drvdata(dev); 662 int ret; 663 u8 val; 664 665 ret = pm_runtime_resume_and_get(bdi->dev); 666 if (ret < 0) { 667 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", ret); 668 return ret; 669 } 670 671 ret = bq24190_read_mask(bdi, BQ24190_REG_POC, 672 BQ24296_REG_POC_OTG_CONFIG_MASK, 673 BQ24296_REG_POC_OTG_CONFIG_SHIFT, &val); 674 675 pm_runtime_mark_last_busy(bdi->dev); 676 pm_runtime_put_autosuspend(bdi->dev); 677 678 if (ret) 679 return ret; 680 681 bdi->otg_vbus_enabled = (val == BQ24296_REG_POC_OTG_CONFIG_OTG); 682 683 return bdi->otg_vbus_enabled; 684 } 685 686 static const struct regulator_ops bq24190_vbus_ops = { 687 .enable = bq24190_vbus_enable, 688 .disable = bq24190_vbus_disable, 689 .is_enabled = bq24190_vbus_is_enabled, 690 }; 691 692 static const struct regulator_desc bq24190_vbus_desc = { 693 .name = "usb_otg_vbus", 694 .of_match = "usb-otg-vbus", 695 .type = REGULATOR_VOLTAGE, 696 .owner = THIS_MODULE, 697 .ops = &bq24190_vbus_ops, 698 .fixed_uV = 5000000, 699 .n_voltages = 1, 700 }; 701 702 static const struct regulator_ops bq24296_vbus_ops = { 703 .enable = bq24296_vbus_enable, 704 .disable = bq24296_vbus_disable, 705 .is_enabled = bq24296_vbus_is_enabled, 706 }; 707 708 static const struct regulator_desc bq24296_vbus_desc = { 709 .name = "usb_otg_vbus", 710 .of_match = "usb-otg-vbus", 711 .type = REGULATOR_VOLTAGE, 712 .owner = THIS_MODULE, 713 .ops = &bq24296_vbus_ops, 714 .fixed_uV = 5000000, 715 .n_voltages = 1, 716 }; 717 718 static const struct regulator_init_data bq24190_vbus_init_data = { 719 .constraints = { 720 .valid_ops_mask = REGULATOR_CHANGE_STATUS, 721 }, 722 }; 723 724 static int bq24190_register_vbus_regulator(struct bq24190_dev_info *bdi) 725 { 726 struct bq24190_platform_data *pdata = bdi->dev->platform_data; 727 struct regulator_config cfg = { }; 728 struct regulator_dev *reg; 729 int ret = 0; 730 731 cfg.dev = bdi->dev; 732 if (pdata && pdata->regulator_init_data) 733 cfg.init_data = pdata->regulator_init_data; 734 else 735 cfg.init_data = &bq24190_vbus_init_data; 736 cfg.driver_data = bdi; 737 reg = devm_regulator_register(bdi->dev, bdi->info->vbus_desc, &cfg); 738 if (IS_ERR(reg)) { 739 ret = PTR_ERR(reg); 740 dev_err(bdi->dev, "Can't register regulator: %d\n", ret); 741 } 742 743 return ret; 744 } 745 #else 746 static int bq24190_register_vbus_regulator(struct bq24190_dev_info *bdi) 747 { 748 return 0; 749 } 750 #endif 751 752 static int bq24190_set_config(struct bq24190_dev_info *bdi) 753 { 754 int ret; 755 u8 v; 756 757 ret = bq24190_read(bdi, BQ24190_REG_CTTC, &v); 758 if (ret < 0) 759 return ret; 760 761 bdi->watchdog = ((v & BQ24190_REG_CTTC_WATCHDOG_MASK) >> 762 BQ24190_REG_CTTC_WATCHDOG_SHIFT); 763 764 /* 765 * According to the "Host Mode and default Mode" section of the 766 * manual, a write to any register causes the bq24190 to switch 767 * from default mode to host mode. It will switch back to default 768 * mode after a WDT timeout unless the WDT is turned off as well. 769 * So, by simply turning off the WDT, we accomplish both with the 770 * same write. 771 */ 772 v &= ~BQ24190_REG_CTTC_WATCHDOG_MASK; 773 774 ret = bq24190_write(bdi, BQ24190_REG_CTTC, v); 775 if (ret < 0) 776 return ret; 777 778 if (bdi->sys_min) { 779 v = bdi->sys_min / 100 - 30; // manual section 9.5.1.2, table 9 780 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 781 BQ24190_REG_POC_SYS_MIN_MASK, 782 BQ24190_REG_POC_SYS_MIN_SHIFT, 783 v); 784 if (ret < 0) 785 return ret; 786 } 787 788 if (bdi->iprechg) { 789 v = bdi->iprechg / 128 - 1; // manual section 9.5.1.4, table 11 790 ret = bq24190_write_mask(bdi, BQ24190_REG_PCTCC, 791 BQ24190_REG_PCTCC_IPRECHG_MASK, 792 BQ24190_REG_PCTCC_IPRECHG_SHIFT, 793 v); 794 if (ret < 0) 795 return ret; 796 } 797 798 if (bdi->iterm) { 799 v = bdi->iterm / 128 - 1; // manual section 9.5.1.4, table 11 800 ret = bq24190_write_mask(bdi, BQ24190_REG_PCTCC, 801 BQ24190_REG_PCTCC_ITERM_MASK, 802 BQ24190_REG_PCTCC_ITERM_SHIFT, 803 v); 804 if (ret < 0) 805 return ret; 806 } 807 808 if (bdi->ichg) { 809 ret = bq24190_set_field_val(bdi, BQ24190_REG_CCC, 810 BQ24190_REG_CCC_ICHG_MASK, 811 BQ24190_REG_CCC_ICHG_SHIFT, 812 bq24190_ccc_ichg_values, 813 bdi->info->ichg_array_size, 814 bdi->ichg); 815 if (ret < 0) 816 return ret; 817 } 818 819 if (bdi->vreg) { 820 ret = bq24190_set_field_val(bdi, BQ24190_REG_CVC, 821 BQ24190_REG_CVC_VREG_MASK, 822 BQ24190_REG_CVC_VREG_SHIFT, 823 bq24190_cvc_vreg_values, 824 ARRAY_SIZE(bq24190_cvc_vreg_values), 825 bdi->vreg); 826 if (ret < 0) 827 return ret; 828 } 829 830 return 0; 831 } 832 833 static int bq24190_register_reset(struct bq24190_dev_info *bdi) 834 { 835 int ret, limit = 100; 836 u8 v; 837 838 /* 839 * This prop. can be passed on device instantiation from platform code: 840 * struct property_entry pe[] = 841 * { PROPERTY_ENTRY_BOOL("disable-reset"), ... }; 842 * struct i2c_board_info bi = 843 * { .type = "bq24190", .addr = 0x6b, .properties = pe, .irq = irq }; 844 * struct i2c_adapter ad = { ... }; 845 * i2c_add_adapter(&ad); 846 * i2c_new_client_device(&ad, &bi); 847 */ 848 if (device_property_read_bool(bdi->dev, "disable-reset")) 849 return 0; 850 851 /* Reset the registers */ 852 ret = bq24190_write_mask(bdi, BQ24190_REG_POC, 853 BQ24190_REG_POC_RESET_MASK, 854 BQ24190_REG_POC_RESET_SHIFT, 855 0x1); 856 if (ret < 0) 857 return ret; 858 859 /* Reset bit will be cleared by hardware so poll until it is */ 860 do { 861 ret = bq24190_read_mask(bdi, BQ24190_REG_POC, 862 BQ24190_REG_POC_RESET_MASK, 863 BQ24190_REG_POC_RESET_SHIFT, 864 &v); 865 if (ret < 0) 866 return ret; 867 868 if (v == 0) 869 return 0; 870 871 usleep_range(100, 200); 872 } while (--limit); 873 874 return -EIO; 875 } 876 877 /* Charger power supply property routines */ 878 879 static int bq24190_charger_get_charge_type(struct bq24190_dev_info *bdi, 880 union power_supply_propval *val) 881 { 882 u8 v; 883 int type, ret; 884 885 ret = bq24190_read_mask(bdi, BQ24190_REG_POC, 886 BQ24190_REG_POC_CHG_CONFIG_MASK, 887 BQ24190_REG_POC_CHG_CONFIG_SHIFT, 888 &v); 889 if (ret < 0) 890 return ret; 891 892 /* If POC[CHG_CONFIG] (REG01[5:4]) == 0, charge is disabled */ 893 if (!v) { 894 type = POWER_SUPPLY_CHARGE_TYPE_NONE; 895 } else { 896 ret = bq24190_read_mask(bdi, BQ24190_REG_CCC, 897 BQ24190_REG_CCC_FORCE_20PCT_MASK, 898 BQ24190_REG_CCC_FORCE_20PCT_SHIFT, 899 &v); 900 if (ret < 0) 901 return ret; 902 903 type = (v) ? POWER_SUPPLY_CHARGE_TYPE_TRICKLE : 904 POWER_SUPPLY_CHARGE_TYPE_FAST; 905 } 906 907 val->intval = type; 908 909 return 0; 910 } 911 912 static int bq24190_battery_set_chg_config(struct bq24190_dev_info *bdi, 913 const u8 chg_config) 914 { 915 return bq24190_write_mask(bdi, BQ24190_REG_POC, 916 BQ24190_REG_POC_CHG_CONFIG_MASK, 917 BQ24190_REG_POC_CHG_CONFIG_SHIFT, 918 chg_config); 919 } 920 921 static int bq24296_battery_set_chg_config(struct bq24190_dev_info *bdi, 922 const u8 chg_config) 923 { 924 return bq24190_write_mask(bdi, BQ24190_REG_POC, 925 BQ24296_REG_POC_CHG_CONFIG_MASK, 926 BQ24296_REG_POC_CHG_CONFIG_SHIFT, 927 chg_config); 928 } 929 930 static int bq24190_charger_set_charge_type(struct bq24190_dev_info *bdi, 931 const union power_supply_propval *val) 932 { 933 u8 chg_config, force_20pct, en_term; 934 int ret; 935 936 /* 937 * According to the "Termination when REG02[0] = 1" section of 938 * the bq24190 manual, the trickle charge could be less than the 939 * termination current so it recommends turning off the termination 940 * function. 941 * 942 * Note: AFAICT from the datasheet, the user will have to manually 943 * turn off the charging when in 20% mode. If its not turned off, 944 * there could be battery damage. So, use this mode at your own risk. 945 */ 946 switch (val->intval) { 947 case POWER_SUPPLY_CHARGE_TYPE_NONE: 948 chg_config = 0x0; 949 break; 950 case POWER_SUPPLY_CHARGE_TYPE_TRICKLE: 951 chg_config = 0x1; 952 force_20pct = 0x1; 953 en_term = 0x0; 954 break; 955 case POWER_SUPPLY_CHARGE_TYPE_FAST: 956 chg_config = 0x1; 957 force_20pct = 0x0; 958 en_term = 0x1; 959 break; 960 default: 961 return -EINVAL; 962 } 963 964 bdi->charge_type = val->intval; 965 /* 966 * If the 5V Vbus boost regulator is enabled delay setting 967 * the charge-type until its gets disabled. 968 */ 969 if (bdi->otg_vbus_enabled) 970 return 0; 971 972 if (chg_config) { /* Enabling the charger */ 973 ret = bq24190_write_mask(bdi, BQ24190_REG_CCC, 974 BQ24190_REG_CCC_FORCE_20PCT_MASK, 975 BQ24190_REG_CCC_FORCE_20PCT_SHIFT, 976 force_20pct); 977 if (ret < 0) 978 return ret; 979 980 ret = bq24190_write_mask(bdi, BQ24190_REG_CTTC, 981 BQ24190_REG_CTTC_EN_TERM_MASK, 982 BQ24190_REG_CTTC_EN_TERM_SHIFT, 983 en_term); 984 if (ret < 0) 985 return ret; 986 } 987 988 return bdi->info->set_chg_config(bdi, chg_config); 989 } 990 991 static int bq24190_charger_get_ntc_status(u8 value) 992 { 993 int health; 994 995 switch (value >> BQ24190_REG_F_NTC_FAULT_SHIFT & 0x7) { 996 case 0x1: /* TS1 Cold */ 997 case 0x3: /* TS2 Cold */ 998 case 0x5: /* Both Cold */ 999 health = POWER_SUPPLY_HEALTH_COLD; 1000 break; 1001 case 0x2: /* TS1 Hot */ 1002 case 0x4: /* TS2 Hot */ 1003 case 0x6: /* Both Hot */ 1004 health = POWER_SUPPLY_HEALTH_OVERHEAT; 1005 break; 1006 default: 1007 health = POWER_SUPPLY_HEALTH_UNKNOWN; 1008 } 1009 1010 return health; 1011 } 1012 1013 static int bq24296_charger_get_ntc_status(u8 value) 1014 { 1015 int health; 1016 1017 switch (value >> BQ24296_REG_F_NTC_FAULT_SHIFT & 0x3) { 1018 case 0x0: /* Normal */ 1019 health = POWER_SUPPLY_HEALTH_GOOD; 1020 break; 1021 case 0x1: /* Hot */ 1022 health = POWER_SUPPLY_HEALTH_OVERHEAT; 1023 break; 1024 case 0x2: /* Cold */ 1025 health = POWER_SUPPLY_HEALTH_COLD; 1026 break; 1027 default: 1028 health = POWER_SUPPLY_HEALTH_UNKNOWN; 1029 } 1030 1031 return health; 1032 } 1033 1034 static int bq24190_charger_get_health(struct bq24190_dev_info *bdi, 1035 union power_supply_propval *val) 1036 { 1037 u8 v; 1038 int health; 1039 1040 mutex_lock(&bdi->f_reg_lock); 1041 v = bdi->f_reg; 1042 mutex_unlock(&bdi->f_reg_lock); 1043 1044 if (v & bdi->info->ntc_fault_mask) { 1045 health = bdi->info->get_ntc_status(v); 1046 } else if (v & BQ24190_REG_F_BAT_FAULT_MASK) { 1047 health = POWER_SUPPLY_HEALTH_OVERVOLTAGE; 1048 } else if (v & BQ24190_REG_F_CHRG_FAULT_MASK) { 1049 switch (v >> BQ24190_REG_F_CHRG_FAULT_SHIFT & 0x3) { 1050 case 0x1: /* Input Fault (VBUS OVP or VBAT<VBUS<3.8V) */ 1051 /* 1052 * This could be over-voltage or under-voltage 1053 * and there's no way to tell which. Instead 1054 * of looking foolish and returning 'OVERVOLTAGE' 1055 * when its really under-voltage, just return 1056 * 'UNSPEC_FAILURE'. 1057 */ 1058 health = POWER_SUPPLY_HEALTH_UNSPEC_FAILURE; 1059 break; 1060 case 0x2: /* Thermal Shutdown */ 1061 health = POWER_SUPPLY_HEALTH_OVERHEAT; 1062 break; 1063 case 0x3: /* Charge Safety Timer Expiration */ 1064 health = POWER_SUPPLY_HEALTH_SAFETY_TIMER_EXPIRE; 1065 break; 1066 default: /* prevent compiler warning */ 1067 health = -1; 1068 } 1069 } else if (v & BQ24190_REG_F_BOOST_FAULT_MASK) { 1070 /* 1071 * This could be over-current or over-voltage but there's 1072 * no way to tell which. Return 'OVERVOLTAGE' since there 1073 * isn't an 'OVERCURRENT' value defined that we can return 1074 * even if it was over-current. 1075 */ 1076 health = POWER_SUPPLY_HEALTH_OVERVOLTAGE; 1077 } else { 1078 health = POWER_SUPPLY_HEALTH_GOOD; 1079 } 1080 1081 val->intval = health; 1082 1083 return 0; 1084 } 1085 1086 static int bq24190_charger_get_online(struct bq24190_dev_info *bdi, 1087 union power_supply_propval *val) 1088 { 1089 u8 pg_stat, batfet_disable; 1090 int ret; 1091 1092 ret = bq24190_read_mask(bdi, BQ24190_REG_SS, 1093 BQ24190_REG_SS_PG_STAT_MASK, 1094 BQ24190_REG_SS_PG_STAT_SHIFT, &pg_stat); 1095 if (ret < 0) 1096 return ret; 1097 1098 ret = bq24190_read_mask(bdi, BQ24190_REG_MOC, 1099 BQ24190_REG_MOC_BATFET_DISABLE_MASK, 1100 BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, &batfet_disable); 1101 if (ret < 0) 1102 return ret; 1103 1104 val->intval = pg_stat && !batfet_disable; 1105 1106 return 0; 1107 } 1108 1109 static int bq24190_battery_set_online(struct bq24190_dev_info *bdi, 1110 const union power_supply_propval *val); 1111 static int bq24190_battery_get_status(struct bq24190_dev_info *bdi, 1112 union power_supply_propval *val); 1113 static int bq24190_battery_get_temp_alert_max(struct bq24190_dev_info *bdi, 1114 union power_supply_propval *val); 1115 static int bq24190_battery_set_temp_alert_max(struct bq24190_dev_info *bdi, 1116 const union power_supply_propval *val); 1117 1118 static int bq24190_charger_set_online(struct bq24190_dev_info *bdi, 1119 const union power_supply_propval *val) 1120 { 1121 return bq24190_battery_set_online(bdi, val); 1122 } 1123 1124 static int bq24190_charger_get_status(struct bq24190_dev_info *bdi, 1125 union power_supply_propval *val) 1126 { 1127 return bq24190_battery_get_status(bdi, val); 1128 } 1129 1130 static int bq24190_charger_get_temp_alert_max(struct bq24190_dev_info *bdi, 1131 union power_supply_propval *val) 1132 { 1133 return bq24190_battery_get_temp_alert_max(bdi, val); 1134 } 1135 1136 static int bq24190_charger_set_temp_alert_max(struct bq24190_dev_info *bdi, 1137 const union power_supply_propval *val) 1138 { 1139 return bq24190_battery_set_temp_alert_max(bdi, val); 1140 } 1141 1142 static int bq24190_charger_get_precharge(struct bq24190_dev_info *bdi, 1143 union power_supply_propval *val) 1144 { 1145 u8 v; 1146 int curr, ret; 1147 1148 ret = bq24190_read_mask(bdi, BQ24190_REG_PCTCC, 1149 BQ24190_REG_PCTCC_IPRECHG_MASK, 1150 BQ24190_REG_PCTCC_IPRECHG_SHIFT, &v); 1151 if (ret < 0) 1152 return ret; 1153 1154 curr = ++v * 128 * 1000; 1155 1156 ret = bq24190_read_mask(bdi, BQ24190_REG_CCC, 1157 BQ24190_REG_CCC_FORCE_20PCT_MASK, 1158 BQ24190_REG_CCC_FORCE_20PCT_SHIFT, &v); 1159 if (ret < 0) 1160 return ret; 1161 1162 /* If FORCE_20PCT is enabled, then current is 50% of IPRECHG value */ 1163 if (v) 1164 curr /= 2; 1165 1166 val->intval = curr; 1167 1168 return 0; 1169 } 1170 1171 static int bq24190_charger_get_charge_term(struct bq24190_dev_info *bdi, 1172 union power_supply_propval *val) 1173 { 1174 u8 v; 1175 int ret; 1176 1177 ret = bq24190_read_mask(bdi, BQ24190_REG_PCTCC, 1178 BQ24190_REG_PCTCC_ITERM_MASK, 1179 BQ24190_REG_PCTCC_ITERM_SHIFT, &v); 1180 if (ret < 0) 1181 return ret; 1182 1183 val->intval = ++v * 128 * 1000; 1184 return 0; 1185 } 1186 1187 static int bq24190_charger_get_current(struct bq24190_dev_info *bdi, 1188 union power_supply_propval *val) 1189 { 1190 u8 v; 1191 int curr, ret; 1192 1193 ret = bq24190_get_field_val(bdi, BQ24190_REG_CCC, 1194 BQ24190_REG_CCC_ICHG_MASK, BQ24190_REG_CCC_ICHG_SHIFT, 1195 bq24190_ccc_ichg_values, 1196 bdi->info->ichg_array_size, &curr); 1197 if (ret < 0) 1198 return ret; 1199 1200 ret = bq24190_read_mask(bdi, BQ24190_REG_CCC, 1201 BQ24190_REG_CCC_FORCE_20PCT_MASK, 1202 BQ24190_REG_CCC_FORCE_20PCT_SHIFT, &v); 1203 if (ret < 0) 1204 return ret; 1205 1206 /* If FORCE_20PCT is enabled, then current is 20% of ICHG value */ 1207 if (v) 1208 curr /= 5; 1209 1210 val->intval = curr; 1211 return 0; 1212 } 1213 1214 static int bq24190_charger_set_current(struct bq24190_dev_info *bdi, 1215 const union power_supply_propval *val) 1216 { 1217 u8 v; 1218 int ret, curr = val->intval; 1219 1220 ret = bq24190_read_mask(bdi, BQ24190_REG_CCC, 1221 BQ24190_REG_CCC_FORCE_20PCT_MASK, 1222 BQ24190_REG_CCC_FORCE_20PCT_SHIFT, &v); 1223 if (ret < 0) 1224 return ret; 1225 1226 /* If FORCE_20PCT is enabled, have to multiply value passed in by 5 */ 1227 if (v) 1228 curr *= 5; 1229 1230 if (curr > bdi->ichg_max) 1231 return -EINVAL; 1232 1233 ret = bq24190_set_field_val(bdi, BQ24190_REG_CCC, 1234 BQ24190_REG_CCC_ICHG_MASK, BQ24190_REG_CCC_ICHG_SHIFT, 1235 bq24190_ccc_ichg_values, 1236 bdi->info->ichg_array_size, curr); 1237 if (ret < 0) 1238 return ret; 1239 1240 bdi->ichg = curr; 1241 1242 return 0; 1243 } 1244 1245 static int bq24190_charger_get_voltage(struct bq24190_dev_info *bdi, 1246 union power_supply_propval *val) 1247 { 1248 int voltage, ret; 1249 1250 ret = bq24190_get_field_val(bdi, BQ24190_REG_CVC, 1251 BQ24190_REG_CVC_VREG_MASK, BQ24190_REG_CVC_VREG_SHIFT, 1252 bq24190_cvc_vreg_values, 1253 ARRAY_SIZE(bq24190_cvc_vreg_values), &voltage); 1254 if (ret < 0) 1255 return ret; 1256 1257 val->intval = voltage; 1258 return 0; 1259 } 1260 1261 static int bq24190_charger_set_voltage(struct bq24190_dev_info *bdi, 1262 const union power_supply_propval *val) 1263 { 1264 int ret; 1265 1266 if (val->intval > bdi->vreg_max) 1267 return -EINVAL; 1268 1269 ret = bq24190_set_field_val(bdi, BQ24190_REG_CVC, 1270 BQ24190_REG_CVC_VREG_MASK, BQ24190_REG_CVC_VREG_SHIFT, 1271 bq24190_cvc_vreg_values, 1272 ARRAY_SIZE(bq24190_cvc_vreg_values), val->intval); 1273 if (ret < 0) 1274 return ret; 1275 1276 bdi->vreg = val->intval; 1277 1278 return 0; 1279 } 1280 1281 static int bq24190_charger_get_iinlimit(struct bq24190_dev_info *bdi, 1282 union power_supply_propval *val) 1283 { 1284 int iinlimit, ret; 1285 1286 ret = bq24190_get_field_val(bdi, BQ24190_REG_ISC, 1287 BQ24190_REG_ISC_IINLIM_MASK, 1288 BQ24190_REG_ISC_IINLIM_SHIFT, 1289 bq24190_isc_iinlim_values, 1290 ARRAY_SIZE(bq24190_isc_iinlim_values), &iinlimit); 1291 if (ret < 0) 1292 return ret; 1293 1294 val->intval = iinlimit; 1295 return 0; 1296 } 1297 1298 static int bq24190_charger_set_iinlimit(struct bq24190_dev_info *bdi, 1299 const union power_supply_propval *val) 1300 { 1301 return bq24190_set_field_val(bdi, BQ24190_REG_ISC, 1302 BQ24190_REG_ISC_IINLIM_MASK, 1303 BQ24190_REG_ISC_IINLIM_SHIFT, 1304 bq24190_isc_iinlim_values, 1305 ARRAY_SIZE(bq24190_isc_iinlim_values), val->intval); 1306 } 1307 1308 static int bq24190_charger_get_property(struct power_supply *psy, 1309 enum power_supply_property psp, union power_supply_propval *val) 1310 { 1311 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 1312 int ret; 1313 1314 dev_dbg(bdi->dev, "prop: %d\n", psp); 1315 1316 ret = pm_runtime_resume_and_get(bdi->dev); 1317 if (ret < 0) 1318 return ret; 1319 1320 switch (psp) { 1321 case POWER_SUPPLY_PROP_CHARGE_TYPE: 1322 ret = bq24190_charger_get_charge_type(bdi, val); 1323 break; 1324 case POWER_SUPPLY_PROP_HEALTH: 1325 ret = bq24190_charger_get_health(bdi, val); 1326 break; 1327 case POWER_SUPPLY_PROP_ONLINE: 1328 ret = bq24190_charger_get_online(bdi, val); 1329 break; 1330 case POWER_SUPPLY_PROP_STATUS: 1331 ret = bq24190_charger_get_status(bdi, val); 1332 break; 1333 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1334 ret = bq24190_charger_get_temp_alert_max(bdi, val); 1335 break; 1336 case POWER_SUPPLY_PROP_PRECHARGE_CURRENT: 1337 ret = bq24190_charger_get_precharge(bdi, val); 1338 break; 1339 case POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT: 1340 ret = bq24190_charger_get_charge_term(bdi, val); 1341 break; 1342 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 1343 ret = bq24190_charger_get_current(bdi, val); 1344 break; 1345 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX: 1346 val->intval = bdi->ichg_max; 1347 ret = 0; 1348 break; 1349 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 1350 ret = bq24190_charger_get_voltage(bdi, val); 1351 break; 1352 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX: 1353 val->intval = bdi->vreg_max; 1354 ret = 0; 1355 break; 1356 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 1357 ret = bq24190_charger_get_iinlimit(bdi, val); 1358 break; 1359 case POWER_SUPPLY_PROP_SCOPE: 1360 val->intval = POWER_SUPPLY_SCOPE_SYSTEM; 1361 ret = 0; 1362 break; 1363 case POWER_SUPPLY_PROP_MODEL_NAME: 1364 val->strval = bdi->model_name; 1365 ret = 0; 1366 break; 1367 case POWER_SUPPLY_PROP_MANUFACTURER: 1368 val->strval = BQ24190_MANUFACTURER; 1369 ret = 0; 1370 break; 1371 default: 1372 ret = -ENODATA; 1373 } 1374 1375 pm_runtime_mark_last_busy(bdi->dev); 1376 pm_runtime_put_autosuspend(bdi->dev); 1377 1378 return ret; 1379 } 1380 1381 static int bq24190_charger_set_property(struct power_supply *psy, 1382 enum power_supply_property psp, 1383 const union power_supply_propval *val) 1384 { 1385 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 1386 int ret; 1387 1388 dev_dbg(bdi->dev, "prop: %d\n", psp); 1389 1390 ret = pm_runtime_resume_and_get(bdi->dev); 1391 if (ret < 0) 1392 return ret; 1393 1394 switch (psp) { 1395 case POWER_SUPPLY_PROP_ONLINE: 1396 ret = bq24190_charger_set_online(bdi, val); 1397 break; 1398 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1399 ret = bq24190_charger_set_temp_alert_max(bdi, val); 1400 break; 1401 case POWER_SUPPLY_PROP_CHARGE_TYPE: 1402 ret = bq24190_charger_set_charge_type(bdi, val); 1403 break; 1404 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 1405 ret = bq24190_charger_set_current(bdi, val); 1406 break; 1407 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 1408 ret = bq24190_charger_set_voltage(bdi, val); 1409 break; 1410 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 1411 ret = bq24190_charger_set_iinlimit(bdi, val); 1412 break; 1413 default: 1414 ret = -EINVAL; 1415 } 1416 1417 pm_runtime_mark_last_busy(bdi->dev); 1418 pm_runtime_put_autosuspend(bdi->dev); 1419 1420 return ret; 1421 } 1422 1423 static int bq24190_charger_property_is_writeable(struct power_supply *psy, 1424 enum power_supply_property psp) 1425 { 1426 switch (psp) { 1427 case POWER_SUPPLY_PROP_ONLINE: 1428 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1429 case POWER_SUPPLY_PROP_CHARGE_TYPE: 1430 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 1431 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 1432 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 1433 return 1; 1434 default: 1435 return 0; 1436 } 1437 } 1438 1439 static void bq24190_input_current_limit_work(struct work_struct *work) 1440 { 1441 struct bq24190_dev_info *bdi = 1442 container_of(work, struct bq24190_dev_info, 1443 input_current_limit_work.work); 1444 union power_supply_propval val; 1445 int ret; 1446 1447 ret = power_supply_get_property_from_supplier(bdi->charger, 1448 POWER_SUPPLY_PROP_CURRENT_MAX, 1449 &val); 1450 if (ret) 1451 return; 1452 1453 bq24190_charger_set_property(bdi->charger, 1454 POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT, 1455 &val); 1456 power_supply_changed(bdi->charger); 1457 } 1458 1459 /* Sync the input-current-limit with our parent supply (if we have one) */ 1460 static void bq24190_charger_external_power_changed(struct power_supply *psy) 1461 { 1462 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 1463 1464 /* 1465 * The Power-Good detection may take up to 220ms, sometimes 1466 * the external charger detection is quicker, and the bq24190 will 1467 * reset to iinlim based on its own charger detection (which is not 1468 * hooked up when using external charger detection) resulting in a 1469 * too low default 500mA iinlim. Delay setting the input-current-limit 1470 * for 300ms to avoid this. 1471 */ 1472 queue_delayed_work(system_wq, &bdi->input_current_limit_work, 1473 msecs_to_jiffies(300)); 1474 } 1475 1476 static enum power_supply_property bq24190_charger_properties[] = { 1477 POWER_SUPPLY_PROP_CHARGE_TYPE, 1478 POWER_SUPPLY_PROP_HEALTH, 1479 POWER_SUPPLY_PROP_ONLINE, 1480 POWER_SUPPLY_PROP_STATUS, 1481 POWER_SUPPLY_PROP_TEMP_ALERT_MAX, 1482 POWER_SUPPLY_PROP_PRECHARGE_CURRENT, 1483 POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT, 1484 POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT, 1485 POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX, 1486 POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE, 1487 POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX, 1488 POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT, 1489 POWER_SUPPLY_PROP_SCOPE, 1490 POWER_SUPPLY_PROP_MODEL_NAME, 1491 POWER_SUPPLY_PROP_MANUFACTURER, 1492 }; 1493 1494 static char *bq24190_charger_supplied_to[] = { 1495 "main-battery", 1496 }; 1497 1498 static const struct power_supply_desc bq24190_charger_desc = { 1499 .name = "bq24190-charger", 1500 .type = POWER_SUPPLY_TYPE_USB, 1501 .properties = bq24190_charger_properties, 1502 .num_properties = ARRAY_SIZE(bq24190_charger_properties), 1503 .get_property = bq24190_charger_get_property, 1504 .set_property = bq24190_charger_set_property, 1505 .property_is_writeable = bq24190_charger_property_is_writeable, 1506 .external_power_changed = bq24190_charger_external_power_changed, 1507 }; 1508 1509 /* Battery power supply property routines */ 1510 1511 static int bq24190_battery_get_status(struct bq24190_dev_info *bdi, 1512 union power_supply_propval *val) 1513 { 1514 u8 ss_reg, chrg_fault; 1515 int status, ret; 1516 1517 mutex_lock(&bdi->f_reg_lock); 1518 chrg_fault = bdi->f_reg; 1519 mutex_unlock(&bdi->f_reg_lock); 1520 1521 chrg_fault &= BQ24190_REG_F_CHRG_FAULT_MASK; 1522 chrg_fault >>= BQ24190_REG_F_CHRG_FAULT_SHIFT; 1523 1524 ret = bq24190_read(bdi, BQ24190_REG_SS, &ss_reg); 1525 if (ret < 0) 1526 return ret; 1527 1528 /* 1529 * The battery must be discharging when any of these are true: 1530 * - there is no good power source; 1531 * - there is a charge fault. 1532 * Could also be discharging when in "supplement mode" but 1533 * there is no way to tell when its in that mode. 1534 */ 1535 if (!(ss_reg & BQ24190_REG_SS_PG_STAT_MASK) || chrg_fault) { 1536 status = POWER_SUPPLY_STATUS_DISCHARGING; 1537 } else { 1538 ss_reg &= BQ24190_REG_SS_CHRG_STAT_MASK; 1539 ss_reg >>= BQ24190_REG_SS_CHRG_STAT_SHIFT; 1540 1541 switch (ss_reg) { 1542 case 0x0: /* Not Charging */ 1543 status = POWER_SUPPLY_STATUS_NOT_CHARGING; 1544 break; 1545 case 0x1: /* Pre-charge */ 1546 case 0x2: /* Fast Charging */ 1547 status = POWER_SUPPLY_STATUS_CHARGING; 1548 break; 1549 case 0x3: /* Charge Termination Done */ 1550 status = POWER_SUPPLY_STATUS_FULL; 1551 break; 1552 default: 1553 ret = -EIO; 1554 } 1555 } 1556 1557 if (!ret) 1558 val->intval = status; 1559 1560 return ret; 1561 } 1562 1563 static int bq24190_battery_get_health(struct bq24190_dev_info *bdi, 1564 union power_supply_propval *val) 1565 { 1566 u8 v; 1567 int health; 1568 1569 mutex_lock(&bdi->f_reg_lock); 1570 v = bdi->f_reg; 1571 mutex_unlock(&bdi->f_reg_lock); 1572 1573 if (v & BQ24190_REG_F_BAT_FAULT_MASK) { 1574 health = POWER_SUPPLY_HEALTH_OVERVOLTAGE; 1575 } else { 1576 v &= bdi->info->ntc_fault_mask; 1577 1578 health = v ? bdi->info->get_ntc_status(v) : POWER_SUPPLY_HEALTH_GOOD; 1579 } 1580 1581 val->intval = health; 1582 return 0; 1583 } 1584 1585 static int bq24190_battery_get_online(struct bq24190_dev_info *bdi, 1586 union power_supply_propval *val) 1587 { 1588 u8 batfet_disable; 1589 int ret; 1590 1591 ret = bq24190_read_mask(bdi, BQ24190_REG_MOC, 1592 BQ24190_REG_MOC_BATFET_DISABLE_MASK, 1593 BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, &batfet_disable); 1594 if (ret < 0) 1595 return ret; 1596 1597 val->intval = !batfet_disable; 1598 return 0; 1599 } 1600 1601 static int bq24190_battery_set_online(struct bq24190_dev_info *bdi, 1602 const union power_supply_propval *val) 1603 { 1604 return bq24190_write_mask(bdi, BQ24190_REG_MOC, 1605 BQ24190_REG_MOC_BATFET_DISABLE_MASK, 1606 BQ24190_REG_MOC_BATFET_DISABLE_SHIFT, !val->intval); 1607 } 1608 1609 static int bq24190_battery_get_temp_alert_max(struct bq24190_dev_info *bdi, 1610 union power_supply_propval *val) 1611 { 1612 int temp, ret; 1613 1614 ret = bq24190_get_field_val(bdi, BQ24190_REG_ICTRC, 1615 BQ24190_REG_ICTRC_TREG_MASK, 1616 BQ24190_REG_ICTRC_TREG_SHIFT, 1617 bq24190_ictrc_treg_values, 1618 ARRAY_SIZE(bq24190_ictrc_treg_values), &temp); 1619 if (ret < 0) 1620 return ret; 1621 1622 val->intval = temp; 1623 return 0; 1624 } 1625 1626 static int bq24190_battery_set_temp_alert_max(struct bq24190_dev_info *bdi, 1627 const union power_supply_propval *val) 1628 { 1629 return bq24190_set_field_val(bdi, BQ24190_REG_ICTRC, 1630 BQ24190_REG_ICTRC_TREG_MASK, 1631 BQ24190_REG_ICTRC_TREG_SHIFT, 1632 bq24190_ictrc_treg_values, 1633 ARRAY_SIZE(bq24190_ictrc_treg_values), val->intval); 1634 } 1635 1636 static int bq24190_battery_get_property(struct power_supply *psy, 1637 enum power_supply_property psp, union power_supply_propval *val) 1638 { 1639 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 1640 int ret; 1641 1642 dev_warn(bdi->dev, "warning: /sys/class/power_supply/bq24190-battery is deprecated\n"); 1643 dev_dbg(bdi->dev, "prop: %d\n", psp); 1644 1645 ret = pm_runtime_resume_and_get(bdi->dev); 1646 if (ret < 0) 1647 return ret; 1648 1649 switch (psp) { 1650 case POWER_SUPPLY_PROP_STATUS: 1651 ret = bq24190_battery_get_status(bdi, val); 1652 break; 1653 case POWER_SUPPLY_PROP_HEALTH: 1654 ret = bq24190_battery_get_health(bdi, val); 1655 break; 1656 case POWER_SUPPLY_PROP_ONLINE: 1657 ret = bq24190_battery_get_online(bdi, val); 1658 break; 1659 case POWER_SUPPLY_PROP_TECHNOLOGY: 1660 /* Could be Li-on or Li-polymer but no way to tell which */ 1661 val->intval = POWER_SUPPLY_TECHNOLOGY_UNKNOWN; 1662 ret = 0; 1663 break; 1664 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1665 ret = bq24190_battery_get_temp_alert_max(bdi, val); 1666 break; 1667 case POWER_SUPPLY_PROP_SCOPE: 1668 val->intval = POWER_SUPPLY_SCOPE_SYSTEM; 1669 ret = 0; 1670 break; 1671 default: 1672 ret = -ENODATA; 1673 } 1674 1675 pm_runtime_mark_last_busy(bdi->dev); 1676 pm_runtime_put_autosuspend(bdi->dev); 1677 1678 return ret; 1679 } 1680 1681 static int bq24190_battery_set_property(struct power_supply *psy, 1682 enum power_supply_property psp, 1683 const union power_supply_propval *val) 1684 { 1685 struct bq24190_dev_info *bdi = power_supply_get_drvdata(psy); 1686 int ret; 1687 1688 dev_warn(bdi->dev, "warning: /sys/class/power_supply/bq24190-battery is deprecated\n"); 1689 dev_dbg(bdi->dev, "prop: %d\n", psp); 1690 1691 ret = pm_runtime_resume_and_get(bdi->dev); 1692 if (ret < 0) 1693 return ret; 1694 1695 switch (psp) { 1696 case POWER_SUPPLY_PROP_ONLINE: 1697 ret = bq24190_battery_set_online(bdi, val); 1698 break; 1699 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1700 ret = bq24190_battery_set_temp_alert_max(bdi, val); 1701 break; 1702 default: 1703 ret = -EINVAL; 1704 } 1705 1706 pm_runtime_mark_last_busy(bdi->dev); 1707 pm_runtime_put_autosuspend(bdi->dev); 1708 1709 return ret; 1710 } 1711 1712 static int bq24190_battery_property_is_writeable(struct power_supply *psy, 1713 enum power_supply_property psp) 1714 { 1715 int ret; 1716 1717 switch (psp) { 1718 case POWER_SUPPLY_PROP_ONLINE: 1719 case POWER_SUPPLY_PROP_TEMP_ALERT_MAX: 1720 ret = 1; 1721 break; 1722 default: 1723 ret = 0; 1724 } 1725 1726 return ret; 1727 } 1728 1729 static enum power_supply_property bq24190_battery_properties[] = { 1730 POWER_SUPPLY_PROP_STATUS, 1731 POWER_SUPPLY_PROP_HEALTH, 1732 POWER_SUPPLY_PROP_ONLINE, 1733 POWER_SUPPLY_PROP_TECHNOLOGY, 1734 POWER_SUPPLY_PROP_TEMP_ALERT_MAX, 1735 POWER_SUPPLY_PROP_SCOPE, 1736 }; 1737 1738 static const struct power_supply_desc bq24190_battery_desc = { 1739 .name = "bq24190-battery", 1740 .type = POWER_SUPPLY_TYPE_BATTERY, 1741 .properties = bq24190_battery_properties, 1742 .num_properties = ARRAY_SIZE(bq24190_battery_properties), 1743 .get_property = bq24190_battery_get_property, 1744 .set_property = bq24190_battery_set_property, 1745 .property_is_writeable = bq24190_battery_property_is_writeable, 1746 }; 1747 1748 static int bq24190_configure_usb_otg(struct bq24190_dev_info *bdi, u8 ss_reg) 1749 { 1750 bool otg_enabled; 1751 int ret; 1752 1753 otg_enabled = !!(ss_reg & BQ24190_REG_SS_VBUS_STAT_MASK); 1754 ret = extcon_set_state_sync(bdi->edev, EXTCON_USB, otg_enabled); 1755 if (ret < 0) 1756 dev_err(bdi->dev, "Can't set extcon state to %d: %d\n", 1757 otg_enabled, ret); 1758 1759 return ret; 1760 } 1761 1762 static void bq24190_check_status(struct bq24190_dev_info *bdi) 1763 { 1764 const u8 battery_mask_ss = BQ24190_REG_SS_CHRG_STAT_MASK; 1765 u8 battery_mask_f = BQ24190_REG_F_BAT_FAULT_MASK; 1766 bool alert_charger = false, alert_battery = false; 1767 u8 ss_reg = 0, f_reg = 0; 1768 int i, ret; 1769 1770 battery_mask_f |= bdi->info->ntc_fault_mask; 1771 1772 ret = bq24190_read(bdi, BQ24190_REG_SS, &ss_reg); 1773 if (ret < 0) { 1774 dev_err(bdi->dev, "Can't read SS reg: %d\n", ret); 1775 return; 1776 } 1777 1778 i = 0; 1779 do { 1780 ret = bq24190_read(bdi, BQ24190_REG_F, &f_reg); 1781 if (ret < 0) { 1782 dev_err(bdi->dev, "Can't read F reg: %d\n", ret); 1783 return; 1784 } 1785 } while (f_reg && ++i < 2); 1786 1787 /* ignore over/under voltage fault after disconnect */ 1788 if (f_reg == (1 << BQ24190_REG_F_CHRG_FAULT_SHIFT) && 1789 !(ss_reg & BQ24190_REG_SS_PG_STAT_MASK)) 1790 f_reg = 0; 1791 1792 if (f_reg != bdi->f_reg) { 1793 dev_warn(bdi->dev, 1794 "Fault: boost %d, charge %d, battery %d, ntc %d\n", 1795 !!(f_reg & BQ24190_REG_F_BOOST_FAULT_MASK), 1796 !!(f_reg & BQ24190_REG_F_CHRG_FAULT_MASK), 1797 !!(f_reg & BQ24190_REG_F_BAT_FAULT_MASK), 1798 !!(f_reg & bdi->info->ntc_fault_mask)); 1799 1800 mutex_lock(&bdi->f_reg_lock); 1801 if ((bdi->f_reg & battery_mask_f) != (f_reg & battery_mask_f)) 1802 alert_battery = true; 1803 if ((bdi->f_reg & ~battery_mask_f) != (f_reg & ~battery_mask_f)) 1804 alert_charger = true; 1805 bdi->f_reg = f_reg; 1806 mutex_unlock(&bdi->f_reg_lock); 1807 } 1808 1809 if (ss_reg != bdi->ss_reg) { 1810 /* 1811 * The device is in host mode so when PG_STAT goes from 1->0 1812 * (i.e., power removed) HIZ needs to be disabled. 1813 */ 1814 if ((bdi->ss_reg & BQ24190_REG_SS_PG_STAT_MASK) && 1815 !(ss_reg & BQ24190_REG_SS_PG_STAT_MASK)) { 1816 ret = bq24190_write_mask(bdi, BQ24190_REG_ISC, 1817 BQ24190_REG_ISC_EN_HIZ_MASK, 1818 BQ24190_REG_ISC_EN_HIZ_SHIFT, 1819 0); 1820 if (ret < 0) 1821 dev_err(bdi->dev, "Can't access ISC reg: %d\n", 1822 ret); 1823 } 1824 1825 if ((bdi->ss_reg & battery_mask_ss) != (ss_reg & battery_mask_ss)) 1826 alert_battery = true; 1827 if ((bdi->ss_reg & ~battery_mask_ss) != (ss_reg & ~battery_mask_ss)) 1828 alert_charger = true; 1829 bdi->ss_reg = ss_reg; 1830 } 1831 1832 if (alert_charger || alert_battery) { 1833 power_supply_changed(bdi->charger); 1834 bq24190_configure_usb_otg(bdi, ss_reg); 1835 } 1836 if (alert_battery && bdi->battery) 1837 power_supply_changed(bdi->battery); 1838 1839 dev_dbg(bdi->dev, "ss_reg: 0x%02x, f_reg: 0x%02x\n", ss_reg, f_reg); 1840 } 1841 1842 static irqreturn_t bq24190_irq_handler_thread(int irq, void *data) 1843 { 1844 struct bq24190_dev_info *bdi = data; 1845 int error; 1846 1847 bdi->irq_event = true; 1848 error = pm_runtime_resume_and_get(bdi->dev); 1849 if (error < 0) { 1850 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error); 1851 return IRQ_NONE; 1852 } 1853 bq24190_check_status(bdi); 1854 pm_runtime_mark_last_busy(bdi->dev); 1855 pm_runtime_put_autosuspend(bdi->dev); 1856 bdi->irq_event = false; 1857 1858 return IRQ_HANDLED; 1859 } 1860 1861 static int bq24190_check_chip(struct bq24190_dev_info *bdi) 1862 { 1863 u8 v; 1864 int ret; 1865 1866 ret = bq24190_read_mask(bdi, BQ24190_REG_VPRS, 1867 BQ24190_REG_VPRS_PN_MASK, 1868 BQ24190_REG_VPRS_PN_SHIFT, 1869 &v); 1870 if (ret < 0) 1871 return ret; 1872 1873 switch (v) { 1874 case BQ24190_REG_VPRS_PN_24190: 1875 case BQ24190_REG_VPRS_PN_24192: 1876 case BQ24190_REG_VPRS_PN_24192I: 1877 break; 1878 default: 1879 dev_err(bdi->dev, "Error unknown model: 0x%02x\n", v); 1880 return -ENODEV; 1881 } 1882 1883 return 0; 1884 } 1885 1886 static int bq24296_check_chip(struct bq24190_dev_info *bdi) 1887 { 1888 u8 v; 1889 int ret; 1890 1891 ret = bq24190_read_mask(bdi, BQ24190_REG_VPRS, 1892 BQ24296_REG_VPRS_PN_MASK, 1893 BQ24296_REG_VPRS_PN_SHIFT, 1894 &v); 1895 if (ret < 0) 1896 return ret; 1897 1898 switch (v) { 1899 case BQ24296_REG_VPRS_PN_24296: 1900 break; 1901 default: 1902 dev_err(bdi->dev, "Error unknown model: 0x%02x\n", v); 1903 return -ENODEV; 1904 } 1905 1906 return 0; 1907 } 1908 1909 static int bq24190_hw_init(struct bq24190_dev_info *bdi) 1910 { 1911 int ret; 1912 1913 ret = bdi->info->check_chip(bdi); 1914 if (ret < 0) 1915 return ret; 1916 1917 ret = bq24190_register_reset(bdi); 1918 if (ret < 0) 1919 return ret; 1920 1921 ret = bq24190_set_config(bdi); 1922 if (ret < 0) 1923 return ret; 1924 1925 return bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg); 1926 } 1927 1928 static int bq24190_get_config(struct bq24190_dev_info *bdi) 1929 { 1930 const char * const s = "ti,system-minimum-microvolt"; 1931 struct power_supply_battery_info *info; 1932 int v, idx; 1933 1934 idx = bdi->info->ichg_array_size - 1; 1935 1936 bdi->ichg_max = bq24190_ccc_ichg_values[idx]; 1937 1938 idx = ARRAY_SIZE(bq24190_cvc_vreg_values) - 1; 1939 bdi->vreg_max = bq24190_cvc_vreg_values[idx]; 1940 1941 if (device_property_read_u32(bdi->dev, s, &v) == 0) { 1942 v /= 1000; 1943 if (v >= BQ24190_REG_POC_SYS_MIN_MIN 1944 && v <= BQ24190_REG_POC_SYS_MIN_MAX) 1945 bdi->sys_min = v; 1946 else 1947 dev_warn(bdi->dev, "invalid value for %s: %u\n", s, v); 1948 } 1949 1950 if (!power_supply_get_battery_info(bdi->charger, &info)) { 1951 v = info->precharge_current_ua / 1000; 1952 if (v >= BQ24190_REG_PCTCC_IPRECHG_MIN 1953 && v <= BQ24190_REG_PCTCC_IPRECHG_MAX) 1954 bdi->iprechg = v; 1955 else 1956 dev_warn(bdi->dev, "invalid value for battery:precharge-current-microamp: %d\n", 1957 v); 1958 1959 v = info->charge_term_current_ua / 1000; 1960 if (v >= BQ24190_REG_PCTCC_ITERM_MIN 1961 && v <= BQ24190_REG_PCTCC_ITERM_MAX) 1962 bdi->iterm = v; 1963 else 1964 dev_warn(bdi->dev, "invalid value for battery:charge-term-current-microamp: %d\n", 1965 v); 1966 1967 /* These are optional, so no warning when not set */ 1968 v = info->constant_charge_current_max_ua; 1969 if (v >= bq24190_ccc_ichg_values[0] && v <= bdi->ichg_max) 1970 bdi->ichg = bdi->ichg_max = v; 1971 1972 v = info->constant_charge_voltage_max_uv; 1973 if (v >= bq24190_cvc_vreg_values[0] && v <= bdi->vreg_max) 1974 bdi->vreg = bdi->vreg_max = v; 1975 } 1976 1977 return 0; 1978 } 1979 1980 static const struct bq24190_chip_info bq24190_chip_info_tbl[] = { 1981 [BQ24190] = { 1982 .ichg_array_size = ARRAY_SIZE(bq24190_ccc_ichg_values), 1983 #ifdef CONFIG_REGULATOR 1984 .vbus_desc = &bq24190_vbus_desc, 1985 #endif 1986 .check_chip = bq24190_check_chip, 1987 .set_chg_config = bq24190_battery_set_chg_config, 1988 .ntc_fault_mask = BQ24190_REG_F_NTC_FAULT_MASK, 1989 .get_ntc_status = bq24190_charger_get_ntc_status, 1990 .set_otg_vbus = bq24190_set_otg_vbus, 1991 }, 1992 [BQ24192] = { 1993 .ichg_array_size = ARRAY_SIZE(bq24190_ccc_ichg_values), 1994 #ifdef CONFIG_REGULATOR 1995 .vbus_desc = &bq24190_vbus_desc, 1996 #endif 1997 .check_chip = bq24190_check_chip, 1998 .set_chg_config = bq24190_battery_set_chg_config, 1999 .ntc_fault_mask = BQ24190_REG_F_NTC_FAULT_MASK, 2000 .get_ntc_status = bq24190_charger_get_ntc_status, 2001 .set_otg_vbus = bq24190_set_otg_vbus, 2002 }, 2003 [BQ24192i] = { 2004 .ichg_array_size = ARRAY_SIZE(bq24190_ccc_ichg_values), 2005 #ifdef CONFIG_REGULATOR 2006 .vbus_desc = &bq24190_vbus_desc, 2007 #endif 2008 .check_chip = bq24190_check_chip, 2009 .set_chg_config = bq24190_battery_set_chg_config, 2010 .ntc_fault_mask = BQ24190_REG_F_NTC_FAULT_MASK, 2011 .get_ntc_status = bq24190_charger_get_ntc_status, 2012 .set_otg_vbus = bq24190_set_otg_vbus, 2013 }, 2014 [BQ24196] = { 2015 .ichg_array_size = ARRAY_SIZE(bq24190_ccc_ichg_values), 2016 #ifdef CONFIG_REGULATOR 2017 .vbus_desc = &bq24190_vbus_desc, 2018 #endif 2019 .check_chip = bq24190_check_chip, 2020 .set_chg_config = bq24190_battery_set_chg_config, 2021 .ntc_fault_mask = BQ24190_REG_F_NTC_FAULT_MASK, 2022 .get_ntc_status = bq24190_charger_get_ntc_status, 2023 .set_otg_vbus = bq24190_set_otg_vbus, 2024 }, 2025 [BQ24296] = { 2026 .ichg_array_size = BQ24296_CCC_ICHG_VALUES_LEN, 2027 #ifdef CONFIG_REGULATOR 2028 .vbus_desc = &bq24296_vbus_desc, 2029 #endif 2030 .check_chip = bq24296_check_chip, 2031 .set_chg_config = bq24296_battery_set_chg_config, 2032 .ntc_fault_mask = BQ24296_REG_F_NTC_FAULT_MASK, 2033 .get_ntc_status = bq24296_charger_get_ntc_status, 2034 .set_otg_vbus = bq24296_set_otg_vbus, 2035 }, 2036 }; 2037 2038 static int bq24190_probe(struct i2c_client *client) 2039 { 2040 const struct i2c_device_id *id = i2c_client_get_device_id(client); 2041 struct i2c_adapter *adapter = client->adapter; 2042 struct device *dev = &client->dev; 2043 struct power_supply_config charger_cfg = {}, battery_cfg = {}; 2044 struct bq24190_dev_info *bdi; 2045 int ret; 2046 2047 if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA)) { 2048 dev_err(dev, "No support for SMBUS_BYTE_DATA\n"); 2049 return -ENODEV; 2050 } 2051 2052 bdi = devm_kzalloc(dev, sizeof(*bdi), GFP_KERNEL); 2053 if (!bdi) { 2054 dev_err(dev, "Can't alloc bdi struct\n"); 2055 return -ENOMEM; 2056 } 2057 2058 bdi->client = client; 2059 bdi->dev = dev; 2060 strscpy(bdi->model_name, id->name, sizeof(bdi->model_name)); 2061 bdi->info = i2c_get_match_data(client); 2062 mutex_init(&bdi->f_reg_lock); 2063 bdi->charge_type = POWER_SUPPLY_CHARGE_TYPE_FAST; 2064 bdi->f_reg = 0; 2065 bdi->ss_reg = BQ24190_REG_SS_VBUS_STAT_MASK; /* impossible state */ 2066 INIT_DELAYED_WORK(&bdi->input_current_limit_work, 2067 bq24190_input_current_limit_work); 2068 2069 i2c_set_clientdata(client, bdi); 2070 2071 if (client->irq <= 0) { 2072 dev_err(dev, "Can't get irq info\n"); 2073 return -EINVAL; 2074 } 2075 2076 bdi->edev = devm_extcon_dev_allocate(dev, bq24190_usb_extcon_cable); 2077 if (IS_ERR(bdi->edev)) 2078 return PTR_ERR(bdi->edev); 2079 2080 ret = devm_extcon_dev_register(dev, bdi->edev); 2081 if (ret < 0) 2082 return ret; 2083 2084 pm_runtime_enable(dev); 2085 pm_runtime_use_autosuspend(dev); 2086 pm_runtime_set_autosuspend_delay(dev, 600); 2087 ret = pm_runtime_get_sync(dev); 2088 if (ret < 0) { 2089 dev_err(dev, "pm_runtime_get failed: %i\n", ret); 2090 goto out_pmrt; 2091 } 2092 2093 #ifdef CONFIG_SYSFS 2094 bq24190_sysfs_init_attrs(); 2095 charger_cfg.attr_grp = bq24190_sysfs_groups; 2096 #endif 2097 2098 charger_cfg.drv_data = bdi; 2099 charger_cfg.of_node = dev->of_node; 2100 charger_cfg.supplied_to = bq24190_charger_supplied_to; 2101 charger_cfg.num_supplicants = ARRAY_SIZE(bq24190_charger_supplied_to); 2102 bdi->charger = power_supply_register(dev, &bq24190_charger_desc, 2103 &charger_cfg); 2104 if (IS_ERR(bdi->charger)) { 2105 dev_err(dev, "Can't register charger\n"); 2106 ret = PTR_ERR(bdi->charger); 2107 goto out_pmrt; 2108 } 2109 2110 /* the battery class is deprecated and will be removed. */ 2111 /* in the interim, this property hides it. */ 2112 if (!device_property_read_bool(dev, "omit-battery-class")) { 2113 battery_cfg.drv_data = bdi; 2114 bdi->battery = power_supply_register(dev, &bq24190_battery_desc, 2115 &battery_cfg); 2116 if (IS_ERR(bdi->battery)) { 2117 dev_err(dev, "Can't register battery\n"); 2118 ret = PTR_ERR(bdi->battery); 2119 goto out_charger; 2120 } 2121 } 2122 2123 ret = bq24190_get_config(bdi); 2124 if (ret < 0) { 2125 dev_err(dev, "Can't get devicetree config\n"); 2126 goto out_charger; 2127 } 2128 2129 ret = bq24190_hw_init(bdi); 2130 if (ret < 0) { 2131 dev_err(dev, "Hardware init failed\n"); 2132 goto out_charger; 2133 } 2134 2135 ret = bq24190_configure_usb_otg(bdi, bdi->ss_reg); 2136 if (ret < 0) 2137 goto out_charger; 2138 2139 bdi->initialized = true; 2140 2141 ret = devm_request_threaded_irq(dev, client->irq, NULL, 2142 bq24190_irq_handler_thread, 2143 IRQF_TRIGGER_FALLING | IRQF_ONESHOT, 2144 "bq24190-charger", bdi); 2145 if (ret < 0) { 2146 dev_err(dev, "Can't set up irq handler\n"); 2147 goto out_charger; 2148 } 2149 2150 ret = bq24190_register_vbus_regulator(bdi); 2151 if (ret < 0) 2152 goto out_charger; 2153 2154 enable_irq_wake(client->irq); 2155 2156 pm_runtime_mark_last_busy(dev); 2157 pm_runtime_put_autosuspend(dev); 2158 2159 return 0; 2160 2161 out_charger: 2162 if (!IS_ERR_OR_NULL(bdi->battery)) 2163 power_supply_unregister(bdi->battery); 2164 power_supply_unregister(bdi->charger); 2165 2166 out_pmrt: 2167 pm_runtime_put_sync(dev); 2168 pm_runtime_dont_use_autosuspend(dev); 2169 pm_runtime_disable(dev); 2170 return ret; 2171 } 2172 2173 static void bq24190_remove(struct i2c_client *client) 2174 { 2175 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2176 int error; 2177 2178 cancel_delayed_work_sync(&bdi->input_current_limit_work); 2179 error = pm_runtime_resume_and_get(bdi->dev); 2180 if (error < 0) 2181 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error); 2182 2183 bq24190_register_reset(bdi); 2184 if (bdi->battery) 2185 power_supply_unregister(bdi->battery); 2186 power_supply_unregister(bdi->charger); 2187 if (error >= 0) 2188 pm_runtime_put_sync(bdi->dev); 2189 pm_runtime_dont_use_autosuspend(bdi->dev); 2190 pm_runtime_disable(bdi->dev); 2191 } 2192 2193 static void bq24190_shutdown(struct i2c_client *client) 2194 { 2195 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2196 2197 /* Turn off 5V boost regulator on shutdown */ 2198 bdi->info->set_otg_vbus(bdi, false); 2199 } 2200 2201 static __maybe_unused int bq24190_runtime_suspend(struct device *dev) 2202 { 2203 struct i2c_client *client = to_i2c_client(dev); 2204 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2205 2206 if (!bdi->initialized) 2207 return 0; 2208 2209 dev_dbg(bdi->dev, "%s\n", __func__); 2210 2211 return 0; 2212 } 2213 2214 static __maybe_unused int bq24190_runtime_resume(struct device *dev) 2215 { 2216 struct i2c_client *client = to_i2c_client(dev); 2217 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2218 2219 if (!bdi->initialized) 2220 return 0; 2221 2222 if (!bdi->irq_event) { 2223 dev_dbg(bdi->dev, "checking events on possible wakeirq\n"); 2224 bq24190_check_status(bdi); 2225 } 2226 2227 return 0; 2228 } 2229 2230 static __maybe_unused int bq24190_pm_suspend(struct device *dev) 2231 { 2232 struct i2c_client *client = to_i2c_client(dev); 2233 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2234 int error; 2235 2236 error = pm_runtime_resume_and_get(bdi->dev); 2237 if (error < 0) 2238 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error); 2239 2240 bq24190_register_reset(bdi); 2241 2242 if (error >= 0) { 2243 pm_runtime_mark_last_busy(bdi->dev); 2244 pm_runtime_put_autosuspend(bdi->dev); 2245 } 2246 2247 return 0; 2248 } 2249 2250 static __maybe_unused int bq24190_pm_resume(struct device *dev) 2251 { 2252 struct i2c_client *client = to_i2c_client(dev); 2253 struct bq24190_dev_info *bdi = i2c_get_clientdata(client); 2254 int error; 2255 2256 bdi->f_reg = 0; 2257 bdi->ss_reg = BQ24190_REG_SS_VBUS_STAT_MASK; /* impossible state */ 2258 2259 error = pm_runtime_resume_and_get(bdi->dev); 2260 if (error < 0) 2261 dev_warn(bdi->dev, "pm_runtime_get failed: %i\n", error); 2262 2263 bq24190_register_reset(bdi); 2264 bq24190_set_config(bdi); 2265 bq24190_read(bdi, BQ24190_REG_SS, &bdi->ss_reg); 2266 2267 if (error >= 0) { 2268 pm_runtime_mark_last_busy(bdi->dev); 2269 pm_runtime_put_autosuspend(bdi->dev); 2270 } 2271 2272 /* Things may have changed while suspended so alert upper layer */ 2273 power_supply_changed(bdi->charger); 2274 if (bdi->battery) 2275 power_supply_changed(bdi->battery); 2276 2277 return 0; 2278 } 2279 2280 static const struct dev_pm_ops bq24190_pm_ops = { 2281 SET_RUNTIME_PM_OPS(bq24190_runtime_suspend, bq24190_runtime_resume, 2282 NULL) 2283 SET_SYSTEM_SLEEP_PM_OPS(bq24190_pm_suspend, bq24190_pm_resume) 2284 }; 2285 2286 static const struct i2c_device_id bq24190_i2c_ids[] = { 2287 { "bq24190", (kernel_ulong_t)&bq24190_chip_info_tbl[BQ24190] }, 2288 { "bq24192", (kernel_ulong_t)&bq24190_chip_info_tbl[BQ24192] }, 2289 { "bq24192i", (kernel_ulong_t)&bq24190_chip_info_tbl[BQ24192i] }, 2290 { "bq24196", (kernel_ulong_t)&bq24190_chip_info_tbl[BQ24196] }, 2291 { "bq24296", (kernel_ulong_t)&bq24190_chip_info_tbl[BQ24296] }, 2292 { }, 2293 }; 2294 MODULE_DEVICE_TABLE(i2c, bq24190_i2c_ids); 2295 2296 static const struct of_device_id bq24190_of_match[] = { 2297 { .compatible = "ti,bq24190", .data = &bq24190_chip_info_tbl[BQ24190] }, 2298 { .compatible = "ti,bq24192", .data = &bq24190_chip_info_tbl[BQ24192] }, 2299 { .compatible = "ti,bq24192i", .data = &bq24190_chip_info_tbl[BQ24192i] }, 2300 { .compatible = "ti,bq24196", .data = &bq24190_chip_info_tbl[BQ24196] }, 2301 { .compatible = "ti,bq24296", .data = &bq24190_chip_info_tbl[BQ24296] }, 2302 { }, 2303 }; 2304 MODULE_DEVICE_TABLE(of, bq24190_of_match); 2305 2306 static struct i2c_driver bq24190_driver = { 2307 .probe = bq24190_probe, 2308 .remove = bq24190_remove, 2309 .shutdown = bq24190_shutdown, 2310 .id_table = bq24190_i2c_ids, 2311 .driver = { 2312 .name = "bq24190-charger", 2313 .pm = &bq24190_pm_ops, 2314 .of_match_table = bq24190_of_match, 2315 }, 2316 }; 2317 module_i2c_driver(bq24190_driver); 2318 2319 MODULE_LICENSE("GPL"); 2320 MODULE_AUTHOR("Mark A. Greer <mgreer@animalcreek.com>"); 2321 MODULE_DESCRIPTION("TI BQ24190 Charger Driver"); 2322