lp872x.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925
  1. /*
  2. * Copyright 2012 Texas Instruments
  3. *
  4. * Author: Milo(Woogyom) Kim <milo.kim@ti.com>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. *
  10. */
  11. #include <linux/module.h>
  12. #include <linux/slab.h>
  13. #include <linux/i2c.h>
  14. #include <linux/regmap.h>
  15. #include <linux/err.h>
  16. #include <linux/gpio.h>
  17. #include <linux/regulator/lp872x.h>
  18. #include <linux/regulator/driver.h>
  19. #include <linux/platform_device.h>
  20. /* Registers : LP8720/8725 shared */
  21. #define LP872X_GENERAL_CFG 0x00
  22. #define LP872X_LDO1_VOUT 0x01
  23. #define LP872X_LDO2_VOUT 0x02
  24. #define LP872X_LDO3_VOUT 0x03
  25. #define LP872X_LDO4_VOUT 0x04
  26. #define LP872X_LDO5_VOUT 0x05
  27. /* Registers : LP8720 */
  28. #define LP8720_BUCK_VOUT1 0x06
  29. #define LP8720_BUCK_VOUT2 0x07
  30. #define LP8720_ENABLE 0x08
  31. /* Registers : LP8725 */
  32. #define LP8725_LILO1_VOUT 0x06
  33. #define LP8725_LILO2_VOUT 0x07
  34. #define LP8725_BUCK1_VOUT1 0x08
  35. #define LP8725_BUCK1_VOUT2 0x09
  36. #define LP8725_BUCK2_VOUT1 0x0A
  37. #define LP8725_BUCK2_VOUT2 0x0B
  38. #define LP8725_BUCK_CTRL 0x0C
  39. #define LP8725_LDO_CTRL 0x0D
  40. /* Mask/shift : LP8720/LP8725 shared */
  41. #define LP872X_VOUT_M 0x1F
  42. #define LP872X_START_DELAY_M 0xE0
  43. #define LP872X_START_DELAY_S 5
  44. #define LP872X_EN_LDO1_M BIT(0)
  45. #define LP872X_EN_LDO2_M BIT(1)
  46. #define LP872X_EN_LDO3_M BIT(2)
  47. #define LP872X_EN_LDO4_M BIT(3)
  48. #define LP872X_EN_LDO5_M BIT(4)
  49. /* Mask/shift : LP8720 */
  50. #define LP8720_TIMESTEP_S 0 /* Addr 00h */
  51. #define LP8720_TIMESTEP_M BIT(0)
  52. #define LP8720_EXT_DVS_M BIT(2)
  53. #define LP8720_BUCK_FPWM_S 5 /* Addr 07h */
  54. #define LP8720_BUCK_FPWM_M BIT(5)
  55. #define LP8720_EN_BUCK_M BIT(5) /* Addr 08h */
  56. #define LP8720_DVS_SEL_M BIT(7)
  57. /* Mask/shift : LP8725 */
  58. #define LP8725_TIMESTEP_M 0xC0 /* Addr 00h */
  59. #define LP8725_TIMESTEP_S 6
  60. #define LP8725_BUCK1_EN_M BIT(0)
  61. #define LP8725_DVS1_M BIT(2)
  62. #define LP8725_DVS2_M BIT(3)
  63. #define LP8725_BUCK2_EN_M BIT(4)
  64. #define LP8725_BUCK_CL_M 0xC0 /* Addr 09h, 0Bh */
  65. #define LP8725_BUCK_CL_S 6
  66. #define LP8725_BUCK1_FPWM_S 1 /* Addr 0Ch */
  67. #define LP8725_BUCK1_FPWM_M BIT(1)
  68. #define LP8725_BUCK2_FPWM_S 5
  69. #define LP8725_BUCK2_FPWM_M BIT(5)
  70. #define LP8725_EN_LILO1_M BIT(5) /* Addr 0Dh */
  71. #define LP8725_EN_LILO2_M BIT(6)
  72. /* PWM mode */
  73. #define LP872X_FORCE_PWM 1
  74. #define LP872X_AUTO_PWM 0
  75. #define LP8720_NUM_REGULATORS 6
  76. #define LP8725_NUM_REGULATORS 9
  77. #define EXTERN_DVS_USED 0
  78. #define MAX_DELAY 6
  79. /* Default DVS Mode */
  80. #define LP8720_DEFAULT_DVS 0
  81. #define LP8725_DEFAULT_DVS BIT(2)
  82. /* dump registers in regmap-debugfs */
  83. #define MAX_REGISTERS 0x0F
  84. enum lp872x_id {
  85. LP8720,
  86. LP8725,
  87. };
  88. struct lp872x {
  89. struct regmap *regmap;
  90. struct device *dev;
  91. enum lp872x_id chipid;
  92. struct lp872x_platform_data *pdata;
  93. struct regulator_dev **regulators;
  94. int num_regulators;
  95. enum lp872x_dvs_state dvs_pin;
  96. int dvs_gpio;
  97. };
  98. /* LP8720/LP8725 shared voltage table for LDOs */
  99. static const unsigned int lp872x_ldo_vtbl[] = {
  100. 1200000, 1250000, 1300000, 1350000, 1400000, 1450000, 1500000, 1550000,
  101. 1600000, 1650000, 1700000, 1750000, 1800000, 1850000, 1900000, 2000000,
  102. 2100000, 2200000, 2300000, 2400000, 2500000, 2600000, 2650000, 2700000,
  103. 2750000, 2800000, 2850000, 2900000, 2950000, 3000000, 3100000, 3300000,
  104. };
  105. /* LP8720 LDO4 voltage table */
  106. static const unsigned int lp8720_ldo4_vtbl[] = {
  107. 800000, 850000, 900000, 1000000, 1100000, 1200000, 1250000, 1300000,
  108. 1350000, 1400000, 1450000, 1500000, 1550000, 1600000, 1650000, 1700000,
  109. 1750000, 1800000, 1850000, 1900000, 2000000, 2100000, 2200000, 2300000,
  110. 2400000, 2500000, 2600000, 2650000, 2700000, 2750000, 2800000, 2850000,
  111. };
  112. /* LP8725 LILO(Low Input Low Output) voltage table */
  113. static const unsigned int lp8725_lilo_vtbl[] = {
  114. 800000, 850000, 900000, 950000, 1000000, 1050000, 1100000, 1150000,
  115. 1200000, 1250000, 1300000, 1350000, 1400000, 1500000, 1600000, 1700000,
  116. 1800000, 1900000, 2000000, 2100000, 2200000, 2300000, 2400000, 2500000,
  117. 2600000, 2700000, 2800000, 2850000, 2900000, 3000000, 3100000, 3300000,
  118. };
  119. /* LP8720 BUCK voltage table */
  120. #define EXT_R 0 /* external resistor divider */
  121. static const unsigned int lp8720_buck_vtbl[] = {
  122. EXT_R, 800000, 850000, 900000, 950000, 1000000, 1050000, 1100000,
  123. 1150000, 1200000, 1250000, 1300000, 1350000, 1400000, 1450000, 1500000,
  124. 1550000, 1600000, 1650000, 1700000, 1750000, 1800000, 1850000, 1900000,
  125. 1950000, 2000000, 2050000, 2100000, 2150000, 2200000, 2250000, 2300000,
  126. };
  127. /* LP8725 BUCK voltage table */
  128. static const unsigned int lp8725_buck_vtbl[] = {
  129. 800000, 850000, 900000, 950000, 1000000, 1050000, 1100000, 1150000,
  130. 1200000, 1250000, 1300000, 1350000, 1400000, 1500000, 1600000, 1700000,
  131. 1750000, 1800000, 1850000, 1900000, 2000000, 2100000, 2200000, 2300000,
  132. 2400000, 2500000, 2600000, 2700000, 2800000, 2850000, 2900000, 3000000,
  133. };
  134. /* LP8725 BUCK current limit */
  135. static const unsigned int lp8725_buck_uA[] = {
  136. 460000, 780000, 1050000, 1370000,
  137. };
  138. static int lp872x_read_byte(struct lp872x *lp, u8 addr, u8 *data)
  139. {
  140. int ret;
  141. unsigned int val;
  142. ret = regmap_read(lp->regmap, addr, &val);
  143. if (ret < 0) {
  144. dev_err(lp->dev, "failed to read 0x%.2x\n", addr);
  145. return ret;
  146. }
  147. *data = (u8)val;
  148. return 0;
  149. }
  150. static inline int lp872x_write_byte(struct lp872x *lp, u8 addr, u8 data)
  151. {
  152. return regmap_write(lp->regmap, addr, data);
  153. }
  154. static inline int lp872x_update_bits(struct lp872x *lp, u8 addr,
  155. unsigned int mask, u8 data)
  156. {
  157. return regmap_update_bits(lp->regmap, addr, mask, data);
  158. }
  159. static int _rdev_to_offset(struct regulator_dev *rdev)
  160. {
  161. enum lp872x_regulator_id id = rdev_get_id(rdev);
  162. switch (id) {
  163. case LP8720_ID_LDO1 ... LP8720_ID_BUCK:
  164. return id;
  165. case LP8725_ID_LDO1 ... LP8725_ID_BUCK2:
  166. return id - LP8725_ID_BASE;
  167. default:
  168. return -EINVAL;
  169. }
  170. }
  171. static int lp872x_get_timestep_usec(struct lp872x *lp)
  172. {
  173. enum lp872x_id chip = lp->chipid;
  174. u8 val, mask, shift;
  175. int *time_usec, size, ret;
  176. int lp8720_time_usec[] = { 25, 50 };
  177. int lp8725_time_usec[] = { 32, 64, 128, 256 };
  178. switch (chip) {
  179. case LP8720:
  180. mask = LP8720_TIMESTEP_M;
  181. shift = LP8720_TIMESTEP_S;
  182. time_usec = &lp8720_time_usec[0];
  183. size = ARRAY_SIZE(lp8720_time_usec);
  184. break;
  185. case LP8725:
  186. mask = LP8725_TIMESTEP_M;
  187. shift = LP8725_TIMESTEP_S;
  188. time_usec = &lp8725_time_usec[0];
  189. size = ARRAY_SIZE(lp8725_time_usec);
  190. break;
  191. default:
  192. return -EINVAL;
  193. }
  194. ret = lp872x_read_byte(lp, LP872X_GENERAL_CFG, &val);
  195. if (ret)
  196. return -EINVAL;
  197. val = (val & mask) >> shift;
  198. if (val >= size)
  199. return -EINVAL;
  200. return *(time_usec + val);
  201. }
  202. static int lp872x_regulator_enable_time(struct regulator_dev *rdev)
  203. {
  204. struct lp872x *lp = rdev_get_drvdata(rdev);
  205. enum lp872x_regulator_id regulator = rdev_get_id(rdev);
  206. int time_step_us = lp872x_get_timestep_usec(lp);
  207. int ret, offset;
  208. u8 addr, val;
  209. if (time_step_us < 0)
  210. return -EINVAL;
  211. switch (regulator) {
  212. case LP8720_ID_LDO1 ... LP8720_ID_LDO5:
  213. case LP8725_ID_LDO1 ... LP8725_ID_LILO2:
  214. offset = _rdev_to_offset(rdev);
  215. if (offset < 0)
  216. return -EINVAL;
  217. addr = LP872X_LDO1_VOUT + offset;
  218. break;
  219. case LP8720_ID_BUCK:
  220. addr = LP8720_BUCK_VOUT1;
  221. break;
  222. case LP8725_ID_BUCK1:
  223. addr = LP8725_BUCK1_VOUT1;
  224. break;
  225. case LP8725_ID_BUCK2:
  226. addr = LP8725_BUCK2_VOUT1;
  227. break;
  228. default:
  229. return -EINVAL;
  230. }
  231. ret = lp872x_read_byte(lp, addr, &val);
  232. if (ret)
  233. return ret;
  234. val = (val & LP872X_START_DELAY_M) >> LP872X_START_DELAY_S;
  235. return val > MAX_DELAY ? 0 : val * time_step_us;
  236. }
  237. static void lp872x_set_dvs(struct lp872x *lp, enum lp872x_dvs_sel dvs_sel,
  238. int gpio)
  239. {
  240. enum lp872x_dvs_state state;
  241. state = dvs_sel == SEL_V1 ? DVS_HIGH : DVS_LOW;
  242. gpio_set_value(gpio, state);
  243. lp->dvs_pin = state;
  244. }
  245. static u8 lp872x_select_buck_vout_addr(struct lp872x *lp,
  246. enum lp872x_regulator_id buck)
  247. {
  248. u8 val, addr;
  249. if (lp872x_read_byte(lp, LP872X_GENERAL_CFG, &val))
  250. return 0;
  251. switch (buck) {
  252. case LP8720_ID_BUCK:
  253. if (val & LP8720_EXT_DVS_M) {
  254. addr = (lp->dvs_pin == DVS_HIGH) ?
  255. LP8720_BUCK_VOUT1 : LP8720_BUCK_VOUT2;
  256. } else {
  257. if (lp872x_read_byte(lp, LP8720_ENABLE, &val))
  258. return 0;
  259. addr = val & LP8720_DVS_SEL_M ?
  260. LP8720_BUCK_VOUT1 : LP8720_BUCK_VOUT2;
  261. }
  262. break;
  263. case LP8725_ID_BUCK1:
  264. if (val & LP8725_DVS1_M)
  265. addr = LP8725_BUCK1_VOUT1;
  266. else
  267. addr = (lp->dvs_pin == DVS_HIGH) ?
  268. LP8725_BUCK1_VOUT1 : LP8725_BUCK1_VOUT2;
  269. break;
  270. case LP8725_ID_BUCK2:
  271. addr = val & LP8725_DVS2_M ?
  272. LP8725_BUCK2_VOUT1 : LP8725_BUCK2_VOUT2;
  273. break;
  274. default:
  275. return 0;
  276. }
  277. return addr;
  278. }
  279. static bool lp872x_is_valid_buck_addr(u8 addr)
  280. {
  281. switch (addr) {
  282. case LP8720_BUCK_VOUT1:
  283. case LP8720_BUCK_VOUT2:
  284. case LP8725_BUCK1_VOUT1:
  285. case LP8725_BUCK1_VOUT2:
  286. case LP8725_BUCK2_VOUT1:
  287. case LP8725_BUCK2_VOUT2:
  288. return true;
  289. default:
  290. return false;
  291. }
  292. }
  293. static int lp872x_buck_set_voltage_sel(struct regulator_dev *rdev,
  294. unsigned selector)
  295. {
  296. struct lp872x *lp = rdev_get_drvdata(rdev);
  297. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  298. u8 addr, mask = LP872X_VOUT_M;
  299. struct lp872x_dvs *dvs = lp->pdata ? lp->pdata->dvs : NULL;
  300. if (dvs && gpio_is_valid(dvs->gpio))
  301. lp872x_set_dvs(lp, dvs->vsel, dvs->gpio);
  302. addr = lp872x_select_buck_vout_addr(lp, buck);
  303. if (!lp872x_is_valid_buck_addr(addr))
  304. return -EINVAL;
  305. return lp872x_update_bits(lp, addr, mask, selector);
  306. }
  307. static int lp872x_buck_get_voltage_sel(struct regulator_dev *rdev)
  308. {
  309. struct lp872x *lp = rdev_get_drvdata(rdev);
  310. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  311. u8 addr, val;
  312. int ret;
  313. addr = lp872x_select_buck_vout_addr(lp, buck);
  314. if (!lp872x_is_valid_buck_addr(addr))
  315. return -EINVAL;
  316. ret = lp872x_read_byte(lp, addr, &val);
  317. if (ret)
  318. return ret;
  319. return val & LP872X_VOUT_M;
  320. }
  321. static int lp8725_buck_set_current_limit(struct regulator_dev *rdev,
  322. int min_uA, int max_uA)
  323. {
  324. struct lp872x *lp = rdev_get_drvdata(rdev);
  325. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  326. int i;
  327. u8 addr;
  328. switch (buck) {
  329. case LP8725_ID_BUCK1:
  330. addr = LP8725_BUCK1_VOUT2;
  331. break;
  332. case LP8725_ID_BUCK2:
  333. addr = LP8725_BUCK2_VOUT2;
  334. break;
  335. default:
  336. return -EINVAL;
  337. }
  338. for (i = ARRAY_SIZE(lp8725_buck_uA) - 1 ; i >= 0; i--) {
  339. if (lp8725_buck_uA[i] >= min_uA &&
  340. lp8725_buck_uA[i] <= max_uA)
  341. return lp872x_update_bits(lp, addr,
  342. LP8725_BUCK_CL_M,
  343. i << LP8725_BUCK_CL_S);
  344. }
  345. return -EINVAL;
  346. }
  347. static int lp8725_buck_get_current_limit(struct regulator_dev *rdev)
  348. {
  349. struct lp872x *lp = rdev_get_drvdata(rdev);
  350. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  351. u8 addr, val;
  352. int ret;
  353. switch (buck) {
  354. case LP8725_ID_BUCK1:
  355. addr = LP8725_BUCK1_VOUT2;
  356. break;
  357. case LP8725_ID_BUCK2:
  358. addr = LP8725_BUCK2_VOUT2;
  359. break;
  360. default:
  361. return -EINVAL;
  362. }
  363. ret = lp872x_read_byte(lp, addr, &val);
  364. if (ret)
  365. return ret;
  366. val = (val & LP8725_BUCK_CL_M) >> LP8725_BUCK_CL_S;
  367. return (val < ARRAY_SIZE(lp8725_buck_uA)) ?
  368. lp8725_buck_uA[val] : -EINVAL;
  369. }
  370. static int lp872x_buck_set_mode(struct regulator_dev *rdev, unsigned int mode)
  371. {
  372. struct lp872x *lp = rdev_get_drvdata(rdev);
  373. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  374. u8 addr, mask, shift, val;
  375. switch (buck) {
  376. case LP8720_ID_BUCK:
  377. addr = LP8720_BUCK_VOUT2;
  378. mask = LP8720_BUCK_FPWM_M;
  379. shift = LP8720_BUCK_FPWM_S;
  380. break;
  381. case LP8725_ID_BUCK1:
  382. addr = LP8725_BUCK_CTRL;
  383. mask = LP8725_BUCK1_FPWM_M;
  384. shift = LP8725_BUCK1_FPWM_S;
  385. break;
  386. case LP8725_ID_BUCK2:
  387. addr = LP8725_BUCK_CTRL;
  388. mask = LP8725_BUCK2_FPWM_M;
  389. shift = LP8725_BUCK2_FPWM_S;
  390. break;
  391. default:
  392. return -EINVAL;
  393. }
  394. if (mode == REGULATOR_MODE_FAST)
  395. val = LP872X_FORCE_PWM << shift;
  396. else if (mode == REGULATOR_MODE_NORMAL)
  397. val = LP872X_AUTO_PWM << shift;
  398. else
  399. return -EINVAL;
  400. return lp872x_update_bits(lp, addr, mask, val);
  401. }
  402. static unsigned int lp872x_buck_get_mode(struct regulator_dev *rdev)
  403. {
  404. struct lp872x *lp = rdev_get_drvdata(rdev);
  405. enum lp872x_regulator_id buck = rdev_get_id(rdev);
  406. u8 addr, mask, val;
  407. int ret;
  408. switch (buck) {
  409. case LP8720_ID_BUCK:
  410. addr = LP8720_BUCK_VOUT2;
  411. mask = LP8720_BUCK_FPWM_M;
  412. break;
  413. case LP8725_ID_BUCK1:
  414. addr = LP8725_BUCK_CTRL;
  415. mask = LP8725_BUCK1_FPWM_M;
  416. break;
  417. case LP8725_ID_BUCK2:
  418. addr = LP8725_BUCK_CTRL;
  419. mask = LP8725_BUCK2_FPWM_M;
  420. break;
  421. default:
  422. return -EINVAL;
  423. }
  424. ret = lp872x_read_byte(lp, addr, &val);
  425. if (ret)
  426. return ret;
  427. return val & mask ? REGULATOR_MODE_FAST : REGULATOR_MODE_NORMAL;
  428. }
  429. static struct regulator_ops lp872x_ldo_ops = {
  430. .list_voltage = regulator_list_voltage_table,
  431. .set_voltage_sel = regulator_set_voltage_sel_regmap,
  432. .get_voltage_sel = regulator_get_voltage_sel_regmap,
  433. .enable = regulator_enable_regmap,
  434. .disable = regulator_disable_regmap,
  435. .is_enabled = regulator_is_enabled_regmap,
  436. .enable_time = lp872x_regulator_enable_time,
  437. };
  438. static struct regulator_ops lp8720_buck_ops = {
  439. .list_voltage = regulator_list_voltage_table,
  440. .set_voltage_sel = lp872x_buck_set_voltage_sel,
  441. .get_voltage_sel = lp872x_buck_get_voltage_sel,
  442. .enable = regulator_enable_regmap,
  443. .disable = regulator_disable_regmap,
  444. .is_enabled = regulator_is_enabled_regmap,
  445. .enable_time = lp872x_regulator_enable_time,
  446. .set_mode = lp872x_buck_set_mode,
  447. .get_mode = lp872x_buck_get_mode,
  448. };
  449. static struct regulator_ops lp8725_buck_ops = {
  450. .list_voltage = regulator_list_voltage_table,
  451. .set_voltage_sel = lp872x_buck_set_voltage_sel,
  452. .get_voltage_sel = lp872x_buck_get_voltage_sel,
  453. .enable = regulator_enable_regmap,
  454. .disable = regulator_disable_regmap,
  455. .is_enabled = regulator_is_enabled_regmap,
  456. .enable_time = lp872x_regulator_enable_time,
  457. .set_mode = lp872x_buck_set_mode,
  458. .get_mode = lp872x_buck_get_mode,
  459. .set_current_limit = lp8725_buck_set_current_limit,
  460. .get_current_limit = lp8725_buck_get_current_limit,
  461. };
  462. static struct regulator_desc lp8720_regulator_desc[] = {
  463. {
  464. .name = "ldo1",
  465. .id = LP8720_ID_LDO1,
  466. .ops = &lp872x_ldo_ops,
  467. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  468. .volt_table = lp872x_ldo_vtbl,
  469. .type = REGULATOR_VOLTAGE,
  470. .owner = THIS_MODULE,
  471. .vsel_reg = LP872X_LDO1_VOUT,
  472. .vsel_mask = LP872X_VOUT_M,
  473. .enable_reg = LP8720_ENABLE,
  474. .enable_mask = LP872X_EN_LDO1_M,
  475. },
  476. {
  477. .name = "ldo2",
  478. .id = LP8720_ID_LDO2,
  479. .ops = &lp872x_ldo_ops,
  480. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  481. .volt_table = lp872x_ldo_vtbl,
  482. .type = REGULATOR_VOLTAGE,
  483. .owner = THIS_MODULE,
  484. .vsel_reg = LP872X_LDO2_VOUT,
  485. .vsel_mask = LP872X_VOUT_M,
  486. .enable_reg = LP8720_ENABLE,
  487. .enable_mask = LP872X_EN_LDO2_M,
  488. },
  489. {
  490. .name = "ldo3",
  491. .id = LP8720_ID_LDO3,
  492. .ops = &lp872x_ldo_ops,
  493. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  494. .volt_table = lp872x_ldo_vtbl,
  495. .type = REGULATOR_VOLTAGE,
  496. .owner = THIS_MODULE,
  497. .vsel_reg = LP872X_LDO3_VOUT,
  498. .vsel_mask = LP872X_VOUT_M,
  499. .enable_reg = LP8720_ENABLE,
  500. .enable_mask = LP872X_EN_LDO3_M,
  501. },
  502. {
  503. .name = "ldo4",
  504. .id = LP8720_ID_LDO4,
  505. .ops = &lp872x_ldo_ops,
  506. .n_voltages = ARRAY_SIZE(lp8720_ldo4_vtbl),
  507. .volt_table = lp8720_ldo4_vtbl,
  508. .type = REGULATOR_VOLTAGE,
  509. .owner = THIS_MODULE,
  510. .vsel_reg = LP872X_LDO4_VOUT,
  511. .vsel_mask = LP872X_VOUT_M,
  512. .enable_reg = LP8720_ENABLE,
  513. .enable_mask = LP872X_EN_LDO4_M,
  514. },
  515. {
  516. .name = "ldo5",
  517. .id = LP8720_ID_LDO5,
  518. .ops = &lp872x_ldo_ops,
  519. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  520. .volt_table = lp872x_ldo_vtbl,
  521. .type = REGULATOR_VOLTAGE,
  522. .owner = THIS_MODULE,
  523. .vsel_reg = LP872X_LDO5_VOUT,
  524. .vsel_mask = LP872X_VOUT_M,
  525. .enable_reg = LP8720_ENABLE,
  526. .enable_mask = LP872X_EN_LDO5_M,
  527. },
  528. {
  529. .name = "buck",
  530. .id = LP8720_ID_BUCK,
  531. .ops = &lp8720_buck_ops,
  532. .n_voltages = ARRAY_SIZE(lp8720_buck_vtbl),
  533. .volt_table = lp8720_buck_vtbl,
  534. .type = REGULATOR_VOLTAGE,
  535. .owner = THIS_MODULE,
  536. .enable_reg = LP8720_ENABLE,
  537. .enable_mask = LP8720_EN_BUCK_M,
  538. },
  539. };
  540. static struct regulator_desc lp8725_regulator_desc[] = {
  541. {
  542. .name = "ldo1",
  543. .id = LP8725_ID_LDO1,
  544. .ops = &lp872x_ldo_ops,
  545. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  546. .volt_table = lp872x_ldo_vtbl,
  547. .type = REGULATOR_VOLTAGE,
  548. .owner = THIS_MODULE,
  549. .vsel_reg = LP872X_LDO1_VOUT,
  550. .vsel_mask = LP872X_VOUT_M,
  551. .enable_reg = LP8725_LDO_CTRL,
  552. .enable_mask = LP872X_EN_LDO1_M,
  553. },
  554. {
  555. .name = "ldo2",
  556. .id = LP8725_ID_LDO2,
  557. .ops = &lp872x_ldo_ops,
  558. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  559. .volt_table = lp872x_ldo_vtbl,
  560. .type = REGULATOR_VOLTAGE,
  561. .owner = THIS_MODULE,
  562. .vsel_reg = LP872X_LDO2_VOUT,
  563. .vsel_mask = LP872X_VOUT_M,
  564. .enable_reg = LP8725_LDO_CTRL,
  565. .enable_mask = LP872X_EN_LDO2_M,
  566. },
  567. {
  568. .name = "ldo3",
  569. .id = LP8725_ID_LDO3,
  570. .ops = &lp872x_ldo_ops,
  571. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  572. .volt_table = lp872x_ldo_vtbl,
  573. .type = REGULATOR_VOLTAGE,
  574. .owner = THIS_MODULE,
  575. .vsel_reg = LP872X_LDO3_VOUT,
  576. .vsel_mask = LP872X_VOUT_M,
  577. .enable_reg = LP8725_LDO_CTRL,
  578. .enable_mask = LP872X_EN_LDO3_M,
  579. },
  580. {
  581. .name = "ldo4",
  582. .id = LP8725_ID_LDO4,
  583. .ops = &lp872x_ldo_ops,
  584. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  585. .volt_table = lp872x_ldo_vtbl,
  586. .type = REGULATOR_VOLTAGE,
  587. .owner = THIS_MODULE,
  588. .vsel_reg = LP872X_LDO4_VOUT,
  589. .vsel_mask = LP872X_VOUT_M,
  590. .enable_reg = LP8725_LDO_CTRL,
  591. .enable_mask = LP872X_EN_LDO4_M,
  592. },
  593. {
  594. .name = "ldo5",
  595. .id = LP8725_ID_LDO5,
  596. .ops = &lp872x_ldo_ops,
  597. .n_voltages = ARRAY_SIZE(lp872x_ldo_vtbl),
  598. .volt_table = lp872x_ldo_vtbl,
  599. .type = REGULATOR_VOLTAGE,
  600. .owner = THIS_MODULE,
  601. .vsel_reg = LP872X_LDO5_VOUT,
  602. .vsel_mask = LP872X_VOUT_M,
  603. .enable_reg = LP8725_LDO_CTRL,
  604. .enable_mask = LP872X_EN_LDO5_M,
  605. },
  606. {
  607. .name = "lilo1",
  608. .id = LP8725_ID_LILO1,
  609. .ops = &lp872x_ldo_ops,
  610. .n_voltages = ARRAY_SIZE(lp8725_lilo_vtbl),
  611. .volt_table = lp8725_lilo_vtbl,
  612. .type = REGULATOR_VOLTAGE,
  613. .owner = THIS_MODULE,
  614. .vsel_reg = LP8725_LILO1_VOUT,
  615. .vsel_mask = LP872X_VOUT_M,
  616. .enable_reg = LP8725_LDO_CTRL,
  617. .enable_mask = LP8725_EN_LILO1_M,
  618. },
  619. {
  620. .name = "lilo2",
  621. .id = LP8725_ID_LILO2,
  622. .ops = &lp872x_ldo_ops,
  623. .n_voltages = ARRAY_SIZE(lp8725_lilo_vtbl),
  624. .volt_table = lp8725_lilo_vtbl,
  625. .type = REGULATOR_VOLTAGE,
  626. .owner = THIS_MODULE,
  627. .vsel_reg = LP8725_LILO2_VOUT,
  628. .vsel_mask = LP872X_VOUT_M,
  629. .enable_reg = LP8725_LDO_CTRL,
  630. .enable_mask = LP8725_EN_LILO2_M,
  631. },
  632. {
  633. .name = "buck1",
  634. .id = LP8725_ID_BUCK1,
  635. .ops = &lp8725_buck_ops,
  636. .n_voltages = ARRAY_SIZE(lp8725_buck_vtbl),
  637. .volt_table = lp8725_buck_vtbl,
  638. .type = REGULATOR_VOLTAGE,
  639. .owner = THIS_MODULE,
  640. .enable_reg = LP872X_GENERAL_CFG,
  641. .enable_mask = LP8725_BUCK1_EN_M,
  642. },
  643. {
  644. .name = "buck2",
  645. .id = LP8725_ID_BUCK2,
  646. .ops = &lp8725_buck_ops,
  647. .n_voltages = ARRAY_SIZE(lp8725_buck_vtbl),
  648. .volt_table = lp8725_buck_vtbl,
  649. .type = REGULATOR_VOLTAGE,
  650. .owner = THIS_MODULE,
  651. .enable_reg = LP872X_GENERAL_CFG,
  652. .enable_mask = LP8725_BUCK2_EN_M,
  653. },
  654. };
  655. static int lp872x_init_dvs(struct lp872x *lp)
  656. {
  657. int ret, gpio;
  658. struct lp872x_dvs *dvs = lp->pdata ? lp->pdata->dvs : NULL;
  659. enum lp872x_dvs_state pinstate;
  660. u8 mask[] = { LP8720_EXT_DVS_M, LP8725_DVS1_M | LP8725_DVS2_M };
  661. u8 default_dvs_mode[] = { LP8720_DEFAULT_DVS, LP8725_DEFAULT_DVS };
  662. if (!dvs)
  663. goto set_default_dvs_mode;
  664. gpio = dvs->gpio;
  665. if (!gpio_is_valid(gpio)) {
  666. dev_err(lp->dev, "invalid gpio: %d\n", gpio);
  667. return -EINVAL;
  668. }
  669. pinstate = dvs->init_state;
  670. ret = devm_gpio_request_one(lp->dev, gpio, pinstate, "LP872X DVS");
  671. if (ret) {
  672. dev_err(lp->dev, "gpio request err: %d\n", ret);
  673. return ret;
  674. }
  675. lp->dvs_pin = pinstate;
  676. lp->dvs_gpio = gpio;
  677. return 0;
  678. set_default_dvs_mode:
  679. return lp872x_update_bits(lp, LP872X_GENERAL_CFG, mask[lp->chipid],
  680. default_dvs_mode[lp->chipid]);
  681. }
  682. static int lp872x_config(struct lp872x *lp)
  683. {
  684. struct lp872x_platform_data *pdata = lp->pdata;
  685. int ret;
  686. if (!pdata || !pdata->update_config)
  687. goto init_dvs;
  688. ret = lp872x_write_byte(lp, LP872X_GENERAL_CFG, pdata->general_config);
  689. if (ret)
  690. return ret;
  691. init_dvs:
  692. return lp872x_init_dvs(lp);
  693. }
  694. static struct regulator_init_data
  695. *lp872x_find_regulator_init_data(int id, struct lp872x *lp)
  696. {
  697. struct lp872x_platform_data *pdata = lp->pdata;
  698. int i;
  699. if (!pdata)
  700. return NULL;
  701. for (i = 0; i < lp->num_regulators; i++) {
  702. if (pdata->regulator_data[i].id == id)
  703. return pdata->regulator_data[i].init_data;
  704. }
  705. return NULL;
  706. }
  707. static int lp872x_regulator_register(struct lp872x *lp)
  708. {
  709. struct regulator_desc *desc;
  710. struct regulator_config cfg = { };
  711. struct regulator_dev *rdev;
  712. int i, ret;
  713. for (i = 0 ; i < lp->num_regulators ; i++) {
  714. desc = (lp->chipid == LP8720) ? &lp8720_regulator_desc[i] :
  715. &lp8725_regulator_desc[i];
  716. cfg.dev = lp->dev;
  717. cfg.init_data = lp872x_find_regulator_init_data(desc->id, lp);
  718. cfg.driver_data = lp;
  719. cfg.regmap = lp->regmap;
  720. rdev = regulator_register(desc, &cfg);
  721. if (IS_ERR(rdev)) {
  722. dev_err(lp->dev, "regulator register err");
  723. ret = PTR_ERR(rdev);
  724. goto err;
  725. }
  726. *(lp->regulators + i) = rdev;
  727. }
  728. return 0;
  729. err:
  730. while (--i >= 0) {
  731. rdev = *(lp->regulators + i);
  732. regulator_unregister(rdev);
  733. }
  734. return ret;
  735. }
  736. static void lp872x_regulator_unregister(struct lp872x *lp)
  737. {
  738. struct regulator_dev *rdev;
  739. int i;
  740. for (i = 0 ; i < lp->num_regulators ; i++) {
  741. rdev = *(lp->regulators + i);
  742. regulator_unregister(rdev);
  743. }
  744. }
  745. static const struct regmap_config lp872x_regmap_config = {
  746. .reg_bits = 8,
  747. .val_bits = 8,
  748. .max_register = MAX_REGISTERS,
  749. };
  750. static int lp872x_probe(struct i2c_client *cl, const struct i2c_device_id *id)
  751. {
  752. struct lp872x *lp;
  753. int ret, size, num_regulators;
  754. const int lp872x_num_regulators[] = {
  755. [LP8720] = LP8720_NUM_REGULATORS,
  756. [LP8725] = LP8725_NUM_REGULATORS,
  757. };
  758. lp = devm_kzalloc(&cl->dev, sizeof(struct lp872x), GFP_KERNEL);
  759. if (!lp)
  760. goto err_mem;
  761. num_regulators = lp872x_num_regulators[id->driver_data];
  762. size = sizeof(struct regulator_dev *) * num_regulators;
  763. lp->regulators = devm_kzalloc(&cl->dev, size, GFP_KERNEL);
  764. if (!lp->regulators)
  765. goto err_mem;
  766. lp->regmap = devm_regmap_init_i2c(cl, &lp872x_regmap_config);
  767. if (IS_ERR(lp->regmap)) {
  768. ret = PTR_ERR(lp->regmap);
  769. dev_err(&cl->dev, "regmap init i2c err: %d\n", ret);
  770. goto err_dev;
  771. }
  772. lp->dev = &cl->dev;
  773. lp->pdata = cl->dev.platform_data;
  774. lp->chipid = id->driver_data;
  775. lp->num_regulators = num_regulators;
  776. i2c_set_clientdata(cl, lp);
  777. ret = lp872x_config(lp);
  778. if (ret)
  779. goto err_dev;
  780. return lp872x_regulator_register(lp);
  781. err_mem:
  782. return -ENOMEM;
  783. err_dev:
  784. return ret;
  785. }
  786. static int lp872x_remove(struct i2c_client *cl)
  787. {
  788. struct lp872x *lp = i2c_get_clientdata(cl);
  789. lp872x_regulator_unregister(lp);
  790. return 0;
  791. }
  792. static const struct i2c_device_id lp872x_ids[] = {
  793. {"lp8720", LP8720},
  794. {"lp8725", LP8725},
  795. { }
  796. };
  797. MODULE_DEVICE_TABLE(i2c, lp872x_ids);
  798. static struct i2c_driver lp872x_driver = {
  799. .driver = {
  800. .name = "lp872x",
  801. .owner = THIS_MODULE,
  802. },
  803. .probe = lp872x_probe,
  804. .remove = lp872x_remove,
  805. .id_table = lp872x_ids,
  806. };
  807. module_i2c_driver(lp872x_driver);
  808. MODULE_DESCRIPTION("TI/National Semiconductor LP872x PMU Regulator Driver");
  809. MODULE_AUTHOR("Milo Kim");
  810. MODULE_LICENSE("GPL");