tps65217.c 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * tps65217.c
  4. *
  5. * TPS65217 chip family multi-function driver
  6. *
  7. * Copyright (C) 2011 Texas Instruments Incorporated - https://www.ti.com/
  8. */
  9. #include <linux/device.h>
  10. #include <linux/err.h>
  11. #include <linux/init.h>
  12. #include <linux/interrupt.h>
  13. #include <linux/i2c.h>
  14. #include <linux/irq.h>
  15. #include <linux/irqdomain.h>
  16. #include <linux/kernel.h>
  17. #include <linux/module.h>
  18. #include <linux/of.h>
  19. #include <linux/of_device.h>
  20. #include <linux/platform_device.h>
  21. #include <linux/regmap.h>
  22. #include <linux/slab.h>
  23. #include <linux/mfd/core.h>
  24. #include <linux/mfd/tps65217.h>
  25. static const struct resource charger_resources[] = {
  26. DEFINE_RES_IRQ_NAMED(TPS65217_IRQ_AC, "AC"),
  27. DEFINE_RES_IRQ_NAMED(TPS65217_IRQ_USB, "USB"),
  28. };
  29. static const struct resource pb_resources[] = {
  30. DEFINE_RES_IRQ_NAMED(TPS65217_IRQ_PB, "PB"),
  31. };
  32. static void tps65217_irq_lock(struct irq_data *data)
  33. {
  34. struct tps65217 *tps = irq_data_get_irq_chip_data(data);
  35. mutex_lock(&tps->irq_lock);
  36. }
  37. static void tps65217_irq_sync_unlock(struct irq_data *data)
  38. {
  39. struct tps65217 *tps = irq_data_get_irq_chip_data(data);
  40. int ret;
  41. ret = tps65217_set_bits(tps, TPS65217_REG_INT, TPS65217_INT_MASK,
  42. tps->irq_mask, TPS65217_PROTECT_NONE);
  43. if (ret != 0)
  44. dev_err(tps->dev, "Failed to sync IRQ masks\n");
  45. mutex_unlock(&tps->irq_lock);
  46. }
  47. static void tps65217_irq_enable(struct irq_data *data)
  48. {
  49. struct tps65217 *tps = irq_data_get_irq_chip_data(data);
  50. u8 mask = BIT(data->hwirq) << TPS65217_INT_SHIFT;
  51. tps->irq_mask &= ~mask;
  52. }
  53. static void tps65217_irq_disable(struct irq_data *data)
  54. {
  55. struct tps65217 *tps = irq_data_get_irq_chip_data(data);
  56. u8 mask = BIT(data->hwirq) << TPS65217_INT_SHIFT;
  57. tps->irq_mask |= mask;
  58. }
  59. static struct irq_chip tps65217_irq_chip = {
  60. .name = "tps65217",
  61. .irq_bus_lock = tps65217_irq_lock,
  62. .irq_bus_sync_unlock = tps65217_irq_sync_unlock,
  63. .irq_enable = tps65217_irq_enable,
  64. .irq_disable = tps65217_irq_disable,
  65. };
  66. static struct mfd_cell tps65217s[] = {
  67. {
  68. .name = "tps65217-pmic",
  69. .of_compatible = "ti,tps65217-pmic",
  70. },
  71. {
  72. .name = "tps65217-bl",
  73. .of_compatible = "ti,tps65217-bl",
  74. },
  75. {
  76. .name = "tps65217-charger",
  77. .num_resources = ARRAY_SIZE(charger_resources),
  78. .resources = charger_resources,
  79. .of_compatible = "ti,tps65217-charger",
  80. },
  81. {
  82. .name = "tps65217-pwrbutton",
  83. .num_resources = ARRAY_SIZE(pb_resources),
  84. .resources = pb_resources,
  85. .of_compatible = "ti,tps65217-pwrbutton",
  86. },
  87. };
  88. static irqreturn_t tps65217_irq_thread(int irq, void *data)
  89. {
  90. struct tps65217 *tps = data;
  91. unsigned int status;
  92. bool handled = false;
  93. int i;
  94. int ret;
  95. ret = tps65217_reg_read(tps, TPS65217_REG_INT, &status);
  96. if (ret < 0) {
  97. dev_err(tps->dev, "Failed to read IRQ status: %d\n",
  98. ret);
  99. return IRQ_NONE;
  100. }
  101. for (i = 0; i < TPS65217_NUM_IRQ; i++) {
  102. if (status & BIT(i)) {
  103. handle_nested_irq(irq_find_mapping(tps->irq_domain, i));
  104. handled = true;
  105. }
  106. }
  107. if (handled)
  108. return IRQ_HANDLED;
  109. return IRQ_NONE;
  110. }
  111. static int tps65217_irq_map(struct irq_domain *h, unsigned int virq,
  112. irq_hw_number_t hw)
  113. {
  114. struct tps65217 *tps = h->host_data;
  115. irq_set_chip_data(virq, tps);
  116. irq_set_chip_and_handler(virq, &tps65217_irq_chip, handle_edge_irq);
  117. irq_set_nested_thread(virq, 1);
  118. irq_set_parent(virq, tps->irq);
  119. irq_set_noprobe(virq);
  120. return 0;
  121. }
  122. static const struct irq_domain_ops tps65217_irq_domain_ops = {
  123. .map = tps65217_irq_map,
  124. };
  125. static int tps65217_irq_init(struct tps65217 *tps, int irq)
  126. {
  127. int ret;
  128. mutex_init(&tps->irq_lock);
  129. tps->irq = irq;
  130. /* Mask all interrupt sources */
  131. tps->irq_mask = TPS65217_INT_MASK;
  132. tps65217_set_bits(tps, TPS65217_REG_INT, TPS65217_INT_MASK,
  133. TPS65217_INT_MASK, TPS65217_PROTECT_NONE);
  134. tps->irq_domain = irq_domain_add_linear(tps->dev->of_node,
  135. TPS65217_NUM_IRQ, &tps65217_irq_domain_ops, tps);
  136. if (!tps->irq_domain) {
  137. dev_err(tps->dev, "Could not create IRQ domain\n");
  138. return -ENOMEM;
  139. }
  140. ret = devm_request_threaded_irq(tps->dev, irq, NULL,
  141. tps65217_irq_thread, IRQF_ONESHOT,
  142. "tps65217-irq", tps);
  143. if (ret) {
  144. dev_err(tps->dev, "Failed to request IRQ %d: %d\n",
  145. irq, ret);
  146. return ret;
  147. }
  148. enable_irq_wake(irq);
  149. return 0;
  150. }
  151. /**
  152. * tps65217_reg_read: Read a single tps65217 register.
  153. *
  154. * @tps: Device to read from.
  155. * @reg: Register to read.
  156. * @val: Contians the value
  157. */
  158. int tps65217_reg_read(struct tps65217 *tps, unsigned int reg,
  159. unsigned int *val)
  160. {
  161. return regmap_read(tps->regmap, reg, val);
  162. }
  163. EXPORT_SYMBOL_GPL(tps65217_reg_read);
  164. /**
  165. * tps65217_reg_write: Write a single tps65217 register.
  166. *
  167. * @tps: Device to write to.
  168. * @reg: Register to write to.
  169. * @val: Value to write.
  170. * @level: Password protected level
  171. */
  172. int tps65217_reg_write(struct tps65217 *tps, unsigned int reg,
  173. unsigned int val, unsigned int level)
  174. {
  175. int ret;
  176. unsigned int xor_reg_val;
  177. switch (level) {
  178. case TPS65217_PROTECT_NONE:
  179. return regmap_write(tps->regmap, reg, val);
  180. case TPS65217_PROTECT_L1:
  181. xor_reg_val = reg ^ TPS65217_PASSWORD_REGS_UNLOCK;
  182. ret = regmap_write(tps->regmap, TPS65217_REG_PASSWORD,
  183. xor_reg_val);
  184. if (ret < 0)
  185. return ret;
  186. return regmap_write(tps->regmap, reg, val);
  187. case TPS65217_PROTECT_L2:
  188. xor_reg_val = reg ^ TPS65217_PASSWORD_REGS_UNLOCK;
  189. ret = regmap_write(tps->regmap, TPS65217_REG_PASSWORD,
  190. xor_reg_val);
  191. if (ret < 0)
  192. return ret;
  193. ret = regmap_write(tps->regmap, reg, val);
  194. if (ret < 0)
  195. return ret;
  196. ret = regmap_write(tps->regmap, TPS65217_REG_PASSWORD,
  197. xor_reg_val);
  198. if (ret < 0)
  199. return ret;
  200. return regmap_write(tps->regmap, reg, val);
  201. default:
  202. return -EINVAL;
  203. }
  204. }
  205. EXPORT_SYMBOL_GPL(tps65217_reg_write);
  206. /**
  207. * tps65217_update_bits: Modify bits w.r.t mask, val and level.
  208. *
  209. * @tps: Device to write to.
  210. * @reg: Register to read-write to.
  211. * @mask: Mask.
  212. * @val: Value to write.
  213. * @level: Password protected level
  214. */
  215. static int tps65217_update_bits(struct tps65217 *tps, unsigned int reg,
  216. unsigned int mask, unsigned int val, unsigned int level)
  217. {
  218. int ret;
  219. unsigned int data;
  220. ret = tps65217_reg_read(tps, reg, &data);
  221. if (ret) {
  222. dev_err(tps->dev, "Read from reg 0x%x failed\n", reg);
  223. return ret;
  224. }
  225. data &= ~mask;
  226. data |= val & mask;
  227. ret = tps65217_reg_write(tps, reg, data, level);
  228. if (ret)
  229. dev_err(tps->dev, "Write for reg 0x%x failed\n", reg);
  230. return ret;
  231. }
  232. int tps65217_set_bits(struct tps65217 *tps, unsigned int reg,
  233. unsigned int mask, unsigned int val, unsigned int level)
  234. {
  235. return tps65217_update_bits(tps, reg, mask, val, level);
  236. }
  237. EXPORT_SYMBOL_GPL(tps65217_set_bits);
  238. int tps65217_clear_bits(struct tps65217 *tps, unsigned int reg,
  239. unsigned int mask, unsigned int level)
  240. {
  241. return tps65217_update_bits(tps, reg, mask, 0, level);
  242. }
  243. EXPORT_SYMBOL_GPL(tps65217_clear_bits);
  244. static bool tps65217_volatile_reg(struct device *dev, unsigned int reg)
  245. {
  246. switch (reg) {
  247. case TPS65217_REG_INT:
  248. return true;
  249. default:
  250. return false;
  251. }
  252. }
  253. static const struct regmap_config tps65217_regmap_config = {
  254. .reg_bits = 8,
  255. .val_bits = 8,
  256. .max_register = TPS65217_REG_MAX,
  257. .volatile_reg = tps65217_volatile_reg,
  258. };
  259. static const struct of_device_id tps65217_of_match[] = {
  260. { .compatible = "ti,tps65217"},
  261. { /* sentinel */ },
  262. };
  263. MODULE_DEVICE_TABLE(of, tps65217_of_match);
  264. static int tps65217_probe(struct i2c_client *client)
  265. {
  266. struct tps65217 *tps;
  267. unsigned int version;
  268. bool status_off = false;
  269. int ret;
  270. status_off = of_property_read_bool(client->dev.of_node,
  271. "ti,pmic-shutdown-controller");
  272. tps = devm_kzalloc(&client->dev, sizeof(*tps), GFP_KERNEL);
  273. if (!tps)
  274. return -ENOMEM;
  275. i2c_set_clientdata(client, tps);
  276. tps->dev = &client->dev;
  277. tps->regmap = devm_regmap_init_i2c(client, &tps65217_regmap_config);
  278. if (IS_ERR(tps->regmap)) {
  279. ret = PTR_ERR(tps->regmap);
  280. dev_err(tps->dev, "Failed to allocate register map: %d\n",
  281. ret);
  282. return ret;
  283. }
  284. if (client->irq) {
  285. tps65217_irq_init(tps, client->irq);
  286. } else {
  287. int i;
  288. /* Don't tell children about IRQ resources which won't fire */
  289. for (i = 0; i < ARRAY_SIZE(tps65217s); i++)
  290. tps65217s[i].num_resources = 0;
  291. }
  292. ret = devm_mfd_add_devices(tps->dev, -1, tps65217s,
  293. ARRAY_SIZE(tps65217s), NULL, 0,
  294. tps->irq_domain);
  295. if (ret < 0) {
  296. dev_err(tps->dev, "mfd_add_devices failed: %d\n", ret);
  297. return ret;
  298. }
  299. ret = tps65217_reg_read(tps, TPS65217_REG_CHIPID, &version);
  300. if (ret < 0) {
  301. dev_err(tps->dev, "Failed to read revision register: %d\n",
  302. ret);
  303. return ret;
  304. }
  305. /* Set the PMIC to shutdown on PWR_EN toggle */
  306. if (status_off) {
  307. ret = tps65217_set_bits(tps, TPS65217_REG_STATUS,
  308. TPS65217_STATUS_OFF, TPS65217_STATUS_OFF,
  309. TPS65217_PROTECT_NONE);
  310. if (ret)
  311. dev_warn(tps->dev, "unable to set the status OFF\n");
  312. }
  313. dev_info(tps->dev, "TPS65217 ID %#x version 1.%d\n",
  314. (version & TPS65217_CHIPID_CHIP_MASK) >> 4,
  315. version & TPS65217_CHIPID_REV_MASK);
  316. return 0;
  317. }
  318. static void tps65217_remove(struct i2c_client *client)
  319. {
  320. struct tps65217 *tps = i2c_get_clientdata(client);
  321. unsigned int virq;
  322. int i;
  323. for (i = 0; i < TPS65217_NUM_IRQ; i++) {
  324. virq = irq_find_mapping(tps->irq_domain, i);
  325. if (virq)
  326. irq_dispose_mapping(virq);
  327. }
  328. irq_domain_remove(tps->irq_domain);
  329. tps->irq_domain = NULL;
  330. }
  331. static const struct i2c_device_id tps65217_id_table[] = {
  332. {"tps65217", TPS65217},
  333. { /* sentinel */ }
  334. };
  335. MODULE_DEVICE_TABLE(i2c, tps65217_id_table);
  336. static struct i2c_driver tps65217_driver = {
  337. .driver = {
  338. .name = "tps65217",
  339. .of_match_table = tps65217_of_match,
  340. },
  341. .id_table = tps65217_id_table,
  342. .probe_new = tps65217_probe,
  343. .remove = tps65217_remove,
  344. };
  345. static int __init tps65217_init(void)
  346. {
  347. return i2c_add_driver(&tps65217_driver);
  348. }
  349. subsys_initcall(tps65217_init);
  350. static void __exit tps65217_exit(void)
  351. {
  352. i2c_del_driver(&tps65217_driver);
  353. }
  354. module_exit(tps65217_exit);
  355. MODULE_AUTHOR("AnilKumar Ch <[email protected]>");
  356. MODULE_DESCRIPTION("TPS65217 chip family multi-function driver");
  357. MODULE_LICENSE("GPL v2");