board-mop500-regulators.c 31 KB

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