bq24257_charger.c 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859
  1. /*
  2. * TI BQ24257 charger driver
  3. *
  4. * Copyright (C) 2015 Intel Corporation
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. */
  17. #include <linux/module.h>
  18. #include <linux/i2c.h>
  19. #include <linux/power_supply.h>
  20. #include <linux/regmap.h>
  21. #include <linux/types.h>
  22. #include <linux/gpio/consumer.h>
  23. #include <linux/interrupt.h>
  24. #include <linux/delay.h>
  25. #include <linux/acpi.h>
  26. #include <linux/of.h>
  27. #define BQ24257_REG_1 0x00
  28. #define BQ24257_REG_2 0x01
  29. #define BQ24257_REG_3 0x02
  30. #define BQ24257_REG_4 0x03
  31. #define BQ24257_REG_5 0x04
  32. #define BQ24257_REG_6 0x05
  33. #define BQ24257_REG_7 0x06
  34. #define BQ24257_MANUFACTURER "Texas Instruments"
  35. #define BQ24257_STAT_IRQ "stat"
  36. #define BQ24257_PG_GPIO "pg"
  37. #define BQ24257_ILIM_SET_DELAY 1000 /* msec */
  38. enum bq24257_fields {
  39. F_WD_FAULT, F_WD_EN, F_STAT, F_FAULT, /* REG 1 */
  40. F_RESET, F_IILIMIT, F_EN_STAT, F_EN_TERM, F_CE, F_HZ_MODE, /* REG 2 */
  41. F_VBAT, F_USB_DET, /* REG 3 */
  42. F_ICHG, F_ITERM, /* REG 4 */
  43. F_LOOP_STATUS, F_LOW_CHG, F_DPDM_EN, F_CE_STATUS, F_VINDPM, /* REG 5 */
  44. F_X2_TMR_EN, F_TMR, F_SYSOFF, F_TS_STAT, /* REG 6 */
  45. F_VOVP, F_CLR_VDP, F_FORCE_BATDET, F_FORCE_PTM, /* REG 7 */
  46. F_MAX_FIELDS
  47. };
  48. /* initial field values, converted from uV/uA */
  49. struct bq24257_init_data {
  50. u8 ichg; /* charge current */
  51. u8 vbat; /* regulation voltage */
  52. u8 iterm; /* termination current */
  53. };
  54. struct bq24257_state {
  55. u8 status;
  56. u8 fault;
  57. bool power_good;
  58. };
  59. struct bq24257_device {
  60. struct i2c_client *client;
  61. struct device *dev;
  62. struct power_supply *charger;
  63. struct regmap *rmap;
  64. struct regmap_field *rmap_fields[F_MAX_FIELDS];
  65. struct gpio_desc *pg;
  66. struct delayed_work iilimit_setup_work;
  67. struct bq24257_init_data init_data;
  68. struct bq24257_state state;
  69. struct mutex lock; /* protect state data */
  70. };
  71. static bool bq24257_is_volatile_reg(struct device *dev, unsigned int reg)
  72. {
  73. switch (reg) {
  74. case BQ24257_REG_2:
  75. case BQ24257_REG_4:
  76. return false;
  77. default:
  78. return true;
  79. }
  80. }
  81. static const struct regmap_config bq24257_regmap_config = {
  82. .reg_bits = 8,
  83. .val_bits = 8,
  84. .max_register = BQ24257_REG_7,
  85. .cache_type = REGCACHE_RBTREE,
  86. .volatile_reg = bq24257_is_volatile_reg,
  87. };
  88. static const struct reg_field bq24257_reg_fields[] = {
  89. /* REG 1 */
  90. [F_WD_FAULT] = REG_FIELD(BQ24257_REG_1, 7, 7),
  91. [F_WD_EN] = REG_FIELD(BQ24257_REG_1, 6, 6),
  92. [F_STAT] = REG_FIELD(BQ24257_REG_1, 4, 5),
  93. [F_FAULT] = REG_FIELD(BQ24257_REG_1, 0, 3),
  94. /* REG 2 */
  95. [F_RESET] = REG_FIELD(BQ24257_REG_2, 7, 7),
  96. [F_IILIMIT] = REG_FIELD(BQ24257_REG_2, 4, 6),
  97. [F_EN_STAT] = REG_FIELD(BQ24257_REG_2, 3, 3),
  98. [F_EN_TERM] = REG_FIELD(BQ24257_REG_2, 2, 2),
  99. [F_CE] = REG_FIELD(BQ24257_REG_2, 1, 1),
  100. [F_HZ_MODE] = REG_FIELD(BQ24257_REG_2, 0, 0),
  101. /* REG 3 */
  102. [F_VBAT] = REG_FIELD(BQ24257_REG_3, 2, 7),
  103. [F_USB_DET] = REG_FIELD(BQ24257_REG_3, 0, 1),
  104. /* REG 4 */
  105. [F_ICHG] = REG_FIELD(BQ24257_REG_4, 3, 7),
  106. [F_ITERM] = REG_FIELD(BQ24257_REG_4, 0, 2),
  107. /* REG 5 */
  108. [F_LOOP_STATUS] = REG_FIELD(BQ24257_REG_5, 6, 7),
  109. [F_LOW_CHG] = REG_FIELD(BQ24257_REG_5, 5, 5),
  110. [F_DPDM_EN] = REG_FIELD(BQ24257_REG_5, 4, 4),
  111. [F_CE_STATUS] = REG_FIELD(BQ24257_REG_5, 3, 3),
  112. [F_VINDPM] = REG_FIELD(BQ24257_REG_5, 0, 2),
  113. /* REG 6 */
  114. [F_X2_TMR_EN] = REG_FIELD(BQ24257_REG_6, 7, 7),
  115. [F_TMR] = REG_FIELD(BQ24257_REG_6, 5, 6),
  116. [F_SYSOFF] = REG_FIELD(BQ24257_REG_6, 4, 4),
  117. [F_TS_STAT] = REG_FIELD(BQ24257_REG_6, 0, 2),
  118. /* REG 7 */
  119. [F_VOVP] = REG_FIELD(BQ24257_REG_7, 5, 7),
  120. [F_CLR_VDP] = REG_FIELD(BQ24257_REG_7, 4, 4),
  121. [F_FORCE_BATDET] = REG_FIELD(BQ24257_REG_7, 3, 3),
  122. [F_FORCE_PTM] = REG_FIELD(BQ24257_REG_7, 2, 2)
  123. };
  124. static const u32 bq24257_vbat_map[] = {
  125. 3500000, 3520000, 3540000, 3560000, 3580000, 3600000, 3620000, 3640000,
  126. 3660000, 3680000, 3700000, 3720000, 3740000, 3760000, 3780000, 3800000,
  127. 3820000, 3840000, 3860000, 3880000, 3900000, 3920000, 3940000, 3960000,
  128. 3980000, 4000000, 4020000, 4040000, 4060000, 4080000, 4100000, 4120000,
  129. 4140000, 4160000, 4180000, 4200000, 4220000, 4240000, 4260000, 4280000,
  130. 4300000, 4320000, 4340000, 4360000, 4380000, 4400000, 4420000, 4440000
  131. };
  132. #define BQ24257_VBAT_MAP_SIZE ARRAY_SIZE(bq24257_vbat_map)
  133. static const u32 bq24257_ichg_map[] = {
  134. 500000, 550000, 600000, 650000, 700000, 750000, 800000, 850000, 900000,
  135. 950000, 1000000, 1050000, 1100000, 1150000, 1200000, 1250000, 1300000,
  136. 1350000, 1400000, 1450000, 1500000, 1550000, 1600000, 1650000, 1700000,
  137. 1750000, 1800000, 1850000, 1900000, 1950000, 2000000
  138. };
  139. #define BQ24257_ICHG_MAP_SIZE ARRAY_SIZE(bq24257_ichg_map)
  140. static const u32 bq24257_iterm_map[] = {
  141. 50000, 75000, 100000, 125000, 150000, 175000, 200000, 225000
  142. };
  143. #define BQ24257_ITERM_MAP_SIZE ARRAY_SIZE(bq24257_iterm_map)
  144. static int bq24257_field_read(struct bq24257_device *bq,
  145. enum bq24257_fields field_id)
  146. {
  147. int ret;
  148. int val;
  149. ret = regmap_field_read(bq->rmap_fields[field_id], &val);
  150. if (ret < 0)
  151. return ret;
  152. return val;
  153. }
  154. static int bq24257_field_write(struct bq24257_device *bq,
  155. enum bq24257_fields field_id, u8 val)
  156. {
  157. return regmap_field_write(bq->rmap_fields[field_id], val);
  158. }
  159. static u8 bq24257_find_idx(u32 value, const u32 *map, u8 map_size)
  160. {
  161. u8 idx;
  162. for (idx = 1; idx < map_size; idx++)
  163. if (value < map[idx])
  164. break;
  165. return idx - 1;
  166. }
  167. enum bq24257_status {
  168. STATUS_READY,
  169. STATUS_CHARGE_IN_PROGRESS,
  170. STATUS_CHARGE_DONE,
  171. STATUS_FAULT,
  172. };
  173. enum bq24257_fault {
  174. FAULT_NORMAL,
  175. FAULT_INPUT_OVP,
  176. FAULT_INPUT_UVLO,
  177. FAULT_SLEEP,
  178. FAULT_BAT_TS,
  179. FAULT_BAT_OVP,
  180. FAULT_TS,
  181. FAULT_TIMER,
  182. FAULT_NO_BAT,
  183. FAULT_ISET,
  184. FAULT_INPUT_LDO_LOW,
  185. };
  186. static int bq24257_power_supply_get_property(struct power_supply *psy,
  187. enum power_supply_property psp,
  188. union power_supply_propval *val)
  189. {
  190. struct bq24257_device *bq = power_supply_get_drvdata(psy);
  191. struct bq24257_state state;
  192. mutex_lock(&bq->lock);
  193. state = bq->state;
  194. mutex_unlock(&bq->lock);
  195. switch (psp) {
  196. case POWER_SUPPLY_PROP_STATUS:
  197. if (!state.power_good)
  198. val->intval = POWER_SUPPLY_STATUS_DISCHARGING;
  199. else if (state.status == STATUS_READY)
  200. val->intval = POWER_SUPPLY_STATUS_NOT_CHARGING;
  201. else if (state.status == STATUS_CHARGE_IN_PROGRESS)
  202. val->intval = POWER_SUPPLY_STATUS_CHARGING;
  203. else if (state.status == STATUS_CHARGE_DONE)
  204. val->intval = POWER_SUPPLY_STATUS_FULL;
  205. else
  206. val->intval = POWER_SUPPLY_STATUS_UNKNOWN;
  207. break;
  208. case POWER_SUPPLY_PROP_MANUFACTURER:
  209. val->strval = BQ24257_MANUFACTURER;
  210. break;
  211. case POWER_SUPPLY_PROP_ONLINE:
  212. val->intval = state.power_good;
  213. break;
  214. case POWER_SUPPLY_PROP_HEALTH:
  215. switch (state.fault) {
  216. case FAULT_NORMAL:
  217. val->intval = POWER_SUPPLY_HEALTH_GOOD;
  218. break;
  219. case FAULT_INPUT_OVP:
  220. case FAULT_BAT_OVP:
  221. val->intval = POWER_SUPPLY_HEALTH_OVERVOLTAGE;
  222. break;
  223. case FAULT_TS:
  224. case FAULT_BAT_TS:
  225. val->intval = POWER_SUPPLY_HEALTH_OVERHEAT;
  226. break;
  227. case FAULT_TIMER:
  228. val->intval = POWER_SUPPLY_HEALTH_SAFETY_TIMER_EXPIRE;
  229. break;
  230. default:
  231. val->intval = POWER_SUPPLY_HEALTH_UNSPEC_FAILURE;
  232. break;
  233. }
  234. break;
  235. case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT:
  236. val->intval = bq24257_ichg_map[bq->init_data.ichg];
  237. break;
  238. case POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX:
  239. val->intval = bq24257_ichg_map[BQ24257_ICHG_MAP_SIZE - 1];
  240. break;
  241. case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE:
  242. val->intval = bq24257_vbat_map[bq->init_data.vbat];
  243. break;
  244. case POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX:
  245. val->intval = bq24257_vbat_map[BQ24257_VBAT_MAP_SIZE - 1];
  246. break;
  247. case POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT:
  248. val->intval = bq24257_iterm_map[bq->init_data.iterm];
  249. break;
  250. default:
  251. return -EINVAL;
  252. }
  253. return 0;
  254. }
  255. static int bq24257_get_chip_state(struct bq24257_device *bq,
  256. struct bq24257_state *state)
  257. {
  258. int ret;
  259. ret = bq24257_field_read(bq, F_STAT);
  260. if (ret < 0)
  261. return ret;
  262. state->status = ret;
  263. ret = bq24257_field_read(bq, F_FAULT);
  264. if (ret < 0)
  265. return ret;
  266. state->fault = ret;
  267. state->power_good = !gpiod_get_value_cansleep(bq->pg);
  268. return 0;
  269. }
  270. static bool bq24257_state_changed(struct bq24257_device *bq,
  271. struct bq24257_state *new_state)
  272. {
  273. int ret;
  274. mutex_lock(&bq->lock);
  275. ret = (bq->state.status != new_state->status ||
  276. bq->state.fault != new_state->fault ||
  277. bq->state.power_good != new_state->power_good);
  278. mutex_unlock(&bq->lock);
  279. return ret;
  280. }
  281. enum bq24257_loop_status {
  282. LOOP_STATUS_NONE,
  283. LOOP_STATUS_IN_DPM,
  284. LOOP_STATUS_IN_CURRENT_LIMIT,
  285. LOOP_STATUS_THERMAL,
  286. };
  287. enum bq24257_in_ilimit {
  288. IILIMIT_100,
  289. IILIMIT_150,
  290. IILIMIT_500,
  291. IILIMIT_900,
  292. IILIMIT_1500,
  293. IILIMIT_2000,
  294. IILIMIT_EXT,
  295. IILIMIT_NONE,
  296. };
  297. enum bq24257_port_type {
  298. PORT_TYPE_DCP, /* Dedicated Charging Port */
  299. PORT_TYPE_CDP, /* Charging Downstream Port */
  300. PORT_TYPE_SDP, /* Standard Downstream Port */
  301. PORT_TYPE_NON_STANDARD,
  302. };
  303. enum bq24257_safety_timer {
  304. SAFETY_TIMER_45,
  305. SAFETY_TIMER_360,
  306. SAFETY_TIMER_540,
  307. SAFETY_TIMER_NONE,
  308. };
  309. static int bq24257_iilimit_autoset(struct bq24257_device *bq)
  310. {
  311. int loop_status;
  312. int iilimit;
  313. int port_type;
  314. int ret;
  315. const u8 new_iilimit[] = {
  316. [PORT_TYPE_DCP] = IILIMIT_2000,
  317. [PORT_TYPE_CDP] = IILIMIT_2000,
  318. [PORT_TYPE_SDP] = IILIMIT_500,
  319. [PORT_TYPE_NON_STANDARD] = IILIMIT_500
  320. };
  321. ret = bq24257_field_read(bq, F_LOOP_STATUS);
  322. if (ret < 0)
  323. goto error;
  324. loop_status = ret;
  325. ret = bq24257_field_read(bq, F_IILIMIT);
  326. if (ret < 0)
  327. goto error;
  328. iilimit = ret;
  329. /*
  330. * All USB ports should be able to handle 500mA. If not, DPM will lower
  331. * the charging current to accommodate the power source. No need to set
  332. * a lower IILIMIT value.
  333. */
  334. if (loop_status == LOOP_STATUS_IN_DPM && iilimit == IILIMIT_500)
  335. return 0;
  336. ret = bq24257_field_read(bq, F_USB_DET);
  337. if (ret < 0)
  338. goto error;
  339. port_type = ret;
  340. ret = bq24257_field_write(bq, F_IILIMIT, new_iilimit[port_type]);
  341. if (ret < 0)
  342. goto error;
  343. ret = bq24257_field_write(bq, F_TMR, SAFETY_TIMER_360);
  344. if (ret < 0)
  345. goto error;
  346. ret = bq24257_field_write(bq, F_CLR_VDP, 1);
  347. if (ret < 0)
  348. goto error;
  349. dev_dbg(bq->dev, "port/loop = %d/%d -> iilimit = %d\n",
  350. port_type, loop_status, new_iilimit[port_type]);
  351. return 0;
  352. error:
  353. dev_err(bq->dev, "%s: Error communicating with the chip.\n", __func__);
  354. return ret;
  355. }
  356. static void bq24257_iilimit_setup_work(struct work_struct *work)
  357. {
  358. struct bq24257_device *bq = container_of(work, struct bq24257_device,
  359. iilimit_setup_work.work);
  360. bq24257_iilimit_autoset(bq);
  361. }
  362. static void bq24257_handle_state_change(struct bq24257_device *bq,
  363. struct bq24257_state *new_state)
  364. {
  365. int ret;
  366. struct bq24257_state old_state;
  367. bool reset_iilimit = false;
  368. bool config_iilimit = false;
  369. mutex_lock(&bq->lock);
  370. old_state = bq->state;
  371. mutex_unlock(&bq->lock);
  372. if (!new_state->power_good) { /* power removed */
  373. cancel_delayed_work_sync(&bq->iilimit_setup_work);
  374. /* activate D+/D- port detection algorithm */
  375. ret = bq24257_field_write(bq, F_DPDM_EN, 1);
  376. if (ret < 0)
  377. goto error;
  378. reset_iilimit = true;
  379. } else if (!old_state.power_good) { /* power inserted */
  380. config_iilimit = true;
  381. } else if (new_state->fault == FAULT_NO_BAT) { /* battery removed */
  382. cancel_delayed_work_sync(&bq->iilimit_setup_work);
  383. reset_iilimit = true;
  384. } else if (old_state.fault == FAULT_NO_BAT) { /* battery connected */
  385. config_iilimit = true;
  386. } else if (new_state->fault == FAULT_TIMER) { /* safety timer expired */
  387. dev_err(bq->dev, "Safety timer expired! Battery dead?\n");
  388. }
  389. if (reset_iilimit) {
  390. ret = bq24257_field_write(bq, F_IILIMIT, IILIMIT_500);
  391. if (ret < 0)
  392. goto error;
  393. } else if (config_iilimit) {
  394. schedule_delayed_work(&bq->iilimit_setup_work,
  395. msecs_to_jiffies(BQ24257_ILIM_SET_DELAY));
  396. }
  397. return;
  398. error:
  399. dev_err(bq->dev, "%s: Error communicating with the chip.\n", __func__);
  400. }
  401. static irqreturn_t bq24257_irq_handler_thread(int irq, void *private)
  402. {
  403. int ret;
  404. struct bq24257_device *bq = private;
  405. struct bq24257_state state;
  406. ret = bq24257_get_chip_state(bq, &state);
  407. if (ret < 0)
  408. return IRQ_HANDLED;
  409. if (!bq24257_state_changed(bq, &state))
  410. return IRQ_HANDLED;
  411. dev_dbg(bq->dev, "irq(state changed): status/fault/pg = %d/%d/%d\n",
  412. state.status, state.fault, state.power_good);
  413. bq24257_handle_state_change(bq, &state);
  414. mutex_lock(&bq->lock);
  415. bq->state = state;
  416. mutex_unlock(&bq->lock);
  417. power_supply_changed(bq->charger);
  418. return IRQ_HANDLED;
  419. }
  420. static int bq24257_hw_init(struct bq24257_device *bq)
  421. {
  422. int ret;
  423. int i;
  424. struct bq24257_state state;
  425. const struct {
  426. int field;
  427. u32 value;
  428. } init_data[] = {
  429. {F_ICHG, bq->init_data.ichg},
  430. {F_VBAT, bq->init_data.vbat},
  431. {F_ITERM, bq->init_data.iterm}
  432. };
  433. /*
  434. * Disable the watchdog timer to prevent the IC from going back to
  435. * default settings after 50 seconds of I2C inactivity.
  436. */
  437. ret = bq24257_field_write(bq, F_WD_EN, 0);
  438. if (ret < 0)
  439. return ret;
  440. /* configure the charge currents and voltages */
  441. for (i = 0; i < ARRAY_SIZE(init_data); i++) {
  442. ret = bq24257_field_write(bq, init_data[i].field,
  443. init_data[i].value);
  444. if (ret < 0)
  445. return ret;
  446. }
  447. ret = bq24257_get_chip_state(bq, &state);
  448. if (ret < 0)
  449. return ret;
  450. mutex_lock(&bq->lock);
  451. bq->state = state;
  452. mutex_unlock(&bq->lock);
  453. if (!state.power_good)
  454. /* activate D+/D- detection algorithm */
  455. ret = bq24257_field_write(bq, F_DPDM_EN, 1);
  456. else if (state.fault != FAULT_NO_BAT)
  457. ret = bq24257_iilimit_autoset(bq);
  458. return ret;
  459. }
  460. static enum power_supply_property bq24257_power_supply_props[] = {
  461. POWER_SUPPLY_PROP_MANUFACTURER,
  462. POWER_SUPPLY_PROP_STATUS,
  463. POWER_SUPPLY_PROP_ONLINE,
  464. POWER_SUPPLY_PROP_HEALTH,
  465. POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT,
  466. POWER_SUPPLY_PROP_CONSTANT_CHARGE_CURRENT_MAX,
  467. POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE,
  468. POWER_SUPPLY_PROP_CONSTANT_CHARGE_VOLTAGE_MAX,
  469. POWER_SUPPLY_PROP_CHARGE_TERM_CURRENT,
  470. };
  471. static char *bq24257_charger_supplied_to[] = {
  472. "main-battery",
  473. };
  474. static const struct power_supply_desc bq24257_power_supply_desc = {
  475. .name = "bq24257-charger",
  476. .type = POWER_SUPPLY_TYPE_USB,
  477. .properties = bq24257_power_supply_props,
  478. .num_properties = ARRAY_SIZE(bq24257_power_supply_props),
  479. .get_property = bq24257_power_supply_get_property,
  480. };
  481. static int bq24257_power_supply_init(struct bq24257_device *bq)
  482. {
  483. struct power_supply_config psy_cfg = { .drv_data = bq, };
  484. psy_cfg.supplied_to = bq24257_charger_supplied_to;
  485. psy_cfg.num_supplicants = ARRAY_SIZE(bq24257_charger_supplied_to);
  486. bq->charger = power_supply_register(bq->dev, &bq24257_power_supply_desc,
  487. &psy_cfg);
  488. if (IS_ERR(bq->charger))
  489. return PTR_ERR(bq->charger);
  490. return 0;
  491. }
  492. static int bq24257_irq_probe(struct bq24257_device *bq)
  493. {
  494. struct gpio_desc *stat_irq;
  495. stat_irq = devm_gpiod_get_index(bq->dev, BQ24257_STAT_IRQ, 0, GPIOD_IN);
  496. if (IS_ERR(stat_irq)) {
  497. dev_err(bq->dev, "could not probe stat_irq pin\n");
  498. return PTR_ERR(stat_irq);
  499. }
  500. return gpiod_to_irq(stat_irq);
  501. }
  502. static int bq24257_pg_gpio_probe(struct bq24257_device *bq)
  503. {
  504. bq->pg = devm_gpiod_get_index(bq->dev, BQ24257_PG_GPIO, 0, GPIOD_IN);
  505. if (IS_ERR(bq->pg)) {
  506. dev_err(bq->dev, "could not probe PG pin\n");
  507. return PTR_ERR(bq->pg);
  508. }
  509. return 0;
  510. }
  511. static int bq24257_fw_probe(struct bq24257_device *bq)
  512. {
  513. int ret;
  514. u32 property;
  515. ret = device_property_read_u32(bq->dev, "ti,charge-current", &property);
  516. if (ret < 0)
  517. return ret;
  518. bq->init_data.ichg = bq24257_find_idx(property, bq24257_ichg_map,
  519. BQ24257_ICHG_MAP_SIZE);
  520. ret = device_property_read_u32(bq->dev, "ti,battery-regulation-voltage",
  521. &property);
  522. if (ret < 0)
  523. return ret;
  524. bq->init_data.vbat = bq24257_find_idx(property, bq24257_vbat_map,
  525. BQ24257_VBAT_MAP_SIZE);
  526. ret = device_property_read_u32(bq->dev, "ti,termination-current",
  527. &property);
  528. if (ret < 0)
  529. return ret;
  530. bq->init_data.iterm = bq24257_find_idx(property, bq24257_iterm_map,
  531. BQ24257_ITERM_MAP_SIZE);
  532. return 0;
  533. }
  534. static int bq24257_probe(struct i2c_client *client,
  535. const struct i2c_device_id *id)
  536. {
  537. struct i2c_adapter *adapter = to_i2c_adapter(client->dev.parent);
  538. struct device *dev = &client->dev;
  539. struct bq24257_device *bq;
  540. int ret;
  541. int i;
  542. if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA)) {
  543. dev_err(dev, "No support for SMBUS_BYTE_DATA\n");
  544. return -ENODEV;
  545. }
  546. bq = devm_kzalloc(dev, sizeof(*bq), GFP_KERNEL);
  547. if (!bq)
  548. return -ENOMEM;
  549. bq->client = client;
  550. bq->dev = dev;
  551. mutex_init(&bq->lock);
  552. bq->rmap = devm_regmap_init_i2c(client, &bq24257_regmap_config);
  553. if (IS_ERR(bq->rmap)) {
  554. dev_err(dev, "failed to allocate register map\n");
  555. return PTR_ERR(bq->rmap);
  556. }
  557. for (i = 0; i < ARRAY_SIZE(bq24257_reg_fields); i++) {
  558. const struct reg_field *reg_fields = bq24257_reg_fields;
  559. bq->rmap_fields[i] = devm_regmap_field_alloc(dev, bq->rmap,
  560. reg_fields[i]);
  561. if (IS_ERR(bq->rmap_fields[i])) {
  562. dev_err(dev, "cannot allocate regmap field\n");
  563. return PTR_ERR(bq->rmap_fields[i]);
  564. }
  565. }
  566. i2c_set_clientdata(client, bq);
  567. INIT_DELAYED_WORK(&bq->iilimit_setup_work, bq24257_iilimit_setup_work);
  568. if (!dev->platform_data) {
  569. ret = bq24257_fw_probe(bq);
  570. if (ret < 0) {
  571. dev_err(dev, "Cannot read device properties.\n");
  572. return ret;
  573. }
  574. } else {
  575. return -ENODEV;
  576. }
  577. /* we can only check Power Good status by probing the PG pin */
  578. ret = bq24257_pg_gpio_probe(bq);
  579. if (ret < 0)
  580. return ret;
  581. /* reset all registers to defaults */
  582. ret = bq24257_field_write(bq, F_RESET, 1);
  583. if (ret < 0)
  584. return ret;
  585. /*
  586. * Put the RESET bit back to 0, in cache. For some reason the HW always
  587. * returns 1 on this bit, so this is the only way to avoid resetting the
  588. * chip every time we update another field in this register.
  589. */
  590. ret = bq24257_field_write(bq, F_RESET, 0);
  591. if (ret < 0)
  592. return ret;
  593. ret = bq24257_hw_init(bq);
  594. if (ret < 0) {
  595. dev_err(dev, "Cannot initialize the chip.\n");
  596. return ret;
  597. }
  598. if (client->irq <= 0)
  599. client->irq = bq24257_irq_probe(bq);
  600. if (client->irq < 0) {
  601. dev_err(dev, "no irq resource found\n");
  602. return client->irq;
  603. }
  604. ret = devm_request_threaded_irq(dev, client->irq, NULL,
  605. bq24257_irq_handler_thread,
  606. IRQF_TRIGGER_FALLING |
  607. IRQF_TRIGGER_RISING | IRQF_ONESHOT,
  608. BQ24257_STAT_IRQ, bq);
  609. if (ret)
  610. return ret;
  611. ret = bq24257_power_supply_init(bq);
  612. if (ret < 0)
  613. dev_err(dev, "Failed to register power supply\n");
  614. return ret;
  615. }
  616. static int bq24257_remove(struct i2c_client *client)
  617. {
  618. struct bq24257_device *bq = i2c_get_clientdata(client);
  619. cancel_delayed_work_sync(&bq->iilimit_setup_work);
  620. power_supply_unregister(bq->charger);
  621. bq24257_field_write(bq, F_RESET, 1); /* reset to defaults */
  622. return 0;
  623. }
  624. #ifdef CONFIG_PM_SLEEP
  625. static int bq24257_suspend(struct device *dev)
  626. {
  627. struct bq24257_device *bq = dev_get_drvdata(dev);
  628. int ret = 0;
  629. cancel_delayed_work_sync(&bq->iilimit_setup_work);
  630. /* reset all registers to default (and activate standalone mode) */
  631. ret = bq24257_field_write(bq, F_RESET, 1);
  632. if (ret < 0)
  633. dev_err(bq->dev, "Cannot reset chip to standalone mode.\n");
  634. return ret;
  635. }
  636. static int bq24257_resume(struct device *dev)
  637. {
  638. int ret;
  639. struct bq24257_device *bq = dev_get_drvdata(dev);
  640. ret = regcache_drop_region(bq->rmap, BQ24257_REG_1, BQ24257_REG_7);
  641. if (ret < 0)
  642. return ret;
  643. ret = bq24257_field_write(bq, F_RESET, 0);
  644. if (ret < 0)
  645. return ret;
  646. ret = bq24257_hw_init(bq);
  647. if (ret < 0) {
  648. dev_err(bq->dev, "Cannot init chip after resume.\n");
  649. return ret;
  650. }
  651. /* signal userspace, maybe state changed while suspended */
  652. power_supply_changed(bq->charger);
  653. return 0;
  654. }
  655. #endif
  656. static const struct dev_pm_ops bq24257_pm = {
  657. SET_SYSTEM_SLEEP_PM_OPS(bq24257_suspend, bq24257_resume)
  658. };
  659. static const struct i2c_device_id bq24257_i2c_ids[] = {
  660. { "bq24257", 0 },
  661. {},
  662. };
  663. MODULE_DEVICE_TABLE(i2c, bq24257_i2c_ids);
  664. static const struct of_device_id bq24257_of_match[] = {
  665. { .compatible = "ti,bq24257", },
  666. { },
  667. };
  668. MODULE_DEVICE_TABLE(of, bq24257_of_match);
  669. static const struct acpi_device_id bq24257_acpi_match[] = {
  670. {"BQ242570", 0},
  671. {},
  672. };
  673. MODULE_DEVICE_TABLE(acpi, bq24257_acpi_match);
  674. static struct i2c_driver bq24257_driver = {
  675. .driver = {
  676. .name = "bq24257-charger",
  677. .of_match_table = of_match_ptr(bq24257_of_match),
  678. .acpi_match_table = ACPI_PTR(bq24257_acpi_match),
  679. .pm = &bq24257_pm,
  680. },
  681. .probe = bq24257_probe,
  682. .remove = bq24257_remove,
  683. .id_table = bq24257_i2c_ids,
  684. };
  685. module_i2c_driver(bq24257_driver);
  686. MODULE_AUTHOR("Laurentiu Palcu <laurentiu.palcu@intel.com>");
  687. MODULE_DESCRIPTION("bq24257 charger driver");
  688. MODULE_LICENSE("GPL");