board-mop500-regulators.c 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077
  1. /*
  2. * Copyright (C) ST-Ericsson SA 2010
  3. *
  4. * License Terms: GNU General Public License v2
  5. *
  6. * Authors: Sundar Iyer <sundar.iyer@stericsson.com>
  7. * Bengt Jonsson <bengt.g.jonsson@stericsson.com>
  8. * Daniel Willerud <daniel.willerud@stericsson.com>
  9. *
  10. * MOP500 board specific initialization for regulators
  11. */
  12. #include <linux/kernel.h>
  13. #include <linux/regulator/machine.h>
  14. #include <linux/regulator/ab8500.h>
  15. #include "board-mop500-regulators.h"
  16. #include "id.h"
  17. static struct regulator_consumer_supply gpio_en_3v3_consumers[] = {
  18. REGULATOR_SUPPLY("vdd33a", "smsc911x.0"),
  19. };
  20. struct regulator_init_data gpio_en_3v3_regulator = {
  21. .constraints = {
  22. .name = "EN-3V3",
  23. .min_uV = 3300000,
  24. .max_uV = 3300000,
  25. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  26. },
  27. .num_consumer_supplies = ARRAY_SIZE(gpio_en_3v3_consumers),
  28. .consumer_supplies = gpio_en_3v3_consumers,
  29. };
  30. static struct regulator_consumer_supply sdi0_reg_consumers[] = {
  31. REGULATOR_SUPPLY("vqmmc", "sdi0"),
  32. };
  33. struct regulator_init_data sdi0_reg_init_data = {
  34. .constraints = {
  35. .min_uV = 1800000,
  36. .max_uV = 2900000,
  37. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE|REGULATOR_CHANGE_STATUS,
  38. },
  39. .num_consumer_supplies = ARRAY_SIZE(sdi0_reg_consumers),
  40. .consumer_supplies = sdi0_reg_consumers,
  41. };
  42. /*
  43. * TPS61052 regulator
  44. */
  45. static struct regulator_consumer_supply tps61052_vaudio_consumers[] = {
  46. /*
  47. * Boost converter supply to raise voltage on audio speaker, this
  48. * is actually connected to three pins, VInVhfL (left amplifier)
  49. * VInVhfR (right amplifier) and VIntDClassInt - all three must
  50. * be connected to the same voltage.
  51. */
  52. REGULATOR_SUPPLY("vintdclassint", "ab8500-codec.0"),
  53. };
  54. struct regulator_init_data tps61052_regulator = {
  55. .constraints = {
  56. .name = "vaudio-hf",
  57. .min_uV = 4500000,
  58. .max_uV = 4500000,
  59. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  60. },
  61. .num_consumer_supplies = ARRAY_SIZE(tps61052_vaudio_consumers),
  62. .consumer_supplies = tps61052_vaudio_consumers,
  63. };
  64. static struct regulator_consumer_supply ab8500_vaux1_consumers[] = {
  65. /* Main display, u8500 R3 uib */
  66. REGULATOR_SUPPLY("vddi", "mcde_disp_sony_acx424akp.0"),
  67. /* Main display, u8500 uib and ST uib */
  68. REGULATOR_SUPPLY("vdd1", "samsung_s6d16d0.0"),
  69. /* Secondary display, ST uib */
  70. REGULATOR_SUPPLY("vdd1", "samsung_s6d16d0.1"),
  71. /* SFH7741 proximity sensor */
  72. REGULATOR_SUPPLY("vcc", "gpio-keys.0"),
  73. /* BH1780GLS ambient light sensor */
  74. REGULATOR_SUPPLY("vcc", "2-0029"),
  75. /* lsm303dlh accelerometer */
  76. REGULATOR_SUPPLY("vdd", "2-0018"),
  77. /* lsm303dlhc accelerometer */
  78. REGULATOR_SUPPLY("vdd", "2-0019"),
  79. /* lsm303dlh magnetometer */
  80. REGULATOR_SUPPLY("vdd", "2-001e"),
  81. /* Rohm BU21013 Touchscreen devices */
  82. REGULATOR_SUPPLY("avdd", "3-005c"),
  83. REGULATOR_SUPPLY("avdd", "3-005d"),
  84. /* Synaptics RMI4 Touchscreen device */
  85. REGULATOR_SUPPLY("vdd", "3-004b"),
  86. /* L3G4200D Gyroscope device */
  87. REGULATOR_SUPPLY("vdd", "2-0068"),
  88. /* Ambient light sensor device */
  89. REGULATOR_SUPPLY("vdd", "3-0029"),
  90. /* Pressure sensor device */
  91. REGULATOR_SUPPLY("vdd", "2-005c"),
  92. /* Cypress TrueTouch Touchscreen device */
  93. REGULATOR_SUPPLY("vcpin", "spi8.0"),
  94. /* Camera device */
  95. REGULATOR_SUPPLY("vaux12v5", "mmio_camera"),
  96. };
  97. static struct regulator_consumer_supply ab8500_vaux2_consumers[] = {
  98. /* On-board eMMC power */
  99. REGULATOR_SUPPLY("vmmc", "sdi4"),
  100. /* AB8500 audio codec */
  101. REGULATOR_SUPPLY("vcc-N2158", "ab8500-codec.0"),
  102. /* AB8500 accessory detect 1 */
  103. REGULATOR_SUPPLY("vcc-N2158", "ab8500-acc-det.0"),
  104. /* AB8500 Tv-out device */
  105. REGULATOR_SUPPLY("vcc-N2158", "mcde_tv_ab8500.4"),
  106. /* AV8100 HDMI device */
  107. REGULATOR_SUPPLY("vcc-N2158", "av8100_hdmi.3"),
  108. };
  109. static struct regulator_consumer_supply ab8500_vaux3_consumers[] = {
  110. REGULATOR_SUPPLY("v-SD-STM", "stm"),
  111. /* External MMC slot power */
  112. REGULATOR_SUPPLY("vmmc", "sdi0"),
  113. };
  114. static struct regulator_consumer_supply ab8505_vaux4_consumers[] = {
  115. };
  116. static struct regulator_consumer_supply ab8505_vaux5_consumers[] = {
  117. };
  118. static struct regulator_consumer_supply ab8505_vaux6_consumers[] = {
  119. };
  120. static struct regulator_consumer_supply ab8505_vaux8_consumers[] = {
  121. /* AB8500 audio codec device */
  122. REGULATOR_SUPPLY("v-aux8", NULL),
  123. };
  124. static struct regulator_consumer_supply ab8505_vadc_consumers[] = {
  125. /* Internal general-purpose ADC */
  126. REGULATOR_SUPPLY("vddadc", "ab8500-gpadc.0"),
  127. /* ADC for charger */
  128. REGULATOR_SUPPLY("vddadc", "ab8500-charger.0"),
  129. };
  130. static struct regulator_consumer_supply ab8500_vtvout_consumers[] = {
  131. /* TV-out DENC supply */
  132. REGULATOR_SUPPLY("vtvout", "ab8500-denc.0"),
  133. /* Internal general-purpose ADC */
  134. REGULATOR_SUPPLY("vddadc", "ab8500-gpadc.0"),
  135. /* ADC for charger */
  136. REGULATOR_SUPPLY("vddadc", "ab8500-charger.0"),
  137. /* AB8500 Tv-out device */
  138. REGULATOR_SUPPLY("vtvout", "mcde_tv_ab8500.4"),
  139. };
  140. static struct regulator_consumer_supply ab8500_vaud_consumers[] = {
  141. /* AB8500 audio-codec main supply */
  142. REGULATOR_SUPPLY("vaud", "ab8500-codec.0"),
  143. };
  144. static struct regulator_consumer_supply ab8500_vamic1_consumers[] = {
  145. /* AB8500 audio-codec Mic1 supply */
  146. REGULATOR_SUPPLY("vamic1", "ab8500-codec.0"),
  147. };
  148. static struct regulator_consumer_supply ab8500_vamic2_consumers[] = {
  149. /* AB8500 audio-codec Mic2 supply */
  150. REGULATOR_SUPPLY("vamic2", "ab8500-codec.0"),
  151. };
  152. static struct regulator_consumer_supply ab8500_vdmic_consumers[] = {
  153. /* AB8500 audio-codec DMic supply */
  154. REGULATOR_SUPPLY("vdmic", "ab8500-codec.0"),
  155. };
  156. static struct regulator_consumer_supply ab8500_vintcore_consumers[] = {
  157. /* SoC core supply, no device */
  158. REGULATOR_SUPPLY("v-intcore", NULL),
  159. /* USB Transceiver */
  160. REGULATOR_SUPPLY("vddulpivio18", "ab8500-usb.0"),
  161. /* Handled by abx500 clk driver */
  162. REGULATOR_SUPPLY("v-intcore", "abx500-clk.0"),
  163. };
  164. static struct regulator_consumer_supply ab8505_usb_consumers[] = {
  165. /* HS USB OTG physical interface */
  166. REGULATOR_SUPPLY("v-ape", NULL),
  167. };
  168. static struct regulator_consumer_supply ab8500_vana_consumers[] = {
  169. /* DB8500 DSI */
  170. REGULATOR_SUPPLY("vdddsi1v2", "mcde"),
  171. REGULATOR_SUPPLY("vdddsi1v2", "b2r2_core"),
  172. REGULATOR_SUPPLY("vdddsi1v2", "b2r2_1_core"),
  173. REGULATOR_SUPPLY("vdddsi1v2", "dsilink.0"),
  174. REGULATOR_SUPPLY("vdddsi1v2", "dsilink.1"),
  175. REGULATOR_SUPPLY("vdddsi1v2", "dsilink.2"),
  176. /* DB8500 CSI */
  177. REGULATOR_SUPPLY("vddcsi1v2", "mmio_camera"),
  178. };
  179. /* ab8500 regulator register initialization */
  180. static struct ab8500_regulator_reg_init ab8500_reg_init[] = {
  181. /*
  182. * VanaRequestCtrl = HP/LP depending on VxRequest
  183. * VextSupply1RequestCtrl = HP/LP depending on VxRequest
  184. */
  185. INIT_REGULATOR_REGISTER(AB8500_REGUREQUESTCTRL2, 0xf0, 0x00),
  186. /*
  187. * VextSupply2RequestCtrl = HP/LP depending on VxRequest
  188. * VextSupply3RequestCtrl = HP/LP depending on VxRequest
  189. * Vaux1RequestCtrl = HP/LP depending on VxRequest
  190. * Vaux2RequestCtrl = HP/LP depending on VxRequest
  191. */
  192. INIT_REGULATOR_REGISTER(AB8500_REGUREQUESTCTRL3, 0xff, 0x00),
  193. /*
  194. * Vaux3RequestCtrl = HP/LP depending on VxRequest
  195. * SwHPReq = Control through SWValid disabled
  196. */
  197. INIT_REGULATOR_REGISTER(AB8500_REGUREQUESTCTRL4, 0x07, 0x00),
  198. /*
  199. * VanaSysClkReq1HPValid = disabled
  200. * Vaux1SysClkReq1HPValid = disabled
  201. * Vaux2SysClkReq1HPValid = disabled
  202. * Vaux3SysClkReq1HPValid = disabled
  203. */
  204. INIT_REGULATOR_REGISTER(AB8500_REGUSYSCLKREQ1HPVALID1, 0xe8, 0x00),
  205. /*
  206. * VextSupply1SysClkReq1HPValid = disabled
  207. * VextSupply2SysClkReq1HPValid = disabled
  208. * VextSupply3SysClkReq1HPValid = SysClkReq1 controlled
  209. */
  210. INIT_REGULATOR_REGISTER(AB8500_REGUSYSCLKREQ1HPVALID2, 0x70, 0x40),
  211. /*
  212. * VanaHwHPReq1Valid = disabled
  213. * Vaux1HwHPreq1Valid = disabled
  214. * Vaux2HwHPReq1Valid = disabled
  215. * Vaux3HwHPReqValid = disabled
  216. */
  217. INIT_REGULATOR_REGISTER(AB8500_REGUHWHPREQ1VALID1, 0xe8, 0x00),
  218. /*
  219. * VextSupply1HwHPReq1Valid = disabled
  220. * VextSupply2HwHPReq1Valid = disabled
  221. * VextSupply3HwHPReq1Valid = disabled
  222. */
  223. INIT_REGULATOR_REGISTER(AB8500_REGUHWHPREQ1VALID2, 0x07, 0x00),
  224. /*
  225. * VanaHwHPReq2Valid = disabled
  226. * Vaux1HwHPReq2Valid = disabled
  227. * Vaux2HwHPReq2Valid = disabled
  228. * Vaux3HwHPReq2Valid = disabled
  229. */
  230. INIT_REGULATOR_REGISTER(AB8500_REGUHWHPREQ2VALID1, 0xe8, 0x00),
  231. /*
  232. * VextSupply1HwHPReq2Valid = disabled
  233. * VextSupply2HwHPReq2Valid = disabled
  234. * VextSupply3HwHPReq2Valid = HWReq2 controlled
  235. */
  236. INIT_REGULATOR_REGISTER(AB8500_REGUHWHPREQ2VALID2, 0x07, 0x04),
  237. /*
  238. * VanaSwHPReqValid = disabled
  239. * Vaux1SwHPReqValid = disabled
  240. */
  241. INIT_REGULATOR_REGISTER(AB8500_REGUSWHPREQVALID1, 0xa0, 0x00),
  242. /*
  243. * Vaux2SwHPReqValid = disabled
  244. * Vaux3SwHPReqValid = disabled
  245. * VextSupply1SwHPReqValid = disabled
  246. * VextSupply2SwHPReqValid = disabled
  247. * VextSupply3SwHPReqValid = disabled
  248. */
  249. INIT_REGULATOR_REGISTER(AB8500_REGUSWHPREQVALID2, 0x1f, 0x00),
  250. /*
  251. * SysClkReq2Valid1 = SysClkReq2 controlled
  252. * SysClkReq3Valid1 = disabled
  253. * SysClkReq4Valid1 = SysClkReq4 controlled
  254. * SysClkReq5Valid1 = disabled
  255. * SysClkReq6Valid1 = SysClkReq6 controlled
  256. * SysClkReq7Valid1 = disabled
  257. * SysClkReq8Valid1 = disabled
  258. */
  259. INIT_REGULATOR_REGISTER(AB8500_REGUSYSCLKREQVALID1, 0xfe, 0x2a),
  260. /*
  261. * SysClkReq2Valid2 = disabled
  262. * SysClkReq3Valid2 = disabled
  263. * SysClkReq4Valid2 = disabled
  264. * SysClkReq5Valid2 = disabled
  265. * SysClkReq6Valid2 = SysClkReq6 controlled
  266. * SysClkReq7Valid2 = disabled
  267. * SysClkReq8Valid2 = disabled
  268. */
  269. INIT_REGULATOR_REGISTER(AB8500_REGUSYSCLKREQVALID2, 0xfe, 0x20),
  270. /*
  271. * VTVoutEna = disabled
  272. * Vintcore12Ena = disabled
  273. * Vintcore12Sel = 1.25 V
  274. * Vintcore12LP = inactive (HP)
  275. * VTVoutLP = inactive (HP)
  276. */
  277. INIT_REGULATOR_REGISTER(AB8500_REGUMISC1, 0xfe, 0x10),
  278. /*
  279. * VaudioEna = disabled
  280. * VdmicEna = disabled
  281. * Vamic1Ena = disabled
  282. * Vamic2Ena = disabled
  283. */
  284. INIT_REGULATOR_REGISTER(AB8500_VAUDIOSUPPLY, 0x1e, 0x00),
  285. /*
  286. * Vamic1_dzout = high-Z when Vamic1 is disabled
  287. * Vamic2_dzout = high-Z when Vamic2 is disabled
  288. */
  289. INIT_REGULATOR_REGISTER(AB8500_REGUCTRL1VAMIC, 0x03, 0x00),
  290. /*
  291. * VPll = Hw controlled (NOTE! PRCMU bits)
  292. * VanaRegu = force off
  293. */
  294. INIT_REGULATOR_REGISTER(AB8500_VPLLVANAREGU, 0x0f, 0x02),
  295. /*
  296. * VrefDDREna = disabled
  297. * VrefDDRSleepMode = inactive (no pulldown)
  298. */
  299. INIT_REGULATOR_REGISTER(AB8500_VREFDDR, 0x03, 0x00),
  300. /*
  301. * VextSupply1Regu = force LP
  302. * VextSupply2Regu = force OFF
  303. * VextSupply3Regu = force HP (-> STBB2=LP and TPS=LP)
  304. * ExtSupply2Bypass = ExtSupply12LPn ball is 0 when Ena is 0
  305. * ExtSupply3Bypass = ExtSupply3LPn ball is 0 when Ena is 0
  306. */
  307. INIT_REGULATOR_REGISTER(AB8500_EXTSUPPLYREGU, 0xff, 0x13),
  308. /*
  309. * Vaux1Regu = force HP
  310. * Vaux2Regu = force off
  311. */
  312. INIT_REGULATOR_REGISTER(AB8500_VAUX12REGU, 0x0f, 0x01),
  313. /*
  314. * Vaux3Regu = force off
  315. */
  316. INIT_REGULATOR_REGISTER(AB8500_VRF1VAUX3REGU, 0x03, 0x00),
  317. /*
  318. * Vaux1Sel = 2.8 V
  319. */
  320. INIT_REGULATOR_REGISTER(AB8500_VAUX1SEL, 0x0f, 0x0C),
  321. /*
  322. * Vaux2Sel = 2.9 V
  323. */
  324. INIT_REGULATOR_REGISTER(AB8500_VAUX2SEL, 0x0f, 0x0d),
  325. /*
  326. * Vaux3Sel = 2.91 V
  327. */
  328. INIT_REGULATOR_REGISTER(AB8500_VRF1VAUX3SEL, 0x07, 0x07),
  329. /*
  330. * VextSupply12LP = disabled (no LP)
  331. */
  332. INIT_REGULATOR_REGISTER(AB8500_REGUCTRL2SPARE, 0x01, 0x00),
  333. /*
  334. * Vaux1Disch = short discharge time
  335. * Vaux2Disch = short discharge time
  336. * Vaux3Disch = short discharge time
  337. * Vintcore12Disch = short discharge time
  338. * VTVoutDisch = short discharge time
  339. * VaudioDisch = short discharge time
  340. */
  341. INIT_REGULATOR_REGISTER(AB8500_REGUCTRLDISCH, 0xfc, 0x00),
  342. /*
  343. * VanaDisch = short discharge time
  344. * VdmicPullDownEna = pulldown disabled when Vdmic is disabled
  345. * VdmicDisch = short discharge time
  346. */
  347. INIT_REGULATOR_REGISTER(AB8500_REGUCTRLDISCH2, 0x16, 0x00),
  348. };
  349. /* AB8500 regulators */
  350. static struct regulator_init_data ab8500_regulators[AB8500_NUM_REGULATORS] = {
  351. /* supplies to the display/camera */
  352. [AB8500_LDO_AUX1] = {
  353. .constraints = {
  354. .name = "V-DISPLAY",
  355. .min_uV = 2800000,
  356. .max_uV = 3300000,
  357. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  358. REGULATOR_CHANGE_STATUS,
  359. .boot_on = 1, /* display is on at boot */
  360. },
  361. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux1_consumers),
  362. .consumer_supplies = ab8500_vaux1_consumers,
  363. },
  364. /* supplies to the on-board eMMC */
  365. [AB8500_LDO_AUX2] = {
  366. .constraints = {
  367. .name = "V-eMMC1",
  368. .min_uV = 1100000,
  369. .max_uV = 3300000,
  370. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  371. REGULATOR_CHANGE_STATUS |
  372. REGULATOR_CHANGE_MODE,
  373. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  374. REGULATOR_MODE_IDLE,
  375. },
  376. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux2_consumers),
  377. .consumer_supplies = ab8500_vaux2_consumers,
  378. },
  379. /* supply for VAUX3, supplies to SDcard slots */
  380. [AB8500_LDO_AUX3] = {
  381. .constraints = {
  382. .name = "V-MMC-SD",
  383. .min_uV = 1100000,
  384. .max_uV = 3300000,
  385. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  386. REGULATOR_CHANGE_STATUS |
  387. REGULATOR_CHANGE_MODE,
  388. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  389. REGULATOR_MODE_IDLE,
  390. },
  391. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux3_consumers),
  392. .consumer_supplies = ab8500_vaux3_consumers,
  393. },
  394. /* supply for tvout, gpadc, TVOUT LDO */
  395. [AB8500_LDO_TVOUT] = {
  396. .constraints = {
  397. .name = "V-TVOUT",
  398. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  399. },
  400. .num_consumer_supplies = ARRAY_SIZE(ab8500_vtvout_consumers),
  401. .consumer_supplies = ab8500_vtvout_consumers,
  402. },
  403. /* supply for ab8500-vaudio, VAUDIO LDO */
  404. [AB8500_LDO_AUDIO] = {
  405. .constraints = {
  406. .name = "V-AUD",
  407. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  408. },
  409. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaud_consumers),
  410. .consumer_supplies = ab8500_vaud_consumers,
  411. },
  412. /* supply for v-anamic1 VAMic1-LDO */
  413. [AB8500_LDO_ANAMIC1] = {
  414. .constraints = {
  415. .name = "V-AMIC1",
  416. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  417. },
  418. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic1_consumers),
  419. .consumer_supplies = ab8500_vamic1_consumers,
  420. },
  421. /* supply for v-amic2, VAMIC2 LDO, reuse constants for AMIC1 */
  422. [AB8500_LDO_ANAMIC2] = {
  423. .constraints = {
  424. .name = "V-AMIC2",
  425. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  426. },
  427. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic2_consumers),
  428. .consumer_supplies = ab8500_vamic2_consumers,
  429. },
  430. /* supply for v-dmic, VDMIC LDO */
  431. [AB8500_LDO_DMIC] = {
  432. .constraints = {
  433. .name = "V-DMIC",
  434. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  435. },
  436. .num_consumer_supplies = ARRAY_SIZE(ab8500_vdmic_consumers),
  437. .consumer_supplies = ab8500_vdmic_consumers,
  438. },
  439. /* supply for v-intcore12, VINTCORE12 LDO */
  440. [AB8500_LDO_INTCORE] = {
  441. .constraints = {
  442. .name = "V-INTCORE",
  443. .min_uV = 1250000,
  444. .max_uV = 1350000,
  445. .input_uV = 1800000,
  446. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  447. REGULATOR_CHANGE_STATUS |
  448. REGULATOR_CHANGE_MODE |
  449. REGULATOR_CHANGE_DRMS,
  450. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  451. REGULATOR_MODE_IDLE,
  452. },
  453. .num_consumer_supplies = ARRAY_SIZE(ab8500_vintcore_consumers),
  454. .consumer_supplies = ab8500_vintcore_consumers,
  455. },
  456. /* supply for U8500 CSI-DSI, VANA LDO */
  457. [AB8500_LDO_ANA] = {
  458. .constraints = {
  459. .name = "V-CSI-DSI",
  460. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  461. },
  462. .num_consumer_supplies = ARRAY_SIZE(ab8500_vana_consumers),
  463. .consumer_supplies = ab8500_vana_consumers,
  464. },
  465. };
  466. /* supply for VextSupply3 */
  467. static struct regulator_consumer_supply ab8500_ext_supply3_consumers[] = {
  468. /* SIM supply for 3 V SIM cards */
  469. REGULATOR_SUPPLY("vinvsim", "sim-detect.0"),
  470. };
  471. /* extended configuration for VextSupply2, only used for HREFP_V20 boards */
  472. static struct ab8500_ext_regulator_cfg ab8500_ext_supply2 = {
  473. .hwreq = true,
  474. };
  475. /*
  476. * AB8500 external regulators
  477. */
  478. static struct regulator_init_data ab8500_ext_regulators[] = {
  479. /* fixed Vbat supplies VSMPS1_EXT_1V8 */
  480. [AB8500_EXT_SUPPLY1] = {
  481. .constraints = {
  482. .name = "ab8500-ext-supply1",
  483. .min_uV = 1800000,
  484. .max_uV = 1800000,
  485. .initial_mode = REGULATOR_MODE_IDLE,
  486. .boot_on = 1,
  487. .always_on = 1,
  488. },
  489. },
  490. /* fixed Vbat supplies VSMPS2_EXT_1V36 and VSMPS5_EXT_1V15 */
  491. [AB8500_EXT_SUPPLY2] = {
  492. .constraints = {
  493. .name = "ab8500-ext-supply2",
  494. .min_uV = 1360000,
  495. .max_uV = 1360000,
  496. },
  497. },
  498. /* fixed Vbat supplies VSMPS3_EXT_3V4 and VSMPS4_EXT_3V4 */
  499. [AB8500_EXT_SUPPLY3] = {
  500. .constraints = {
  501. .name = "ab8500-ext-supply3",
  502. .min_uV = 3400000,
  503. .max_uV = 3400000,
  504. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  505. .boot_on = 1,
  506. },
  507. .num_consumer_supplies =
  508. ARRAY_SIZE(ab8500_ext_supply3_consumers),
  509. .consumer_supplies = ab8500_ext_supply3_consumers,
  510. },
  511. };
  512. /* ab8505 regulator register initialization */
  513. static struct ab8500_regulator_reg_init ab8505_reg_init[] = {
  514. /*
  515. * VarmRequestCtrl
  516. * VsmpsCRequestCtrl
  517. * VsmpsARequestCtrl
  518. * VsmpsBRequestCtrl
  519. */
  520. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL1, 0x00, 0x00),
  521. /*
  522. * VsafeRequestCtrl
  523. * VpllRequestCtrl
  524. * VanaRequestCtrl = HP/LP depending on VxRequest
  525. */
  526. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL2, 0x30, 0x00),
  527. /*
  528. * Vaux1RequestCtrl = HP/LP depending on VxRequest
  529. * Vaux2RequestCtrl = HP/LP depending on VxRequest
  530. */
  531. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL3, 0xf0, 0x00),
  532. /*
  533. * Vaux3RequestCtrl = HP/LP depending on VxRequest
  534. * SwHPReq = Control through SWValid disabled
  535. */
  536. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL4, 0x07, 0x00),
  537. /*
  538. * VsmpsASysClkReq1HPValid
  539. * VsmpsBSysClkReq1HPValid
  540. * VsafeSysClkReq1HPValid
  541. * VanaSysClkReq1HPValid = disabled
  542. * VpllSysClkReq1HPValid
  543. * Vaux1SysClkReq1HPValid = disabled
  544. * Vaux2SysClkReq1HPValid = disabled
  545. * Vaux3SysClkReq1HPValid = disabled
  546. */
  547. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQ1HPVALID1, 0xe8, 0x00),
  548. /*
  549. * VsmpsCSysClkReq1HPValid
  550. * VarmSysClkReq1HPValid
  551. * VbbSysClkReq1HPValid
  552. * VsmpsMSysClkReq1HPValid
  553. */
  554. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQ1HPVALID2, 0x00, 0x00),
  555. /*
  556. * VsmpsAHwHPReq1Valid
  557. * VsmpsBHwHPReq1Valid
  558. * VsafeHwHPReq1Valid
  559. * VanaHwHPReq1Valid = disabled
  560. * VpllHwHPReq1Valid
  561. * Vaux1HwHPreq1Valid = disabled
  562. * Vaux2HwHPReq1Valid = disabled
  563. * Vaux3HwHPReqValid = disabled
  564. */
  565. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ1VALID1, 0xe8, 0x00),
  566. /*
  567. * VsmpsMHwHPReq1Valid
  568. */
  569. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ1VALID2, 0x00, 0x00),
  570. /*
  571. * VsmpsAHwHPReq2Valid
  572. * VsmpsBHwHPReq2Valid
  573. * VsafeHwHPReq2Valid
  574. * VanaHwHPReq2Valid = disabled
  575. * VpllHwHPReq2Valid
  576. * Vaux1HwHPReq2Valid = disabled
  577. * Vaux2HwHPReq2Valid = disabled
  578. * Vaux3HwHPReq2Valid = disabled
  579. */
  580. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ2VALID1, 0xe8, 0x00),
  581. /*
  582. * VsmpsMHwHPReq2Valid
  583. */
  584. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ2VALID2, 0x00, 0x00),
  585. /**
  586. * VsmpsCSwHPReqValid
  587. * VarmSwHPReqValid
  588. * VsmpsASwHPReqValid
  589. * VsmpsBSwHPReqValid
  590. * VsafeSwHPReqValid
  591. * VanaSwHPReqValid
  592. * VanaSwHPReqValid = disabled
  593. * VpllSwHPReqValid
  594. * Vaux1SwHPReqValid = disabled
  595. */
  596. INIT_REGULATOR_REGISTER(AB8505_REGUSWHPREQVALID1, 0xa0, 0x00),
  597. /*
  598. * Vaux2SwHPReqValid = disabled
  599. * Vaux3SwHPReqValid = disabled
  600. * VsmpsMSwHPReqValid
  601. */
  602. INIT_REGULATOR_REGISTER(AB8505_REGUSWHPREQVALID2, 0x03, 0x00),
  603. /*
  604. * SysClkReq2Valid1 = SysClkReq2 controlled
  605. * SysClkReq3Valid1 = disabled
  606. * SysClkReq4Valid1 = SysClkReq4 controlled
  607. */
  608. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQVALID1, 0x0e, 0x0a),
  609. /*
  610. * SysClkReq2Valid2 = disabled
  611. * SysClkReq3Valid2 = disabled
  612. * SysClkReq4Valid2 = disabled
  613. */
  614. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQVALID2, 0x0e, 0x00),
  615. /*
  616. * Vaux4SwHPReqValid
  617. * Vaux4HwHPReq2Valid
  618. * Vaux4HwHPReq1Valid
  619. * Vaux4SysClkReq1HPValid
  620. */
  621. INIT_REGULATOR_REGISTER(AB8505_REGUVAUX4REQVALID, 0x00, 0x00),
  622. /*
  623. * VadcEna = disabled
  624. * VintCore12Ena = disabled
  625. * VintCore12Sel = 1.25 V
  626. * VintCore12LP = inactive (HP)
  627. * VadcLP = inactive (HP)
  628. */
  629. INIT_REGULATOR_REGISTER(AB8505_REGUMISC1, 0xfe, 0x10),
  630. /*
  631. * VaudioEna = disabled
  632. * Vaux8Ena = disabled
  633. * Vamic1Ena = disabled
  634. * Vamic2Ena = disabled
  635. */
  636. INIT_REGULATOR_REGISTER(AB8505_VAUDIOSUPPLY, 0x1e, 0x00),
  637. /*
  638. * Vamic1_dzout = high-Z when Vamic1 is disabled
  639. * Vamic2_dzout = high-Z when Vamic2 is disabled
  640. */
  641. INIT_REGULATOR_REGISTER(AB8505_REGUCTRL1VAMIC, 0x03, 0x00),
  642. /*
  643. * VsmpsARegu
  644. * VsmpsASelCtrl
  645. * VsmpsAAutoMode
  646. * VsmpsAPWMMode
  647. */
  648. INIT_REGULATOR_REGISTER(AB8505_VSMPSAREGU, 0x00, 0x00),
  649. /*
  650. * VsmpsBRegu
  651. * VsmpsBSelCtrl
  652. * VsmpsBAutoMode
  653. * VsmpsBPWMMode
  654. */
  655. INIT_REGULATOR_REGISTER(AB8505_VSMPSBREGU, 0x00, 0x00),
  656. /*
  657. * VsafeRegu
  658. * VsafeSelCtrl
  659. * VsafeAutoMode
  660. * VsafePWMMode
  661. */
  662. INIT_REGULATOR_REGISTER(AB8505_VSAFEREGU, 0x00, 0x00),
  663. /*
  664. * VPll = Hw controlled (NOTE! PRCMU bits)
  665. * VanaRegu = force off
  666. */
  667. INIT_REGULATOR_REGISTER(AB8505_VPLLVANAREGU, 0x0f, 0x02),
  668. /*
  669. * VextSupply1Regu = force OFF (OTP_ExtSupply12LPnPolarity 1)
  670. * VextSupply2Regu = force OFF (OTP_ExtSupply12LPnPolarity 1)
  671. * VextSupply3Regu = force OFF (OTP_ExtSupply3LPnPolarity 0)
  672. * ExtSupply2Bypass = ExtSupply12LPn ball is 0 when Ena is 0
  673. * ExtSupply3Bypass = ExtSupply3LPn ball is 0 when Ena is 0
  674. */
  675. INIT_REGULATOR_REGISTER(AB8505_EXTSUPPLYREGU, 0xff, 0x30),
  676. /*
  677. * Vaux1Regu = force HP
  678. * Vaux2Regu = force off
  679. */
  680. INIT_REGULATOR_REGISTER(AB8505_VAUX12REGU, 0x0f, 0x01),
  681. /*
  682. * Vaux3Regu = force off
  683. */
  684. INIT_REGULATOR_REGISTER(AB8505_VRF1VAUX3REGU, 0x03, 0x00),
  685. /*
  686. * VsmpsASel1
  687. */
  688. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL1, 0x00, 0x00),
  689. /*
  690. * VsmpsASel2
  691. */
  692. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL2, 0x00, 0x00),
  693. /*
  694. * VsmpsASel3
  695. */
  696. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL3, 0x00, 0x00),
  697. /*
  698. * VsmpsBSel1
  699. */
  700. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL1, 0x00, 0x00),
  701. /*
  702. * VsmpsBSel2
  703. */
  704. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL2, 0x00, 0x00),
  705. /*
  706. * VsmpsBSel3
  707. */
  708. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL3, 0x00, 0x00),
  709. /*
  710. * VsafeSel1
  711. */
  712. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL1, 0x00, 0x00),
  713. /*
  714. * VsafeSel2
  715. */
  716. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL2, 0x00, 0x00),
  717. /*
  718. * VsafeSel3
  719. */
  720. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL3, 0x00, 0x00),
  721. /*
  722. * Vaux1Sel = 2.8 V
  723. */
  724. INIT_REGULATOR_REGISTER(AB8505_VAUX1SEL, 0x0f, 0x0C),
  725. /*
  726. * Vaux2Sel = 2.9 V
  727. */
  728. INIT_REGULATOR_REGISTER(AB8505_VAUX2SEL, 0x0f, 0x0d),
  729. /*
  730. * Vaux3Sel = 2.91 V
  731. */
  732. INIT_REGULATOR_REGISTER(AB8505_VRF1VAUX3SEL, 0x07, 0x07),
  733. /*
  734. * Vaux4RequestCtrl
  735. */
  736. INIT_REGULATOR_REGISTER(AB8505_VAUX4REQCTRL, 0x00, 0x00),
  737. /*
  738. * Vaux4Regu
  739. */
  740. INIT_REGULATOR_REGISTER(AB8505_VAUX4REGU, 0x00, 0x00),
  741. /*
  742. * Vaux4Sel
  743. */
  744. INIT_REGULATOR_REGISTER(AB8505_VAUX4SEL, 0x00, 0x00),
  745. /*
  746. * Vaux1Disch = short discharge time
  747. * Vaux2Disch = short discharge time
  748. * Vaux3Disch = short discharge time
  749. * Vintcore12Disch = short discharge time
  750. * VTVoutDisch = short discharge time
  751. * VaudioDisch = short discharge time
  752. */
  753. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH, 0xfc, 0x00),
  754. /*
  755. * VanaDisch = short discharge time
  756. * Vaux8PullDownEna = pulldown disabled when Vaux8 is disabled
  757. * Vaux8Disch = short discharge time
  758. */
  759. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH2, 0x16, 0x00),
  760. /*
  761. * Vaux4Disch = short discharge time
  762. */
  763. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH3, 0x01, 0x00),
  764. /*
  765. * Vaux5Sel
  766. * Vaux5LP
  767. * Vaux5Ena
  768. * Vaux5Disch
  769. * Vaux5DisSfst
  770. * Vaux5DisPulld
  771. */
  772. INIT_REGULATOR_REGISTER(AB8505_CTRLVAUX5, 0x00, 0x00),
  773. /*
  774. * Vaux6Sel
  775. * Vaux6LP
  776. * Vaux6Ena
  777. * Vaux6DisPulld
  778. */
  779. INIT_REGULATOR_REGISTER(AB8505_CTRLVAUX6, 0x00, 0x00),
  780. };
  781. struct regulator_init_data ab8505_regulators[AB8505_NUM_REGULATORS] = {
  782. /* supplies to the display/camera */
  783. [AB8505_LDO_AUX1] = {
  784. .constraints = {
  785. .name = "V-DISPLAY",
  786. .min_uV = 2800000,
  787. .max_uV = 3300000,
  788. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  789. REGULATOR_CHANGE_STATUS,
  790. .boot_on = 1, /* display is on at boot */
  791. },
  792. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux1_consumers),
  793. .consumer_supplies = ab8500_vaux1_consumers,
  794. },
  795. /* supplies to the on-board eMMC */
  796. [AB8505_LDO_AUX2] = {
  797. .constraints = {
  798. .name = "V-eMMC1",
  799. .min_uV = 1100000,
  800. .max_uV = 3300000,
  801. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  802. REGULATOR_CHANGE_STATUS |
  803. REGULATOR_CHANGE_MODE,
  804. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  805. REGULATOR_MODE_IDLE,
  806. },
  807. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux2_consumers),
  808. .consumer_supplies = ab8500_vaux2_consumers,
  809. },
  810. /* supply for VAUX3, supplies to SDcard slots */
  811. [AB8505_LDO_AUX3] = {
  812. .constraints = {
  813. .name = "V-MMC-SD",
  814. .min_uV = 1100000,
  815. .max_uV = 3300000,
  816. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  817. REGULATOR_CHANGE_STATUS |
  818. REGULATOR_CHANGE_MODE,
  819. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  820. REGULATOR_MODE_IDLE,
  821. },
  822. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux3_consumers),
  823. .consumer_supplies = ab8500_vaux3_consumers,
  824. },
  825. /* supply for VAUX4, supplies to NFC and standalone secure element */
  826. [AB8505_LDO_AUX4] = {
  827. .constraints = {
  828. .name = "V-NFC-SE",
  829. .min_uV = 1100000,
  830. .max_uV = 3300000,
  831. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  832. REGULATOR_CHANGE_STATUS |
  833. REGULATOR_CHANGE_MODE,
  834. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  835. REGULATOR_MODE_IDLE,
  836. },
  837. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux4_consumers),
  838. .consumer_supplies = ab8505_vaux4_consumers,
  839. },
  840. /* supply for VAUX5, supplies to TBD */
  841. [AB8505_LDO_AUX5] = {
  842. .constraints = {
  843. .name = "V-AUX5",
  844. .min_uV = 1050000,
  845. .max_uV = 2790000,
  846. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  847. REGULATOR_CHANGE_STATUS |
  848. REGULATOR_CHANGE_MODE,
  849. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  850. REGULATOR_MODE_IDLE,
  851. },
  852. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux5_consumers),
  853. .consumer_supplies = ab8505_vaux5_consumers,
  854. },
  855. /* supply for VAUX6, supplies to TBD */
  856. [AB8505_LDO_AUX6] = {
  857. .constraints = {
  858. .name = "V-AUX6",
  859. .min_uV = 1050000,
  860. .max_uV = 2790000,
  861. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  862. REGULATOR_CHANGE_STATUS |
  863. REGULATOR_CHANGE_MODE,
  864. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  865. REGULATOR_MODE_IDLE,
  866. },
  867. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux6_consumers),
  868. .consumer_supplies = ab8505_vaux6_consumers,
  869. },
  870. /* supply for gpadc, ADC LDO */
  871. [AB8505_LDO_ADC] = {
  872. .constraints = {
  873. .name = "V-ADC",
  874. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  875. },
  876. .num_consumer_supplies = ARRAY_SIZE(ab8505_vadc_consumers),
  877. .consumer_supplies = ab8505_vadc_consumers,
  878. },
  879. /* supply for ab8500-vaudio, VAUDIO LDO */
  880. [AB8505_LDO_AUDIO] = {
  881. .constraints = {
  882. .name = "V-AUD",
  883. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  884. },
  885. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaud_consumers),
  886. .consumer_supplies = ab8500_vaud_consumers,
  887. },
  888. /* supply for v-anamic1 VAMic1-LDO */
  889. [AB8505_LDO_ANAMIC1] = {
  890. .constraints = {
  891. .name = "V-AMIC1",
  892. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  893. REGULATOR_CHANGE_MODE,
  894. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  895. REGULATOR_MODE_IDLE,
  896. },
  897. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic1_consumers),
  898. .consumer_supplies = ab8500_vamic1_consumers,
  899. },
  900. /* supply for v-amic2, VAMIC2 LDO, reuse constants for AMIC1 */
  901. [AB8505_LDO_ANAMIC2] = {
  902. .constraints = {
  903. .name = "V-AMIC2",
  904. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  905. REGULATOR_CHANGE_MODE,
  906. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  907. REGULATOR_MODE_IDLE,
  908. },
  909. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic2_consumers),
  910. .consumer_supplies = ab8500_vamic2_consumers,
  911. },
  912. /* supply for v-aux8, VAUX8 LDO */
  913. [AB8505_LDO_AUX8] = {
  914. .constraints = {
  915. .name = "V-AUX8",
  916. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  917. },
  918. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux8_consumers),
  919. .consumer_supplies = ab8505_vaux8_consumers,
  920. },
  921. /* supply for v-intcore12, VINTCORE12 LDO */
  922. [AB8505_LDO_INTCORE] = {
  923. .constraints = {
  924. .name = "V-INTCORE",
  925. .min_uV = 1250000,
  926. .max_uV = 1350000,
  927. .input_uV = 1800000,
  928. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  929. REGULATOR_CHANGE_STATUS |
  930. REGULATOR_CHANGE_MODE |
  931. REGULATOR_CHANGE_DRMS,
  932. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  933. REGULATOR_MODE_IDLE,
  934. },
  935. .num_consumer_supplies = ARRAY_SIZE(ab8500_vintcore_consumers),
  936. .consumer_supplies = ab8500_vintcore_consumers,
  937. },
  938. /* supply for LDO USB */
  939. [AB8505_LDO_USB] = {
  940. .constraints = {
  941. .name = "V-USB",
  942. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  943. REGULATOR_CHANGE_MODE,
  944. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  945. REGULATOR_MODE_IDLE,
  946. },
  947. .num_consumer_supplies = ARRAY_SIZE(ab8505_usb_consumers),
  948. .consumer_supplies = ab8505_usb_consumers,
  949. },
  950. /* supply for U8500 CSI-DSI, VANA LDO */
  951. [AB8505_LDO_ANA] = {
  952. .constraints = {
  953. .name = "V-CSI-DSI",
  954. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  955. },
  956. .num_consumer_supplies = ARRAY_SIZE(ab8500_vana_consumers),
  957. .consumer_supplies = ab8500_vana_consumers,
  958. },
  959. };
  960. struct ab8500_regulator_platform_data ab8500_regulator_plat_data = {
  961. .reg_init = ab8500_reg_init,
  962. .num_reg_init = ARRAY_SIZE(ab8500_reg_init),
  963. .regulator = ab8500_regulators,
  964. .num_regulator = ARRAY_SIZE(ab8500_regulators),
  965. .ext_regulator = ab8500_ext_regulators,
  966. .num_ext_regulator = ARRAY_SIZE(ab8500_ext_regulators),
  967. };
  968. /* Use the AB8500 init settings for AB8505 as they are the same right now */
  969. struct ab8500_regulator_platform_data ab8505_regulator_plat_data = {
  970. .reg_init = ab8505_reg_init,
  971. .num_reg_init = ARRAY_SIZE(ab8505_reg_init),
  972. .regulator = ab8505_regulators,
  973. .num_regulator = ARRAY_SIZE(ab8505_regulators),
  974. };
  975. static void ab8500_modify_reg_init(int id, u8 mask, u8 value)
  976. {
  977. int i;
  978. if (cpu_is_u8520()) {
  979. for (i = ARRAY_SIZE(ab8505_reg_init) - 1; i >= 0; i--) {
  980. if (ab8505_reg_init[i].id == id) {
  981. u8 initval = ab8505_reg_init[i].value;
  982. initval = (initval & ~mask) | (value & mask);
  983. ab8505_reg_init[i].value = initval;
  984. BUG_ON(mask & ~ab8505_reg_init[i].mask);
  985. return;
  986. }
  987. }
  988. } else {
  989. for (i = ARRAY_SIZE(ab8500_reg_init) - 1; i >= 0; i--) {
  990. if (ab8500_reg_init[i].id == id) {
  991. u8 initval = ab8500_reg_init[i].value;
  992. initval = (initval & ~mask) | (value & mask);
  993. ab8500_reg_init[i].value = initval;
  994. BUG_ON(mask & ~ab8500_reg_init[i].mask);
  995. return;
  996. }
  997. }
  998. }
  999. BUG_ON(1);
  1000. }
  1001. void mop500_regulator_init(void)
  1002. {
  1003. struct regulator_init_data *regulator;
  1004. /*
  1005. * Temporarily turn on Vaux2 on 8520 machine
  1006. */
  1007. if (cpu_is_u8520()) {
  1008. /* Vaux2 initialized to be on */
  1009. ab8500_modify_reg_init(AB8505_VAUX12REGU, 0x0f, 0x05);
  1010. }
  1011. /*
  1012. * Handle AB8500_EXT_SUPPLY2 on HREFP_V20_V50 boards (do it for
  1013. * all HREFP_V20 boards)
  1014. */
  1015. if (cpu_is_u8500v20()) {
  1016. /* VextSupply2RequestCtrl = HP/OFF depending on VxRequest */
  1017. ab8500_modify_reg_init(AB8500_REGUREQUESTCTRL3, 0x01, 0x01);
  1018. /* VextSupply2SysClkReq1HPValid = SysClkReq1 controlled */
  1019. ab8500_modify_reg_init(AB8500_REGUSYSCLKREQ1HPVALID2,
  1020. 0x20, 0x20);
  1021. /* VextSupply2 = force HP at initialization */
  1022. ab8500_modify_reg_init(AB8500_EXTSUPPLYREGU, 0x0c, 0x04);
  1023. /* enable VextSupply2 during platform active */
  1024. regulator = &ab8500_ext_regulators[AB8500_EXT_SUPPLY2];
  1025. regulator->constraints.always_on = 1;
  1026. /* disable VextSupply2 in suspend */
  1027. regulator = &ab8500_ext_regulators[AB8500_EXT_SUPPLY2];
  1028. regulator->constraints.state_mem.disabled = 1;
  1029. regulator->constraints.state_standby.disabled = 1;
  1030. /* enable VextSupply2 HW control (used in suspend) */
  1031. regulator->driver_data = (void *)&ab8500_ext_supply2;
  1032. }
  1033. }