blob: a90f0534f7bf191102279b515bf338b777dcedba [file] [log] [blame]
Syed Rameez Mustafa3971c142013-01-09 19:04:53 -08001/* Copyright (c) 2012-2013, The Linux Foundation. All rights reserved.
David Collinsc6b34832012-10-24 12:57:57 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
David Collins852ab682013-03-20 17:05:01 -070013/* SPM controlled regulators */
14
15&spmi_bus {
16 qcom,pm8110@1 {
17 pm8110_s2: spm-regulator@1700 {
18 compatible = "qcom,spm-regulator";
19 regulator-name = "8110_s2";
20 reg = <0x1700 0x100>;
21 regulator-min-microvolt = <900000>;
22 regulator-max-microvolt = <1350000>;
23 };
24 };
25};
26
Willie Ruan101c9792013-03-27 17:03:40 -070027/* CPR controlled regulator */
28
Stepan Moskovchenko7d8cdcaa2013-04-25 17:10:55 -070029&soc {
Willie Ruan101c9792013-03-27 17:03:40 -070030 apc_vreg_corner: regulator@f9018000 {
31 status = "okay";
32 compatible = "qcom,cpr-regulator";
Willie Ruanb17b7832013-04-08 21:30:27 -070033 reg = <0xf9018000 0x1000>, <0xfc4b80b0 8>, <0xfc4bc450 16>;
34 reg-names = "rbcpr", "pvs_efuse", "cpr_efuse";
35 interrupts = <0 15 0>;
Willie Ruan101c9792013-03-27 17:03:40 -070036 regulator-name = "apc_corner";
37 regulator-min-microvolt = <1>;
Willie Ruanb17b7832013-04-08 21:30:27 -070038 regulator-max-microvolt = <3>;
Willie Ruan101c9792013-03-27 17:03:40 -070039 qcom,num-efuse-bits = <5>;
Willie Ruanb17b7832013-04-08 21:30:27 -070040 qcom,pvs-bin-process = <0 0 0 0 0 1 1 1 1 1 2 2 2 2 2 2
Willie Ruan101c9792013-03-27 17:03:40 -070041 2 2 2 2 3 3 3 3 3 3 3 3 0 0 0 0>;
Willie Ruanb17b7832013-04-08 21:30:27 -070042 qcom,pvs-corner-ceiling-slow = <1150000 1150000 1275000>;
43 qcom,pvs-corner-ceiling-nom = <975000 1075000 1200000>;
44 qcom,pvs-corner-ceiling-fast = <900000 1000000 1140000>;
Willie Ruan101c9792013-03-27 17:03:40 -070045 vdd-apc-supply = <&pm8110_s2>;
Willie Ruanb17b7832013-04-08 21:30:27 -070046
Willie Ruan97d63022013-04-11 09:30:07 -070047 vdd-mx-supply = <&pm8110_l3_ao>;
48 qcom,vdd-mx-vmax = <1350000>;
49 qcom,vdd-mx-vmin-method = <1>;
Willie Ruanb17b7832013-04-08 21:30:27 -070050
51 qcom,cpr-ref-clk = <19200>;
52 qcom,cpr-timer-delay = <5000>;
53 qcom,cpr-timer-cons-up = <1>;
54 qcom,cpr-timer-cons-down = <2>;
55 qcom,cpr-irq-line = <0>;
56 qcom,cpr-step-quotient = <15>;
57 qcom,cpr-up-threshold = <1>;
58 qcom,cpr-down-threshold = <2>;
59 qcom,cpr-idle-clocks = <5>;
60 qcom,cpr-gcnt-time = <1>;
61 qcom,vdd-apc-step-up-limit = <1>;
62 qcom,vdd-apc-step-down-limit = <1>;
63 qcom,cpr-apc-volt-step = <5000>;
Willie Ruan101c9792013-03-27 17:03:40 -070064 };
65};
66
Xiaozhe Shi350baa92013-04-09 18:13:50 -070067/* RPM controlled regulators: */
David Collinsc6b34832012-10-24 12:57:57 -070068
Xiaozhe Shi350baa92013-04-09 18:13:50 -070069&rpm_bus {
David Collinsc6b34832012-10-24 12:57:57 -070070
Xiaozhe Shi350baa92013-04-09 18:13:50 -070071 rpm-regulator-smpa1 {
72 status = "okay";
73 pm8110_s1: regulator-s1 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -080074 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -070075 regulator-min-microvolt = <500000>;
76 regulator-max-microvolt = <1275000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -080077 };
David Collinsc6b34832012-10-24 12:57:57 -070078
Xiaozhe Shi350baa92013-04-09 18:13:50 -070079 pm8110_s1_corner: regulator-s1-corner {
80 compatible = "qcom,rpm-regulator-smd";
81 regulator-name = "8110_s1_corner";
82 qcom,set = <3>;
83 regulator-min-microvolt = <1>;
84 regulator-max-microvolt = <7>;
85 qcom,use-voltage-corner;
Patrick Daly4c4452a2013-04-29 12:25:05 -070086 qcom,consumer-supplies = "vdd_dig", "";
Xiaozhe Shi350baa92013-04-09 18:13:50 -070087 };
88
89 pm8110_s1_corner_ao: regulator-s1-corner-ao {
90 compatible = "qcom,rpm-regulator-smd";
91 regulator-name = "8110_s1_corner_ao";
92 qcom,set = <1>;
93 regulator-min-microvolt = <1>;
94 regulator-max-microvolt = <7>;
95 qcom,use-voltage-corner;
Patrick Daly4c4452a2013-04-29 12:25:05 -070096 qcom,consumer-supplies = "vdd_sr2_dig", "";
Xiaozhe Shi350baa92013-04-09 18:13:50 -070097 };
98 };
99
100 rpm-regulator-smpa3 {
101 status = "okay";
102 pm8110_s3: regulator-s3 {
103 regulator-min-microvolt = <1200000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800104 regulator-max-microvolt = <1350000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700105 qcom,init-voltage = <1200000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800106 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700107 };
108 };
109
110 rpm-regulator-smpa4 {
111 status = "okay";
112 pm8110_s4: regulator-s4 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800113 regulator-min-microvolt = <2150000>;
114 regulator-max-microvolt = <2150000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700115 qcom,init-voltage = <2150000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800116 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700117 };
118 };
119
120 rpm-regulator-ldoa1 {
121 status = "okay";
122 pm8110_l1: regulator-l1 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800123 regulator-min-microvolt = <1225000>;
124 regulator-max-microvolt = <1225000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700125 qcom,init-voltage = <1225000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800126 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700127 };
128 };
129
130 rpm-regulator-ldoa2 {
131 status = "okay";
132 pm8110_l2: regulator-l2 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800133 regulator-min-microvolt = <1200000>;
134 regulator-max-microvolt = <1200000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700135 qcom,init-voltage = <1200000>;
136 status = "okay";
137 };
138 };
139
140 rpm-regulator-ldoa3 {
141 status = "okay";
142 pm8110_l3: regulator-l3 {
143 regulator-min-microvolt = <750000>;
144 regulator-max-microvolt = <1275000>;
145 status = "okay";
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800146 };
David Collinsc6b34832012-10-24 12:57:57 -0700147
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700148 pm8110_l3_ao: regulator-l3-ao {
149 compatible = "qcom,rpm-regulator-smd";
150 regulator-name = "8110_l3_ao";
151 qcom,set = <1>;
152 regulator-min-microvolt = <750000>;
153 regulator-max-microvolt = <1275000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800154 status = "okay";
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800155 };
David Collinsc6b34832012-10-24 12:57:57 -0700156
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700157 pm8110_l3_so: regulator-l3-so {
158 compatible = "qcom,rpm-regulator-smd";
159 regulator-name = "8110_l3_so";
160 qcom,set = <2>;
161 regulator-min-microvolt = <750000>;
162 regulator-max-microvolt = <1275000>;
163 qcom,init-voltage = <750000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800164 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700165 };
166 };
167
168 rpm-regulator-ldoa4 {
169 status = "okay";
170 pm8110_l4: regulator-l4 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800171 regulator-min-microvolt = <1200000>;
172 regulator-max-microvolt = <1200000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700173 qcom,init-voltage = <1200000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800174 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700175 };
176 };
177
178 rpm-regulator-ldoa5 {
179 status = "okay";
180 pm8110_l5: regulator-l5 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800181 regulator-min-microvolt = <1300000>;
182 regulator-max-microvolt = <1300000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700183 qcom,init-voltage = <1300000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800184 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700185 };
186 };
187
188 rpm-regulator-ldoa6 {
189 status = "okay";
190 pm8110_l6: regulator-l6 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800191 regulator-min-microvolt = <1800000>;
192 regulator-max-microvolt = <1800000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700193 qcom,init-voltage = <1800000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800194 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700195 };
196 };
197
198 rpm-regulator-ldoa7 {
199 status = "okay";
200 pm8110_l7: regulator-l7 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800201 regulator-min-microvolt = <2050000>;
202 regulator-max-microvolt = <2050000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700203 qcom,init-voltage = <2050000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800204 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700205 };
206 };
207
208 rpm-regulator-ldoa8 {
209 status = "okay";
210 pm8110_l8: regulator-l8 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800211 regulator-min-microvolt = <1800000>;
212 regulator-max-microvolt = <1800000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700213 qcom,init-voltage = <1800000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800214 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700215 };
216 };
217
218 rpm-regulator-ldoa9 {
219 status = "okay";
220 pm8110_l9: regulator-l9 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800221 regulator-min-microvolt = <2050000>;
222 regulator-max-microvolt = <2050000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700223 qcom,init-voltage = <2050000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800224 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700225 };
226 };
227
228 rpm-regulator-ldoa10 {
229 status = "okay";
230 pm8110_l10: regulator-l10 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800231 regulator-min-microvolt = <1800000>;
232 regulator-max-microvolt = <1800000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700233 qcom,init-voltage = <1800000>;
234 status = "okay";
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800235 qcom,consumer-supplies = "vdd_sr2_pll", "";
236 };
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700237 };
David Collinsc6b34832012-10-24 12:57:57 -0700238
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700239 rpm-regulator-ldoa12 {
240 status = "okay";
241 pm8110_l12: regulator-l12 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800242 regulator-min-microvolt = <1800000>;
243 regulator-max-microvolt = <3300000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700244 qcom,init-voltage = <3300000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800245 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700246 };
247 };
248
249 rpm-regulator-ldoa14 {
250 status = "okay";
251 pm8110_l14: regulator-l14 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800252 regulator-min-microvolt = <1800000>;
253 regulator-max-microvolt = <1800000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700254 qcom,init-voltage = <1800000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800255 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700256 };
257 };
258
259 rpm-regulator-ldoa15 {
260 status = "okay";
261 pm8110_l15: regulator-l15 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800262 regulator-min-microvolt = <1800000>;
263 regulator-max-microvolt = <3300000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700264 qcom,init-voltage = <3300000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800265 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700266 };
267 };
268
269 rpm-regulator-ldoa16 {
270 status = "okay";
271 pm8110_l16: regulator-l16 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800272 regulator-min-microvolt = <3000000>;
273 regulator-max-microvolt = <3000000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700274 qcom,init-voltage = <3000000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800275 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700276 };
277 };
278
279 rpm-regulator-ldoa17 {
280 status = "okay";
281 pm8110_l17: regulator-l17 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800282 regulator-min-microvolt = <2900000>;
283 regulator-max-microvolt = <2900000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700284 qcom,init-voltage = <2900000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800285 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700286 };
287 };
288
289 rpm-regulator-ldoa18 {
290 status = "okay";
291 pm8110_l18: regulator-l18 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800292 regulator-min-microvolt = <1800000>;
293 regulator-max-microvolt = <2950000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700294 qcom,init-voltage = <2950000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800295 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700296 };
297 };
298
299 rpm-regulator-ldoa19 {
300 status = "okay";
301 pm8110_l19: regulator-l19 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800302 regulator-min-microvolt = <2850000>;
303 regulator-max-microvolt = <2850000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700304 qcom,init-voltage = <2850000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800305 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700306 };
307 };
308
309 rpm-regulator-ldoa20 {
310 status = "okay";
311 pm8110_l20: regulator-l20 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800312 regulator-min-microvolt = <3075000>;
313 regulator-max-microvolt = <3075000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700314 qcom,init-voltage = <3075000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800315 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700316 };
317 };
318
319 rpm-regulator-ldoa21 {
320 status = "okay";
321 pm8110_l21: regulator-l21 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800322 regulator-min-microvolt = <1800000>;
323 regulator-max-microvolt = <2950000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700324 qcom,init-voltage = <2950000>;
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800325 status = "okay";
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700326 };
327 };
328
329 rpm-regulator-ldoa22 {
330 status = "okay";
331 pm8110_l22: regulator-l22 {
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800332 regulator-min-microvolt = <1800000>;
333 regulator-max-microvolt = <3300000>;
Xiaozhe Shi350baa92013-04-09 18:13:50 -0700334 qcom,init-voltage = <3300000>;
335 status = "okay";
Xiaozhe Shi1581a7b2013-02-21 15:17:57 -0800336 };
David Collinsc6b34832012-10-24 12:57:57 -0700337 };
338};