blob: 10aff70f9eab2ae5f46242715a495afbf95b228d [file] [log] [blame]
Mahesh Sivasubramaniand9827c02014-01-23 12:46:22 -07001/* Copyright (c) 2013-2014 The Linux Foundation. All rights reserved.
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -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
Stepan Moskovchenko7d8cdcaa2013-04-25 17:10:55 -070013&soc {
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070014 qcom,spm@f9089000 {
15 compatible = "qcom,spm-v2";
16 #address-cells = <1>;
17 #size-cells = <1>;
18 reg = <0xf9089000 0x1000>;
19 qcom,core-id = <0>;
20 qcom,saw2-ver-reg = <0xfd0>;
Priyanka Mathurb9c8e532013-06-20 14:22:30 -070021 qcom,saw2-cfg = <0x00>;
Priyanka Mathur03048552013-02-11 18:15:13 -080022 qcom,saw2-spm-dly= <0x3c102800>;
Priyanka Mathur37ec54a2013-07-02 16:49:04 -070023 qcom,saw2-spm-ctl = <0x8>;
Priyanka Mathur03048552013-02-11 18:15:13 -080024 qcom,saw2-spm-cmd-wfi = [60 03 60 0b 0f];
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070025 qcom,saw2-spm-cmd-spc = [20 10 80 30 90 5b 60 03 60 3b 76 76
26 0b 94 5b 80 10 26 30 0f];
Murali Nalajala4e614732013-08-07 18:25:34 +053027 qcom,saw2-spm-cmd-pc = [20 10 80 30 90 5b 60 03 60 3b 76 76
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070028 0b 94 5b 80 10 26 30 0f];
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070029 };
30
31 qcom,spm@f9099000 {
32 compatible = "qcom,spm-v2";
33 #address-cells = <1>;
34 #size-cells = <1>;
35 reg = <0xf9099000 0x1000>;
36 qcom,core-id = <1>;
37 qcom,saw2-ver-reg = <0xfd0>;
Priyanka Mathurb9c8e532013-06-20 14:22:30 -070038 qcom,saw2-cfg = <0x00>;
Priyanka Mathur03048552013-02-11 18:15:13 -080039 qcom,saw2-spm-dly= <0x3c102800>;
Priyanka Mathur37ec54a2013-07-02 16:49:04 -070040 qcom,saw2-spm-ctl = <0x8>;
Priyanka Mathur03048552013-02-11 18:15:13 -080041 qcom,saw2-spm-cmd-wfi = [60 03 60 0b 0f];
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070042 qcom,saw2-spm-cmd-spc = [20 10 80 30 90 5b 60 03 60 3b 76 76
43 0b 94 5b 80 10 26 30 0f];
Murali Nalajala4e614732013-08-07 18:25:34 +053044 qcom,saw2-spm-cmd-pc = [20 10 80 30 90 5b 60 03 60 3b 76 76
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070045 0b 94 5b 80 10 26 30 0f];
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070046 };
47
48 qcom,spm@f90a9000 {
49 compatible = "qcom,spm-v2";
50 #address-cells = <1>;
51 #size-cells = <1>;
52 reg = <0xf90a9000 0x1000>;
53 qcom,core-id = <2>;
54 qcom,saw2-ver-reg = <0xfd0>;
Priyanka Mathurb9c8e532013-06-20 14:22:30 -070055 qcom,saw2-cfg = <0x00>;
Priyanka Mathur03048552013-02-11 18:15:13 -080056 qcom,saw2-spm-dly= <0x3c102800>;
Priyanka Mathur37ec54a2013-07-02 16:49:04 -070057 qcom,saw2-spm-ctl = <0x8>;
Priyanka Mathur3c4d7692013-03-18 11:09:35 -070058 qcom,saw2-spm-cmd-wfi = [60 03 60 0b 0f];
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070059 qcom,saw2-spm-cmd-spc = [20 10 80 30 90 5b 60 03 60 3b 76 76
60 0b 94 5b 80 10 26 30 0f];
Murali Nalajala4e614732013-08-07 18:25:34 +053061 qcom,saw2-spm-cmd-pc = [20 10 80 30 90 5b 60 03 60 3b 76 76
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070062 0b 94 5b 80 10 26 30 0f];
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070063 };
64
65 qcom,spm@f90b9000 {
66 compatible = "qcom,spm-v2";
67 #address-cells = <1>;
68 #size-cells = <1>;
69 reg = <0xf90b9000 0x1000>;
70 qcom,core-id = <3>;
71 qcom,saw2-ver-reg = <0xfd0>;
Priyanka Mathurb9c8e532013-06-20 14:22:30 -070072 qcom,saw2-cfg = <0x00>;
Priyanka Mathur03048552013-02-11 18:15:13 -080073 qcom,saw2-spm-dly= <0x3c102800>;
Priyanka Mathur37ec54a2013-07-02 16:49:04 -070074 qcom,saw2-spm-ctl = <0x8>;
Priyanka Mathur3c4d7692013-03-18 11:09:35 -070075 qcom,saw2-spm-cmd-wfi = [60 03 60 0b 0f];
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070076 qcom,saw2-spm-cmd-spc = [20 10 80 30 90 5b 60 03 60 3b 76 76
77 0b 94 5b 80 10 26 30 0f];
Murali Nalajala4e614732013-08-07 18:25:34 +053078 qcom,saw2-spm-cmd-pc = [20 10 80 30 90 5b 60 03 60 3b 76 76
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070079 0b 94 5b 80 10 26 30 0f];
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070080 };
81
82 qcom,spm@f9012000 {
83 compatible = "qcom,spm-v2";
84 #address-cells = <1>;
85 #size-cells = <1>;
86 reg = <0xf9012000 0x1000>;
87 qcom,core-id = <0xffff>; /* L2/APCS SAW */
88 qcom,saw2-ver-reg = <0xfd0>;
89 qcom,saw2-cfg = <0x14>;
Priyanka Mathur03048552013-02-11 18:15:13 -080090 qcom,saw2-spm-dly= <0x3c102800>;
Priyanka Mathur4bc42012013-03-14 13:01:14 -070091 qcom,saw2-spm-ctl = <0x0>;
Priyanka Mathur3c4d7692013-03-18 11:09:35 -070092 qcom,saw2-pmic-data0 = <0x02030080>;
93 qcom,saw2-pmic-data1 = <0x00030000>;
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -070094 qcom,vctl-timeout-us = <50>;
95 qcom,vctl-port = <0x0>;
96 qcom,phase-port = <0x1>;
97 qcom,pfm-port = <0x2>;
Priyanka Mathur9c9927f2013-07-02 16:45:30 -070098 qcom,saw2-spm-cmd-ret = [00 03 00 0f];
Priyanka Mathur3c4d7692013-03-18 11:09:35 -070099 qcom,saw2-spm-cmd-pc = [00 32 b0 10 e0 d0 6b c0 42 f0
Priyanka Mathur9c9927f2013-07-02 16:45:30 -0700100 11 07 01 b0 50 4e 02 02 c0 d0 12 e0 6b 02 32
101 50 f0 0f]; /*APCS_PMIC_OFF_L2RAM_OFF*/
Murali Nalajalacd7b28f2013-10-10 11:15:26 +0530102 qcom,saw2-spm-cmd-pc-no-rpm = [00 32 b0 10 e0 d0 6b c0 42 f0
103 11 03 01 b0 50 4e 02 02 c0 d0 12 e0 6b 02 32
104 50 f0 0f]; /*APCS_PMIC_OFF_L2RAM_OFF*/
Praveen Chidambaram48197dd2013-03-21 15:51:43 -0600105 qcom,L2-spm-is-apcs-master;
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700106 };
107
Mahesh Sivasubramaniand9827c02014-01-23 12:46:22 -0700108 lpm_levels: qcom,lpm-levels {
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700109 compatible = "qcom,lpm-levels";
Girish Mahadevanc45b4c72013-04-24 14:07:11 -0600110 qcom,default-l2-state = "l2_cache_active";
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700111 #address-cells = <1>;
112 #size-cells = <0>;
113
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600114 qcm,cpu-modes {
115 compatible = "qcom,cpu-modes";
116
117 qcom,cpu-modes@0 {
118 qcom,mode = "wfi";
119 qcom,latency-us = <1>;
120 qcom,ss-power = <530>;
121 qcom,energy-overhead = <52800>;
122 qcom,time-overhead = <100>;
123 };
124
125 qcom,cpu-modes@1 {
126 qcom,mode = "standalone_pc";
127 qcom,latency-us = <500>;
128 qcom,ss-power = <410>;
129 qcom,energy-overhead = <603400>;
130 qcom,time-overhead = <1200>;
131 qcom,use-broadcast-timer;
132 };
133
134 qcom,cpu-modes@2 {
135 qcom,mode = "pc";
136 qcom,latency-us = <550>;
137 qcom,ss-power = <372>;
138 qcom,energy-overhead = <700000>;
139 qcom,time-overhead = <1410>;
140 qcom,use-broadcast-timer;
141 };
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700142 };
143
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600144 qcom,system-modes {
145 compatible = "qcom,system-modes";
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700146
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600147 qcom,system-modes@0 {
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600148 qcom,l2 = "l2_cache_pc_no_rpm";
149 qcom,latency-us = <1000>;
150 qcom,ss-power = <315>;
151 qcom,energy-overhead = <1027150>;
152 qcom,time-overhead = <2400>;
Mahesh Sivasubramanian704ea9c2013-12-13 17:37:15 -0700153 qcom,min-cpu-mode= "standalone_pc";
Mahesh Sivasubramanian65c62362013-05-08 14:30:06 -0600154 qcom,sync-cpus;
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600155 };
156
Anil kumar mamidalaa39a3352014-02-06 20:42:01 +0530157 qcom,system-modes@1 {
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600158 qcom,l2 = "l2_cache_pc";
159 qcom,latency-us = <12700>;
160 qcom,ss-power = <315>;
161 qcom,energy-overhead = <1027150>;
162 qcom,time-overhead = <2400>;
Mahesh Sivasubramanian65c62362013-05-08 14:30:06 -0600163 qcom,min-cpu-mode= "pc";
164 qcom,sync-cpus;
Anil kumar mamidalaa39a3352014-02-06 20:42:01 +0530165 qcom,send-rpm-sleep-set;
Mahesh Sivasubramaniandab0ec32013-10-24 15:09:31 -0600166 };
Priyanka Mathur69f3e902013-03-18 17:15:07 -0700167 };
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700168 };
169
170 qcom,pm-boot {
171 compatible = "qcom,pm-boot";
Archana Sathyakumar28441012013-02-01 17:45:38 -0700172 qcom,mode = "tz";
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700173 };
174
175 qcom,mpm@fc4281d0 {
176 compatible = "qcom,mpm-v2";
177 reg = <0xfc4281d0 0x1000>, /* MSM_RPM_MPM_BASE 4K */
178 <0xf9011008 0x4>; /* MSM_APCS_GCC_BASE 4K */
179 reg-names = "vmpm", "ipc";
180 interrupts = <0 171 1>;
181
182 qcom,ipc-bit-offset = <1>;
183
184 qcom,gic-parent = <&intc>;
185 qcom,gic-map = <47 172>, /* usb2_hsic_async_wakeup_irq */
186 <53 104>, /* mdss_irq */
187 <62 222>, /* ee0_krait_hlos_spmi_periph_irq */
Priyanka Mathur6ad1cb62013-04-02 19:21:03 -0700188 <2 216>, /* tsens_upper_lower_int */
Priyanka Mathur1e2f3802013-08-12 12:22:08 -0700189 <0xff 18>, /* APC_qgicQTmrSecPhysIrptReq */
190 <0xff 19>, /* APC_qgicQTmrNonSecPhysIrptReq */
191 <0xff 35>, /* WDT_barkInt */
192 <0xff 40>, /* qtmr_phy_irq[0] */
193 <0xff 47>, /* rbif_irq[0] */
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800194 <0xff 56>, /* q6_wdog_expired_irq */
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700195 <0xff 57>, /* mss_to_apps_irq(0) */
196 <0xff 58>, /* mss_to_apps_irq(1) */
197 <0xff 59>, /* mss_to_apps_irq(2) */
198 <0xff 60>, /* mss_to_apps_irq(3) */
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800199 <0xff 61>, /* mss_a2_bam_irq */
Priyanka Mathur1e2f3802013-08-12 12:22:08 -0700200 <0xff 65>, /* o_gc_sys_irq[0] */
201 <0xff 74>, /* venus0_mmu_cirpt[1] */
202 <0xff 75>, /* venus0_mmu_cirpt[0] */
203 <0xff 78>, /* mdss_mmu_cirpt[0] */
204 <0xff 79>, /* mdss_mmu_cirpt[1] */
205 <0xff 97>, /* camss_vfe_mmu_cirpt[1] */
206 <0xff 102>, /* camss_jpeg_mmu_cirpt[1] */
207 <0xff 109>, /* ocmem_dm_nonsec_irq */
208 <0xff 131>, /* blsp1_qup_5_irq */
209 <0xff 141>, /* blsp1_uart_3_irq */
210 <0xff 155>, /* sdc1_irq(0) */
211 <0xff 157>, /* sdc2_irq(0) */
212 <0xff 161>, /* lpass_irq_out_spare[4] */
213 <0xff 162>, /* lpass_irq_out_spare[5]*/
214 <0xff 170>, /* sdc1_pwr_cmd_irq */
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700215 <0xff 173>, /* o_wcss_apss_smd_hi */
216 <0xff 174>, /* o_wcss_apss_smd_med */
217 <0xff 175>, /* o_wcss_apss_smd_low */
218 <0xff 176>, /* o_wcss_apss_smsm_irq */
219 <0xff 177>, /* o_wcss_apss_wlan_data_xfer_done */
220 <0xff 178>, /* o_wcss_apss_wlan_rx_data_avail */
Venkat Devarasetty4f6edc72013-08-19 15:08:48 +0530221 <0xff 179>, /* o_wcss_apss_asic_intr */
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800222 <0xff 181>, /* o_wcss_apss_wdog_bite_and_reset_rdy */
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700223 <0xff 188>, /* lpass_irq_out_apcs(0) */
224 <0xff 189>, /* lpass_irq_out_apcs(1) */
225 <0xff 190>, /* lpass_irq_out_apcs(2) */
226 <0xff 191>, /* lpass_irq_out_apcs(3) */
227 <0xff 192>, /* lpass_irq_out_apcs(4) */
Priyanka Mathur1e2f3802013-08-12 12:22:08 -0700228 <0xff 194>, /* lpass_irq_out_apcs(6) */
Murali Nalajalaa325c162013-11-27 16:09:04 +0530229 <0xff 195>, /* SLIMbus slimbus_core_ee1_irq */
230 <0xff 196>, /* BAM-Lite - SlimBus */
231 <0xff 198>, /* coresight-tmc-etr interrupt */
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700232 <0xff 200>, /* rpm_ipc(4) */
233 <0xff 201>, /* rpm_ipc(5) */
234 <0xff 202>, /* rpm_ipc(6) */
235 <0xff 203>, /* rpm_ipc(7) */
236 <0xff 204>, /* rpm_ipc(24) */
237 <0xff 205>, /* rpm_ipc(25) */
238 <0xff 206>, /* rpm_ipc(26) */
239 <0xff 207>, /* rpm_ipc(27) */
Priyanka Mathur1e2f3802013-08-12 12:22:08 -0700240 <0xff 234>, /* lpass_irq_out_spare[6]*/
241 <0xff 235>, /* lpass_irq_out_spare[7]*/
242 <0xff 240>, /* summary_irq_kpss */
243 <0xff 253>, /* sdc2_pwr_cmd_irq */
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800244 <0xff 258>, /* rpm_ipc(28) */
245 <0xff 259>, /* rpm_ipc(29) */
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800246 <0xff 269>, /* rpm_wdog_expired_irq */
Priyanka Mathur1e2f3802013-08-12 12:22:08 -0700247 <0xff 270>, /* blsp1_bam_irq[0] */
248 <0xff 275>, /* rpm_ipc(30) */
249 <0xff 276>; /* rpm_ipc(31) */
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700250
251 qcom,gpio-parent = <&msmgpio>;
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800252 qcom,gpio-map = <3 1>,
253 <4 4 >,
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700254 <5 5 >,
255 <6 9 >,
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800256 <7 13>,
257 <8 17>,
258 <9 21>,
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700259 <10 27>,
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800260 <11 29>,
261 <12 31>,
262 <13 33>,
263 <14 35>,
264 <15 37>,
265 <16 38>,
266 <17 39>,
267 <18 41>,
268 <19 46>,
269 <20 48>,
270 <21 49>,
271 <22 50>,
272 <23 51>,
273 <24 52>,
274 <25 54>,
275 <26 62>,
276 <27 63>,
277 <28 64>,
278 <29 65>,
279 <30 66>,
280 <31 67>,
281 <32 68>,
282 <33 69>,
283 <34 71>,
284 <35 72>,
285 <36 106>,
286 <37 107>,
287 <38 108>,
288 <39 109>,
289 <40 110>,
Murali Nalajala99724f42013-09-25 14:46:19 +0530290 <41 115>,
Priyanka Mathur4d074d52013-02-15 12:36:04 -0800291 <54 111>,
292 <55 113>;
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700293 };
294
Priyanka Mathur29b2bd22013-02-22 14:48:09 -0800295 qcom,pm-8x60@fe805664 {
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700296 compatible = "qcom,pm-8x60";
Priyanka Mathur29b2bd22013-02-22 14:48:09 -0800297 reg = <0xfe805664 0x40>;
Archana Sathyakumar2b91dc82013-02-01 17:38:23 -0700298 qcom,pc-mode = "tz_l2_int";
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700299 qcom,use-sync-timer;
Priyanka Mathur6bd02e72013-04-11 17:00:55 -0700300 qcom,pc-resets-timer;
Patrick Daly784c5f62013-07-23 19:33:32 -0700301 qcom,cpus-as-clocks;
302 qcom,synced-clocks;
Mahesh Sivasubramaniand9827c02014-01-23 12:46:22 -0700303 qcom,lpm-levels = <&lpm_levels>;
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700304 };
305
Priyanka Mathurbd7633132013-05-21 17:01:56 -0700306 qcom,cpu-sleep-status@f9088008{
307 compatible = "qcom,cpu-sleep-status";
308 reg = <0xf9088008 0x100>;
309 qcom,cpu-alias-addr = <0x10000>;
310 qcom,sleep-status-mask= <0x80000>;
311 };
312
Priyanka Mathuref0f4fa2013-04-03 12:40:03 -0700313 qcom,rpm-log@fc19dc00 {
314 compatible = "qcom,rpm-log";
315 reg = <0xfc19dc00 0x4000>;
316 qcom,rpm-addr-phys = <0xfc000000>;
317 qcom,offset-version = <4>;
318 qcom,offset-page-buffer-addr = <36>;
319 qcom,offset-log-len = <40>;
320 qcom,offset-log-len-mask = <44>;
321 qcom,offset-page-indices = <56>;
322 };
323
Priyanka Mathur3d1ff532013-04-23 17:38:21 -0700324 qcom,rpm-stats@fc19dba0 {
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700325 compatible = "qcom,rpm-stats";
Priyanka Mathur3d1ff532013-04-23 17:38:21 -0700326 reg = <0xfc19dba0 0x1000>;
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700327 reg-names = "phys_addr_base";
328 qcom,sleep-stats-version = <2>;
329 };
Girish Mahadevan947b8032013-05-20 12:11:27 -0600330
331 qcom,rpm-rbcpr-stats@fc000000 {
332 compatible = "qcom,rpmrbcpr-stats";
333 reg = <0xfc000000 0x1a0000>;
334 qcom,start-offset = <0x190010>;
335 };
Murali Nalajalad30e7be2013-08-01 15:56:15 +0530336
337 qcom,rpm-master-stats@fc428150 {
338 compatible = "qcom,rpm-master-stats";
339 reg = <0xfc428150 0x3200>;
340 qcom,masters = "APSS", "MPSS", "LPSS", "PRONTO";
341 qcom,master-stats-version = <2>;
342 qcom,master-offset = <2560>;
343 };
Praveen Chidambaramc8af25e2012-12-19 11:27:36 -0700344};