bq25980_charger.c (32504B)
1// SPDX-License-Identifier: GPL-2.0 2// BQ25980 Battery Charger Driver 3// Copyright (C) 2020 Texas Instruments Incorporated - http://www.ti.com/ 4 5#include <linux/err.h> 6#include <linux/i2c.h> 7#include <linux/init.h> 8#include <linux/interrupt.h> 9#include <linux/kernel.h> 10#include <linux/module.h> 11#include <linux/gpio/consumer.h> 12#include <linux/power_supply.h> 13#include <linux/regmap.h> 14#include <linux/types.h> 15#include <linux/delay.h> 16#include <linux/device.h> 17#include <linux/moduleparam.h> 18#include <linux/slab.h> 19 20#include "bq25980_charger.h" 21 22struct bq25980_state { 23 bool dischg; 24 bool ovp; 25 bool ocp; 26 bool wdt; 27 bool tflt; 28 bool online; 29 bool ce; 30 bool hiz; 31 bool bypass; 32 33 u32 vbat_adc; 34 u32 vsys_adc; 35 u32 ibat_adc; 36}; 37 38enum bq25980_id { 39 BQ25980, 40 BQ25975, 41 BQ25960, 42}; 43 44struct bq25980_chip_info { 45 46 int model_id; 47 48 const struct regmap_config *regmap_config; 49 50 int busocp_def; 51 int busocp_sc_max; 52 int busocp_byp_max; 53 int busocp_sc_min; 54 int busocp_byp_min; 55 56 int busovp_sc_def; 57 int busovp_byp_def; 58 int busovp_sc_step; 59 60 int busovp_sc_offset; 61 int busovp_byp_step; 62 int busovp_byp_offset; 63 int busovp_sc_min; 64 int busovp_sc_max; 65 int busovp_byp_min; 66 int busovp_byp_max; 67 68 int batovp_def; 69 int batovp_max; 70 int batovp_min; 71 int batovp_step; 72 int batovp_offset; 73 74 int batocp_def; 75 int batocp_max; 76}; 77 78struct bq25980_init_data { 79 u32 ichg; 80 u32 bypass_ilim; 81 u32 sc_ilim; 82 u32 vreg; 83 u32 iterm; 84 u32 iprechg; 85 u32 bypass_vlim; 86 u32 sc_vlim; 87 u32 ichg_max; 88 u32 vreg_max; 89}; 90 91struct bq25980_device { 92 struct i2c_client *client; 93 struct device *dev; 94 struct power_supply *charger; 95 struct power_supply *battery; 96 struct mutex lock; 97 struct regmap *regmap; 98 99 char model_name[I2C_NAME_SIZE]; 100 101 struct bq25980_init_data init_data; 102 const struct bq25980_chip_info *chip_info; 103 struct bq25980_state state; 104 int watchdog_timer; 105}; 106 107static struct reg_default bq25980_reg_defs[] = { 108 {BQ25980_BATOVP, 0x5A}, 109 {BQ25980_BATOVP_ALM, 0x46}, 110 {BQ25980_BATOCP, 0x51}, 111 {BQ25980_BATOCP_ALM, 0x50}, 112 {BQ25980_BATUCP_ALM, 0x28}, 113 {BQ25980_CHRGR_CTRL_1, 0x0}, 114 {BQ25980_BUSOVP, 0x26}, 115 {BQ25980_BUSOVP_ALM, 0x22}, 116 {BQ25980_BUSOCP, 0xD}, 117 {BQ25980_BUSOCP_ALM, 0xC}, 118 {BQ25980_TEMP_CONTROL, 0x30}, 119 {BQ25980_TDIE_ALM, 0xC8}, 120 {BQ25980_TSBUS_FLT, 0x15}, 121 {BQ25980_TSBAT_FLG, 0x15}, 122 {BQ25980_VAC_CONTROL, 0x0}, 123 {BQ25980_CHRGR_CTRL_2, 0x0}, 124 {BQ25980_CHRGR_CTRL_3, 0x20}, 125 {BQ25980_CHRGR_CTRL_4, 0x1D}, 126 {BQ25980_CHRGR_CTRL_5, 0x18}, 127 {BQ25980_STAT1, 0x0}, 128 {BQ25980_STAT2, 0x0}, 129 {BQ25980_STAT3, 0x0}, 130 {BQ25980_STAT4, 0x0}, 131 {BQ25980_STAT5, 0x0}, 132 {BQ25980_FLAG1, 0x0}, 133 {BQ25980_FLAG2, 0x0}, 134 {BQ25980_FLAG3, 0x0}, 135 {BQ25980_FLAG4, 0x0}, 136 {BQ25980_FLAG5, 0x0}, 137 {BQ25980_MASK1, 0x0}, 138 {BQ25980_MASK2, 0x0}, 139 {BQ25980_MASK3, 0x0}, 140 {BQ25980_MASK4, 0x0}, 141 {BQ25980_MASK5, 0x0}, 142 {BQ25980_DEVICE_INFO, 0x8}, 143 {BQ25980_ADC_CONTROL1, 0x0}, 144 {BQ25980_ADC_CONTROL2, 0x0}, 145 {BQ25980_IBUS_ADC_LSB, 0x0}, 146 {BQ25980_IBUS_ADC_MSB, 0x0}, 147 {BQ25980_VBUS_ADC_LSB, 0x0}, 148 {BQ25980_VBUS_ADC_MSB, 0x0}, 149 {BQ25980_VAC1_ADC_LSB, 0x0}, 150 {BQ25980_VAC2_ADC_LSB, 0x0}, 151 {BQ25980_VOUT_ADC_LSB, 0x0}, 152 {BQ25980_VBAT_ADC_LSB, 0x0}, 153 {BQ25980_IBAT_ADC_MSB, 0x0}, 154 {BQ25980_IBAT_ADC_LSB, 0x0}, 155 {BQ25980_TSBUS_ADC_LSB, 0x0}, 156 {BQ25980_TSBAT_ADC_LSB, 0x0}, 157 {BQ25980_TDIE_ADC_LSB, 0x0}, 158 {BQ25980_DEGLITCH_TIME, 0x0}, 159 {BQ25980_CHRGR_CTRL_6, 0x0}, 160}; 161 162static struct reg_default bq25975_reg_defs[] = { 163 {BQ25980_BATOVP, 0x5A}, 164 {BQ25980_BATOVP_ALM, 0x46}, 165 {BQ25980_BATOCP, 0x51}, 166 {BQ25980_BATOCP_ALM, 0x50}, 167 {BQ25980_BATUCP_ALM, 0x28}, 168 {BQ25980_CHRGR_CTRL_1, 0x0}, 169 {BQ25980_BUSOVP, 0x26}, 170 {BQ25980_BUSOVP_ALM, 0x22}, 171 {BQ25980_BUSOCP, 0xD}, 172 {BQ25980_BUSOCP_ALM, 0xC}, 173 {BQ25980_TEMP_CONTROL, 0x30}, 174 {BQ25980_TDIE_ALM, 0xC8}, 175 {BQ25980_TSBUS_FLT, 0x15}, 176 {BQ25980_TSBAT_FLG, 0x15}, 177 {BQ25980_VAC_CONTROL, 0x0}, 178 {BQ25980_CHRGR_CTRL_2, 0x0}, 179 {BQ25980_CHRGR_CTRL_3, 0x20}, 180 {BQ25980_CHRGR_CTRL_4, 0x1D}, 181 {BQ25980_CHRGR_CTRL_5, 0x18}, 182 {BQ25980_STAT1, 0x0}, 183 {BQ25980_STAT2, 0x0}, 184 {BQ25980_STAT3, 0x0}, 185 {BQ25980_STAT4, 0x0}, 186 {BQ25980_STAT5, 0x0}, 187 {BQ25980_FLAG1, 0x0}, 188 {BQ25980_FLAG2, 0x0}, 189 {BQ25980_FLAG3, 0x0}, 190 {BQ25980_FLAG4, 0x0}, 191 {BQ25980_FLAG5, 0x0}, 192 {BQ25980_MASK1, 0x0}, 193 {BQ25980_MASK2, 0x0}, 194 {BQ25980_MASK3, 0x0}, 195 {BQ25980_MASK4, 0x0}, 196 {BQ25980_MASK5, 0x0}, 197 {BQ25980_DEVICE_INFO, 0x8}, 198 {BQ25980_ADC_CONTROL1, 0x0}, 199 {BQ25980_ADC_CONTROL2, 0x0}, 200 {BQ25980_IBUS_ADC_LSB, 0x0}, 201 {BQ25980_IBUS_ADC_MSB, 0x0}, 202 {BQ25980_VBUS_ADC_LSB, 0x0}, 203 {BQ25980_VBUS_ADC_MSB, 0x0}, 204 {BQ25980_VAC1_ADC_LSB, 0x0}, 205 {BQ25980_VAC2_ADC_LSB, 0x0}, 206 {BQ25980_VOUT_ADC_LSB, 0x0}, 207 {BQ25980_VBAT_ADC_LSB, 0x0}, 208 {BQ25980_IBAT_ADC_MSB, 0x0}, 209 {BQ25980_IBAT_ADC_LSB, 0x0}, 210 {BQ25980_TSBUS_ADC_LSB, 0x0}, 211 {BQ25980_TSBAT_ADC_LSB, 0x0}, 212 {BQ25980_TDIE_ADC_LSB, 0x0}, 213 {BQ25980_DEGLITCH_TIME, 0x0}, 214 {BQ25980_CHRGR_CTRL_6, 0x0}, 215}; 216 217static struct reg_default bq25960_reg_defs[] = { 218 {BQ25980_BATOVP, 0x5A}, 219 {BQ25980_BATOVP_ALM, 0x46}, 220 {BQ25980_BATOCP, 0x51}, 221 {BQ25980_BATOCP_ALM, 0x50}, 222 {BQ25980_BATUCP_ALM, 0x28}, 223 {BQ25980_CHRGR_CTRL_1, 0x0}, 224 {BQ25980_BUSOVP, 0x26}, 225 {BQ25980_BUSOVP_ALM, 0x22}, 226 {BQ25980_BUSOCP, 0xD}, 227 {BQ25980_BUSOCP_ALM, 0xC}, 228 {BQ25980_TEMP_CONTROL, 0x30}, 229 {BQ25980_TDIE_ALM, 0xC8}, 230 {BQ25980_TSBUS_FLT, 0x15}, 231 {BQ25980_TSBAT_FLG, 0x15}, 232 {BQ25980_VAC_CONTROL, 0x0}, 233 {BQ25980_CHRGR_CTRL_2, 0x0}, 234 {BQ25980_CHRGR_CTRL_3, 0x20}, 235 {BQ25980_CHRGR_CTRL_4, 0x1D}, 236 {BQ25980_CHRGR_CTRL_5, 0x18}, 237 {BQ25980_STAT1, 0x0}, 238 {BQ25980_STAT2, 0x0}, 239 {BQ25980_STAT3, 0x0}, 240 {BQ25980_STAT4, 0x0}, 241 {BQ25980_STAT5, 0x0}, 242 {BQ25980_FLAG1, 0x0}, 243 {BQ25980_FLAG2, 0x0}, 244 {BQ25980_FLAG3, 0x0}, 245 {BQ25980_FLAG4, 0x0}, 246 {BQ25980_FLAG5, 0x0}, 247 {BQ25980_MASK1, 0x0}, 248 {BQ25980_MASK2, 0x0}, 249 {BQ25980_MASK3, 0x0}, 250 {BQ25980_MASK4, 0x0}, 251 {BQ25980_MASK5, 0x0}, 252 {BQ25980_DEVICE_INFO, 0x8}, 253 {BQ25980_ADC_CONTROL1, 0x0}, 254 {BQ25980_ADC_CONTROL2, 0x0}, 255 {BQ25980_IBUS_ADC_LSB, 0x0}, 256 {BQ25980_IBUS_ADC_MSB, 0x0}, 257 {BQ25980_VBUS_ADC_LSB, 0x0}, 258 {BQ25980_VBUS_ADC_MSB, 0x0}, 259 {BQ25980_VAC1_ADC_LSB, 0x0}, 260 {BQ25980_VAC2_ADC_LSB, 0x0}, 261 {BQ25980_VOUT_ADC_LSB, 0x0}, 262 {BQ25980_VBAT_ADC_LSB, 0x0}, 263 {BQ25980_IBAT_ADC_MSB, 0x0}, 264 {BQ25980_IBAT_ADC_LSB, 0x0}, 265 {BQ25980_TSBUS_ADC_LSB, 0x0}, 266 {BQ25980_TSBAT_ADC_LSB, 0x0}, 267 {BQ25980_TDIE_ADC_LSB, 0x0}, 268 {BQ25980_DEGLITCH_TIME, 0x0}, 269 {BQ25980_CHRGR_CTRL_6, 0x0}, 270}; 271 272static int bq25980_watchdog_time[BQ25980_NUM_WD_VAL] = {5000, 10000, 50000, 273 300000}; 274 275static int bq25980_get_input_curr_lim(struct bq25980_device *bq) 276{ 277 unsigned int busocp_reg_code; 278 int ret; 279 280 ret = regmap_read(bq->regmap, BQ25980_BUSOCP, &busocp_reg_code); 281 if (ret) 282 return ret; 283 284 return (busocp_reg_code * BQ25980_BUSOCP_STEP_uA) + BQ25980_BUSOCP_OFFSET_uA; 285} 286 287static int bq25980_set_hiz(struct bq25980_device *bq, int setting) 288{ 289 return regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 290 BQ25980_EN_HIZ, setting); 291} 292 293static int bq25980_set_input_curr_lim(struct bq25980_device *bq, int busocp) 294{ 295 unsigned int busocp_reg_code; 296 int ret; 297 298 if (!busocp) 299 return bq25980_set_hiz(bq, BQ25980_ENABLE_HIZ); 300 301 bq25980_set_hiz(bq, BQ25980_DISABLE_HIZ); 302 303 if (busocp < BQ25980_BUSOCP_MIN_uA) 304 busocp = BQ25980_BUSOCP_MIN_uA; 305 306 if (bq->state.bypass) 307 busocp = min(busocp, bq->chip_info->busocp_sc_max); 308 else 309 busocp = min(busocp, bq->chip_info->busocp_byp_max); 310 311 busocp_reg_code = (busocp - BQ25980_BUSOCP_OFFSET_uA) 312 / BQ25980_BUSOCP_STEP_uA; 313 314 ret = regmap_write(bq->regmap, BQ25980_BUSOCP, busocp_reg_code); 315 if (ret) 316 return ret; 317 318 return regmap_write(bq->regmap, BQ25980_BUSOCP_ALM, busocp_reg_code); 319} 320 321static int bq25980_get_input_volt_lim(struct bq25980_device *bq) 322{ 323 unsigned int busovp_reg_code; 324 unsigned int busovp_offset; 325 unsigned int busovp_step; 326 int ret; 327 328 if (bq->state.bypass) { 329 busovp_step = bq->chip_info->busovp_byp_step; 330 busovp_offset = bq->chip_info->busovp_byp_offset; 331 } else { 332 busovp_step = bq->chip_info->busovp_sc_step; 333 busovp_offset = bq->chip_info->busovp_sc_offset; 334 } 335 336 ret = regmap_read(bq->regmap, BQ25980_BUSOVP, &busovp_reg_code); 337 if (ret) 338 return ret; 339 340 return (busovp_reg_code * busovp_step) + busovp_offset; 341} 342 343static int bq25980_set_input_volt_lim(struct bq25980_device *bq, int busovp) 344{ 345 unsigned int busovp_reg_code; 346 unsigned int busovp_step; 347 unsigned int busovp_offset; 348 int ret; 349 350 if (bq->state.bypass) { 351 busovp_step = bq->chip_info->busovp_byp_step; 352 busovp_offset = bq->chip_info->busovp_byp_offset; 353 if (busovp > bq->chip_info->busovp_byp_max) 354 busovp = bq->chip_info->busovp_byp_max; 355 else if (busovp < bq->chip_info->busovp_byp_min) 356 busovp = bq->chip_info->busovp_byp_min; 357 } else { 358 busovp_step = bq->chip_info->busovp_sc_step; 359 busovp_offset = bq->chip_info->busovp_sc_offset; 360 if (busovp > bq->chip_info->busovp_sc_max) 361 busovp = bq->chip_info->busovp_sc_max; 362 else if (busovp < bq->chip_info->busovp_sc_min) 363 busovp = bq->chip_info->busovp_sc_min; 364 } 365 366 busovp_reg_code = (busovp - busovp_offset) / busovp_step; 367 368 ret = regmap_write(bq->regmap, BQ25980_BUSOVP, busovp_reg_code); 369 if (ret) 370 return ret; 371 372 return regmap_write(bq->regmap, BQ25980_BUSOVP_ALM, busovp_reg_code); 373} 374 375static int bq25980_get_const_charge_curr(struct bq25980_device *bq) 376{ 377 unsigned int batocp_reg_code; 378 int ret; 379 380 ret = regmap_read(bq->regmap, BQ25980_BATOCP, &batocp_reg_code); 381 if (ret) 382 return ret; 383 384 return (batocp_reg_code & BQ25980_BATOCP_MASK) * 385 BQ25980_BATOCP_STEP_uA; 386} 387 388static int bq25980_set_const_charge_curr(struct bq25980_device *bq, int batocp) 389{ 390 unsigned int batocp_reg_code; 391 int ret; 392 393 batocp = max(batocp, BQ25980_BATOCP_MIN_uA); 394 batocp = min(batocp, bq->chip_info->batocp_max); 395 396 batocp_reg_code = batocp / BQ25980_BATOCP_STEP_uA; 397 398 ret = regmap_update_bits(bq->regmap, BQ25980_BATOCP, 399 BQ25980_BATOCP_MASK, batocp_reg_code); 400 if (ret) 401 return ret; 402 403 return regmap_update_bits(bq->regmap, BQ25980_BATOCP_ALM, 404 BQ25980_BATOCP_MASK, batocp_reg_code); 405} 406 407static int bq25980_get_const_charge_volt(struct bq25980_device *bq) 408{ 409 unsigned int batovp_reg_code; 410 int ret; 411 412 ret = regmap_read(bq->regmap, BQ25980_BATOVP, &batovp_reg_code); 413 if (ret) 414 return ret; 415 416 return ((batovp_reg_code * bq->chip_info->batovp_step) + 417 bq->chip_info->batovp_offset); 418} 419 420static int bq25980_set_const_charge_volt(struct bq25980_device *bq, int batovp) 421{ 422 unsigned int batovp_reg_code; 423 int ret; 424 425 if (batovp < bq->chip_info->batovp_min) 426 batovp = bq->chip_info->batovp_min; 427 428 if (batovp > bq->chip_info->batovp_max) 429 batovp = bq->chip_info->batovp_max; 430 431 batovp_reg_code = (batovp - bq->chip_info->batovp_offset) / 432 bq->chip_info->batovp_step; 433 434 ret = regmap_write(bq->regmap, BQ25980_BATOVP, batovp_reg_code); 435 if (ret) 436 return ret; 437 438 return regmap_write(bq->regmap, BQ25980_BATOVP_ALM, batovp_reg_code); 439} 440 441static int bq25980_set_bypass(struct bq25980_device *bq, bool en_bypass) 442{ 443 int ret; 444 445 if (en_bypass) 446 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 447 BQ25980_EN_BYPASS, BQ25980_EN_BYPASS); 448 else 449 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 450 BQ25980_EN_BYPASS, en_bypass); 451 if (ret) 452 return ret; 453 454 bq->state.bypass = en_bypass; 455 456 return bq->state.bypass; 457} 458 459static int bq25980_set_chg_en(struct bq25980_device *bq, bool en_chg) 460{ 461 int ret; 462 463 if (en_chg) 464 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 465 BQ25980_CHG_EN, BQ25980_CHG_EN); 466 else 467 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 468 BQ25980_CHG_EN, en_chg); 469 if (ret) 470 return ret; 471 472 bq->state.ce = en_chg; 473 474 return 0; 475} 476 477static int bq25980_get_adc_ibus(struct bq25980_device *bq) 478{ 479 int ibus_adc_lsb, ibus_adc_msb; 480 u16 ibus_adc; 481 int ret; 482 483 ret = regmap_read(bq->regmap, BQ25980_IBUS_ADC_MSB, &ibus_adc_msb); 484 if (ret) 485 return ret; 486 487 ret = regmap_read(bq->regmap, BQ25980_IBUS_ADC_LSB, &ibus_adc_lsb); 488 if (ret) 489 return ret; 490 491 ibus_adc = (ibus_adc_msb << 8) | ibus_adc_lsb; 492 493 if (ibus_adc_msb & BQ25980_ADC_POLARITY_BIT) 494 return ((ibus_adc ^ 0xffff) + 1) * BQ25980_ADC_CURR_STEP_uA; 495 496 return ibus_adc * BQ25980_ADC_CURR_STEP_uA; 497} 498 499static int bq25980_get_adc_vbus(struct bq25980_device *bq) 500{ 501 int vbus_adc_lsb, vbus_adc_msb; 502 u16 vbus_adc; 503 int ret; 504 505 ret = regmap_read(bq->regmap, BQ25980_VBUS_ADC_MSB, &vbus_adc_msb); 506 if (ret) 507 return ret; 508 509 ret = regmap_read(bq->regmap, BQ25980_VBUS_ADC_LSB, &vbus_adc_lsb); 510 if (ret) 511 return ret; 512 513 vbus_adc = (vbus_adc_msb << 8) | vbus_adc_lsb; 514 515 return vbus_adc * BQ25980_ADC_VOLT_STEP_uV; 516} 517 518static int bq25980_get_ibat_adc(struct bq25980_device *bq) 519{ 520 int ret; 521 int ibat_adc_lsb, ibat_adc_msb; 522 int ibat_adc; 523 524 ret = regmap_read(bq->regmap, BQ25980_IBAT_ADC_MSB, &ibat_adc_msb); 525 if (ret) 526 return ret; 527 528 ret = regmap_read(bq->regmap, BQ25980_IBAT_ADC_LSB, &ibat_adc_lsb); 529 if (ret) 530 return ret; 531 532 ibat_adc = (ibat_adc_msb << 8) | ibat_adc_lsb; 533 534 if (ibat_adc_msb & BQ25980_ADC_POLARITY_BIT) 535 return ((ibat_adc ^ 0xffff) + 1) * BQ25980_ADC_CURR_STEP_uA; 536 537 return ibat_adc * BQ25980_ADC_CURR_STEP_uA; 538} 539 540static int bq25980_get_adc_vbat(struct bq25980_device *bq) 541{ 542 int vsys_adc_lsb, vsys_adc_msb; 543 u16 vsys_adc; 544 int ret; 545 546 ret = regmap_read(bq->regmap, BQ25980_VBAT_ADC_MSB, &vsys_adc_msb); 547 if (ret) 548 return ret; 549 550 ret = regmap_read(bq->regmap, BQ25980_VBAT_ADC_LSB, &vsys_adc_lsb); 551 if (ret) 552 return ret; 553 554 vsys_adc = (vsys_adc_msb << 8) | vsys_adc_lsb; 555 556 return vsys_adc * BQ25980_ADC_VOLT_STEP_uV; 557} 558 559static int bq25980_get_state(struct bq25980_device *bq, 560 struct bq25980_state *state) 561{ 562 unsigned int chg_ctrl_2; 563 unsigned int stat1; 564 unsigned int stat2; 565 unsigned int stat3; 566 unsigned int stat4; 567 unsigned int ibat_adc_msb; 568 int ret; 569 570 ret = regmap_read(bq->regmap, BQ25980_STAT1, &stat1); 571 if (ret) 572 return ret; 573 574 ret = regmap_read(bq->regmap, BQ25980_STAT2, &stat2); 575 if (ret) 576 return ret; 577 578 ret = regmap_read(bq->regmap, BQ25980_STAT3, &stat3); 579 if (ret) 580 return ret; 581 582 ret = regmap_read(bq->regmap, BQ25980_STAT4, &stat4); 583 if (ret) 584 return ret; 585 586 ret = regmap_read(bq->regmap, BQ25980_CHRGR_CTRL_2, &chg_ctrl_2); 587 if (ret) 588 return ret; 589 590 ret = regmap_read(bq->regmap, BQ25980_IBAT_ADC_MSB, &ibat_adc_msb); 591 if (ret) 592 return ret; 593 594 state->dischg = ibat_adc_msb & BQ25980_ADC_POLARITY_BIT; 595 state->ovp = (stat1 & BQ25980_STAT1_OVP_MASK) | 596 (stat3 & BQ25980_STAT3_OVP_MASK); 597 state->ocp = (stat1 & BQ25980_STAT1_OCP_MASK) | 598 (stat2 & BQ25980_STAT2_OCP_MASK); 599 state->tflt = stat4 & BQ25980_STAT4_TFLT_MASK; 600 state->wdt = stat4 & BQ25980_WD_STAT; 601 state->online = stat3 & BQ25980_PRESENT_MASK; 602 state->ce = chg_ctrl_2 & BQ25980_CHG_EN; 603 state->hiz = chg_ctrl_2 & BQ25980_EN_HIZ; 604 state->bypass = chg_ctrl_2 & BQ25980_EN_BYPASS; 605 606 return 0; 607} 608 609static int bq25980_get_battery_property(struct power_supply *psy, 610 enum power_supply_property psp, 611 union power_supply_propval *val) 612{ 613 struct bq25980_device *bq = power_supply_get_drvdata(psy); 614 int ret = 0; 615 616 switch (psp) { 617 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX: 618 val->intval = bq->init_data.ichg_max; 619 break; 620 621 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX: 622 val->intval = bq->init_data.vreg_max; 623 break; 624 625 case POWER_SUPPLY_PROP_CURRENT_NOW: 626 ret = bq25980_get_ibat_adc(bq); 627 val->intval = ret; 628 break; 629 630 case POWER_SUPPLY_PROP_VOLTAGE_NOW: 631 ret = bq25980_get_adc_vbat(bq); 632 if (ret < 0) 633 return ret; 634 635 val->intval = ret; 636 break; 637 638 default: 639 return -EINVAL; 640 } 641 642 return ret; 643} 644 645static int bq25980_set_charger_property(struct power_supply *psy, 646 enum power_supply_property prop, 647 const union power_supply_propval *val) 648{ 649 struct bq25980_device *bq = power_supply_get_drvdata(psy); 650 int ret = -EINVAL; 651 652 switch (prop) { 653 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 654 ret = bq25980_set_input_curr_lim(bq, val->intval); 655 if (ret) 656 return ret; 657 break; 658 659 case POWER_SUPPLY_PROP_INPUT_VOLTAGE_LIMIT: 660 ret = bq25980_set_input_volt_lim(bq, val->intval); 661 if (ret) 662 return ret; 663 break; 664 665 case POWER_SUPPLY_PROP_CHARGE_TYPE: 666 ret = bq25980_set_bypass(bq, val->intval); 667 if (ret) 668 return ret; 669 break; 670 671 case POWER_SUPPLY_PROP_STATUS: 672 ret = bq25980_set_chg_en(bq, val->intval); 673 if (ret) 674 return ret; 675 break; 676 677 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 678 ret = bq25980_set_const_charge_curr(bq, val->intval); 679 if (ret) 680 return ret; 681 break; 682 683 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 684 ret = bq25980_set_const_charge_volt(bq, val->intval); 685 if (ret) 686 return ret; 687 break; 688 689 default: 690 return -EINVAL; 691 } 692 693 return ret; 694} 695 696static int bq25980_get_charger_property(struct power_supply *psy, 697 enum power_supply_property psp, 698 union power_supply_propval *val) 699{ 700 struct bq25980_device *bq = power_supply_get_drvdata(psy); 701 struct bq25980_state state; 702 int ret = 0; 703 704 mutex_lock(&bq->lock); 705 ret = bq25980_get_state(bq, &state); 706 mutex_unlock(&bq->lock); 707 if (ret) 708 return ret; 709 710 switch (psp) { 711 case POWER_SUPPLY_PROP_MANUFACTURER: 712 val->strval = BQ25980_MANUFACTURER; 713 break; 714 case POWER_SUPPLY_PROP_MODEL_NAME: 715 val->strval = bq->model_name; 716 break; 717 case POWER_SUPPLY_PROP_ONLINE: 718 val->intval = state.online; 719 break; 720 721 case POWER_SUPPLY_PROP_INPUT_VOLTAGE_LIMIT: 722 ret = bq25980_get_input_volt_lim(bq); 723 if (ret < 0) 724 return ret; 725 val->intval = ret; 726 break; 727 728 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 729 ret = bq25980_get_input_curr_lim(bq); 730 if (ret < 0) 731 return ret; 732 733 val->intval = ret; 734 break; 735 736 case POWER_SUPPLY_PROP_HEALTH: 737 val->intval = POWER_SUPPLY_HEALTH_GOOD; 738 739 if (state.tflt) 740 val->intval = POWER_SUPPLY_HEALTH_OVERHEAT; 741 else if (state.ovp) 742 val->intval = POWER_SUPPLY_HEALTH_OVERVOLTAGE; 743 else if (state.ocp) 744 val->intval = POWER_SUPPLY_HEALTH_OVERCURRENT; 745 else if (state.wdt) 746 val->intval = 747 POWER_SUPPLY_HEALTH_WATCHDOG_TIMER_EXPIRE; 748 break; 749 750 case POWER_SUPPLY_PROP_STATUS: 751 val->intval = POWER_SUPPLY_STATUS_UNKNOWN; 752 753 if ((state.ce) && (!state.hiz)) 754 val->intval = POWER_SUPPLY_STATUS_CHARGING; 755 else if (state.dischg) 756 val->intval = POWER_SUPPLY_STATUS_DISCHARGING; 757 else if (!state.ce) 758 val->intval = POWER_SUPPLY_STATUS_NOT_CHARGING; 759 break; 760 761 case POWER_SUPPLY_PROP_CHARGE_TYPE: 762 val->intval = POWER_SUPPLY_CHARGE_TYPE_UNKNOWN; 763 764 if (!state.ce) 765 val->intval = POWER_SUPPLY_CHARGE_TYPE_NONE; 766 else if (state.bypass) 767 val->intval = POWER_SUPPLY_CHARGE_TYPE_BYPASS; 768 else if (!state.bypass) 769 val->intval = POWER_SUPPLY_CHARGE_TYPE_STANDARD; 770 break; 771 772 case POWER_SUPPLY_PROP_CURRENT_NOW: 773 ret = bq25980_get_adc_ibus(bq); 774 if (ret < 0) 775 return ret; 776 777 val->intval = ret; 778 break; 779 780 case POWER_SUPPLY_PROP_VOLTAGE_NOW: 781 ret = bq25980_get_adc_vbus(bq); 782 if (ret < 0) 783 return ret; 784 785 val->intval = ret; 786 break; 787 788 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 789 ret = bq25980_get_const_charge_curr(bq); 790 if (ret < 0) 791 return ret; 792 793 val->intval = ret; 794 break; 795 796 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 797 ret = bq25980_get_const_charge_volt(bq); 798 if (ret < 0) 799 return ret; 800 801 val->intval = ret; 802 break; 803 804 default: 805 return -EINVAL; 806 } 807 808 return ret; 809} 810 811static bool bq25980_state_changed(struct bq25980_device *bq, 812 struct bq25980_state *new_state) 813{ 814 struct bq25980_state old_state; 815 816 mutex_lock(&bq->lock); 817 old_state = bq->state; 818 mutex_unlock(&bq->lock); 819 820 return (old_state.dischg != new_state->dischg || 821 old_state.ovp != new_state->ovp || 822 old_state.ocp != new_state->ocp || 823 old_state.online != new_state->online || 824 old_state.wdt != new_state->wdt || 825 old_state.tflt != new_state->tflt || 826 old_state.ce != new_state->ce || 827 old_state.hiz != new_state->hiz || 828 old_state.bypass != new_state->bypass); 829} 830 831static irqreturn_t bq25980_irq_handler_thread(int irq, void *private) 832{ 833 struct bq25980_device *bq = private; 834 struct bq25980_state state; 835 int ret; 836 837 ret = bq25980_get_state(bq, &state); 838 if (ret < 0) 839 goto irq_out; 840 841 if (!bq25980_state_changed(bq, &state)) 842 goto irq_out; 843 844 mutex_lock(&bq->lock); 845 bq->state = state; 846 mutex_unlock(&bq->lock); 847 848 power_supply_changed(bq->charger); 849 850irq_out: 851 return IRQ_HANDLED; 852} 853 854static enum power_supply_property bq25980_power_supply_props[] = { 855 POWER_SUPPLY_PROP_MANUFACTURER, 856 POWER_SUPPLY_PROP_MODEL_NAME, 857 POWER_SUPPLY_PROP_STATUS, 858 POWER_SUPPLY_PROP_ONLINE, 859 POWER_SUPPLY_PROP_HEALTH, 860 POWER_SUPPLY_PROP_INPUT_VOLTAGE_LIMIT, 861 POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT, 862 POWER_SUPPLY_PROP_CHARGE_TYPE, 863 POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT, 864 POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE, 865 POWER_SUPPLY_PROP_CURRENT_NOW, 866 POWER_SUPPLY_PROP_VOLTAGE_NOW, 867}; 868 869static enum power_supply_property bq25980_battery_props[] = { 870 POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX, 871 POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX, 872 POWER_SUPPLY_PROP_CURRENT_NOW, 873 POWER_SUPPLY_PROP_VOLTAGE_NOW, 874}; 875 876static char *bq25980_charger_supplied_to[] = { 877 "main-battery", 878}; 879 880static int bq25980_property_is_writeable(struct power_supply *psy, 881 enum power_supply_property prop) 882{ 883 switch (prop) { 884 case POWER_SUPPLY_PROP_INPUT_CURRENT_LIMIT: 885 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE: 886 case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT: 887 case POWER_SUPPLY_PROP_CHARGE_TYPE: 888 case POWER_SUPPLY_PROP_STATUS: 889 case POWER_SUPPLY_PROP_INPUT_VOLTAGE_LIMIT: 890 return true; 891 default: 892 return false; 893 } 894} 895 896static const struct power_supply_desc bq25980_power_supply_desc = { 897 .name = "bq25980-charger", 898 .type = POWER_SUPPLY_TYPE_MAINS, 899 .properties = bq25980_power_supply_props, 900 .num_properties = ARRAY_SIZE(bq25980_power_supply_props), 901 .get_property = bq25980_get_charger_property, 902 .set_property = bq25980_set_charger_property, 903 .property_is_writeable = bq25980_property_is_writeable, 904}; 905 906static struct power_supply_desc bq25980_battery_desc = { 907 .name = "bq25980-battery", 908 .type = POWER_SUPPLY_TYPE_BATTERY, 909 .get_property = bq25980_get_battery_property, 910 .properties = bq25980_battery_props, 911 .num_properties = ARRAY_SIZE(bq25980_battery_props), 912 .property_is_writeable = bq25980_property_is_writeable, 913}; 914 915 916static bool bq25980_is_volatile_reg(struct device *dev, unsigned int reg) 917{ 918 switch (reg) { 919 case BQ25980_CHRGR_CTRL_2: 920 case BQ25980_STAT1...BQ25980_FLAG5: 921 case BQ25980_ADC_CONTROL1...BQ25980_TDIE_ADC_LSB: 922 return true; 923 default: 924 return false; 925 } 926} 927 928static const struct regmap_config bq25980_regmap_config = { 929 .reg_bits = 8, 930 .val_bits = 8, 931 932 .max_register = BQ25980_CHRGR_CTRL_6, 933 .reg_defaults = bq25980_reg_defs, 934 .num_reg_defaults = ARRAY_SIZE(bq25980_reg_defs), 935 .cache_type = REGCACHE_RBTREE, 936 .volatile_reg = bq25980_is_volatile_reg, 937}; 938 939static const struct regmap_config bq25975_regmap_config = { 940 .reg_bits = 8, 941 .val_bits = 8, 942 943 .max_register = BQ25980_CHRGR_CTRL_6, 944 .reg_defaults = bq25975_reg_defs, 945 .num_reg_defaults = ARRAY_SIZE(bq25975_reg_defs), 946 .cache_type = REGCACHE_RBTREE, 947 .volatile_reg = bq25980_is_volatile_reg, 948}; 949 950static const struct regmap_config bq25960_regmap_config = { 951 .reg_bits = 8, 952 .val_bits = 8, 953 954 .max_register = BQ25980_CHRGR_CTRL_6, 955 .reg_defaults = bq25960_reg_defs, 956 .num_reg_defaults = ARRAY_SIZE(bq25960_reg_defs), 957 .cache_type = REGCACHE_RBTREE, 958 .volatile_reg = bq25980_is_volatile_reg, 959}; 960 961static const struct bq25980_chip_info bq25980_chip_info_tbl[] = { 962 [BQ25980] = { 963 .model_id = BQ25980, 964 .regmap_config = &bq25980_regmap_config, 965 966 .busocp_def = BQ25980_BUSOCP_DFLT_uA, 967 .busocp_sc_min = BQ25960_BUSOCP_SC_MAX_uA, 968 .busocp_sc_max = BQ25980_BUSOCP_SC_MAX_uA, 969 .busocp_byp_max = BQ25980_BUSOCP_BYP_MAX_uA, 970 .busocp_byp_min = BQ25980_BUSOCP_MIN_uA, 971 972 .busovp_sc_def = BQ25980_BUSOVP_DFLT_uV, 973 .busovp_byp_def = BQ25980_BUSOVP_BYPASS_DFLT_uV, 974 .busovp_sc_step = BQ25980_BUSOVP_SC_STEP_uV, 975 .busovp_sc_offset = BQ25980_BUSOVP_SC_OFFSET_uV, 976 .busovp_byp_step = BQ25980_BUSOVP_BYP_STEP_uV, 977 .busovp_byp_offset = BQ25980_BUSOVP_BYP_OFFSET_uV, 978 .busovp_sc_min = BQ25980_BUSOVP_SC_MIN_uV, 979 .busovp_sc_max = BQ25980_BUSOVP_SC_MAX_uV, 980 .busovp_byp_min = BQ25980_BUSOVP_BYP_MIN_uV, 981 .busovp_byp_max = BQ25980_BUSOVP_BYP_MAX_uV, 982 983 .batovp_def = BQ25980_BATOVP_DFLT_uV, 984 .batovp_max = BQ25980_BATOVP_MAX_uV, 985 .batovp_min = BQ25980_BATOVP_MIN_uV, 986 .batovp_step = BQ25980_BATOVP_STEP_uV, 987 .batovp_offset = BQ25980_BATOVP_OFFSET_uV, 988 989 .batocp_def = BQ25980_BATOCP_DFLT_uA, 990 .batocp_max = BQ25980_BATOCP_MAX_uA, 991 }, 992 993 [BQ25975] = { 994 .model_id = BQ25975, 995 .regmap_config = &bq25975_regmap_config, 996 997 .busocp_def = BQ25975_BUSOCP_DFLT_uA, 998 .busocp_sc_min = BQ25975_BUSOCP_SC_MAX_uA, 999 .busocp_sc_max = BQ25975_BUSOCP_SC_MAX_uA, 1000 .busocp_byp_min = BQ25980_BUSOCP_MIN_uA, 1001 .busocp_byp_max = BQ25975_BUSOCP_BYP_MAX_uA, 1002 1003 .busovp_sc_def = BQ25975_BUSOVP_DFLT_uV, 1004 .busovp_byp_def = BQ25975_BUSOVP_BYPASS_DFLT_uV, 1005 .busovp_sc_step = BQ25975_BUSOVP_SC_STEP_uV, 1006 .busovp_sc_offset = BQ25975_BUSOVP_SC_OFFSET_uV, 1007 .busovp_byp_step = BQ25975_BUSOVP_BYP_STEP_uV, 1008 .busovp_byp_offset = BQ25975_BUSOVP_BYP_OFFSET_uV, 1009 .busovp_sc_min = BQ25975_BUSOVP_SC_MIN_uV, 1010 .busovp_sc_max = BQ25975_BUSOVP_SC_MAX_uV, 1011 .busovp_byp_min = BQ25975_BUSOVP_BYP_MIN_uV, 1012 .busovp_byp_max = BQ25975_BUSOVP_BYP_MAX_uV, 1013 1014 .batovp_def = BQ25975_BATOVP_DFLT_uV, 1015 .batovp_max = BQ25975_BATOVP_MAX_uV, 1016 .batovp_min = BQ25975_BATOVP_MIN_uV, 1017 .batovp_step = BQ25975_BATOVP_STEP_uV, 1018 .batovp_offset = BQ25975_BATOVP_OFFSET_uV, 1019 1020 .batocp_def = BQ25980_BATOCP_DFLT_uA, 1021 .batocp_max = BQ25980_BATOCP_MAX_uA, 1022 }, 1023 1024 [BQ25960] = { 1025 .model_id = BQ25960, 1026 .regmap_config = &bq25960_regmap_config, 1027 1028 .busocp_def = BQ25960_BUSOCP_DFLT_uA, 1029 .busocp_sc_min = BQ25960_BUSOCP_SC_MAX_uA, 1030 .busocp_sc_max = BQ25960_BUSOCP_SC_MAX_uA, 1031 .busocp_byp_min = BQ25960_BUSOCP_SC_MAX_uA, 1032 .busocp_byp_max = BQ25960_BUSOCP_BYP_MAX_uA, 1033 1034 .busovp_sc_def = BQ25975_BUSOVP_DFLT_uV, 1035 .busovp_byp_def = BQ25975_BUSOVP_BYPASS_DFLT_uV, 1036 .busovp_sc_step = BQ25960_BUSOVP_SC_STEP_uV, 1037 .busovp_sc_offset = BQ25960_BUSOVP_SC_OFFSET_uV, 1038 .busovp_byp_step = BQ25960_BUSOVP_BYP_STEP_uV, 1039 .busovp_byp_offset = BQ25960_BUSOVP_BYP_OFFSET_uV, 1040 .busovp_sc_min = BQ25960_BUSOVP_SC_MIN_uV, 1041 .busovp_sc_max = BQ25960_BUSOVP_SC_MAX_uV, 1042 .busovp_byp_min = BQ25960_BUSOVP_BYP_MIN_uV, 1043 .busovp_byp_max = BQ25960_BUSOVP_BYP_MAX_uV, 1044 1045 .batovp_def = BQ25960_BATOVP_DFLT_uV, 1046 .batovp_max = BQ25960_BATOVP_MAX_uV, 1047 .batovp_min = BQ25960_BATOVP_MIN_uV, 1048 .batovp_step = BQ25960_BATOVP_STEP_uV, 1049 .batovp_offset = BQ25960_BATOVP_OFFSET_uV, 1050 1051 .batocp_def = BQ25960_BATOCP_DFLT_uA, 1052 .batocp_max = BQ25960_BATOCP_MAX_uA, 1053 }, 1054}; 1055 1056static int bq25980_power_supply_init(struct bq25980_device *bq, 1057 struct device *dev) 1058{ 1059 struct power_supply_config psy_cfg = { .drv_data = bq, 1060 .of_node = dev->of_node, }; 1061 1062 psy_cfg.supplied_to = bq25980_charger_supplied_to; 1063 psy_cfg.num_supplicants = ARRAY_SIZE(bq25980_charger_supplied_to); 1064 1065 bq->charger = devm_power_supply_register(bq->dev, 1066 &bq25980_power_supply_desc, 1067 &psy_cfg); 1068 if (IS_ERR(bq->charger)) 1069 return -EINVAL; 1070 1071 bq->battery = devm_power_supply_register(bq->dev, 1072 &bq25980_battery_desc, 1073 &psy_cfg); 1074 if (IS_ERR(bq->battery)) 1075 return -EINVAL; 1076 1077 return 0; 1078} 1079 1080static int bq25980_hw_init(struct bq25980_device *bq) 1081{ 1082 struct power_supply_battery_info *bat_info; 1083 int wd_reg_val = BQ25980_WATCHDOG_DIS; 1084 int wd_max_val = BQ25980_NUM_WD_VAL - 1; 1085 int ret = 0; 1086 int curr_val; 1087 int volt_val; 1088 int i; 1089 1090 if (bq->watchdog_timer) { 1091 if (bq->watchdog_timer >= bq25980_watchdog_time[wd_max_val]) 1092 wd_reg_val = wd_max_val; 1093 else { 1094 for (i = 0; i < wd_max_val; i++) { 1095 if (bq->watchdog_timer > bq25980_watchdog_time[i] && 1096 bq->watchdog_timer < bq25980_watchdog_time[i + 1]) { 1097 wd_reg_val = i; 1098 break; 1099 } 1100 } 1101 } 1102 } 1103 1104 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_3, 1105 BQ25980_WATCHDOG_MASK, wd_reg_val); 1106 if (ret) 1107 return ret; 1108 1109 ret = power_supply_get_battery_info(bq->charger, &bat_info); 1110 if (ret) { 1111 dev_warn(bq->dev, "battery info missing\n"); 1112 return -EINVAL; 1113 } 1114 1115 bq->init_data.ichg_max = bat_info->constant_charge_current_max_ua; 1116 bq->init_data.vreg_max = bat_info->constant_charge_voltage_max_uv; 1117 1118 if (bq->state.bypass) { 1119 ret = regmap_update_bits(bq->regmap, BQ25980_CHRGR_CTRL_2, 1120 BQ25980_EN_BYPASS, BQ25980_EN_BYPASS); 1121 if (ret) 1122 return ret; 1123 1124 curr_val = bq->init_data.bypass_ilim; 1125 volt_val = bq->init_data.bypass_vlim; 1126 } else { 1127 curr_val = bq->init_data.sc_ilim; 1128 volt_val = bq->init_data.sc_vlim; 1129 } 1130 1131 ret = bq25980_set_input_curr_lim(bq, curr_val); 1132 if (ret) 1133 return ret; 1134 1135 ret = bq25980_set_input_volt_lim(bq, volt_val); 1136 if (ret) 1137 return ret; 1138 1139 return regmap_update_bits(bq->regmap, BQ25980_ADC_CONTROL1, 1140 BQ25980_ADC_EN, BQ25980_ADC_EN); 1141} 1142 1143static int bq25980_parse_dt(struct bq25980_device *bq) 1144{ 1145 int ret; 1146 1147 ret = device_property_read_u32(bq->dev, "ti,watchdog-timeout-ms", 1148 &bq->watchdog_timer); 1149 if (ret) 1150 bq->watchdog_timer = BQ25980_WATCHDOG_MIN; 1151 1152 if (bq->watchdog_timer > BQ25980_WATCHDOG_MAX || 1153 bq->watchdog_timer < BQ25980_WATCHDOG_MIN) 1154 return -EINVAL; 1155 1156 ret = device_property_read_u32(bq->dev, 1157 "ti,sc-ovp-limit-microvolt", 1158 &bq->init_data.sc_vlim); 1159 if (ret) 1160 bq->init_data.sc_vlim = bq->chip_info->busovp_sc_def; 1161 1162 if (bq->init_data.sc_vlim > bq->chip_info->busovp_sc_max || 1163 bq->init_data.sc_vlim < bq->chip_info->busovp_sc_min) { 1164 dev_err(bq->dev, "SC ovp limit is out of range\n"); 1165 return -EINVAL; 1166 } 1167 1168 ret = device_property_read_u32(bq->dev, 1169 "ti,sc-ocp-limit-microamp", 1170 &bq->init_data.sc_ilim); 1171 if (ret) 1172 bq->init_data.sc_ilim = bq->chip_info->busocp_def; 1173 1174 if (bq->init_data.sc_ilim > bq->chip_info->busocp_sc_max || 1175 bq->init_data.sc_ilim < bq->chip_info->busocp_sc_min) { 1176 dev_err(bq->dev, "SC ocp limit is out of range\n"); 1177 return -EINVAL; 1178 } 1179 1180 ret = device_property_read_u32(bq->dev, 1181 "ti,bypass-ovp-limit-microvolt", 1182 &bq->init_data.bypass_vlim); 1183 if (ret) 1184 bq->init_data.bypass_vlim = bq->chip_info->busovp_byp_def; 1185 1186 if (bq->init_data.bypass_vlim > bq->chip_info->busovp_byp_max || 1187 bq->init_data.bypass_vlim < bq->chip_info->busovp_byp_min) { 1188 dev_err(bq->dev, "Bypass ovp limit is out of range\n"); 1189 return -EINVAL; 1190 } 1191 1192 ret = device_property_read_u32(bq->dev, 1193 "ti,bypass-ocp-limit-microamp", 1194 &bq->init_data.bypass_ilim); 1195 if (ret) 1196 bq->init_data.bypass_ilim = bq->chip_info->busocp_def; 1197 1198 if (bq->init_data.bypass_ilim > bq->chip_info->busocp_byp_max || 1199 bq->init_data.bypass_ilim < bq->chip_info->busocp_byp_min) { 1200 dev_err(bq->dev, "Bypass ocp limit is out of range\n"); 1201 return -EINVAL; 1202 } 1203 1204 1205 bq->state.bypass = device_property_read_bool(bq->dev, 1206 "ti,bypass-enable"); 1207 return 0; 1208} 1209 1210static int bq25980_probe(struct i2c_client *client, 1211 const struct i2c_device_id *id) 1212{ 1213 struct device *dev = &client->dev; 1214 struct bq25980_device *bq; 1215 int ret; 1216 1217 bq = devm_kzalloc(dev, sizeof(*bq), GFP_KERNEL); 1218 if (!bq) 1219 return -ENOMEM; 1220 1221 bq->client = client; 1222 bq->dev = dev; 1223 1224 mutex_init(&bq->lock); 1225 1226 strncpy(bq->model_name, id->name, I2C_NAME_SIZE); 1227 bq->chip_info = &bq25980_chip_info_tbl[id->driver_data]; 1228 1229 bq->regmap = devm_regmap_init_i2c(client, 1230 bq->chip_info->regmap_config); 1231 if (IS_ERR(bq->regmap)) { 1232 dev_err(dev, "Failed to allocate register map\n"); 1233 return PTR_ERR(bq->regmap); 1234 } 1235 1236 i2c_set_clientdata(client, bq); 1237 1238 ret = bq25980_parse_dt(bq); 1239 if (ret) { 1240 dev_err(dev, "Failed to read device tree properties%d\n", ret); 1241 return ret; 1242 } 1243 1244 if (client->irq) { 1245 ret = devm_request_threaded_irq(dev, client->irq, NULL, 1246 bq25980_irq_handler_thread, 1247 IRQF_TRIGGER_FALLING | 1248 IRQF_ONESHOT, 1249 dev_name(&client->dev), bq); 1250 if (ret) 1251 return ret; 1252 } 1253 1254 ret = bq25980_power_supply_init(bq, dev); 1255 if (ret) { 1256 dev_err(dev, "Failed to register power supply\n"); 1257 return ret; 1258 } 1259 1260 ret = bq25980_hw_init(bq); 1261 if (ret) { 1262 dev_err(dev, "Cannot initialize the chip.\n"); 1263 return ret; 1264 } 1265 1266 return 0; 1267} 1268 1269static const struct i2c_device_id bq25980_i2c_ids[] = { 1270 { "bq25980", BQ25980 }, 1271 { "bq25975", BQ25975 }, 1272 { "bq25960", BQ25960 }, 1273 {}, 1274}; 1275MODULE_DEVICE_TABLE(i2c, bq25980_i2c_ids); 1276 1277static const struct of_device_id bq25980_of_match[] = { 1278 { .compatible = "ti,bq25980", .data = (void *)BQ25980 }, 1279 { .compatible = "ti,bq25975", .data = (void *)BQ25975 }, 1280 { .compatible = "ti,bq25960", .data = (void *)BQ25960 }, 1281 { }, 1282}; 1283MODULE_DEVICE_TABLE(of, bq25980_of_match); 1284 1285static struct i2c_driver bq25980_driver = { 1286 .driver = { 1287 .name = "bq25980-charger", 1288 .of_match_table = bq25980_of_match, 1289 }, 1290 .probe = bq25980_probe, 1291 .id_table = bq25980_i2c_ids, 1292}; 1293module_i2c_driver(bq25980_driver); 1294 1295MODULE_AUTHOR("Dan Murphy <dmurphy@ti.com>"); 1296MODULE_AUTHOR("Ricardo Rivera-Matos <r-rivera-matos@ti.com>"); 1297MODULE_DESCRIPTION("bq25980 charger driver"); 1298MODULE_LICENSE("GPL v2");