]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blob - arch/arm/boot/dts/tegra124.dtsi
Merge tag 'cleanup-for-3.17' of git://git.kernel.org/pub/scm/linux/kernel/git/arm...
[mirror_ubuntu-artful-kernel.git] / arch / arm / boot / dts / tegra124.dtsi
1 #include <dt-bindings/clock/tegra124-car.h>
2 #include <dt-bindings/gpio/tegra-gpio.h>
3 #include <dt-bindings/pinctrl/pinctrl-tegra.h>
4 #include <dt-bindings/interrupt-controller/arm-gic.h>
5
6 #include "skeleton.dtsi"
7
8 / {
9 compatible = "nvidia,tegra124";
10 interrupt-parent = <&gic>;
11 #address-cells = <2>;
12 #size-cells = <2>;
13
14 host1x@0,50000000 {
15 compatible = "nvidia,tegra124-host1x", "simple-bus";
16 reg = <0x0 0x50000000 0x0 0x00034000>;
17 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */
18 <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */
19 clocks = <&tegra_car TEGRA124_CLK_HOST1X>;
20 resets = <&tegra_car 28>;
21 reset-names = "host1x";
22
23 #address-cells = <2>;
24 #size-cells = <2>;
25
26 ranges = <0 0x54000000 0 0x54000000 0 0x01000000>;
27
28 dc@0,54200000 {
29 compatible = "nvidia,tegra124-dc";
30 reg = <0x0 0x54200000 0x0 0x00040000>;
31 interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
32 clocks = <&tegra_car TEGRA124_CLK_DISP1>,
33 <&tegra_car TEGRA124_CLK_PLL_P>;
34 clock-names = "dc", "parent";
35 resets = <&tegra_car 27>;
36 reset-names = "dc";
37
38 nvidia,head = <0>;
39 };
40
41 dc@0,54240000 {
42 compatible = "nvidia,tegra124-dc";
43 reg = <0x0 0x54240000 0x0 0x00040000>;
44 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
45 clocks = <&tegra_car TEGRA124_CLK_DISP2>,
46 <&tegra_car TEGRA124_CLK_PLL_P>;
47 clock-names = "dc", "parent";
48 resets = <&tegra_car 26>;
49 reset-names = "dc";
50
51 nvidia,head = <1>;
52 };
53
54 hdmi@0,54280000 {
55 compatible = "nvidia,tegra124-hdmi";
56 reg = <0x0 0x54280000 0x0 0x00040000>;
57 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
58 clocks = <&tegra_car TEGRA124_CLK_HDMI>,
59 <&tegra_car TEGRA124_CLK_PLL_D2_OUT0>;
60 clock-names = "hdmi", "parent";
61 resets = <&tegra_car 51>;
62 reset-names = "hdmi";
63 status = "disabled";
64 };
65
66 sor@0,54540000 {
67 compatible = "nvidia,tegra124-sor";
68 reg = <0x0 0x54540000 0x0 0x00040000>;
69 interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
70 clocks = <&tegra_car TEGRA124_CLK_SOR0>,
71 <&tegra_car TEGRA124_CLK_PLL_D_OUT0>,
72 <&tegra_car TEGRA124_CLK_PLL_DP>,
73 <&tegra_car TEGRA124_CLK_CLK_M>;
74 clock-names = "sor", "parent", "dp", "safe";
75 resets = <&tegra_car 182>;
76 reset-names = "sor";
77 status = "disabled";
78 };
79
80 dpaux@0,545c0000 {
81 compatible = "nvidia,tegra124-dpaux";
82 reg = <0x0 0x545c0000 0x0 0x00040000>;
83 interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
84 clocks = <&tegra_car TEGRA124_CLK_DPAUX>,
85 <&tegra_car TEGRA124_CLK_PLL_DP>;
86 clock-names = "dpaux", "parent";
87 resets = <&tegra_car 181>;
88 reset-names = "dpaux";
89 status = "disabled";
90 };
91 };
92
93 gic: interrupt-controller@0,50041000 {
94 compatible = "arm,cortex-a15-gic";
95 #interrupt-cells = <3>;
96 interrupt-controller;
97 reg = <0x0 0x50041000 0x0 0x1000>,
98 <0x0 0x50042000 0x0 0x1000>,
99 <0x0 0x50044000 0x0 0x2000>,
100 <0x0 0x50046000 0x0 0x2000>;
101 interrupts = <GIC_PPI 9
102 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
103 };
104
105 timer@0,60005000 {
106 compatible = "nvidia,tegra124-timer", "nvidia,tegra20-timer";
107 reg = <0x0 0x60005000 0x0 0x400>;
108 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
109 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
110 <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
111 <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
112 <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
113 <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
114 clocks = <&tegra_car TEGRA124_CLK_TIMER>;
115 };
116
117 tegra_car: clock@0,60006000 {
118 compatible = "nvidia,tegra124-car";
119 reg = <0x0 0x60006000 0x0 0x1000>;
120 #clock-cells = <1>;
121 #reset-cells = <1>;
122 };
123
124 gpio: gpio@0,6000d000 {
125 compatible = "nvidia,tegra124-gpio", "nvidia,tegra30-gpio";
126 reg = <0x0 0x6000d000 0x0 0x1000>;
127 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
128 <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
129 <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
130 <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
131 <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
132 <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
133 <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
134 <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>;
135 #gpio-cells = <2>;
136 gpio-controller;
137 #interrupt-cells = <2>;
138 interrupt-controller;
139 };
140
141 apbdma: dma@0,60020000 {
142 compatible = "nvidia,tegra124-apbdma", "nvidia,tegra148-apbdma";
143 reg = <0x0 0x60020000 0x0 0x1400>;
144 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
145 <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
146 <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
147 <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
148 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
149 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
150 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
151 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
152 <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
153 <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
154 <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
155 <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
156 <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
157 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
158 <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
159 <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
160 <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
161 <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
162 <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
163 <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
164 <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
165 <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
166 <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
167 <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
168 <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
169 <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
170 <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
171 <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
172 <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
173 <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
174 <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
175 <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
176 clocks = <&tegra_car TEGRA124_CLK_APBDMA>;
177 resets = <&tegra_car 34>;
178 reset-names = "dma";
179 #dma-cells = <1>;
180 };
181
182 apbmisc@0,70000800 {
183 compatible = "nvidia,tegra124-apbmisc", "nvidia,tegra20-apbmisc";
184 reg = <0x0 0x70000800 0x0 0x64>, /* Chip revision */
185 <0x0 0x7000E864 0x0 0x04>; /* Strapping options */
186 };
187
188 pinmux: pinmux@0,70000868 {
189 compatible = "nvidia,tegra124-pinmux";
190 reg = <0x0 0x70000868 0x0 0x164>, /* Pad control registers */
191 <0x0 0x70003000 0x0 0x434>; /* Mux registers */
192 };
193
194 /*
195 * There are two serial driver i.e. 8250 based simple serial
196 * driver and APB DMA based serial driver for higher baudrate
197 * and performace. To enable the 8250 based driver, the compatible
198 * is "nvidia,tegra124-uart", "nvidia,tegra20-uart" and to enable
199 * the APB DMA based serial driver, the comptible is
200 * "nvidia,tegra124-hsuart", "nvidia,tegra30-hsuart".
201 */
202 serial@0,70006000 {
203 compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
204 reg = <0x0 0x70006000 0x0 0x40>;
205 reg-shift = <2>;
206 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
207 clocks = <&tegra_car TEGRA124_CLK_UARTA>;
208 resets = <&tegra_car 6>;
209 reset-names = "serial";
210 dmas = <&apbdma 8>, <&apbdma 8>;
211 dma-names = "rx", "tx";
212 status = "disabled";
213 };
214
215 serial@0,70006040 {
216 compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
217 reg = <0x0 0x70006040 0x0 0x40>;
218 reg-shift = <2>;
219 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
220 clocks = <&tegra_car TEGRA124_CLK_UARTB>;
221 resets = <&tegra_car 7>;
222 reset-names = "serial";
223 dmas = <&apbdma 9>, <&apbdma 9>;
224 dma-names = "rx", "tx";
225 status = "disabled";
226 };
227
228 serial@0,70006200 {
229 compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
230 reg = <0x0 0x70006200 0x0 0x40>;
231 reg-shift = <2>;
232 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
233 clocks = <&tegra_car TEGRA124_CLK_UARTC>;
234 resets = <&tegra_car 55>;
235 reset-names = "serial";
236 dmas = <&apbdma 10>, <&apbdma 10>;
237 dma-names = "rx", "tx";
238 status = "disabled";
239 };
240
241 serial@0,70006300 {
242 compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart";
243 reg = <0x0 0x70006300 0x0 0x40>;
244 reg-shift = <2>;
245 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
246 clocks = <&tegra_car TEGRA124_CLK_UARTD>;
247 resets = <&tegra_car 65>;
248 reset-names = "serial";
249 dmas = <&apbdma 19>, <&apbdma 19>;
250 dma-names = "rx", "tx";
251 status = "disabled";
252 };
253
254 pwm@0,7000a000 {
255 compatible = "nvidia,tegra124-pwm", "nvidia,tegra20-pwm";
256 reg = <0x0 0x7000a000 0x0 0x100>;
257 #pwm-cells = <2>;
258 clocks = <&tegra_car TEGRA124_CLK_PWM>;
259 resets = <&tegra_car 17>;
260 reset-names = "pwm";
261 status = "disabled";
262 };
263
264 i2c@0,7000c000 {
265 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
266 reg = <0x0 0x7000c000 0x0 0x100>;
267 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
268 #address-cells = <1>;
269 #size-cells = <0>;
270 clocks = <&tegra_car TEGRA124_CLK_I2C1>;
271 clock-names = "div-clk";
272 resets = <&tegra_car 12>;
273 reset-names = "i2c";
274 dmas = <&apbdma 21>, <&apbdma 21>;
275 dma-names = "rx", "tx";
276 status = "disabled";
277 };
278
279 i2c@0,7000c400 {
280 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
281 reg = <0x0 0x7000c400 0x0 0x100>;
282 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
283 #address-cells = <1>;
284 #size-cells = <0>;
285 clocks = <&tegra_car TEGRA124_CLK_I2C2>;
286 clock-names = "div-clk";
287 resets = <&tegra_car 54>;
288 reset-names = "i2c";
289 dmas = <&apbdma 22>, <&apbdma 22>;
290 dma-names = "rx", "tx";
291 status = "disabled";
292 };
293
294 i2c@0,7000c500 {
295 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
296 reg = <0x0 0x7000c500 0x0 0x100>;
297 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
298 #address-cells = <1>;
299 #size-cells = <0>;
300 clocks = <&tegra_car TEGRA124_CLK_I2C3>;
301 clock-names = "div-clk";
302 resets = <&tegra_car 67>;
303 reset-names = "i2c";
304 dmas = <&apbdma 23>, <&apbdma 23>;
305 dma-names = "rx", "tx";
306 status = "disabled";
307 };
308
309 i2c@0,7000c700 {
310 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
311 reg = <0x0 0x7000c700 0x0 0x100>;
312 interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
313 #address-cells = <1>;
314 #size-cells = <0>;
315 clocks = <&tegra_car TEGRA124_CLK_I2C4>;
316 clock-names = "div-clk";
317 resets = <&tegra_car 103>;
318 reset-names = "i2c";
319 dmas = <&apbdma 26>, <&apbdma 26>;
320 dma-names = "rx", "tx";
321 status = "disabled";
322 };
323
324 i2c@0,7000d000 {
325 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
326 reg = <0x0 0x7000d000 0x0 0x100>;
327 interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
328 #address-cells = <1>;
329 #size-cells = <0>;
330 clocks = <&tegra_car TEGRA124_CLK_I2C5>;
331 clock-names = "div-clk";
332 resets = <&tegra_car 47>;
333 reset-names = "i2c";
334 dmas = <&apbdma 24>, <&apbdma 24>;
335 dma-names = "rx", "tx";
336 status = "disabled";
337 };
338
339 i2c@0,7000d100 {
340 compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c";
341 reg = <0x0 0x7000d100 0x0 0x100>;
342 interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
343 #address-cells = <1>;
344 #size-cells = <0>;
345 clocks = <&tegra_car TEGRA124_CLK_I2C6>;
346 clock-names = "div-clk";
347 resets = <&tegra_car 166>;
348 reset-names = "i2c";
349 dmas = <&apbdma 30>, <&apbdma 30>;
350 dma-names = "rx", "tx";
351 status = "disabled";
352 };
353
354 spi@0,7000d400 {
355 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
356 reg = <0x0 0x7000d400 0x0 0x200>;
357 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
358 #address-cells = <1>;
359 #size-cells = <0>;
360 clocks = <&tegra_car TEGRA124_CLK_SBC1>;
361 clock-names = "spi";
362 resets = <&tegra_car 41>;
363 reset-names = "spi";
364 dmas = <&apbdma 15>, <&apbdma 15>;
365 dma-names = "rx", "tx";
366 status = "disabled";
367 };
368
369 spi@0,7000d600 {
370 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
371 reg = <0x0 0x7000d600 0x0 0x200>;
372 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
373 #address-cells = <1>;
374 #size-cells = <0>;
375 clocks = <&tegra_car TEGRA124_CLK_SBC2>;
376 clock-names = "spi";
377 resets = <&tegra_car 44>;
378 reset-names = "spi";
379 dmas = <&apbdma 16>, <&apbdma 16>;
380 dma-names = "rx", "tx";
381 status = "disabled";
382 };
383
384 spi@0,7000d800 {
385 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
386 reg = <0x0 0x7000d800 0x0 0x200>;
387 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
388 #address-cells = <1>;
389 #size-cells = <0>;
390 clocks = <&tegra_car TEGRA124_CLK_SBC3>;
391 clock-names = "spi";
392 resets = <&tegra_car 46>;
393 reset-names = "spi";
394 dmas = <&apbdma 17>, <&apbdma 17>;
395 dma-names = "rx", "tx";
396 status = "disabled";
397 };
398
399 spi@0,7000da00 {
400 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
401 reg = <0x0 0x7000da00 0x0 0x200>;
402 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
403 #address-cells = <1>;
404 #size-cells = <0>;
405 clocks = <&tegra_car TEGRA124_CLK_SBC4>;
406 clock-names = "spi";
407 resets = <&tegra_car 68>;
408 reset-names = "spi";
409 dmas = <&apbdma 18>, <&apbdma 18>;
410 dma-names = "rx", "tx";
411 status = "disabled";
412 };
413
414 spi@0,7000dc00 {
415 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
416 reg = <0x0 0x7000dc00 0x0 0x200>;
417 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
418 #address-cells = <1>;
419 #size-cells = <0>;
420 clocks = <&tegra_car TEGRA124_CLK_SBC5>;
421 clock-names = "spi";
422 resets = <&tegra_car 104>;
423 reset-names = "spi";
424 dmas = <&apbdma 27>, <&apbdma 27>;
425 dma-names = "rx", "tx";
426 status = "disabled";
427 };
428
429 spi@0,7000de00 {
430 compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi";
431 reg = <0x0 0x7000de00 0x0 0x200>;
432 interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
433 #address-cells = <1>;
434 #size-cells = <0>;
435 clocks = <&tegra_car TEGRA124_CLK_SBC6>;
436 clock-names = "spi";
437 resets = <&tegra_car 105>;
438 reset-names = "spi";
439 dmas = <&apbdma 28>, <&apbdma 28>;
440 dma-names = "rx", "tx";
441 status = "disabled";
442 };
443
444 rtc@0,7000e000 {
445 compatible = "nvidia,tegra124-rtc", "nvidia,tegra20-rtc";
446 reg = <0x0 0x7000e000 0x0 0x100>;
447 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
448 clocks = <&tegra_car TEGRA124_CLK_RTC>;
449 };
450
451 pmc@0,7000e400 {
452 compatible = "nvidia,tegra124-pmc";
453 reg = <0x0 0x7000e400 0x0 0x400>;
454 clocks = <&tegra_car TEGRA124_CLK_PCLK>, <&clk32k_in>;
455 clock-names = "pclk", "clk32k_in";
456 };
457
458 fuse@0,7000f800 {
459 compatible = "nvidia,tegra124-efuse";
460 reg = <0x0 0x7000f800 0x0 0x400>;
461 clocks = <&tegra_car TEGRA124_CLK_FUSE>;
462 clock-names = "fuse";
463 resets = <&tegra_car 39>;
464 reset-names = "fuse";
465 };
466
467 sdhci@0,700b0000 {
468 compatible = "nvidia,tegra124-sdhci";
469 reg = <0x0 0x700b0000 0x0 0x200>;
470 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
471 clocks = <&tegra_car TEGRA124_CLK_SDMMC1>;
472 resets = <&tegra_car 14>;
473 reset-names = "sdhci";
474 status = "disabled";
475 };
476
477 sdhci@0,700b0200 {
478 compatible = "nvidia,tegra124-sdhci";
479 reg = <0x0 0x700b0200 0x0 0x200>;
480 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
481 clocks = <&tegra_car TEGRA124_CLK_SDMMC2>;
482 resets = <&tegra_car 9>;
483 reset-names = "sdhci";
484 status = "disabled";
485 };
486
487 sdhci@0,700b0400 {
488 compatible = "nvidia,tegra124-sdhci";
489 reg = <0x0 0x700b0400 0x0 0x200>;
490 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
491 clocks = <&tegra_car TEGRA124_CLK_SDMMC3>;
492 resets = <&tegra_car 69>;
493 reset-names = "sdhci";
494 status = "disabled";
495 };
496
497 sdhci@0,700b0600 {
498 compatible = "nvidia,tegra124-sdhci";
499 reg = <0x0 0x700b0600 0x0 0x200>;
500 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
501 clocks = <&tegra_car TEGRA124_CLK_SDMMC4>;
502 resets = <&tegra_car 15>;
503 reset-names = "sdhci";
504 status = "disabled";
505 };
506
507 ahub@0,70300000 {
508 compatible = "nvidia,tegra124-ahub";
509 reg = <0x0 0x70300000 0x0 0x200>,
510 <0x0 0x70300800 0x0 0x800>,
511 <0x0 0x70300200 0x0 0x600>;
512 interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
513 clocks = <&tegra_car TEGRA124_CLK_D_AUDIO>,
514 <&tegra_car TEGRA124_CLK_APBIF>;
515 clock-names = "d_audio", "apbif";
516 resets = <&tegra_car 106>, /* d_audio */
517 <&tegra_car 107>, /* apbif */
518 <&tegra_car 30>, /* i2s0 */
519 <&tegra_car 11>, /* i2s1 */
520 <&tegra_car 18>, /* i2s2 */
521 <&tegra_car 101>, /* i2s3 */
522 <&tegra_car 102>, /* i2s4 */
523 <&tegra_car 108>, /* dam0 */
524 <&tegra_car 109>, /* dam1 */
525 <&tegra_car 110>, /* dam2 */
526 <&tegra_car 10>, /* spdif */
527 <&tegra_car 153>, /* amx */
528 <&tegra_car 185>, /* amx1 */
529 <&tegra_car 154>, /* adx */
530 <&tegra_car 180>, /* adx1 */
531 <&tegra_car 186>, /* afc0 */
532 <&tegra_car 187>, /* afc1 */
533 <&tegra_car 188>, /* afc2 */
534 <&tegra_car 189>, /* afc3 */
535 <&tegra_car 190>, /* afc4 */
536 <&tegra_car 191>; /* afc5 */
537 reset-names = "d_audio", "apbif", "i2s0", "i2s1", "i2s2",
538 "i2s3", "i2s4", "dam0", "dam1", "dam2",
539 "spdif", "amx", "amx1", "adx", "adx1",
540 "afc0", "afc1", "afc2", "afc3", "afc4", "afc5";
541 dmas = <&apbdma 1>, <&apbdma 1>,
542 <&apbdma 2>, <&apbdma 2>,
543 <&apbdma 3>, <&apbdma 3>,
544 <&apbdma 4>, <&apbdma 4>,
545 <&apbdma 6>, <&apbdma 6>,
546 <&apbdma 7>, <&apbdma 7>,
547 <&apbdma 12>, <&apbdma 12>,
548 <&apbdma 13>, <&apbdma 13>,
549 <&apbdma 14>, <&apbdma 14>,
550 <&apbdma 29>, <&apbdma 29>;
551 dma-names = "rx0", "tx0", "rx1", "tx1", "rx2", "tx2",
552 "rx3", "tx3", "rx4", "tx4", "rx5", "tx5",
553 "rx6", "tx6", "rx7", "tx7", "rx8", "tx8",
554 "rx9", "tx9";
555 ranges;
556 #address-cells = <2>;
557 #size-cells = <2>;
558
559 tegra_i2s0: i2s@0,70301000 {
560 compatible = "nvidia,tegra124-i2s";
561 reg = <0x0 0x70301000 0x0 0x100>;
562 nvidia,ahub-cif-ids = <4 4>;
563 clocks = <&tegra_car TEGRA124_CLK_I2S0>;
564 resets = <&tegra_car 30>;
565 reset-names = "i2s";
566 status = "disabled";
567 };
568
569 tegra_i2s1: i2s@0,70301100 {
570 compatible = "nvidia,tegra124-i2s";
571 reg = <0x0 0x70301100 0x0 0x100>;
572 nvidia,ahub-cif-ids = <5 5>;
573 clocks = <&tegra_car TEGRA124_CLK_I2S1>;
574 resets = <&tegra_car 11>;
575 reset-names = "i2s";
576 status = "disabled";
577 };
578
579 tegra_i2s2: i2s@0,70301200 {
580 compatible = "nvidia,tegra124-i2s";
581 reg = <0x0 0x70301200 0x0 0x100>;
582 nvidia,ahub-cif-ids = <6 6>;
583 clocks = <&tegra_car TEGRA124_CLK_I2S2>;
584 resets = <&tegra_car 18>;
585 reset-names = "i2s";
586 status = "disabled";
587 };
588
589 tegra_i2s3: i2s@0,70301300 {
590 compatible = "nvidia,tegra124-i2s";
591 reg = <0x0 0x70301300 0x0 0x100>;
592 nvidia,ahub-cif-ids = <7 7>;
593 clocks = <&tegra_car TEGRA124_CLK_I2S3>;
594 resets = <&tegra_car 101>;
595 reset-names = "i2s";
596 status = "disabled";
597 };
598
599 tegra_i2s4: i2s@0,70301400 {
600 compatible = "nvidia,tegra124-i2s";
601 reg = <0x0 0x70301400 0x0 0x100>;
602 nvidia,ahub-cif-ids = <8 8>;
603 clocks = <&tegra_car TEGRA124_CLK_I2S4>;
604 resets = <&tegra_car 102>;
605 reset-names = "i2s";
606 status = "disabled";
607 };
608 };
609
610 usb@0,7d000000 {
611 compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci";
612 reg = <0x0 0x7d000000 0x0 0x4000>;
613 interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
614 phy_type = "utmi";
615 clocks = <&tegra_car TEGRA124_CLK_USBD>;
616 resets = <&tegra_car 22>;
617 reset-names = "usb";
618 nvidia,phy = <&phy1>;
619 status = "disabled";
620 };
621
622 phy1: usb-phy@0,7d000000 {
623 compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
624 reg = <0x0 0x7d000000 0x0 0x4000>,
625 <0x0 0x7d000000 0x0 0x4000>;
626 phy_type = "utmi";
627 clocks = <&tegra_car TEGRA124_CLK_USBD>,
628 <&tegra_car TEGRA124_CLK_PLL_U>,
629 <&tegra_car TEGRA124_CLK_USBD>;
630 clock-names = "reg", "pll_u", "utmi-pads";
631 resets = <&tegra_car 59>, <&tegra_car 22>;
632 reset-names = "usb", "utmi-pads";
633 nvidia,hssync-start-delay = <0>;
634 nvidia,idle-wait-delay = <17>;
635 nvidia,elastic-limit = <16>;
636 nvidia,term-range-adj = <6>;
637 nvidia,xcvr-setup = <9>;
638 nvidia,xcvr-lsfslew = <0>;
639 nvidia,xcvr-lsrslew = <3>;
640 nvidia,hssquelch-level = <2>;
641 nvidia,hsdiscon-level = <5>;
642 nvidia,xcvr-hsslew = <12>;
643 status = "disabled";
644 };
645
646 usb@0,7d004000 {
647 compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci";
648 reg = <0x0 0x7d004000 0x0 0x4000>;
649 interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
650 phy_type = "utmi";
651 clocks = <&tegra_car TEGRA124_CLK_USB2>;
652 resets = <&tegra_car 58>;
653 reset-names = "usb";
654 nvidia,phy = <&phy2>;
655 status = "disabled";
656 };
657
658 phy2: usb-phy@0,7d004000 {
659 compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
660 reg = <0x0 0x7d004000 0x0 0x4000>,
661 <0x0 0x7d000000 0x0 0x4000>;
662 phy_type = "utmi";
663 clocks = <&tegra_car TEGRA124_CLK_USB2>,
664 <&tegra_car TEGRA124_CLK_PLL_U>,
665 <&tegra_car TEGRA124_CLK_USBD>;
666 clock-names = "reg", "pll_u", "utmi-pads";
667 resets = <&tegra_car 22>, <&tegra_car 22>;
668 reset-names = "usb", "utmi-pads";
669 nvidia,hssync-start-delay = <0>;
670 nvidia,idle-wait-delay = <17>;
671 nvidia,elastic-limit = <16>;
672 nvidia,term-range-adj = <6>;
673 nvidia,xcvr-setup = <9>;
674 nvidia,xcvr-lsfslew = <0>;
675 nvidia,xcvr-lsrslew = <3>;
676 nvidia,hssquelch-level = <2>;
677 nvidia,hsdiscon-level = <5>;
678 nvidia,xcvr-hsslew = <12>;
679 nvidia,has-utmi-pad-registers;
680 status = "disabled";
681 };
682
683 usb@0,7d008000 {
684 compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci";
685 reg = <0x0 0x7d008000 0x0 0x4000>;
686 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
687 phy_type = "utmi";
688 clocks = <&tegra_car TEGRA124_CLK_USB3>;
689 resets = <&tegra_car 59>;
690 reset-names = "usb";
691 nvidia,phy = <&phy3>;
692 status = "disabled";
693 };
694
695 phy3: usb-phy@0,7d008000 {
696 compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy";
697 reg = <0x0 0x7d008000 0x0 0x4000>,
698 <0x0 0x7d000000 0x0 0x4000>;
699 phy_type = "utmi";
700 clocks = <&tegra_car TEGRA124_CLK_USB3>,
701 <&tegra_car TEGRA124_CLK_PLL_U>,
702 <&tegra_car TEGRA124_CLK_USBD>;
703 clock-names = "reg", "pll_u", "utmi-pads";
704 resets = <&tegra_car 58>, <&tegra_car 22>;
705 reset-names = "usb", "utmi-pads";
706 nvidia,hssync-start-delay = <0>;
707 nvidia,idle-wait-delay = <17>;
708 nvidia,elastic-limit = <16>;
709 nvidia,term-range-adj = <6>;
710 nvidia,xcvr-setup = <9>;
711 nvidia,xcvr-lsfslew = <0>;
712 nvidia,xcvr-lsrslew = <3>;
713 nvidia,hssquelch-level = <2>;
714 nvidia,hsdiscon-level = <5>;
715 nvidia,xcvr-hsslew = <12>;
716 status = "disabled";
717 };
718
719 cpus {
720 #address-cells = <1>;
721 #size-cells = <0>;
722
723 cpu@0 {
724 device_type = "cpu";
725 compatible = "arm,cortex-a15";
726 reg = <0>;
727 };
728
729 cpu@1 {
730 device_type = "cpu";
731 compatible = "arm,cortex-a15";
732 reg = <1>;
733 };
734
735 cpu@2 {
736 device_type = "cpu";
737 compatible = "arm,cortex-a15";
738 reg = <2>;
739 };
740
741 cpu@3 {
742 device_type = "cpu";
743 compatible = "arm,cortex-a15";
744 reg = <3>;
745 };
746 };
747
748 timer {
749 compatible = "arm,armv7-timer";
750 interrupts = <GIC_PPI 13
751 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
752 <GIC_PPI 14
753 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
754 <GIC_PPI 11
755 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
756 <GIC_PPI 10
757 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
758 };
759 };