smb347-charger.c 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148
  1. /*
  2. * Summit Microelectronics SMB347 Battery Charger Driver
  3. *
  4. * Copyright (C) 2011, Intel Corporation
  5. *
  6. * Authors: Bruce E. Robertson <bruce.e.robertson@intel.com>
  7. * Mika Westerberg <mika.westerberg@linux.intel.com>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License version 2 as
  11. * published by the Free Software Foundation.
  12. */
  13. #include <linux/err.h>
  14. #include <linux/gpio.h>
  15. #include <linux/kernel.h>
  16. #include <linux/module.h>
  17. #include <linux/init.h>
  18. #include <linux/interrupt.h>
  19. #include <linux/i2c.h>
  20. #include <linux/mutex.h>
  21. #include <linux/power_supply.h>
  22. #include <linux/power/smb347-charger.h>
  23. #include <linux/regmap.h>
  24. /*
  25. * Configuration registers. These are mirrored to volatile RAM and can be
  26. * written once %CMD_A_ALLOW_WRITE is set in %CMD_A register. They will be
  27. * reloaded from non-volatile registers after POR.
  28. */
  29. #define CFG_CHARGE_CURRENT 0x00
  30. #define CFG_CHARGE_CURRENT_FCC_MASK 0xe0
  31. #define CFG_CHARGE_CURRENT_FCC_SHIFT 5
  32. #define CFG_CHARGE_CURRENT_PCC_MASK 0x18
  33. #define CFG_CHARGE_CURRENT_PCC_SHIFT 3
  34. #define CFG_CHARGE_CURRENT_TC_MASK 0x07
  35. #define CFG_CURRENT_LIMIT 0x01
  36. #define CFG_CURRENT_LIMIT_DC_MASK 0xf0
  37. #define CFG_CURRENT_LIMIT_DC_SHIFT 4
  38. #define CFG_CURRENT_LIMIT_USB_MASK 0x0f
  39. #define CFG_FLOAT_VOLTAGE 0x03
  40. #define CFG_FLOAT_VOLTAGE_FLOAT_MASK 0x3f
  41. #define CFG_FLOAT_VOLTAGE_THRESHOLD_MASK 0xc0
  42. #define CFG_FLOAT_VOLTAGE_THRESHOLD_SHIFT 6
  43. #define CFG_STAT 0x05
  44. #define CFG_STAT_DISABLED BIT(5)
  45. #define CFG_STAT_ACTIVE_HIGH BIT(7)
  46. #define CFG_PIN 0x06
  47. #define CFG_PIN_EN_CTRL_MASK 0x60
  48. #define CFG_PIN_EN_CTRL_ACTIVE_HIGH 0x40
  49. #define CFG_PIN_EN_CTRL_ACTIVE_LOW 0x60
  50. #define CFG_PIN_EN_APSD_IRQ BIT(1)
  51. #define CFG_PIN_EN_CHARGER_ERROR BIT(2)
  52. #define CFG_THERM 0x07
  53. #define CFG_THERM_SOFT_HOT_COMPENSATION_MASK 0x03
  54. #define CFG_THERM_SOFT_HOT_COMPENSATION_SHIFT 0
  55. #define CFG_THERM_SOFT_COLD_COMPENSATION_MASK 0x0c
  56. #define CFG_THERM_SOFT_COLD_COMPENSATION_SHIFT 2
  57. #define CFG_THERM_MONITOR_DISABLED BIT(4)
  58. #define CFG_SYSOK 0x08
  59. #define CFG_SYSOK_SUSPEND_HARD_LIMIT_DISABLED BIT(2)
  60. #define CFG_OTHER 0x09
  61. #define CFG_OTHER_RID_MASK 0xc0
  62. #define CFG_OTHER_RID_ENABLED_AUTO_OTG 0xc0
  63. #define CFG_OTG 0x0a
  64. #define CFG_OTG_TEMP_THRESHOLD_MASK 0x30
  65. #define CFG_OTG_TEMP_THRESHOLD_SHIFT 4
  66. #define CFG_OTG_CC_COMPENSATION_MASK 0xc0
  67. #define CFG_OTG_CC_COMPENSATION_SHIFT 6
  68. #define CFG_TEMP_LIMIT 0x0b
  69. #define CFG_TEMP_LIMIT_SOFT_HOT_MASK 0x03
  70. #define CFG_TEMP_LIMIT_SOFT_HOT_SHIFT 0
  71. #define CFG_TEMP_LIMIT_SOFT_COLD_MASK 0x0c
  72. #define CFG_TEMP_LIMIT_SOFT_COLD_SHIFT 2
  73. #define CFG_TEMP_LIMIT_HARD_HOT_MASK 0x30
  74. #define CFG_TEMP_LIMIT_HARD_HOT_SHIFT 4
  75. #define CFG_TEMP_LIMIT_HARD_COLD_MASK 0xc0
  76. #define CFG_TEMP_LIMIT_HARD_COLD_SHIFT 6
  77. #define CFG_FAULT_IRQ 0x0c
  78. #define CFG_FAULT_IRQ_DCIN_UV BIT(2)
  79. #define CFG_STATUS_IRQ 0x0d
  80. #define CFG_STATUS_IRQ_TERMINATION_OR_TAPER BIT(4)
  81. #define CFG_ADDRESS 0x0e
  82. /* Command registers */
  83. #define CMD_A 0x30
  84. #define CMD_A_CHG_ENABLED BIT(1)
  85. #define CMD_A_SUSPEND_ENABLED BIT(2)
  86. #define CMD_A_ALLOW_WRITE BIT(7)
  87. #define CMD_B 0x31
  88. #define CMD_C 0x33
  89. /* Interrupt Status registers */
  90. #define IRQSTAT_A 0x35
  91. #define IRQSTAT_C 0x37
  92. #define IRQSTAT_C_TERMINATION_STAT BIT(0)
  93. #define IRQSTAT_C_TERMINATION_IRQ BIT(1)
  94. #define IRQSTAT_C_TAPER_IRQ BIT(3)
  95. #define IRQSTAT_E 0x39
  96. #define IRQSTAT_E_USBIN_UV_STAT BIT(0)
  97. #define IRQSTAT_E_USBIN_UV_IRQ BIT(1)
  98. #define IRQSTAT_E_DCIN_UV_STAT BIT(4)
  99. #define IRQSTAT_E_DCIN_UV_IRQ BIT(5)
  100. #define IRQSTAT_F 0x3a
  101. /* Status registers */
  102. #define STAT_A 0x3b
  103. #define STAT_A_FLOAT_VOLTAGE_MASK 0x3f
  104. #define STAT_B 0x3c
  105. #define STAT_C 0x3d
  106. #define STAT_C_CHG_ENABLED BIT(0)
  107. #define STAT_C_CHG_MASK 0x06
  108. #define STAT_C_CHG_SHIFT 1
  109. #define STAT_C_CHARGER_ERROR BIT(6)
  110. #define STAT_E 0x3f
  111. #define SMB347_MAX_REGISTER 0x3f
  112. /**
  113. * struct smb347_charger - smb347 charger instance
  114. * @lock: protects concurrent access to online variables
  115. * @dev: pointer to device
  116. * @regmap: pointer to driver regmap
  117. * @mains: power_supply instance for AC/DC power
  118. * @usb: power_supply instance for USB power
  119. * @battery: power_supply instance for battery
  120. * @mains_online: is AC/DC input connected
  121. * @usb_online: is USB input connected
  122. * @charging_enabled: is charging enabled
  123. * @pdata: pointer to platform data
  124. */
  125. struct smb347_charger {
  126. struct mutex lock;
  127. struct device *dev;
  128. struct regmap *regmap;
  129. struct power_supply mains;
  130. struct power_supply usb;
  131. struct power_supply battery;
  132. bool mains_online;
  133. bool usb_online;
  134. bool charging_enabled;
  135. const struct smb347_charger_platform_data *pdata;
  136. };
  137. /* Fast charge current in uA */
  138. static const unsigned int fcc_tbl[] = {
  139. 700000,
  140. 900000,
  141. 1200000,
  142. 1500000,
  143. 1800000,
  144. 2000000,
  145. 2200000,
  146. 2500000,
  147. };
  148. /* Pre-charge current in uA */
  149. static const unsigned int pcc_tbl[] = {
  150. 100000,
  151. 150000,
  152. 200000,
  153. 250000,
  154. };
  155. /* Termination current in uA */
  156. static const unsigned int tc_tbl[] = {
  157. 37500,
  158. 50000,
  159. 100000,
  160. 150000,
  161. 200000,
  162. 250000,
  163. 500000,
  164. 600000,
  165. };
  166. /* Input current limit in uA */
  167. static const unsigned int icl_tbl[] = {
  168. 300000,
  169. 500000,
  170. 700000,
  171. 900000,
  172. 1200000,
  173. 1500000,
  174. 1800000,
  175. 2000000,
  176. 2200000,
  177. 2500000,
  178. };
  179. /* Charge current compensation in uA */
  180. static const unsigned int ccc_tbl[] = {
  181. 250000,
  182. 700000,
  183. 900000,
  184. 1200000,
  185. };
  186. /* Convert current to register value using lookup table */
  187. static int current_to_hw(const unsigned int *tbl, size_t size, unsigned int val)
  188. {
  189. size_t i;
  190. for (i = 0; i < size; i++)
  191. if (val < tbl[i])
  192. break;
  193. return i > 0 ? i - 1 : -EINVAL;
  194. }
  195. /**
  196. * smb347_update_ps_status - refreshes the power source status
  197. * @smb: pointer to smb347 charger instance
  198. *
  199. * Function checks whether any power source is connected to the charger and
  200. * updates internal state accordingly. If there is a change to previous state
  201. * function returns %1, otherwise %0 and negative errno in case of errror.
  202. */
  203. static int smb347_update_ps_status(struct smb347_charger *smb)
  204. {
  205. bool usb = false;
  206. bool dc = false;
  207. unsigned int val;
  208. int ret;
  209. ret = regmap_read(smb->regmap, IRQSTAT_E, &val);
  210. if (ret < 0)
  211. return ret;
  212. /*
  213. * Dc and usb are set depending on whether they are enabled in
  214. * platform data _and_ whether corresponding undervoltage is set.
  215. */
  216. if (smb->pdata->use_mains)
  217. dc = !(val & IRQSTAT_E_DCIN_UV_STAT);
  218. if (smb->pdata->use_usb)
  219. usb = !(val & IRQSTAT_E_USBIN_UV_STAT);
  220. mutex_lock(&smb->lock);
  221. ret = smb->mains_online != dc || smb->usb_online != usb;
  222. smb->mains_online = dc;
  223. smb->usb_online = usb;
  224. mutex_unlock(&smb->lock);
  225. return ret;
  226. }
  227. /*
  228. * smb347_is_ps_online - returns whether input power source is connected
  229. * @smb: pointer to smb347 charger instance
  230. *
  231. * Returns %true if input power source is connected. Note that this is
  232. * dependent on what platform has configured for usable power sources. For
  233. * example if USB is disabled, this will return %false even if the USB cable
  234. * is connected.
  235. */
  236. static bool smb347_is_ps_online(struct smb347_charger *smb)
  237. {
  238. bool ret;
  239. mutex_lock(&smb->lock);
  240. ret = smb->usb_online || smb->mains_online;
  241. mutex_unlock(&smb->lock);
  242. return ret;
  243. }
  244. /**
  245. * smb347_charging_status - returns status of charging
  246. * @smb: pointer to smb347 charger instance
  247. *
  248. * Function returns charging status. %0 means no charging is in progress,
  249. * %1 means pre-charging, %2 fast-charging and %3 taper-charging.
  250. */
  251. static int smb347_charging_status(struct smb347_charger *smb)
  252. {
  253. unsigned int val;
  254. int ret;
  255. if (!smb347_is_ps_online(smb))
  256. return 0;
  257. ret = regmap_read(smb->regmap, STAT_C, &val);
  258. if (ret < 0)
  259. return 0;
  260. return (val & STAT_C_CHG_MASK) >> STAT_C_CHG_SHIFT;
  261. }
  262. static int smb347_charging_set(struct smb347_charger *smb, bool enable)
  263. {
  264. int ret = 0;
  265. if (smb->pdata->enable_control != SMB347_CHG_ENABLE_SW) {
  266. dev_dbg(smb->dev, "charging enable/disable in SW disabled\n");
  267. return 0;
  268. }
  269. mutex_lock(&smb->lock);
  270. if (smb->charging_enabled != enable) {
  271. ret = regmap_update_bits(smb->regmap, CMD_A, CMD_A_CHG_ENABLED,
  272. enable ? CMD_A_CHG_ENABLED : 0);
  273. if (!ret)
  274. smb->charging_enabled = enable;
  275. }
  276. mutex_unlock(&smb->lock);
  277. return ret;
  278. }
  279. static inline int smb347_charging_enable(struct smb347_charger *smb)
  280. {
  281. return smb347_charging_set(smb, true);
  282. }
  283. static inline int smb347_charging_disable(struct smb347_charger *smb)
  284. {
  285. return smb347_charging_set(smb, false);
  286. }
  287. static int smb347_start_stop_charging(struct smb347_charger *smb)
  288. {
  289. int ret;
  290. /*
  291. * Depending on whether valid power source is connected or not, we
  292. * disable or enable the charging. We do it manually because it
  293. * depends on how the platform has configured the valid inputs.
  294. */
  295. if (smb347_is_ps_online(smb)) {
  296. ret = smb347_charging_enable(smb);
  297. if (ret < 0)
  298. dev_err(smb->dev, "failed to enable charging\n");
  299. } else {
  300. ret = smb347_charging_disable(smb);
  301. if (ret < 0)
  302. dev_err(smb->dev, "failed to disable charging\n");
  303. }
  304. return ret;
  305. }
  306. static int smb347_set_charge_current(struct smb347_charger *smb)
  307. {
  308. int ret;
  309. if (smb->pdata->max_charge_current) {
  310. ret = current_to_hw(fcc_tbl, ARRAY_SIZE(fcc_tbl),
  311. smb->pdata->max_charge_current);
  312. if (ret < 0)
  313. return ret;
  314. ret = regmap_update_bits(smb->regmap, CFG_CHARGE_CURRENT,
  315. CFG_CHARGE_CURRENT_FCC_MASK,
  316. ret << CFG_CHARGE_CURRENT_FCC_SHIFT);
  317. if (ret < 0)
  318. return ret;
  319. }
  320. if (smb->pdata->pre_charge_current) {
  321. ret = current_to_hw(pcc_tbl, ARRAY_SIZE(pcc_tbl),
  322. smb->pdata->pre_charge_current);
  323. if (ret < 0)
  324. return ret;
  325. ret = regmap_update_bits(smb->regmap, CFG_CHARGE_CURRENT,
  326. CFG_CHARGE_CURRENT_PCC_MASK,
  327. ret << CFG_CHARGE_CURRENT_PCC_SHIFT);
  328. if (ret < 0)
  329. return ret;
  330. }
  331. if (smb->pdata->termination_current) {
  332. ret = current_to_hw(tc_tbl, ARRAY_SIZE(tc_tbl),
  333. smb->pdata->termination_current);
  334. if (ret < 0)
  335. return ret;
  336. ret = regmap_update_bits(smb->regmap, CFG_CHARGE_CURRENT,
  337. CFG_CHARGE_CURRENT_TC_MASK, ret);
  338. if (ret < 0)
  339. return ret;
  340. }
  341. return 0;
  342. }
  343. static int smb347_set_current_limits(struct smb347_charger *smb)
  344. {
  345. int ret;
  346. if (smb->pdata->mains_current_limit) {
  347. ret = current_to_hw(icl_tbl, ARRAY_SIZE(icl_tbl),
  348. smb->pdata->mains_current_limit);
  349. if (ret < 0)
  350. return ret;
  351. ret = regmap_update_bits(smb->regmap, CFG_CURRENT_LIMIT,
  352. CFG_CURRENT_LIMIT_DC_MASK,
  353. ret << CFG_CURRENT_LIMIT_DC_SHIFT);
  354. if (ret < 0)
  355. return ret;
  356. }
  357. if (smb->pdata->usb_hc_current_limit) {
  358. ret = current_to_hw(icl_tbl, ARRAY_SIZE(icl_tbl),
  359. smb->pdata->usb_hc_current_limit);
  360. if (ret < 0)
  361. return ret;
  362. ret = regmap_update_bits(smb->regmap, CFG_CURRENT_LIMIT,
  363. CFG_CURRENT_LIMIT_USB_MASK, ret);
  364. if (ret < 0)
  365. return ret;
  366. }
  367. return 0;
  368. }
  369. static int smb347_set_voltage_limits(struct smb347_charger *smb)
  370. {
  371. int ret;
  372. if (smb->pdata->pre_to_fast_voltage) {
  373. ret = smb->pdata->pre_to_fast_voltage;
  374. /* uV */
  375. ret = clamp_val(ret, 2400000, 3000000) - 2400000;
  376. ret /= 200000;
  377. ret = regmap_update_bits(smb->regmap, CFG_FLOAT_VOLTAGE,
  378. CFG_FLOAT_VOLTAGE_THRESHOLD_MASK,
  379. ret << CFG_FLOAT_VOLTAGE_THRESHOLD_SHIFT);
  380. if (ret < 0)
  381. return ret;
  382. }
  383. if (smb->pdata->max_charge_voltage) {
  384. ret = smb->pdata->max_charge_voltage;
  385. /* uV */
  386. ret = clamp_val(ret, 3500000, 4500000) - 3500000;
  387. ret /= 20000;
  388. ret = regmap_update_bits(smb->regmap, CFG_FLOAT_VOLTAGE,
  389. CFG_FLOAT_VOLTAGE_FLOAT_MASK, ret);
  390. if (ret < 0)
  391. return ret;
  392. }
  393. return 0;
  394. }
  395. static int smb347_set_temp_limits(struct smb347_charger *smb)
  396. {
  397. bool enable_therm_monitor = false;
  398. int ret = 0;
  399. int val;
  400. if (smb->pdata->chip_temp_threshold) {
  401. val = smb->pdata->chip_temp_threshold;
  402. /* degree C */
  403. val = clamp_val(val, 100, 130) - 100;
  404. val /= 10;
  405. ret = regmap_update_bits(smb->regmap, CFG_OTG,
  406. CFG_OTG_TEMP_THRESHOLD_MASK,
  407. val << CFG_OTG_TEMP_THRESHOLD_SHIFT);
  408. if (ret < 0)
  409. return ret;
  410. }
  411. if (smb->pdata->soft_cold_temp_limit != SMB347_TEMP_USE_DEFAULT) {
  412. val = smb->pdata->soft_cold_temp_limit;
  413. val = clamp_val(val, 0, 15);
  414. val /= 5;
  415. /* this goes from higher to lower so invert the value */
  416. val = ~val & 0x3;
  417. ret = regmap_update_bits(smb->regmap, CFG_TEMP_LIMIT,
  418. CFG_TEMP_LIMIT_SOFT_COLD_MASK,
  419. val << CFG_TEMP_LIMIT_SOFT_COLD_SHIFT);
  420. if (ret < 0)
  421. return ret;
  422. enable_therm_monitor = true;
  423. }
  424. if (smb->pdata->soft_hot_temp_limit != SMB347_TEMP_USE_DEFAULT) {
  425. val = smb->pdata->soft_hot_temp_limit;
  426. val = clamp_val(val, 40, 55) - 40;
  427. val /= 5;
  428. ret = regmap_update_bits(smb->regmap, CFG_TEMP_LIMIT,
  429. CFG_TEMP_LIMIT_SOFT_HOT_MASK,
  430. val << CFG_TEMP_LIMIT_SOFT_HOT_SHIFT);
  431. if (ret < 0)
  432. return ret;
  433. enable_therm_monitor = true;
  434. }
  435. if (smb->pdata->hard_cold_temp_limit != SMB347_TEMP_USE_DEFAULT) {
  436. val = smb->pdata->hard_cold_temp_limit;
  437. val = clamp_val(val, -5, 10) + 5;
  438. val /= 5;
  439. /* this goes from higher to lower so invert the value */
  440. val = ~val & 0x3;
  441. ret = regmap_update_bits(smb->regmap, CFG_TEMP_LIMIT,
  442. CFG_TEMP_LIMIT_HARD_COLD_MASK,
  443. val << CFG_TEMP_LIMIT_HARD_COLD_SHIFT);
  444. if (ret < 0)
  445. return ret;
  446. enable_therm_monitor = true;
  447. }
  448. if (smb->pdata->hard_hot_temp_limit != SMB347_TEMP_USE_DEFAULT) {
  449. val = smb->pdata->hard_hot_temp_limit;
  450. val = clamp_val(val, 50, 65) - 50;
  451. val /= 5;
  452. ret = regmap_update_bits(smb->regmap, CFG_TEMP_LIMIT,
  453. CFG_TEMP_LIMIT_HARD_HOT_MASK,
  454. val << CFG_TEMP_LIMIT_HARD_HOT_SHIFT);
  455. if (ret < 0)
  456. return ret;
  457. enable_therm_monitor = true;
  458. }
  459. /*
  460. * If any of the temperature limits are set, we also enable the
  461. * thermistor monitoring.
  462. *
  463. * When soft limits are hit, the device will start to compensate
  464. * current and/or voltage depending on the configuration.
  465. *
  466. * When hard limit is hit, the device will suspend charging
  467. * depending on the configuration.
  468. */
  469. if (enable_therm_monitor) {
  470. ret = regmap_update_bits(smb->regmap, CFG_THERM,
  471. CFG_THERM_MONITOR_DISABLED, 0);
  472. if (ret < 0)
  473. return ret;
  474. }
  475. if (smb->pdata->suspend_on_hard_temp_limit) {
  476. ret = regmap_update_bits(smb->regmap, CFG_SYSOK,
  477. CFG_SYSOK_SUSPEND_HARD_LIMIT_DISABLED, 0);
  478. if (ret < 0)
  479. return ret;
  480. }
  481. if (smb->pdata->soft_temp_limit_compensation !=
  482. SMB347_SOFT_TEMP_COMPENSATE_DEFAULT) {
  483. val = smb->pdata->soft_temp_limit_compensation & 0x3;
  484. ret = regmap_update_bits(smb->regmap, CFG_THERM,
  485. CFG_THERM_SOFT_HOT_COMPENSATION_MASK,
  486. val << CFG_THERM_SOFT_HOT_COMPENSATION_SHIFT);
  487. if (ret < 0)
  488. return ret;
  489. ret = regmap_update_bits(smb->regmap, CFG_THERM,
  490. CFG_THERM_SOFT_COLD_COMPENSATION_MASK,
  491. val << CFG_THERM_SOFT_COLD_COMPENSATION_SHIFT);
  492. if (ret < 0)
  493. return ret;
  494. }
  495. if (smb->pdata->charge_current_compensation) {
  496. val = current_to_hw(ccc_tbl, ARRAY_SIZE(ccc_tbl),
  497. smb->pdata->charge_current_compensation);
  498. if (val < 0)
  499. return val;
  500. ret = regmap_update_bits(smb->regmap, CFG_OTG,
  501. CFG_OTG_CC_COMPENSATION_MASK,
  502. (val & 0x3) << CFG_OTG_CC_COMPENSATION_SHIFT);
  503. if (ret < 0)
  504. return ret;
  505. }
  506. return ret;
  507. }
  508. /*
  509. * smb347_set_writable - enables/disables writing to non-volatile registers
  510. * @smb: pointer to smb347 charger instance
  511. *
  512. * You can enable/disable writing to the non-volatile configuration
  513. * registers by calling this function.
  514. *
  515. * Returns %0 on success and negative errno in case of failure.
  516. */
  517. static int smb347_set_writable(struct smb347_charger *smb, bool writable)
  518. {
  519. return regmap_update_bits(smb->regmap, CMD_A, CMD_A_ALLOW_WRITE,
  520. writable ? CMD_A_ALLOW_WRITE : 0);
  521. }
  522. static int smb347_hw_init(struct smb347_charger *smb)
  523. {
  524. unsigned int val;
  525. int ret;
  526. ret = smb347_set_writable(smb, true);
  527. if (ret < 0)
  528. return ret;
  529. /*
  530. * Program the platform specific configuration values to the device
  531. * first.
  532. */
  533. ret = smb347_set_charge_current(smb);
  534. if (ret < 0)
  535. goto fail;
  536. ret = smb347_set_current_limits(smb);
  537. if (ret < 0)
  538. goto fail;
  539. ret = smb347_set_voltage_limits(smb);
  540. if (ret < 0)
  541. goto fail;
  542. ret = smb347_set_temp_limits(smb);
  543. if (ret < 0)
  544. goto fail;
  545. /* If USB charging is disabled we put the USB in suspend mode */
  546. if (!smb->pdata->use_usb) {
  547. ret = regmap_update_bits(smb->regmap, CMD_A,
  548. CMD_A_SUSPEND_ENABLED,
  549. CMD_A_SUSPEND_ENABLED);
  550. if (ret < 0)
  551. goto fail;
  552. }
  553. /*
  554. * If configured by platform data, we enable hardware Auto-OTG
  555. * support for driving VBUS. Otherwise we disable it.
  556. */
  557. ret = regmap_update_bits(smb->regmap, CFG_OTHER, CFG_OTHER_RID_MASK,
  558. smb->pdata->use_usb_otg ? CFG_OTHER_RID_ENABLED_AUTO_OTG : 0);
  559. if (ret < 0)
  560. goto fail;
  561. /*
  562. * Make the charging functionality controllable by a write to the
  563. * command register unless pin control is specified in the platform
  564. * data.
  565. */
  566. switch (smb->pdata->enable_control) {
  567. case SMB347_CHG_ENABLE_PIN_ACTIVE_LOW:
  568. val = CFG_PIN_EN_CTRL_ACTIVE_LOW;
  569. break;
  570. case SMB347_CHG_ENABLE_PIN_ACTIVE_HIGH:
  571. val = CFG_PIN_EN_CTRL_ACTIVE_HIGH;
  572. break;
  573. default:
  574. val = 0;
  575. break;
  576. }
  577. ret = regmap_update_bits(smb->regmap, CFG_PIN, CFG_PIN_EN_CTRL_MASK,
  578. val);
  579. if (ret < 0)
  580. goto fail;
  581. /* Disable Automatic Power Source Detection (APSD) interrupt. */
  582. ret = regmap_update_bits(smb->regmap, CFG_PIN, CFG_PIN_EN_APSD_IRQ, 0);
  583. if (ret < 0)
  584. goto fail;
  585. ret = smb347_update_ps_status(smb);
  586. if (ret < 0)
  587. goto fail;
  588. ret = smb347_start_stop_charging(smb);
  589. fail:
  590. smb347_set_writable(smb, false);
  591. return ret;
  592. }
  593. static irqreturn_t smb347_interrupt(int irq, void *data)
  594. {
  595. struct smb347_charger *smb = data;
  596. unsigned int stat_c, irqstat_e, irqstat_c;
  597. bool handled = false;
  598. int ret;
  599. ret = regmap_read(smb->regmap, STAT_C, &stat_c);
  600. if (ret < 0) {
  601. dev_warn(smb->dev, "reading STAT_C failed\n");
  602. return IRQ_NONE;
  603. }
  604. ret = regmap_read(smb->regmap, IRQSTAT_C, &irqstat_c);
  605. if (ret < 0) {
  606. dev_warn(smb->dev, "reading IRQSTAT_C failed\n");
  607. return IRQ_NONE;
  608. }
  609. ret = regmap_read(smb->regmap, IRQSTAT_E, &irqstat_e);
  610. if (ret < 0) {
  611. dev_warn(smb->dev, "reading IRQSTAT_E failed\n");
  612. return IRQ_NONE;
  613. }
  614. /*
  615. * If we get charger error we report the error back to user and
  616. * disable charging.
  617. */
  618. if (stat_c & STAT_C_CHARGER_ERROR) {
  619. dev_err(smb->dev, "error in charger, disabling charging\n");
  620. smb347_charging_disable(smb);
  621. power_supply_changed(&smb->battery);
  622. handled = true;
  623. }
  624. /*
  625. * If we reached the termination current the battery is charged and
  626. * we can update the status now. Charging is automatically
  627. * disabled by the hardware.
  628. */
  629. if (irqstat_c & (IRQSTAT_C_TERMINATION_IRQ | IRQSTAT_C_TAPER_IRQ)) {
  630. if (irqstat_c & IRQSTAT_C_TERMINATION_STAT)
  631. power_supply_changed(&smb->battery);
  632. handled = true;
  633. }
  634. /*
  635. * If we got an under voltage interrupt it means that AC/USB input
  636. * was connected or disconnected.
  637. */
  638. if (irqstat_e & (IRQSTAT_E_USBIN_UV_IRQ | IRQSTAT_E_DCIN_UV_IRQ)) {
  639. if (smb347_update_ps_status(smb) > 0) {
  640. smb347_start_stop_charging(smb);
  641. if (smb->pdata->use_mains)
  642. power_supply_changed(&smb->mains);
  643. if (smb->pdata->use_usb)
  644. power_supply_changed(&smb->usb);
  645. }
  646. handled = true;
  647. }
  648. return handled ? IRQ_HANDLED : IRQ_NONE;
  649. }
  650. static int smb347_irq_set(struct smb347_charger *smb, bool enable)
  651. {
  652. int ret;
  653. ret = smb347_set_writable(smb, true);
  654. if (ret < 0)
  655. return ret;
  656. /*
  657. * Enable/disable interrupts for:
  658. * - under voltage
  659. * - termination current reached
  660. * - charger error
  661. */
  662. ret = regmap_update_bits(smb->regmap, CFG_FAULT_IRQ, 0xff,
  663. enable ? CFG_FAULT_IRQ_DCIN_UV : 0);
  664. if (ret < 0)
  665. goto fail;
  666. ret = regmap_update_bits(smb->regmap, CFG_STATUS_IRQ, 0xff,
  667. enable ? CFG_STATUS_IRQ_TERMINATION_OR_TAPER : 0);
  668. if (ret < 0)
  669. goto fail;
  670. ret = regmap_update_bits(smb->regmap, CFG_PIN, CFG_PIN_EN_CHARGER_ERROR,
  671. enable ? CFG_PIN_EN_CHARGER_ERROR : 0);
  672. fail:
  673. smb347_set_writable(smb, false);
  674. return ret;
  675. }
  676. static inline int smb347_irq_enable(struct smb347_charger *smb)
  677. {
  678. return smb347_irq_set(smb, true);
  679. }
  680. static inline int smb347_irq_disable(struct smb347_charger *smb)
  681. {
  682. return smb347_irq_set(smb, false);
  683. }
  684. static int smb347_irq_init(struct smb347_charger *smb,
  685. struct i2c_client *client)
  686. {
  687. const struct smb347_charger_platform_data *pdata = smb->pdata;
  688. int ret, irq = gpio_to_irq(pdata->irq_gpio);
  689. ret = gpio_request_one(pdata->irq_gpio, GPIOF_IN, client->name);
  690. if (ret < 0)
  691. goto fail;
  692. ret = request_threaded_irq(irq, NULL, smb347_interrupt,
  693. IRQF_TRIGGER_FALLING, client->name, smb);
  694. if (ret < 0)
  695. goto fail_gpio;
  696. ret = smb347_set_writable(smb, true);
  697. if (ret < 0)
  698. goto fail_irq;
  699. /*
  700. * Configure the STAT output to be suitable for interrupts: disable
  701. * all other output (except interrupts) and make it active low.
  702. */
  703. ret = regmap_update_bits(smb->regmap, CFG_STAT,
  704. CFG_STAT_ACTIVE_HIGH | CFG_STAT_DISABLED,
  705. CFG_STAT_DISABLED);
  706. if (ret < 0)
  707. goto fail_readonly;
  708. smb347_set_writable(smb, false);
  709. client->irq = irq;
  710. return 0;
  711. fail_readonly:
  712. smb347_set_writable(smb, false);
  713. fail_irq:
  714. free_irq(irq, smb);
  715. fail_gpio:
  716. gpio_free(pdata->irq_gpio);
  717. fail:
  718. client->irq = 0;
  719. return ret;
  720. }
  721. static int smb347_mains_get_property(struct power_supply *psy,
  722. enum power_supply_property prop,
  723. union power_supply_propval *val)
  724. {
  725. struct smb347_charger *smb =
  726. container_of(psy, struct smb347_charger, mains);
  727. if (prop == POWER_SUPPLY_PROP_ONLINE) {
  728. val->intval = smb->mains_online;
  729. return 0;
  730. }
  731. return -EINVAL;
  732. }
  733. static enum power_supply_property smb347_mains_properties[] = {
  734. POWER_SUPPLY_PROP_ONLINE,
  735. };
  736. static int smb347_usb_get_property(struct power_supply *psy,
  737. enum power_supply_property prop,
  738. union power_supply_propval *val)
  739. {
  740. struct smb347_charger *smb =
  741. container_of(psy, struct smb347_charger, usb);
  742. if (prop == POWER_SUPPLY_PROP_ONLINE) {
  743. val->intval = smb->usb_online;
  744. return 0;
  745. }
  746. return -EINVAL;
  747. }
  748. static enum power_supply_property smb347_usb_properties[] = {
  749. POWER_SUPPLY_PROP_ONLINE,
  750. };
  751. static int smb347_battery_get_property(struct power_supply *psy,
  752. enum power_supply_property prop,
  753. union power_supply_propval *val)
  754. {
  755. struct smb347_charger *smb =
  756. container_of(psy, struct smb347_charger, battery);
  757. const struct smb347_charger_platform_data *pdata = smb->pdata;
  758. int ret;
  759. ret = smb347_update_ps_status(smb);
  760. if (ret < 0)
  761. return ret;
  762. switch (prop) {
  763. case POWER_SUPPLY_PROP_STATUS:
  764. if (!smb347_is_ps_online(smb)) {
  765. val->intval = POWER_SUPPLY_STATUS_DISCHARGING;
  766. break;
  767. }
  768. if (smb347_charging_status(smb))
  769. val->intval = POWER_SUPPLY_STATUS_CHARGING;
  770. else
  771. val->intval = POWER_SUPPLY_STATUS_FULL;
  772. break;
  773. case POWER_SUPPLY_PROP_CHARGE_TYPE:
  774. if (!smb347_is_ps_online(smb))
  775. return -ENODATA;
  776. /*
  777. * We handle trickle and pre-charging the same, and taper
  778. * and none the same.
  779. */
  780. switch (smb347_charging_status(smb)) {
  781. case 1:
  782. val->intval = POWER_SUPPLY_CHARGE_TYPE_TRICKLE;
  783. break;
  784. case 2:
  785. val->intval = POWER_SUPPLY_CHARGE_TYPE_FAST;
  786. break;
  787. default:
  788. val->intval = POWER_SUPPLY_CHARGE_TYPE_NONE;
  789. break;
  790. }
  791. break;
  792. case POWER_SUPPLY_PROP_TECHNOLOGY:
  793. val->intval = pdata->battery_info.technology;
  794. break;
  795. case POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN:
  796. val->intval = pdata->battery_info.voltage_min_design;
  797. break;
  798. case POWER_SUPPLY_PROP_VOLTAGE_MAX_DESIGN:
  799. val->intval = pdata->battery_info.voltage_max_design;
  800. break;
  801. case POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN:
  802. val->intval = pdata->battery_info.charge_full_design;
  803. break;
  804. case POWER_SUPPLY_PROP_MODEL_NAME:
  805. val->strval = pdata->battery_info.name;
  806. break;
  807. default:
  808. return -EINVAL;
  809. }
  810. return 0;
  811. }
  812. static enum power_supply_property smb347_battery_properties[] = {
  813. POWER_SUPPLY_PROP_STATUS,
  814. POWER_SUPPLY_PROP_CHARGE_TYPE,
  815. POWER_SUPPLY_PROP_TECHNOLOGY,
  816. POWER_SUPPLY_PROP_VOLTAGE_MIN_DESIGN,
  817. POWER_SUPPLY_PROP_VOLTAGE_MAX_DESIGN,
  818. POWER_SUPPLY_PROP_CHARGE_FULL_DESIGN,
  819. POWER_SUPPLY_PROP_MODEL_NAME,
  820. };
  821. static bool smb347_volatile_reg(struct device *dev, unsigned int reg)
  822. {
  823. switch (reg) {
  824. case IRQSTAT_A:
  825. case IRQSTAT_C:
  826. case IRQSTAT_E:
  827. case IRQSTAT_F:
  828. case STAT_A:
  829. case STAT_B:
  830. case STAT_C:
  831. case STAT_E:
  832. return true;
  833. }
  834. return false;
  835. }
  836. static bool smb347_readable_reg(struct device *dev, unsigned int reg)
  837. {
  838. switch (reg) {
  839. case CFG_CHARGE_CURRENT:
  840. case CFG_CURRENT_LIMIT:
  841. case CFG_FLOAT_VOLTAGE:
  842. case CFG_STAT:
  843. case CFG_PIN:
  844. case CFG_THERM:
  845. case CFG_SYSOK:
  846. case CFG_OTHER:
  847. case CFG_OTG:
  848. case CFG_TEMP_LIMIT:
  849. case CFG_FAULT_IRQ:
  850. case CFG_STATUS_IRQ:
  851. case CFG_ADDRESS:
  852. case CMD_A:
  853. case CMD_B:
  854. case CMD_C:
  855. return true;
  856. }
  857. return smb347_volatile_reg(dev, reg);
  858. }
  859. static const struct regmap_config smb347_regmap = {
  860. .reg_bits = 8,
  861. .val_bits = 8,
  862. .max_register = SMB347_MAX_REGISTER,
  863. .volatile_reg = smb347_volatile_reg,
  864. .readable_reg = smb347_readable_reg,
  865. };
  866. static int smb347_probe(struct i2c_client *client,
  867. const struct i2c_device_id *id)
  868. {
  869. static char *battery[] = { "smb347-battery" };
  870. const struct smb347_charger_platform_data *pdata;
  871. struct device *dev = &client->dev;
  872. struct smb347_charger *smb;
  873. int ret;
  874. pdata = dev->platform_data;
  875. if (!pdata)
  876. return -EINVAL;
  877. if (!pdata->use_mains && !pdata->use_usb)
  878. return -EINVAL;
  879. smb = devm_kzalloc(dev, sizeof(*smb), GFP_KERNEL);
  880. if (!smb)
  881. return -ENOMEM;
  882. i2c_set_clientdata(client, smb);
  883. mutex_init(&smb->lock);
  884. smb->dev = &client->dev;
  885. smb->pdata = pdata;
  886. smb->regmap = devm_regmap_init_i2c(client, &smb347_regmap);
  887. if (IS_ERR(smb->regmap))
  888. return PTR_ERR(smb->regmap);
  889. ret = smb347_hw_init(smb);
  890. if (ret < 0)
  891. return ret;
  892. if (smb->pdata->use_mains) {
  893. smb->mains.name = "smb347-mains";
  894. smb->mains.type = POWER_SUPPLY_TYPE_MAINS;
  895. smb->mains.get_property = smb347_mains_get_property;
  896. smb->mains.properties = smb347_mains_properties;
  897. smb->mains.num_properties = ARRAY_SIZE(smb347_mains_properties);
  898. smb->mains.supplied_to = battery;
  899. smb->mains.num_supplicants = ARRAY_SIZE(battery);
  900. ret = power_supply_register(dev, &smb->mains);
  901. if (ret < 0)
  902. return ret;
  903. }
  904. if (smb->pdata->use_usb) {
  905. smb->usb.name = "smb347-usb";
  906. smb->usb.type = POWER_SUPPLY_TYPE_USB;
  907. smb->usb.get_property = smb347_usb_get_property;
  908. smb->usb.properties = smb347_usb_properties;
  909. smb->usb.num_properties = ARRAY_SIZE(smb347_usb_properties);
  910. smb->usb.supplied_to = battery;
  911. smb->usb.num_supplicants = ARRAY_SIZE(battery);
  912. ret = power_supply_register(dev, &smb->usb);
  913. if (ret < 0) {
  914. if (smb->pdata->use_mains)
  915. power_supply_unregister(&smb->mains);
  916. return ret;
  917. }
  918. }
  919. smb->battery.name = "smb347-battery";
  920. smb->battery.type = POWER_SUPPLY_TYPE_BATTERY;
  921. smb->battery.get_property = smb347_battery_get_property;
  922. smb->battery.properties = smb347_battery_properties;
  923. smb->battery.num_properties = ARRAY_SIZE(smb347_battery_properties);
  924. ret = power_supply_register(dev, &smb->battery);
  925. if (ret < 0) {
  926. if (smb->pdata->use_usb)
  927. power_supply_unregister(&smb->usb);
  928. if (smb->pdata->use_mains)
  929. power_supply_unregister(&smb->mains);
  930. return ret;
  931. }
  932. /*
  933. * Interrupt pin is optional. If it is connected, we setup the
  934. * interrupt support here.
  935. */
  936. if (pdata->irq_gpio >= 0) {
  937. ret = smb347_irq_init(smb, client);
  938. if (ret < 0) {
  939. dev_warn(dev, "failed to initialize IRQ: %d\n", ret);
  940. dev_warn(dev, "disabling IRQ support\n");
  941. } else {
  942. smb347_irq_enable(smb);
  943. }
  944. }
  945. return 0;
  946. }
  947. static int smb347_remove(struct i2c_client *client)
  948. {
  949. struct smb347_charger *smb = i2c_get_clientdata(client);
  950. if (client->irq) {
  951. smb347_irq_disable(smb);
  952. free_irq(client->irq, smb);
  953. gpio_free(smb->pdata->irq_gpio);
  954. }
  955. power_supply_unregister(&smb->battery);
  956. if (smb->pdata->use_usb)
  957. power_supply_unregister(&smb->usb);
  958. if (smb->pdata->use_mains)
  959. power_supply_unregister(&smb->mains);
  960. return 0;
  961. }
  962. static const struct i2c_device_id smb347_id[] = {
  963. { "smb347", 0 },
  964. { }
  965. };
  966. MODULE_DEVICE_TABLE(i2c, smb347_id);
  967. static struct i2c_driver smb347_driver = {
  968. .driver = {
  969. .name = "smb347",
  970. },
  971. .probe = smb347_probe,
  972. .remove = __devexit_p(smb347_remove),
  973. .id_table = smb347_id,
  974. };
  975. module_i2c_driver(smb347_driver);
  976. MODULE_AUTHOR("Bruce E. Robertson <bruce.e.robertson@intel.com>");
  977. MODULE_AUTHOR("Mika Westerberg <mika.westerberg@linux.intel.com>");
  978. MODULE_DESCRIPTION("SMB347 battery charger driver");
  979. MODULE_LICENSE("GPL");
  980. MODULE_ALIAS("i2c:smb347");