bq27xxx_battery_i2c.c 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. /*
  2. * BQ27xxx battery monitor I2C driver
  3. *
  4. * Copyright (C) 2015 Texas Instruments Incorporated - http://www.ti.com/
  5. * Andrew F. Davis <afd@ti.com>
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License version 2 as
  9. * published by the Free Software Foundation.
  10. *
  11. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  12. * kind, whether express or implied; without even the implied warranty
  13. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. */
  16. #include <linux/i2c.h>
  17. #include <linux/interrupt.h>
  18. #include <linux/module.h>
  19. #include <asm/unaligned.h>
  20. #include <linux/power/bq27xxx_battery.h>
  21. static DEFINE_IDR(battery_id);
  22. static DEFINE_MUTEX(battery_mutex);
  23. static irqreturn_t bq27xxx_battery_irq_handler_thread(int irq, void *data)
  24. {
  25. struct bq27xxx_device_info *di = data;
  26. bq27xxx_battery_update(di);
  27. return IRQ_HANDLED;
  28. }
  29. static int bq27xxx_battery_i2c_read(struct bq27xxx_device_info *di, u8 reg,
  30. bool single)
  31. {
  32. struct i2c_client *client = to_i2c_client(di->dev);
  33. struct i2c_msg msg[2];
  34. u8 data[2];
  35. int ret;
  36. if (!client->adapter)
  37. return -ENODEV;
  38. msg[0].addr = client->addr;
  39. msg[0].flags = 0;
  40. msg[0].buf = &reg;
  41. msg[0].len = sizeof(reg);
  42. msg[1].addr = client->addr;
  43. msg[1].flags = I2C_M_RD;
  44. msg[1].buf = data;
  45. if (single)
  46. msg[1].len = 1;
  47. else
  48. msg[1].len = 2;
  49. ret = i2c_transfer(client->adapter, msg, ARRAY_SIZE(msg));
  50. if (ret < 0)
  51. return ret;
  52. if (!single)
  53. ret = get_unaligned_le16(data);
  54. else
  55. ret = data[0];
  56. return ret;
  57. }
  58. static int bq27xxx_battery_i2c_write(struct bq27xxx_device_info *di, u8 reg,
  59. int value, bool single)
  60. {
  61. struct i2c_client *client = to_i2c_client(di->dev);
  62. struct i2c_msg msg;
  63. u8 data[4];
  64. int ret;
  65. if (!client->adapter)
  66. return -ENODEV;
  67. data[0] = reg;
  68. if (single) {
  69. data[1] = (u8) value;
  70. msg.len = 2;
  71. } else {
  72. put_unaligned_le16(value, &data[1]);
  73. msg.len = 3;
  74. }
  75. msg.buf = data;
  76. msg.addr = client->addr;
  77. msg.flags = 0;
  78. ret = i2c_transfer(client->adapter, &msg, 1);
  79. if (ret < 0)
  80. return ret;
  81. if (ret != 1)
  82. return -EINVAL;
  83. return 0;
  84. }
  85. static int bq27xxx_battery_i2c_bulk_read(struct bq27xxx_device_info *di, u8 reg,
  86. u8 *data, int len)
  87. {
  88. struct i2c_client *client = to_i2c_client(di->dev);
  89. int ret;
  90. if (!client->adapter)
  91. return -ENODEV;
  92. ret = i2c_smbus_read_i2c_block_data(client, reg, len, data);
  93. if (ret < 0)
  94. return ret;
  95. if (ret != len)
  96. return -EINVAL;
  97. return 0;
  98. }
  99. static int bq27xxx_battery_i2c_bulk_write(struct bq27xxx_device_info *di,
  100. u8 reg, u8 *data, int len)
  101. {
  102. struct i2c_client *client = to_i2c_client(di->dev);
  103. struct i2c_msg msg;
  104. u8 buf[33];
  105. int ret;
  106. if (!client->adapter)
  107. return -ENODEV;
  108. buf[0] = reg;
  109. memcpy(&buf[1], data, len);
  110. msg.buf = buf;
  111. msg.addr = client->addr;
  112. msg.flags = 0;
  113. msg.len = len + 1;
  114. ret = i2c_transfer(client->adapter, &msg, 1);
  115. if (ret < 0)
  116. return ret;
  117. if (ret != 1)
  118. return -EINVAL;
  119. return 0;
  120. }
  121. static int bq27xxx_battery_i2c_probe(struct i2c_client *client,
  122. const struct i2c_device_id *id)
  123. {
  124. struct bq27xxx_device_info *di;
  125. int ret;
  126. char *name;
  127. int num;
  128. /* Get new ID for the new battery device */
  129. mutex_lock(&battery_mutex);
  130. num = idr_alloc(&battery_id, client, 0, 0, GFP_KERNEL);
  131. mutex_unlock(&battery_mutex);
  132. if (num < 0)
  133. return num;
  134. name = devm_kasprintf(&client->dev, GFP_KERNEL, "%s-%d", id->name, num);
  135. if (!name)
  136. goto err_mem;
  137. di = devm_kzalloc(&client->dev, sizeof(*di), GFP_KERNEL);
  138. if (!di)
  139. goto err_mem;
  140. di->id = num;
  141. di->dev = &client->dev;
  142. di->chip = id->driver_data;
  143. di->name = name;
  144. di->bus.read = bq27xxx_battery_i2c_read;
  145. di->bus.write = bq27xxx_battery_i2c_write;
  146. di->bus.read_bulk = bq27xxx_battery_i2c_bulk_read;
  147. di->bus.write_bulk = bq27xxx_battery_i2c_bulk_write;
  148. ret = bq27xxx_battery_setup(di);
  149. if (ret)
  150. goto err_failed;
  151. /* Schedule a polling after about 1 min */
  152. schedule_delayed_work(&di->work, 60 * HZ);
  153. i2c_set_clientdata(client, di);
  154. if (client->irq) {
  155. ret = devm_request_threaded_irq(&client->dev, client->irq,
  156. NULL, bq27xxx_battery_irq_handler_thread,
  157. IRQF_ONESHOT,
  158. di->name, di);
  159. if (ret) {
  160. dev_err(&client->dev,
  161. "Unable to register IRQ %d error %d\n",
  162. client->irq, ret);
  163. return ret;
  164. }
  165. }
  166. return 0;
  167. err_mem:
  168. ret = -ENOMEM;
  169. err_failed:
  170. mutex_lock(&battery_mutex);
  171. idr_remove(&battery_id, num);
  172. mutex_unlock(&battery_mutex);
  173. return ret;
  174. }
  175. static int bq27xxx_battery_i2c_remove(struct i2c_client *client)
  176. {
  177. struct bq27xxx_device_info *di = i2c_get_clientdata(client);
  178. bq27xxx_battery_teardown(di);
  179. mutex_lock(&battery_mutex);
  180. idr_remove(&battery_id, di->id);
  181. mutex_unlock(&battery_mutex);
  182. return 0;
  183. }
  184. static const struct i2c_device_id bq27xxx_i2c_id_table[] = {
  185. { "bq27200", BQ27000 },
  186. { "bq27210", BQ27010 },
  187. { "bq27500", BQ2750X },
  188. { "bq27510", BQ2751X },
  189. { "bq27520", BQ2752X },
  190. { "bq27500-1", BQ27500 },
  191. { "bq27510g1", BQ27510G1 },
  192. { "bq27510g2", BQ27510G2 },
  193. { "bq27510g3", BQ27510G3 },
  194. { "bq27520g1", BQ27520G1 },
  195. { "bq27520g2", BQ27520G2 },
  196. { "bq27520g3", BQ27520G3 },
  197. { "bq27520g4", BQ27520G4 },
  198. { "bq27521", BQ27521 },
  199. { "bq27530", BQ27530 },
  200. { "bq27531", BQ27531 },
  201. { "bq27541", BQ27541 },
  202. { "bq27542", BQ27542 },
  203. { "bq27546", BQ27546 },
  204. { "bq27742", BQ27742 },
  205. { "bq27545", BQ27545 },
  206. { "bq27421", BQ27421 },
  207. { "bq27425", BQ27425 },
  208. { "bq27426", BQ27426 },
  209. { "bq27441", BQ27441 },
  210. { "bq27621", BQ27621 },
  211. {},
  212. };
  213. MODULE_DEVICE_TABLE(i2c, bq27xxx_i2c_id_table);
  214. #ifdef CONFIG_OF
  215. static const struct of_device_id bq27xxx_battery_i2c_of_match_table[] = {
  216. { .compatible = "ti,bq27200" },
  217. { .compatible = "ti,bq27210" },
  218. { .compatible = "ti,bq27500" },
  219. { .compatible = "ti,bq27510" },
  220. { .compatible = "ti,bq27520" },
  221. { .compatible = "ti,bq27500-1" },
  222. { .compatible = "ti,bq27510g1" },
  223. { .compatible = "ti,bq27510g2" },
  224. { .compatible = "ti,bq27510g3" },
  225. { .compatible = "ti,bq27520g1" },
  226. { .compatible = "ti,bq27520g2" },
  227. { .compatible = "ti,bq27520g3" },
  228. { .compatible = "ti,bq27520g4" },
  229. { .compatible = "ti,bq27521" },
  230. { .compatible = "ti,bq27530" },
  231. { .compatible = "ti,bq27531" },
  232. { .compatible = "ti,bq27541" },
  233. { .compatible = "ti,bq27542" },
  234. { .compatible = "ti,bq27546" },
  235. { .compatible = "ti,bq27742" },
  236. { .compatible = "ti,bq27545" },
  237. { .compatible = "ti,bq27421" },
  238. { .compatible = "ti,bq27425" },
  239. { .compatible = "ti,bq27426" },
  240. { .compatible = "ti,bq27441" },
  241. { .compatible = "ti,bq27621" },
  242. {},
  243. };
  244. MODULE_DEVICE_TABLE(of, bq27xxx_battery_i2c_of_match_table);
  245. #endif
  246. static struct i2c_driver bq27xxx_battery_i2c_driver = {
  247. .driver = {
  248. .name = "bq27xxx-battery",
  249. .of_match_table = of_match_ptr(bq27xxx_battery_i2c_of_match_table),
  250. },
  251. .probe = bq27xxx_battery_i2c_probe,
  252. .remove = bq27xxx_battery_i2c_remove,
  253. .id_table = bq27xxx_i2c_id_table,
  254. };
  255. module_i2c_driver(bq27xxx_battery_i2c_driver);
  256. MODULE_AUTHOR("Andrew F. Davis <afd@ti.com>");
  257. MODULE_DESCRIPTION("BQ27xxx battery monitor i2c driver");
  258. MODULE_LICENSE("GPL");