board-mop500-regulators.c 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079
  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. .supply_regulator = "ab8500-ext-supply3",
  354. .constraints = {
  355. .name = "V-DISPLAY",
  356. .min_uV = 2800000,
  357. .max_uV = 3300000,
  358. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  359. REGULATOR_CHANGE_STATUS,
  360. .boot_on = 1, /* display is on at boot */
  361. },
  362. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux1_consumers),
  363. .consumer_supplies = ab8500_vaux1_consumers,
  364. },
  365. /* supplies to the on-board eMMC */
  366. [AB8500_LDO_AUX2] = {
  367. .supply_regulator = "ab8500-ext-supply3",
  368. .constraints = {
  369. .name = "V-eMMC1",
  370. .min_uV = 1100000,
  371. .max_uV = 3300000,
  372. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  373. REGULATOR_CHANGE_STATUS |
  374. REGULATOR_CHANGE_MODE,
  375. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  376. REGULATOR_MODE_IDLE,
  377. },
  378. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux2_consumers),
  379. .consumer_supplies = ab8500_vaux2_consumers,
  380. },
  381. /* supply for VAUX3, supplies to SDcard slots */
  382. [AB8500_LDO_AUX3] = {
  383. .supply_regulator = "ab8500-ext-supply3",
  384. .constraints = {
  385. .name = "V-MMC-SD",
  386. .min_uV = 1100000,
  387. .max_uV = 3300000,
  388. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  389. REGULATOR_CHANGE_STATUS |
  390. REGULATOR_CHANGE_MODE,
  391. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  392. REGULATOR_MODE_IDLE,
  393. },
  394. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux3_consumers),
  395. .consumer_supplies = ab8500_vaux3_consumers,
  396. },
  397. /* supply for tvout, gpadc, TVOUT LDO */
  398. [AB8500_LDO_TVOUT] = {
  399. .constraints = {
  400. .name = "V-TVOUT",
  401. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  402. },
  403. .num_consumer_supplies = ARRAY_SIZE(ab8500_vtvout_consumers),
  404. .consumer_supplies = ab8500_vtvout_consumers,
  405. },
  406. /* supply for ab8500-vaudio, VAUDIO LDO */
  407. [AB8500_LDO_AUDIO] = {
  408. .constraints = {
  409. .name = "V-AUD",
  410. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  411. },
  412. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaud_consumers),
  413. .consumer_supplies = ab8500_vaud_consumers,
  414. },
  415. /* supply for v-anamic1 VAMic1-LDO */
  416. [AB8500_LDO_ANAMIC1] = {
  417. .constraints = {
  418. .name = "V-AMIC1",
  419. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  420. },
  421. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic1_consumers),
  422. .consumer_supplies = ab8500_vamic1_consumers,
  423. },
  424. /* supply for v-amic2, VAMIC2 LDO, reuse constants for AMIC1 */
  425. [AB8500_LDO_ANAMIC2] = {
  426. .constraints = {
  427. .name = "V-AMIC2",
  428. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  429. },
  430. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic2_consumers),
  431. .consumer_supplies = ab8500_vamic2_consumers,
  432. },
  433. /* supply for v-dmic, VDMIC LDO */
  434. [AB8500_LDO_DMIC] = {
  435. .constraints = {
  436. .name = "V-DMIC",
  437. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  438. },
  439. .num_consumer_supplies = ARRAY_SIZE(ab8500_vdmic_consumers),
  440. .consumer_supplies = ab8500_vdmic_consumers,
  441. },
  442. /* supply for v-intcore12, VINTCORE12 LDO */
  443. [AB8500_LDO_INTCORE] = {
  444. .constraints = {
  445. .name = "V-INTCORE",
  446. .min_uV = 1250000,
  447. .max_uV = 1350000,
  448. .input_uV = 1800000,
  449. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  450. REGULATOR_CHANGE_STATUS |
  451. REGULATOR_CHANGE_MODE |
  452. REGULATOR_CHANGE_DRMS,
  453. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  454. REGULATOR_MODE_IDLE,
  455. },
  456. .num_consumer_supplies = ARRAY_SIZE(ab8500_vintcore_consumers),
  457. .consumer_supplies = ab8500_vintcore_consumers,
  458. },
  459. /* supply for U8500 CSI-DSI, VANA LDO */
  460. [AB8500_LDO_ANA] = {
  461. .constraints = {
  462. .name = "V-CSI-DSI",
  463. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  464. },
  465. .num_consumer_supplies = ARRAY_SIZE(ab8500_vana_consumers),
  466. .consumer_supplies = ab8500_vana_consumers,
  467. },
  468. };
  469. /* supply for VextSupply3 */
  470. static struct regulator_consumer_supply ab8500_ext_supply3_consumers[] = {
  471. /* SIM supply for 3 V SIM cards */
  472. REGULATOR_SUPPLY("vinvsim", "sim-detect.0"),
  473. };
  474. /* extended configuration for VextSupply2, only used for HREFP_V20 boards */
  475. static struct ab8500_ext_regulator_cfg ab8500_ext_supply2 = {
  476. .hwreq = true,
  477. };
  478. /*
  479. * AB8500 external regulators
  480. */
  481. static struct regulator_init_data ab8500_ext_regulators[] = {
  482. /* fixed Vbat supplies VSMPS1_EXT_1V8 */
  483. [AB8500_EXT_SUPPLY1] = {
  484. .constraints = {
  485. .name = "ab8500-ext-supply1",
  486. .min_uV = 1800000,
  487. .max_uV = 1800000,
  488. .initial_mode = REGULATOR_MODE_IDLE,
  489. .boot_on = 1,
  490. .always_on = 1,
  491. },
  492. },
  493. /* fixed Vbat supplies VSMPS2_EXT_1V36 and VSMPS5_EXT_1V15 */
  494. [AB8500_EXT_SUPPLY2] = {
  495. .constraints = {
  496. .name = "ab8500-ext-supply2",
  497. .min_uV = 1360000,
  498. .max_uV = 1360000,
  499. },
  500. },
  501. /* fixed Vbat supplies VSMPS3_EXT_3V4 and VSMPS4_EXT_3V4 */
  502. [AB8500_EXT_SUPPLY3] = {
  503. .constraints = {
  504. .name = "ab8500-ext-supply3",
  505. .min_uV = 3400000,
  506. .max_uV = 3400000,
  507. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  508. .boot_on = 1,
  509. },
  510. .num_consumer_supplies =
  511. ARRAY_SIZE(ab8500_ext_supply3_consumers),
  512. .consumer_supplies = ab8500_ext_supply3_consumers,
  513. },
  514. };
  515. /* ab8505 regulator register initialization */
  516. static struct ab8500_regulator_reg_init ab8505_reg_init[] = {
  517. /*
  518. * VarmRequestCtrl
  519. * VsmpsCRequestCtrl
  520. * VsmpsARequestCtrl
  521. * VsmpsBRequestCtrl
  522. */
  523. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL1, 0x00, 0x00),
  524. /*
  525. * VsafeRequestCtrl
  526. * VpllRequestCtrl
  527. * VanaRequestCtrl = HP/LP depending on VxRequest
  528. */
  529. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL2, 0x30, 0x00),
  530. /*
  531. * Vaux1RequestCtrl = HP/LP depending on VxRequest
  532. * Vaux2RequestCtrl = HP/LP depending on VxRequest
  533. */
  534. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL3, 0xf0, 0x00),
  535. /*
  536. * Vaux3RequestCtrl = HP/LP depending on VxRequest
  537. * SwHPReq = Control through SWValid disabled
  538. */
  539. INIT_REGULATOR_REGISTER(AB8505_REGUREQUESTCTRL4, 0x07, 0x00),
  540. /*
  541. * VsmpsASysClkReq1HPValid
  542. * VsmpsBSysClkReq1HPValid
  543. * VsafeSysClkReq1HPValid
  544. * VanaSysClkReq1HPValid = disabled
  545. * VpllSysClkReq1HPValid
  546. * Vaux1SysClkReq1HPValid = disabled
  547. * Vaux2SysClkReq1HPValid = disabled
  548. * Vaux3SysClkReq1HPValid = disabled
  549. */
  550. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQ1HPVALID1, 0xe8, 0x00),
  551. /*
  552. * VsmpsCSysClkReq1HPValid
  553. * VarmSysClkReq1HPValid
  554. * VbbSysClkReq1HPValid
  555. * VsmpsMSysClkReq1HPValid
  556. */
  557. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQ1HPVALID2, 0x00, 0x00),
  558. /*
  559. * VsmpsAHwHPReq1Valid
  560. * VsmpsBHwHPReq1Valid
  561. * VsafeHwHPReq1Valid
  562. * VanaHwHPReq1Valid = disabled
  563. * VpllHwHPReq1Valid
  564. * Vaux1HwHPreq1Valid = disabled
  565. * Vaux2HwHPReq1Valid = disabled
  566. * Vaux3HwHPReqValid = disabled
  567. */
  568. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ1VALID1, 0xe8, 0x00),
  569. /*
  570. * VsmpsMHwHPReq1Valid
  571. */
  572. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ1VALID2, 0x00, 0x00),
  573. /*
  574. * VsmpsAHwHPReq2Valid
  575. * VsmpsBHwHPReq2Valid
  576. * VsafeHwHPReq2Valid
  577. * VanaHwHPReq2Valid = disabled
  578. * VpllHwHPReq2Valid
  579. * Vaux1HwHPReq2Valid = disabled
  580. * Vaux2HwHPReq2Valid = disabled
  581. * Vaux3HwHPReq2Valid = disabled
  582. */
  583. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ2VALID1, 0xe8, 0x00),
  584. /*
  585. * VsmpsMHwHPReq2Valid
  586. */
  587. INIT_REGULATOR_REGISTER(AB8505_REGUHWHPREQ2VALID2, 0x00, 0x00),
  588. /**
  589. * VsmpsCSwHPReqValid
  590. * VarmSwHPReqValid
  591. * VsmpsASwHPReqValid
  592. * VsmpsBSwHPReqValid
  593. * VsafeSwHPReqValid
  594. * VanaSwHPReqValid
  595. * VanaSwHPReqValid = disabled
  596. * VpllSwHPReqValid
  597. * Vaux1SwHPReqValid = disabled
  598. */
  599. INIT_REGULATOR_REGISTER(AB8505_REGUSWHPREQVALID1, 0xa0, 0x00),
  600. /*
  601. * Vaux2SwHPReqValid = disabled
  602. * Vaux3SwHPReqValid = disabled
  603. * VsmpsMSwHPReqValid
  604. */
  605. INIT_REGULATOR_REGISTER(AB8505_REGUSWHPREQVALID2, 0x03, 0x00),
  606. /*
  607. * SysClkReq2Valid1 = SysClkReq2 controlled
  608. * SysClkReq3Valid1 = disabled
  609. * SysClkReq4Valid1 = SysClkReq4 controlled
  610. */
  611. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQVALID1, 0x0e, 0x0a),
  612. /*
  613. * SysClkReq2Valid2 = disabled
  614. * SysClkReq3Valid2 = disabled
  615. * SysClkReq4Valid2 = disabled
  616. */
  617. INIT_REGULATOR_REGISTER(AB8505_REGUSYSCLKREQVALID2, 0x0e, 0x00),
  618. /*
  619. * Vaux4SwHPReqValid
  620. * Vaux4HwHPReq2Valid
  621. * Vaux4HwHPReq1Valid
  622. * Vaux4SysClkReq1HPValid
  623. */
  624. INIT_REGULATOR_REGISTER(AB8505_REGUVAUX4REQVALID, 0x00, 0x00),
  625. /*
  626. * VadcEna = disabled
  627. * VintCore12Ena = disabled
  628. * VintCore12Sel = 1.25 V
  629. * VintCore12LP = inactive (HP)
  630. * VadcLP = inactive (HP)
  631. */
  632. INIT_REGULATOR_REGISTER(AB8505_REGUMISC1, 0xfe, 0x10),
  633. /*
  634. * VaudioEna = disabled
  635. * Vaux8Ena = disabled
  636. * Vamic1Ena = disabled
  637. * Vamic2Ena = disabled
  638. */
  639. INIT_REGULATOR_REGISTER(AB8505_VAUDIOSUPPLY, 0x1e, 0x00),
  640. /*
  641. * Vamic1_dzout = high-Z when Vamic1 is disabled
  642. * Vamic2_dzout = high-Z when Vamic2 is disabled
  643. */
  644. INIT_REGULATOR_REGISTER(AB8505_REGUCTRL1VAMIC, 0x03, 0x00),
  645. /*
  646. * VsmpsARegu
  647. * VsmpsASelCtrl
  648. * VsmpsAAutoMode
  649. * VsmpsAPWMMode
  650. */
  651. INIT_REGULATOR_REGISTER(AB8505_VSMPSAREGU, 0x00, 0x00),
  652. /*
  653. * VsmpsBRegu
  654. * VsmpsBSelCtrl
  655. * VsmpsBAutoMode
  656. * VsmpsBPWMMode
  657. */
  658. INIT_REGULATOR_REGISTER(AB8505_VSMPSBREGU, 0x00, 0x00),
  659. /*
  660. * VsafeRegu
  661. * VsafeSelCtrl
  662. * VsafeAutoMode
  663. * VsafePWMMode
  664. */
  665. INIT_REGULATOR_REGISTER(AB8505_VSAFEREGU, 0x00, 0x00),
  666. /*
  667. * VPll = Hw controlled (NOTE! PRCMU bits)
  668. * VanaRegu = force off
  669. */
  670. INIT_REGULATOR_REGISTER(AB8505_VPLLVANAREGU, 0x0f, 0x02),
  671. /*
  672. * VextSupply1Regu = force OFF (OTP_ExtSupply12LPnPolarity 1)
  673. * VextSupply2Regu = force OFF (OTP_ExtSupply12LPnPolarity 1)
  674. * VextSupply3Regu = force OFF (OTP_ExtSupply3LPnPolarity 0)
  675. * ExtSupply2Bypass = ExtSupply12LPn ball is 0 when Ena is 0
  676. * ExtSupply3Bypass = ExtSupply3LPn ball is 0 when Ena is 0
  677. */
  678. INIT_REGULATOR_REGISTER(AB8505_EXTSUPPLYREGU, 0xff, 0x30),
  679. /*
  680. * Vaux1Regu = force HP
  681. * Vaux2Regu = force off
  682. */
  683. INIT_REGULATOR_REGISTER(AB8505_VAUX12REGU, 0x0f, 0x01),
  684. /*
  685. * Vaux3Regu = force off
  686. */
  687. INIT_REGULATOR_REGISTER(AB8505_VRF1VAUX3REGU, 0x03, 0x00),
  688. /*
  689. * VsmpsASel1
  690. */
  691. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL1, 0x00, 0x00),
  692. /*
  693. * VsmpsASel2
  694. */
  695. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL2, 0x00, 0x00),
  696. /*
  697. * VsmpsASel3
  698. */
  699. INIT_REGULATOR_REGISTER(AB8505_VSMPSASEL3, 0x00, 0x00),
  700. /*
  701. * VsmpsBSel1
  702. */
  703. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL1, 0x00, 0x00),
  704. /*
  705. * VsmpsBSel2
  706. */
  707. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL2, 0x00, 0x00),
  708. /*
  709. * VsmpsBSel3
  710. */
  711. INIT_REGULATOR_REGISTER(AB8505_VSMPSBSEL3, 0x00, 0x00),
  712. /*
  713. * VsafeSel1
  714. */
  715. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL1, 0x00, 0x00),
  716. /*
  717. * VsafeSel2
  718. */
  719. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL2, 0x00, 0x00),
  720. /*
  721. * VsafeSel3
  722. */
  723. INIT_REGULATOR_REGISTER(AB8505_VSAFESEL3, 0x00, 0x00),
  724. /*
  725. * Vaux1Sel = 2.8 V
  726. */
  727. INIT_REGULATOR_REGISTER(AB8505_VAUX1SEL, 0x0f, 0x0C),
  728. /*
  729. * Vaux2Sel = 2.9 V
  730. */
  731. INIT_REGULATOR_REGISTER(AB8505_VAUX2SEL, 0x0f, 0x0d),
  732. /*
  733. * Vaux3Sel = 2.91 V
  734. */
  735. INIT_REGULATOR_REGISTER(AB8505_VRF1VAUX3SEL, 0x07, 0x07),
  736. /*
  737. * Vaux4RequestCtrl
  738. */
  739. INIT_REGULATOR_REGISTER(AB8505_VAUX4REQCTRL, 0x00, 0x00),
  740. /*
  741. * Vaux4Regu
  742. */
  743. INIT_REGULATOR_REGISTER(AB8505_VAUX4REGU, 0x00, 0x00),
  744. /*
  745. * Vaux4Sel
  746. */
  747. INIT_REGULATOR_REGISTER(AB8505_VAUX4SEL, 0x00, 0x00),
  748. /*
  749. * Vaux1Disch = short discharge time
  750. * Vaux2Disch = short discharge time
  751. * Vaux3Disch = short discharge time
  752. * Vintcore12Disch = short discharge time
  753. * VTVoutDisch = short discharge time
  754. * VaudioDisch = short discharge time
  755. */
  756. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH, 0xfc, 0x00),
  757. /*
  758. * VanaDisch = short discharge time
  759. * Vaux8PullDownEna = pulldown disabled when Vaux8 is disabled
  760. * Vaux8Disch = short discharge time
  761. */
  762. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH2, 0x16, 0x00),
  763. /*
  764. * Vaux4Disch = short discharge time
  765. */
  766. INIT_REGULATOR_REGISTER(AB8505_REGUCTRLDISCH3, 0x01, 0x00),
  767. /*
  768. * Vaux5Sel
  769. * Vaux5LP
  770. * Vaux5Ena
  771. * Vaux5Disch
  772. * Vaux5DisSfst
  773. * Vaux5DisPulld
  774. */
  775. INIT_REGULATOR_REGISTER(AB8505_CTRLVAUX5, 0x00, 0x00),
  776. /*
  777. * Vaux6Sel
  778. * Vaux6LP
  779. * Vaux6Ena
  780. * Vaux6DisPulld
  781. */
  782. INIT_REGULATOR_REGISTER(AB8505_CTRLVAUX6, 0x00, 0x00),
  783. };
  784. struct regulator_init_data ab8505_regulators[AB8505_NUM_REGULATORS] = {
  785. /* supplies to the display/camera */
  786. [AB8505_LDO_AUX1] = {
  787. .constraints = {
  788. .name = "V-DISPLAY",
  789. .min_uV = 2800000,
  790. .max_uV = 3300000,
  791. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  792. REGULATOR_CHANGE_STATUS,
  793. .boot_on = 1, /* display is on at boot */
  794. },
  795. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux1_consumers),
  796. .consumer_supplies = ab8500_vaux1_consumers,
  797. },
  798. /* supplies to the on-board eMMC */
  799. [AB8505_LDO_AUX2] = {
  800. .constraints = {
  801. .name = "V-eMMC1",
  802. .min_uV = 1100000,
  803. .max_uV = 3300000,
  804. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  805. REGULATOR_CHANGE_STATUS |
  806. REGULATOR_CHANGE_MODE,
  807. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  808. REGULATOR_MODE_IDLE,
  809. },
  810. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux2_consumers),
  811. .consumer_supplies = ab8500_vaux2_consumers,
  812. },
  813. /* supply for VAUX3, supplies to SDcard slots */
  814. [AB8505_LDO_AUX3] = {
  815. .constraints = {
  816. .name = "V-MMC-SD",
  817. .min_uV = 1100000,
  818. .max_uV = 3300000,
  819. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  820. REGULATOR_CHANGE_STATUS |
  821. REGULATOR_CHANGE_MODE,
  822. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  823. REGULATOR_MODE_IDLE,
  824. },
  825. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaux3_consumers),
  826. .consumer_supplies = ab8500_vaux3_consumers,
  827. },
  828. /* supply for VAUX4, supplies to NFC and standalone secure element */
  829. [AB8505_LDO_AUX4] = {
  830. .constraints = {
  831. .name = "V-NFC-SE",
  832. .min_uV = 1100000,
  833. .max_uV = 3300000,
  834. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  835. REGULATOR_CHANGE_STATUS |
  836. REGULATOR_CHANGE_MODE,
  837. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  838. REGULATOR_MODE_IDLE,
  839. },
  840. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux4_consumers),
  841. .consumer_supplies = ab8505_vaux4_consumers,
  842. },
  843. /* supply for VAUX5, supplies to TBD */
  844. [AB8505_LDO_AUX5] = {
  845. .constraints = {
  846. .name = "V-AUX5",
  847. .min_uV = 1050000,
  848. .max_uV = 2790000,
  849. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  850. REGULATOR_CHANGE_STATUS |
  851. REGULATOR_CHANGE_MODE,
  852. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  853. REGULATOR_MODE_IDLE,
  854. },
  855. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux5_consumers),
  856. .consumer_supplies = ab8505_vaux5_consumers,
  857. },
  858. /* supply for VAUX6, supplies to TBD */
  859. [AB8505_LDO_AUX6] = {
  860. .constraints = {
  861. .name = "V-AUX6",
  862. .min_uV = 1050000,
  863. .max_uV = 2790000,
  864. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  865. REGULATOR_CHANGE_STATUS |
  866. REGULATOR_CHANGE_MODE,
  867. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  868. REGULATOR_MODE_IDLE,
  869. },
  870. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux6_consumers),
  871. .consumer_supplies = ab8505_vaux6_consumers,
  872. },
  873. /* supply for gpadc, ADC LDO */
  874. [AB8505_LDO_ADC] = {
  875. .constraints = {
  876. .name = "V-ADC",
  877. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  878. },
  879. .num_consumer_supplies = ARRAY_SIZE(ab8505_vadc_consumers),
  880. .consumer_supplies = ab8505_vadc_consumers,
  881. },
  882. /* supply for ab8500-vaudio, VAUDIO LDO */
  883. [AB8505_LDO_AUDIO] = {
  884. .constraints = {
  885. .name = "V-AUD",
  886. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  887. },
  888. .num_consumer_supplies = ARRAY_SIZE(ab8500_vaud_consumers),
  889. .consumer_supplies = ab8500_vaud_consumers,
  890. },
  891. /* supply for v-anamic1 VAMic1-LDO */
  892. [AB8505_LDO_ANAMIC1] = {
  893. .constraints = {
  894. .name = "V-AMIC1",
  895. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  896. REGULATOR_CHANGE_MODE,
  897. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  898. REGULATOR_MODE_IDLE,
  899. },
  900. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic1_consumers),
  901. .consumer_supplies = ab8500_vamic1_consumers,
  902. },
  903. /* supply for v-amic2, VAMIC2 LDO, reuse constants for AMIC1 */
  904. [AB8505_LDO_ANAMIC2] = {
  905. .constraints = {
  906. .name = "V-AMIC2",
  907. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  908. REGULATOR_CHANGE_MODE,
  909. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  910. REGULATOR_MODE_IDLE,
  911. },
  912. .num_consumer_supplies = ARRAY_SIZE(ab8500_vamic2_consumers),
  913. .consumer_supplies = ab8500_vamic2_consumers,
  914. },
  915. /* supply for v-aux8, VAUX8 LDO */
  916. [AB8505_LDO_AUX8] = {
  917. .constraints = {
  918. .name = "V-AUX8",
  919. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  920. },
  921. .num_consumer_supplies = ARRAY_SIZE(ab8505_vaux8_consumers),
  922. .consumer_supplies = ab8505_vaux8_consumers,
  923. },
  924. /* supply for v-intcore12, VINTCORE12 LDO */
  925. [AB8505_LDO_INTCORE] = {
  926. .constraints = {
  927. .name = "V-INTCORE",
  928. .min_uV = 1250000,
  929. .max_uV = 1350000,
  930. .input_uV = 1800000,
  931. .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE |
  932. REGULATOR_CHANGE_STATUS |
  933. REGULATOR_CHANGE_MODE |
  934. REGULATOR_CHANGE_DRMS,
  935. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  936. REGULATOR_MODE_IDLE,
  937. },
  938. .num_consumer_supplies = ARRAY_SIZE(ab8500_vintcore_consumers),
  939. .consumer_supplies = ab8500_vintcore_consumers,
  940. },
  941. /* supply for LDO USB */
  942. [AB8505_LDO_USB] = {
  943. .constraints = {
  944. .name = "V-USB",
  945. .valid_ops_mask = REGULATOR_CHANGE_STATUS |
  946. REGULATOR_CHANGE_MODE,
  947. .valid_modes_mask = REGULATOR_MODE_NORMAL |
  948. REGULATOR_MODE_IDLE,
  949. },
  950. .num_consumer_supplies = ARRAY_SIZE(ab8505_usb_consumers),
  951. .consumer_supplies = ab8505_usb_consumers,
  952. },
  953. /* supply for U8500 CSI-DSI, VANA LDO */
  954. [AB8505_LDO_ANA] = {
  955. .constraints = {
  956. .name = "V-CSI-DSI",
  957. .valid_ops_mask = REGULATOR_CHANGE_STATUS,
  958. },
  959. .num_consumer_supplies = ARRAY_SIZE(ab8500_vana_consumers),
  960. .consumer_supplies = ab8500_vana_consumers,
  961. },
  962. };
  963. struct ab8500_regulator_platform_data ab8500_regulator_plat_data = {
  964. .reg_init = ab8500_reg_init,
  965. .num_reg_init = ARRAY_SIZE(ab8500_reg_init),
  966. .regulator = ab8500_regulators,
  967. .num_regulator = ARRAY_SIZE(ab8500_regulators),
  968. .ext_regulator = ab8500_ext_regulators,
  969. .num_ext_regulator = ARRAY_SIZE(ab8500_ext_regulators),
  970. };
  971. struct ab8500_regulator_platform_data ab8505_regulator_plat_data = {
  972. .reg_init = ab8505_reg_init,
  973. .num_reg_init = ARRAY_SIZE(ab8505_reg_init),
  974. .regulator = ab8505_regulators,
  975. .num_regulator = ARRAY_SIZE(ab8505_regulators),
  976. };
  977. static void ab8500_modify_reg_init(int id, u8 mask, u8 value)
  978. {
  979. int i;
  980. if (cpu_is_u8520()) {
  981. for (i = ARRAY_SIZE(ab8505_reg_init) - 1; i >= 0; i--) {
  982. if (ab8505_reg_init[i].id == id) {
  983. u8 initval = ab8505_reg_init[i].value;
  984. initval = (initval & ~mask) | (value & mask);
  985. ab8505_reg_init[i].value = initval;
  986. BUG_ON(mask & ~ab8505_reg_init[i].mask);
  987. return;
  988. }
  989. }
  990. } else {
  991. for (i = ARRAY_SIZE(ab8500_reg_init) - 1; i >= 0; i--) {
  992. if (ab8500_reg_init[i].id == id) {
  993. u8 initval = ab8500_reg_init[i].value;
  994. initval = (initval & ~mask) | (value & mask);
  995. ab8500_reg_init[i].value = initval;
  996. BUG_ON(mask & ~ab8500_reg_init[i].mask);
  997. return;
  998. }
  999. }
  1000. }
  1001. BUG_ON(1);
  1002. }
  1003. void mop500_regulator_init(void)
  1004. {
  1005. struct regulator_init_data *regulator;
  1006. /*
  1007. * Temporarily turn on Vaux2 on 8520 machine
  1008. */
  1009. if (cpu_is_u8520()) {
  1010. /* Vaux2 initialized to be on */
  1011. ab8500_modify_reg_init(AB8505_VAUX12REGU, 0x0f, 0x05);
  1012. }
  1013. /*
  1014. * Handle AB8500_EXT_SUPPLY2 on HREFP_V20_V50 boards (do it for
  1015. * all HREFP_V20 boards)
  1016. */
  1017. if (cpu_is_u8500v20()) {
  1018. /* VextSupply2RequestCtrl = HP/OFF depending on VxRequest */
  1019. ab8500_modify_reg_init(AB8500_REGUREQUESTCTRL3, 0x01, 0x01);
  1020. /* VextSupply2SysClkReq1HPValid = SysClkReq1 controlled */
  1021. ab8500_modify_reg_init(AB8500_REGUSYSCLKREQ1HPVALID2,
  1022. 0x20, 0x20);
  1023. /* VextSupply2 = force HP at initialization */
  1024. ab8500_modify_reg_init(AB8500_EXTSUPPLYREGU, 0x0c, 0x04);
  1025. /* enable VextSupply2 during platform active */
  1026. regulator = &ab8500_ext_regulators[AB8500_EXT_SUPPLY2];
  1027. regulator->constraints.always_on = 1;
  1028. /* disable VextSupply2 in suspend */
  1029. regulator = &ab8500_ext_regulators[AB8500_EXT_SUPPLY2];
  1030. regulator->constraints.state_mem.disabled = 1;
  1031. regulator->constraints.state_standby.disabled = 1;
  1032. /* enable VextSupply2 HW control (used in suspend) */
  1033. regulator->driver_data = (void *)&ab8500_ext_supply2;
  1034. }
  1035. }