da9055-regulator.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598
  1. // SPDX-License-Identifier: GPL-2.0+
  2. //
  3. // Regulator driver for DA9055 PMIC
  4. //
  5. // Copyright(c) 2012 Dialog Semiconductor Ltd.
  6. //
  7. // Author: David Dajun Chen <dchen@diasemi.com>
  8. #include <linux/module.h>
  9. #include <linux/init.h>
  10. #include <linux/err.h>
  11. #include <linux/gpio/consumer.h>
  12. #include <linux/platform_device.h>
  13. #include <linux/regulator/driver.h>
  14. #include <linux/regulator/machine.h>
  15. #include <linux/of.h>
  16. #include <linux/regulator/of_regulator.h>
  17. #include <linux/mfd/da9055/core.h>
  18. #include <linux/mfd/da9055/reg.h>
  19. #include <linux/mfd/da9055/pdata.h>
  20. #define DA9055_MIN_UA 0
  21. #define DA9055_MAX_UA 3
  22. #define DA9055_LDO_MODE_SYNC 0
  23. #define DA9055_LDO_MODE_SLEEP 1
  24. #define DA9055_BUCK_MODE_SLEEP 1
  25. #define DA9055_BUCK_MODE_SYNC 2
  26. #define DA9055_BUCK_MODE_AUTO 3
  27. /* DA9055 REGULATOR IDs */
  28. #define DA9055_ID_BUCK1 0
  29. #define DA9055_ID_BUCK2 1
  30. #define DA9055_ID_LDO1 2
  31. #define DA9055_ID_LDO2 3
  32. #define DA9055_ID_LDO3 4
  33. #define DA9055_ID_LDO4 5
  34. #define DA9055_ID_LDO5 6
  35. #define DA9055_ID_LDO6 7
  36. /* DA9055 BUCK current limit */
  37. static const unsigned int da9055_current_limits[] = {
  38. 500000, 600000, 700000, 800000
  39. };
  40. struct da9055_conf_reg {
  41. int reg;
  42. int sel_mask;
  43. int en_mask;
  44. };
  45. struct da9055_volt_reg {
  46. int reg_a;
  47. int reg_b;
  48. int sl_shift;
  49. int v_mask;
  50. };
  51. struct da9055_mode_reg {
  52. int reg;
  53. int mask;
  54. int shift;
  55. };
  56. struct da9055_regulator_info {
  57. struct regulator_desc reg_desc;
  58. struct da9055_conf_reg conf;
  59. struct da9055_volt_reg volt;
  60. struct da9055_mode_reg mode;
  61. };
  62. struct da9055_regulator {
  63. struct da9055 *da9055;
  64. const struct da9055_regulator_info *info;
  65. struct regulator_dev *rdev;
  66. enum gpio_select reg_rselect;
  67. };
  68. static unsigned int da9055_buck_get_mode(struct regulator_dev *rdev)
  69. {
  70. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  71. const struct da9055_regulator_info *info = regulator->info;
  72. int ret, mode = 0;
  73. ret = da9055_reg_read(regulator->da9055, info->mode.reg);
  74. if (ret < 0)
  75. return ret;
  76. switch ((ret & info->mode.mask) >> info->mode.shift) {
  77. case DA9055_BUCK_MODE_SYNC:
  78. mode = REGULATOR_MODE_FAST;
  79. break;
  80. case DA9055_BUCK_MODE_AUTO:
  81. mode = REGULATOR_MODE_NORMAL;
  82. break;
  83. case DA9055_BUCK_MODE_SLEEP:
  84. mode = REGULATOR_MODE_STANDBY;
  85. break;
  86. }
  87. return mode;
  88. }
  89. static int da9055_buck_set_mode(struct regulator_dev *rdev,
  90. unsigned int mode)
  91. {
  92. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  93. const struct da9055_regulator_info *info = regulator->info;
  94. int val = 0;
  95. switch (mode) {
  96. case REGULATOR_MODE_FAST:
  97. val = DA9055_BUCK_MODE_SYNC << info->mode.shift;
  98. break;
  99. case REGULATOR_MODE_NORMAL:
  100. val = DA9055_BUCK_MODE_AUTO << info->mode.shift;
  101. break;
  102. case REGULATOR_MODE_STANDBY:
  103. val = DA9055_BUCK_MODE_SLEEP << info->mode.shift;
  104. break;
  105. }
  106. return da9055_reg_update(regulator->da9055, info->mode.reg,
  107. info->mode.mask, val);
  108. }
  109. static unsigned int da9055_ldo_get_mode(struct regulator_dev *rdev)
  110. {
  111. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  112. const struct da9055_regulator_info *info = regulator->info;
  113. int ret;
  114. ret = da9055_reg_read(regulator->da9055, info->volt.reg_b);
  115. if (ret < 0)
  116. return ret;
  117. if (ret >> info->volt.sl_shift)
  118. return REGULATOR_MODE_STANDBY;
  119. else
  120. return REGULATOR_MODE_NORMAL;
  121. }
  122. static int da9055_ldo_set_mode(struct regulator_dev *rdev, unsigned int mode)
  123. {
  124. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  125. const struct da9055_regulator_info *info = regulator->info;
  126. struct da9055_volt_reg volt = info->volt;
  127. int val = 0;
  128. switch (mode) {
  129. case REGULATOR_MODE_NORMAL:
  130. case REGULATOR_MODE_FAST:
  131. val = DA9055_LDO_MODE_SYNC;
  132. break;
  133. case REGULATOR_MODE_STANDBY:
  134. val = DA9055_LDO_MODE_SLEEP;
  135. break;
  136. }
  137. return da9055_reg_update(regulator->da9055, volt.reg_b,
  138. 1 << volt.sl_shift,
  139. val << volt.sl_shift);
  140. }
  141. static int da9055_regulator_get_voltage_sel(struct regulator_dev *rdev)
  142. {
  143. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  144. const struct da9055_regulator_info *info = regulator->info;
  145. struct da9055_volt_reg volt = info->volt;
  146. int ret, sel;
  147. /*
  148. * There are two voltage register set A & B for voltage ramping but
  149. * either one of then can be active therefore we first determine
  150. * the active register set.
  151. */
  152. ret = da9055_reg_read(regulator->da9055, info->conf.reg);
  153. if (ret < 0)
  154. return ret;
  155. ret &= info->conf.sel_mask;
  156. /* Get the voltage for the active register set A/B */
  157. if (ret == DA9055_REGUALTOR_SET_A)
  158. ret = da9055_reg_read(regulator->da9055, volt.reg_a);
  159. else
  160. ret = da9055_reg_read(regulator->da9055, volt.reg_b);
  161. if (ret < 0)
  162. return ret;
  163. sel = (ret & volt.v_mask);
  164. return sel;
  165. }
  166. static int da9055_regulator_set_voltage_sel(struct regulator_dev *rdev,
  167. unsigned int selector)
  168. {
  169. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  170. const struct da9055_regulator_info *info = regulator->info;
  171. int ret;
  172. /*
  173. * Regulator register set A/B is not selected through GPIO therefore
  174. * we use default register set A for voltage ramping.
  175. */
  176. if (regulator->reg_rselect == NO_GPIO) {
  177. /* Select register set A */
  178. ret = da9055_reg_update(regulator->da9055, info->conf.reg,
  179. info->conf.sel_mask, DA9055_SEL_REG_A);
  180. if (ret < 0)
  181. return ret;
  182. /* Set the voltage */
  183. return da9055_reg_update(regulator->da9055, info->volt.reg_a,
  184. info->volt.v_mask, selector);
  185. }
  186. /*
  187. * Here regulator register set A/B is selected through GPIO.
  188. * Therefore we first determine the selected register set A/B and
  189. * then set the desired voltage for that register set A/B.
  190. */
  191. ret = da9055_reg_read(regulator->da9055, info->conf.reg);
  192. if (ret < 0)
  193. return ret;
  194. ret &= info->conf.sel_mask;
  195. /* Set the voltage */
  196. if (ret == DA9055_REGUALTOR_SET_A)
  197. return da9055_reg_update(regulator->da9055, info->volt.reg_a,
  198. info->volt.v_mask, selector);
  199. else
  200. return da9055_reg_update(regulator->da9055, info->volt.reg_b,
  201. info->volt.v_mask, selector);
  202. }
  203. static int da9055_regulator_set_suspend_voltage(struct regulator_dev *rdev,
  204. int uV)
  205. {
  206. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  207. const struct da9055_regulator_info *info = regulator->info;
  208. int ret;
  209. /* Select register set B for suspend voltage ramping. */
  210. if (regulator->reg_rselect == NO_GPIO) {
  211. ret = da9055_reg_update(regulator->da9055, info->conf.reg,
  212. info->conf.sel_mask, DA9055_SEL_REG_B);
  213. if (ret < 0)
  214. return ret;
  215. }
  216. ret = regulator_map_voltage_linear(rdev, uV, uV);
  217. if (ret < 0)
  218. return ret;
  219. return da9055_reg_update(regulator->da9055, info->volt.reg_b,
  220. info->volt.v_mask, ret);
  221. }
  222. static int da9055_suspend_enable(struct regulator_dev *rdev)
  223. {
  224. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  225. const struct da9055_regulator_info *info = regulator->info;
  226. /* Select register set B for voltage ramping. */
  227. if (regulator->reg_rselect == NO_GPIO)
  228. return da9055_reg_update(regulator->da9055, info->conf.reg,
  229. info->conf.sel_mask, DA9055_SEL_REG_B);
  230. else
  231. return 0;
  232. }
  233. static int da9055_suspend_disable(struct regulator_dev *rdev)
  234. {
  235. struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
  236. const struct da9055_regulator_info *info = regulator->info;
  237. /* Diselect register set B. */
  238. if (regulator->reg_rselect == NO_GPIO)
  239. return da9055_reg_update(regulator->da9055, info->conf.reg,
  240. info->conf.sel_mask, DA9055_SEL_REG_A);
  241. else
  242. return 0;
  243. }
  244. static const struct regulator_ops da9055_buck_ops = {
  245. .get_mode = da9055_buck_get_mode,
  246. .set_mode = da9055_buck_set_mode,
  247. .get_current_limit = regulator_get_current_limit_regmap,
  248. .set_current_limit = regulator_set_current_limit_regmap,
  249. .get_voltage_sel = da9055_regulator_get_voltage_sel,
  250. .set_voltage_sel = da9055_regulator_set_voltage_sel,
  251. .list_voltage = regulator_list_voltage_linear,
  252. .map_voltage = regulator_map_voltage_linear,
  253. .is_enabled = regulator_is_enabled_regmap,
  254. .enable = regulator_enable_regmap,
  255. .disable = regulator_disable_regmap,
  256. .set_suspend_voltage = da9055_regulator_set_suspend_voltage,
  257. .set_suspend_enable = da9055_suspend_enable,
  258. .set_suspend_disable = da9055_suspend_disable,
  259. .set_suspend_mode = da9055_buck_set_mode,
  260. };
  261. static const struct regulator_ops da9055_ldo_ops = {
  262. .get_mode = da9055_ldo_get_mode,
  263. .set_mode = da9055_ldo_set_mode,
  264. .get_voltage_sel = da9055_regulator_get_voltage_sel,
  265. .set_voltage_sel = da9055_regulator_set_voltage_sel,
  266. .list_voltage = regulator_list_voltage_linear,
  267. .map_voltage = regulator_map_voltage_linear,
  268. .is_enabled = regulator_is_enabled_regmap,
  269. .enable = regulator_enable_regmap,
  270. .disable = regulator_disable_regmap,
  271. .set_suspend_voltage = da9055_regulator_set_suspend_voltage,
  272. .set_suspend_enable = da9055_suspend_enable,
  273. .set_suspend_disable = da9055_suspend_disable,
  274. .set_suspend_mode = da9055_ldo_set_mode,
  275. };
  276. #define DA9055_LDO(_id, step, min, max, vbits, voffset) \
  277. {\
  278. .reg_desc = {\
  279. .name = #_id,\
  280. .of_match = of_match_ptr(#_id),\
  281. .regulators_node = of_match_ptr("regulators"),\
  282. .ops = &da9055_ldo_ops,\
  283. .type = REGULATOR_VOLTAGE,\
  284. .id = DA9055_ID_##_id,\
  285. .n_voltages = (max - min) / step + 1 + (voffset), \
  286. .enable_reg = DA9055_REG_BCORE_CONT + DA9055_ID_##_id, \
  287. .enable_mask = 1, \
  288. .min_uV = (min) * 1000,\
  289. .uV_step = (step) * 1000,\
  290. .linear_min_sel = (voffset),\
  291. .owner = THIS_MODULE,\
  292. },\
  293. .conf = {\
  294. .reg = DA9055_REG_BCORE_CONT + DA9055_ID_##_id, \
  295. .sel_mask = (1 << 4),\
  296. .en_mask = 1,\
  297. },\
  298. .volt = {\
  299. .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \
  300. .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \
  301. .sl_shift = 7,\
  302. .v_mask = (1 << (vbits)) - 1,\
  303. },\
  304. }
  305. #define DA9055_BUCK(_id, step, min, max, vbits, voffset, mbits, sbits) \
  306. {\
  307. .reg_desc = {\
  308. .name = #_id,\
  309. .of_match = of_match_ptr(#_id),\
  310. .regulators_node = of_match_ptr("regulators"),\
  311. .ops = &da9055_buck_ops,\
  312. .type = REGULATOR_VOLTAGE,\
  313. .id = DA9055_ID_##_id,\
  314. .n_voltages = (max - min) / step + 1 + (voffset), \
  315. .enable_reg = DA9055_REG_BCORE_CONT + DA9055_ID_##_id, \
  316. .enable_mask = 1,\
  317. .min_uV = (min) * 1000,\
  318. .uV_step = (step) * 1000,\
  319. .linear_min_sel = (voffset),\
  320. .owner = THIS_MODULE,\
  321. .curr_table = da9055_current_limits,\
  322. .n_current_limits = ARRAY_SIZE(da9055_current_limits),\
  323. .csel_reg = DA9055_REG_BUCK_LIM,\
  324. .csel_mask = (mbits),\
  325. },\
  326. .conf = {\
  327. .reg = DA9055_REG_BCORE_CONT + DA9055_ID_##_id, \
  328. .sel_mask = (1 << 4),\
  329. .en_mask = 1,\
  330. },\
  331. .volt = {\
  332. .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \
  333. .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \
  334. .sl_shift = 7,\
  335. .v_mask = (1 << (vbits)) - 1,\
  336. },\
  337. .mode = {\
  338. .reg = DA9055_REG_BCORE_MODE,\
  339. .mask = (mbits),\
  340. .shift = (sbits),\
  341. },\
  342. }
  343. static const struct da9055_regulator_info da9055_regulator_info[] = {
  344. DA9055_BUCK(BUCK1, 25, 725, 2075, 6, 9, 0xc, 2),
  345. DA9055_BUCK(BUCK2, 25, 925, 2500, 6, 0, 3, 0),
  346. DA9055_LDO(LDO1, 50, 900, 3300, 6, 2),
  347. DA9055_LDO(LDO2, 50, 900, 3300, 6, 3),
  348. DA9055_LDO(LDO3, 50, 900, 3300, 6, 2),
  349. DA9055_LDO(LDO4, 50, 900, 3300, 6, 2),
  350. DA9055_LDO(LDO5, 50, 900, 2750, 6, 2),
  351. DA9055_LDO(LDO6, 20, 900, 3300, 7, 0),
  352. };
  353. /*
  354. * Configures regulator to be controlled either through GPIO 1 or 2.
  355. * GPIO can control regulator state and/or select the regulator register
  356. * set A/B for voltage ramping.
  357. */
  358. static int da9055_gpio_init(struct device *dev,
  359. struct da9055_regulator *regulator,
  360. struct regulator_config *config,
  361. struct da9055_pdata *pdata, int id)
  362. {
  363. const struct da9055_regulator_info *info = regulator->info;
  364. struct gpio_desc *ren;
  365. struct gpio_desc *ena;
  366. struct gpio_desc *rsel;
  367. int ret = 0;
  368. /* Look for "regulator-enable-gpios" GPIOs in the regulator node */
  369. ren = devm_gpiod_get_optional(dev, "regulator-enable", GPIOD_IN);
  370. if (IS_ERR(ren))
  371. return PTR_ERR(ren);
  372. if (ren) {
  373. /* This GPIO is not optional at this point */
  374. ena = devm_gpiod_get(dev, "enable", GPIOD_OUT_HIGH);
  375. if (IS_ERR(ena))
  376. return PTR_ERR(ena);
  377. config->ena_gpiod = ena;
  378. /*
  379. * GPI pin is muxed with regulator to control the
  380. * regulator state.
  381. */
  382. gpiod_set_consumer_name(ren, "DA9055 ren GPI");
  383. /*
  384. * Let the regulator know that its state is controlled
  385. * through GPI.
  386. */
  387. ret = da9055_reg_update(regulator->da9055, info->conf.reg,
  388. DA9055_E_GPI_MASK,
  389. pdata->reg_ren[id]
  390. << DA9055_E_GPI_SHIFT);
  391. if (ret < 0)
  392. return ret;
  393. }
  394. /* Look for "regulator-select-gpios" GPIOs in the regulator node */
  395. rsel = devm_gpiod_get_optional(dev, "regulator-select", GPIOD_IN);
  396. if (IS_ERR(rsel))
  397. return PTR_ERR(rsel);
  398. if (rsel) {
  399. regulator->reg_rselect = pdata->reg_rsel[id];
  400. /*
  401. * GPI pin is muxed with regulator to select the
  402. * regulator register set A/B for voltage ramping.
  403. */
  404. gpiod_set_consumer_name(rsel, "DA9055 rsel GPI");
  405. /*
  406. * Let the regulator know that its register set A/B
  407. * will be selected through GPI for voltage ramping.
  408. */
  409. ret = da9055_reg_update(regulator->da9055, info->conf.reg,
  410. DA9055_V_GPI_MASK,
  411. pdata->reg_rsel[id]
  412. << DA9055_V_GPI_SHIFT);
  413. }
  414. return ret;
  415. }
  416. static irqreturn_t da9055_ldo5_6_oc_irq(int irq, void *data)
  417. {
  418. struct da9055_regulator *regulator = data;
  419. regulator_notifier_call_chain(regulator->rdev,
  420. REGULATOR_EVENT_OVER_CURRENT, NULL);
  421. return IRQ_HANDLED;
  422. }
  423. static inline const struct da9055_regulator_info *find_regulator_info(int id)
  424. {
  425. const struct da9055_regulator_info *info;
  426. int i;
  427. for (i = 0; i < ARRAY_SIZE(da9055_regulator_info); i++) {
  428. info = &da9055_regulator_info[i];
  429. if (info->reg_desc.id == id)
  430. return info;
  431. }
  432. return NULL;
  433. }
  434. static int da9055_regulator_probe(struct platform_device *pdev)
  435. {
  436. struct regulator_config config = { };
  437. struct da9055_regulator *regulator;
  438. struct da9055 *da9055 = dev_get_drvdata(pdev->dev.parent);
  439. struct da9055_pdata *pdata = dev_get_platdata(da9055->dev);
  440. int ret, irq;
  441. regulator = devm_kzalloc(&pdev->dev, sizeof(struct da9055_regulator),
  442. GFP_KERNEL);
  443. if (!regulator)
  444. return -ENOMEM;
  445. regulator->info = find_regulator_info(pdev->id);
  446. if (regulator->info == NULL) {
  447. dev_err(&pdev->dev, "invalid regulator ID specified\n");
  448. return -EINVAL;
  449. }
  450. regulator->da9055 = da9055;
  451. config.dev = da9055->dev;
  452. config.driver_data = regulator;
  453. config.regmap = da9055->regmap;
  454. if (pdata)
  455. config.init_data = pdata->regulators[pdev->id];
  456. ret = da9055_gpio_init(&pdev->dev, regulator, &config, pdata, pdev->id);
  457. if (ret < 0)
  458. return ret;
  459. regulator->rdev = devm_regulator_register(&pdev->dev,
  460. &regulator->info->reg_desc,
  461. &config);
  462. if (IS_ERR(regulator->rdev)) {
  463. dev_err(&pdev->dev, "Failed to register regulator %s\n",
  464. regulator->info->reg_desc.name);
  465. return PTR_ERR(regulator->rdev);
  466. }
  467. /* Only LDO 5 and 6 has got the over current interrupt */
  468. if (pdev->id == DA9055_ID_LDO5 || pdev->id == DA9055_ID_LDO6) {
  469. irq = platform_get_irq_byname(pdev, "REGULATOR");
  470. if (irq < 0)
  471. return irq;
  472. ret = devm_request_threaded_irq(&pdev->dev, irq, NULL,
  473. da9055_ldo5_6_oc_irq,
  474. IRQF_TRIGGER_HIGH |
  475. IRQF_ONESHOT |
  476. IRQF_PROBE_SHARED,
  477. pdev->name, regulator);
  478. if (ret != 0) {
  479. if (ret != -EBUSY) {
  480. dev_err(&pdev->dev,
  481. "Failed to request Regulator IRQ %d: %d\n",
  482. irq, ret);
  483. return ret;
  484. }
  485. }
  486. }
  487. platform_set_drvdata(pdev, regulator);
  488. return 0;
  489. }
  490. static struct platform_driver da9055_regulator_driver = {
  491. .probe = da9055_regulator_probe,
  492. .driver = {
  493. .name = "da9055-regulator",
  494. .probe_type = PROBE_PREFER_ASYNCHRONOUS,
  495. },
  496. };
  497. static int __init da9055_regulator_init(void)
  498. {
  499. return platform_driver_register(&da9055_regulator_driver);
  500. }
  501. subsys_initcall(da9055_regulator_init);
  502. static void __exit da9055_regulator_exit(void)
  503. {
  504. platform_driver_unregister(&da9055_regulator_driver);
  505. }
  506. module_exit(da9055_regulator_exit);
  507. MODULE_AUTHOR("David Dajun Chen <dchen@diasemi.com>");
  508. MODULE_DESCRIPTION("Power Regulator driver for Dialog DA9055 PMIC");
  509. MODULE_LICENSE("GPL");
  510. MODULE_ALIAS("platform:da9055-regulator");