max14656_charger_detector.c 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  1. /*
  2. * Maxim MAX14656 / AL32 USB Charger Detector driver
  3. *
  4. * Copyright (C) 2014 LG Electronics, Inc
  5. * Copyright (C) 2016 Alexander Kurz <akurz@blala.de>
  6. *
  7. * Components from Maxim AL32 Charger detection Driver for MX50 Yoshi Board
  8. * Copyright (C) Amazon Technologies Inc. All rights reserved.
  9. * Manish Lachwani (lachwani@lab126.com)
  10. *
  11. * This package is free software; you can redistribute it and/or modify
  12. * it under the terms of the GNU General Public License version 2 and
  13. * only version 2 as published by the Free Software Foundation.
  14. *
  15. */
  16. #include <linux/module.h>
  17. #include <linux/init.h>
  18. #include <linux/delay.h>
  19. #include <linux/i2c.h>
  20. #include <linux/interrupt.h>
  21. #include <linux/slab.h>
  22. #include <linux/gpio.h>
  23. #include <linux/of_gpio.h>
  24. #include <linux/of_device.h>
  25. #include <linux/workqueue.h>
  26. #include <linux/power_supply.h>
  27. #define MAX14656_MANUFACTURER "Maxim Integrated"
  28. #define MAX14656_NAME "max14656"
  29. #define MAX14656_DEVICE_ID 0x00
  30. #define MAX14656_INTERRUPT_1 0x01
  31. #define MAX14656_INTERRUPT_2 0x02
  32. #define MAX14656_STATUS_1 0x03
  33. #define MAX14656_STATUS_2 0x04
  34. #define MAX14656_INTMASK_1 0x05
  35. #define MAX14656_INTMASK_2 0x06
  36. #define MAX14656_CONTROL_1 0x07
  37. #define MAX14656_CONTROL_2 0x08
  38. #define MAX14656_CONTROL_3 0x09
  39. #define DEVICE_VENDOR_MASK 0xf0
  40. #define DEVICE_REV_MASK 0x0f
  41. #define INT_EN_REG_MASK BIT(4)
  42. #define CHG_TYPE_INT_MASK BIT(0)
  43. #define STATUS1_VB_VALID_MASK BIT(4)
  44. #define STATUS1_CHG_TYPE_MASK 0xf
  45. #define INT1_DCD_TIMEOUT_MASK BIT(7)
  46. #define CONTROL1_DEFAULT 0x0d
  47. #define CONTROL1_INT_EN BIT(4)
  48. #define CONTROL1_INT_ACTIVE_HIGH BIT(5)
  49. #define CONTROL1_EDGE BIT(7)
  50. #define CONTROL2_DEFAULT 0x8e
  51. #define CONTROL2_ADC_EN BIT(0)
  52. #define CONTROL3_DEFAULT 0x8d
  53. enum max14656_chg_type {
  54. MAX14656_NO_CHARGER = 0,
  55. MAX14656_SDP_CHARGER,
  56. MAX14656_CDP_CHARGER,
  57. MAX14656_DCP_CHARGER,
  58. MAX14656_APPLE_500MA_CHARGER,
  59. MAX14656_APPLE_1A_CHARGER,
  60. MAX14656_APPLE_2A_CHARGER,
  61. MAX14656_SPECIAL_500MA_CHARGER,
  62. MAX14656_APPLE_12W,
  63. MAX14656_CHARGER_LAST
  64. };
  65. static const struct max14656_chg_type_props {
  66. enum power_supply_type type;
  67. } chg_type_props[] = {
  68. { POWER_SUPPLY_TYPE_UNKNOWN },
  69. { POWER_SUPPLY_TYPE_USB },
  70. { POWER_SUPPLY_TYPE_USB_CDP },
  71. { POWER_SUPPLY_TYPE_USB_DCP },
  72. { POWER_SUPPLY_TYPE_USB_DCP },
  73. { POWER_SUPPLY_TYPE_USB_DCP },
  74. { POWER_SUPPLY_TYPE_USB_DCP },
  75. { POWER_SUPPLY_TYPE_USB_DCP },
  76. { POWER_SUPPLY_TYPE_USB },
  77. };
  78. struct max14656_chip {
  79. struct i2c_client *client;
  80. struct power_supply *detect_psy;
  81. struct power_supply_desc psy_desc;
  82. struct delayed_work irq_work;
  83. int irq;
  84. int online;
  85. };
  86. static int max14656_read_reg(struct i2c_client *client, int reg, u8 *val)
  87. {
  88. s32 ret;
  89. ret = i2c_smbus_read_byte_data(client, reg);
  90. if (ret < 0) {
  91. dev_err(&client->dev,
  92. "i2c read fail: can't read from %02x: %d\n",
  93. reg, ret);
  94. return ret;
  95. }
  96. *val = ret;
  97. return 0;
  98. }
  99. static int max14656_write_reg(struct i2c_client *client, int reg, u8 val)
  100. {
  101. s32 ret;
  102. ret = i2c_smbus_write_byte_data(client, reg, val);
  103. if (ret < 0) {
  104. dev_err(&client->dev,
  105. "i2c write fail: can't write %02x to %02x: %d\n",
  106. val, reg, ret);
  107. return ret;
  108. }
  109. return 0;
  110. }
  111. static int max14656_read_block_reg(struct i2c_client *client, u8 reg,
  112. u8 length, u8 *val)
  113. {
  114. int ret;
  115. ret = i2c_smbus_read_i2c_block_data(client, reg, length, val);
  116. if (ret < 0) {
  117. dev_err(&client->dev, "failed to block read reg 0x%x: %d\n",
  118. reg, ret);
  119. return ret;
  120. }
  121. return 0;
  122. }
  123. #define REG_TOTAL_NUM 5
  124. static void max14656_irq_worker(struct work_struct *work)
  125. {
  126. struct max14656_chip *chip =
  127. container_of(work, struct max14656_chip, irq_work.work);
  128. u8 buf[REG_TOTAL_NUM];
  129. u8 chg_type;
  130. int ret = 0;
  131. ret = max14656_read_block_reg(chip->client, MAX14656_DEVICE_ID,
  132. REG_TOTAL_NUM, buf);
  133. if ((buf[MAX14656_STATUS_1] & STATUS1_VB_VALID_MASK) &&
  134. (buf[MAX14656_STATUS_1] & STATUS1_CHG_TYPE_MASK)) {
  135. chg_type = buf[MAX14656_STATUS_1] & STATUS1_CHG_TYPE_MASK;
  136. if (chg_type < MAX14656_CHARGER_LAST)
  137. chip->psy_desc.type = chg_type_props[chg_type].type;
  138. else
  139. chip->psy_desc.type = POWER_SUPPLY_TYPE_UNKNOWN;
  140. chip->online = 1;
  141. } else {
  142. chip->online = 0;
  143. chip->psy_desc.type = POWER_SUPPLY_TYPE_UNKNOWN;
  144. }
  145. power_supply_changed(chip->detect_psy);
  146. }
  147. static irqreturn_t max14656_irq(int irq, void *dev_id)
  148. {
  149. struct max14656_chip *chip = dev_id;
  150. schedule_delayed_work(&chip->irq_work, msecs_to_jiffies(100));
  151. return IRQ_HANDLED;
  152. }
  153. static int max14656_hw_init(struct max14656_chip *chip)
  154. {
  155. uint8_t val = 0;
  156. uint8_t rev;
  157. struct i2c_client *client = chip->client;
  158. if (max14656_read_reg(client, MAX14656_DEVICE_ID, &val))
  159. return -ENODEV;
  160. if ((val & DEVICE_VENDOR_MASK) != 0x20) {
  161. dev_err(&client->dev, "wrong vendor ID %d\n",
  162. ((val & DEVICE_VENDOR_MASK) >> 4));
  163. return -ENODEV;
  164. }
  165. rev = val & DEVICE_REV_MASK;
  166. /* Turn on ADC_EN */
  167. if (max14656_write_reg(client, MAX14656_CONTROL_2, CONTROL2_ADC_EN))
  168. return -EINVAL;
  169. /* turn on interrupts and low power mode */
  170. if (max14656_write_reg(client, MAX14656_CONTROL_1,
  171. CONTROL1_DEFAULT |
  172. CONTROL1_INT_EN |
  173. CONTROL1_INT_ACTIVE_HIGH |
  174. CONTROL1_EDGE))
  175. return -EINVAL;
  176. if (max14656_write_reg(client, MAX14656_INTMASK_1, 0x3))
  177. return -EINVAL;
  178. if (max14656_write_reg(client, MAX14656_INTMASK_2, 0x1))
  179. return -EINVAL;
  180. dev_info(&client->dev, "detected revision %d\n", rev);
  181. return 0;
  182. }
  183. static int max14656_get_property(struct power_supply *psy,
  184. enum power_supply_property psp,
  185. union power_supply_propval *val)
  186. {
  187. struct max14656_chip *chip = power_supply_get_drvdata(psy);
  188. switch (psp) {
  189. case POWER_SUPPLY_PROP_ONLINE:
  190. val->intval = chip->online;
  191. break;
  192. case POWER_SUPPLY_PROP_MODEL_NAME:
  193. val->strval = MAX14656_NAME;
  194. break;
  195. case POWER_SUPPLY_PROP_MANUFACTURER:
  196. val->strval = MAX14656_MANUFACTURER;
  197. break;
  198. default:
  199. return -EINVAL;
  200. }
  201. return 0;
  202. }
  203. static enum power_supply_property max14656_battery_props[] = {
  204. POWER_SUPPLY_PROP_ONLINE,
  205. POWER_SUPPLY_PROP_MODEL_NAME,
  206. POWER_SUPPLY_PROP_MANUFACTURER,
  207. };
  208. static void stop_irq_work(void *data)
  209. {
  210. struct max14656_chip *chip = data;
  211. cancel_delayed_work_sync(&chip->irq_work);
  212. }
  213. static int max14656_probe(struct i2c_client *client,
  214. const struct i2c_device_id *id)
  215. {
  216. struct i2c_adapter *adapter = to_i2c_adapter(client->dev.parent);
  217. struct device *dev = &client->dev;
  218. struct power_supply_config psy_cfg = {};
  219. struct max14656_chip *chip;
  220. int irq = client->irq;
  221. int ret = 0;
  222. if (irq <= 0) {
  223. dev_err(dev, "invalid irq number: %d\n", irq);
  224. return -ENODEV;
  225. }
  226. if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA)) {
  227. dev_err(dev, "No support for SMBUS_BYTE_DATA\n");
  228. return -ENODEV;
  229. }
  230. chip = devm_kzalloc(dev, sizeof(*chip), GFP_KERNEL);
  231. if (!chip)
  232. return -ENOMEM;
  233. psy_cfg.drv_data = chip;
  234. chip->client = client;
  235. chip->online = 0;
  236. chip->psy_desc.name = MAX14656_NAME;
  237. chip->psy_desc.type = POWER_SUPPLY_TYPE_UNKNOWN;
  238. chip->psy_desc.properties = max14656_battery_props;
  239. chip->psy_desc.num_properties = ARRAY_SIZE(max14656_battery_props);
  240. chip->psy_desc.get_property = max14656_get_property;
  241. chip->irq = irq;
  242. ret = max14656_hw_init(chip);
  243. if (ret)
  244. return -ENODEV;
  245. chip->detect_psy = devm_power_supply_register(dev,
  246. &chip->psy_desc, &psy_cfg);
  247. if (IS_ERR(chip->detect_psy)) {
  248. dev_err(dev, "power_supply_register failed\n");
  249. return -EINVAL;
  250. }
  251. INIT_DELAYED_WORK(&chip->irq_work, max14656_irq_worker);
  252. ret = devm_add_action(dev, stop_irq_work, chip);
  253. if (ret) {
  254. dev_err(dev, "devm_add_action %d failed\n", ret);
  255. return ret;
  256. }
  257. ret = devm_request_irq(dev, chip->irq, max14656_irq,
  258. IRQF_TRIGGER_FALLING,
  259. MAX14656_NAME, chip);
  260. if (ret) {
  261. dev_err(dev, "request_irq %d failed\n", chip->irq);
  262. return -EINVAL;
  263. }
  264. enable_irq_wake(chip->irq);
  265. schedule_delayed_work(&chip->irq_work, msecs_to_jiffies(2000));
  266. return 0;
  267. }
  268. static const struct i2c_device_id max14656_id[] = {
  269. { "max14656", 0 },
  270. {}
  271. };
  272. MODULE_DEVICE_TABLE(i2c, max14656_id);
  273. static const struct of_device_id max14656_match_table[] = {
  274. { .compatible = "maxim,max14656", },
  275. {}
  276. };
  277. MODULE_DEVICE_TABLE(of, max14656_match_table);
  278. static struct i2c_driver max14656_i2c_driver = {
  279. .driver = {
  280. .name = "max14656",
  281. .of_match_table = max14656_match_table,
  282. },
  283. .probe = max14656_probe,
  284. .id_table = max14656_id,
  285. };
  286. module_i2c_driver(max14656_i2c_driver);
  287. MODULE_DESCRIPTION("MAX14656 USB charger detector");
  288. MODULE_LICENSE("GPL v2");