arm: mvebu: add nand pins
[oweals/u-boot.git] / arch / arm / dts / tegra20.dtsi
1 #include <dt-bindings/clock/tegra20-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,tegra20";
10         interrupt-parent = <&lic>;
11
12         host1x@50000000 {
13                 compatible = "nvidia,tegra20-host1x", "simple-bus";
14                 reg = <0x50000000 0x00024000>;
15                 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */
16                              <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */
17                 clocks = <&tegra_car TEGRA20_CLK_HOST1X>;
18                 resets = <&tegra_car 28>;
19                 reset-names = "host1x";
20
21                 #address-cells = <1>;
22                 #size-cells = <1>;
23
24                 ranges = <0x54000000 0x54000000 0x04000000>;
25
26                 mpe@54040000 {
27                         compatible = "nvidia,tegra20-mpe";
28                         reg = <0x54040000 0x00040000>;
29                         interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>;
30                         clocks = <&tegra_car TEGRA20_CLK_MPE>;
31                         resets = <&tegra_car 60>;
32                         reset-names = "mpe";
33                 };
34
35                 vi@54080000 {
36                         compatible = "nvidia,tegra20-vi";
37                         reg = <0x54080000 0x00040000>;
38                         interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
39                         clocks = <&tegra_car TEGRA20_CLK_VI>;
40                         resets = <&tegra_car 20>;
41                         reset-names = "vi";
42                 };
43
44                 epp@540c0000 {
45                         compatible = "nvidia,tegra20-epp";
46                         reg = <0x540c0000 0x00040000>;
47                         interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
48                         clocks = <&tegra_car TEGRA20_CLK_EPP>;
49                         resets = <&tegra_car 19>;
50                         reset-names = "epp";
51                 };
52
53                 isp@54100000 {
54                         compatible = "nvidia,tegra20-isp";
55                         reg = <0x54100000 0x00040000>;
56                         interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
57                         clocks = <&tegra_car TEGRA20_CLK_ISP>;
58                         resets = <&tegra_car 23>;
59                         reset-names = "isp";
60                 };
61
62                 gr2d@54140000 {
63                         compatible = "nvidia,tegra20-gr2d";
64                         reg = <0x54140000 0x00040000>;
65                         interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
66                         clocks = <&tegra_car TEGRA20_CLK_GR2D>;
67                         resets = <&tegra_car 21>;
68                         reset-names = "2d";
69                 };
70
71                 gr3d@54180000 {
72                         compatible = "nvidia,tegra20-gr3d";
73                         reg = <0x54180000 0x00040000>;
74                         clocks = <&tegra_car TEGRA20_CLK_GR3D>;
75                         resets = <&tegra_car 24>;
76                         reset-names = "3d";
77                 };
78
79                 dc@54200000 {
80                         compatible = "nvidia,tegra20-dc";
81                         reg = <0x54200000 0x00040000>;
82                         interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
83                         clocks = <&tegra_car TEGRA20_CLK_DISP1>,
84                                  <&tegra_car TEGRA20_CLK_PLL_P>;
85                         clock-names = "dc", "parent";
86                         resets = <&tegra_car 27>;
87                         reset-names = "dc";
88
89                         nvidia,head = <0>;
90
91                         rgb {
92                                 status = "disabled";
93                         };
94                 };
95
96                 dc@54240000 {
97                         compatible = "nvidia,tegra20-dc";
98                         reg = <0x54240000 0x00040000>;
99                         interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
100                         clocks = <&tegra_car TEGRA20_CLK_DISP2>,
101                                  <&tegra_car TEGRA20_CLK_PLL_P>;
102                         clock-names = "dc", "parent";
103                         resets = <&tegra_car 26>;
104                         reset-names = "dc";
105
106                         nvidia,head = <1>;
107
108                         rgb {
109                                 status = "disabled";
110                         };
111                 };
112
113                 hdmi@54280000 {
114                         compatible = "nvidia,tegra20-hdmi";
115                         reg = <0x54280000 0x00040000>;
116                         interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
117                         clocks = <&tegra_car TEGRA20_CLK_HDMI>,
118                                  <&tegra_car TEGRA20_CLK_PLL_D_OUT0>;
119                         clock-names = "hdmi", "parent";
120                         resets = <&tegra_car 51>;
121                         reset-names = "hdmi";
122                         status = "disabled";
123                 };
124
125                 tvo@542c0000 {
126                         compatible = "nvidia,tegra20-tvo";
127                         reg = <0x542c0000 0x00040000>;
128                         interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
129                         clocks = <&tegra_car TEGRA20_CLK_TVO>;
130                         status = "disabled";
131                 };
132
133                 dsi@54300000 {
134                         compatible = "nvidia,tegra20-dsi";
135                         reg = <0x54300000 0x00040000>;
136                         clocks = <&tegra_car TEGRA20_CLK_DSI>;
137                         resets = <&tegra_car 48>;
138                         reset-names = "dsi";
139                         status = "disabled";
140                 };
141         };
142
143         timer@50040600 {
144                 compatible = "arm,cortex-a9-twd-timer";
145                 interrupt-parent = <&intc>;
146                 reg = <0x50040600 0x20>;
147                 interrupts = <GIC_PPI 13
148                         (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_EDGE_RISING)>;
149                 clocks = <&tegra_car TEGRA20_CLK_TWD>;
150         };
151
152         intc: interrupt-controller@50041000 {
153                 compatible = "arm,cortex-a9-gic";
154                 reg = <0x50041000 0x1000
155                        0x50040100 0x0100>;
156                 interrupt-controller;
157                 #interrupt-cells = <3>;
158                 interrupt-parent = <&intc>;
159         };
160
161         cache-controller@50043000 {
162                 compatible = "arm,pl310-cache";
163                 reg = <0x50043000 0x1000>;
164                 arm,data-latency = <5 5 2>;
165                 arm,tag-latency = <4 4 2>;
166                 cache-unified;
167                 cache-level = <2>;
168         };
169
170         lic: interrupt-controller@60004000 {
171                 compatible = "nvidia,tegra20-ictlr";
172                 reg = <0x60004000 0x100>,
173                       <0x60004100 0x50>,
174                       <0x60004200 0x50>,
175                       <0x60004300 0x50>;
176                 interrupt-controller;
177                 #interrupt-cells = <3>;
178                 interrupt-parent = <&intc>;
179         };
180
181         timer@60005000 {
182                 compatible = "nvidia,tegra20-timer";
183                 reg = <0x60005000 0x60>;
184                 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
185                              <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
186                              <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
187                              <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
188                 clocks = <&tegra_car TEGRA20_CLK_TIMER>;
189         };
190
191         tegra_car: clock@60006000 {
192                 compatible = "nvidia,tegra20-car";
193                 reg = <0x60006000 0x1000>;
194                 #clock-cells = <1>;
195                 #reset-cells = <1>;
196         };
197
198         flow-controller@60007000 {
199                 compatible = "nvidia,tegra20-flowctrl";
200                 reg = <0x60007000 0x1000>;
201         };
202
203         apbdma: dma@6000a000 {
204                 compatible = "nvidia,tegra20-apbdma";
205                 reg = <0x6000a000 0x1200>;
206                 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
207                              <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
208                              <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
209                              <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
210                              <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
211                              <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
212                              <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
213                              <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
214                              <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
215                              <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
216                              <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
217                              <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
218                              <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
219                              <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
220                              <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
221                              <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>;
222                 clocks = <&tegra_car TEGRA20_CLK_APBDMA>;
223                 resets = <&tegra_car 34>;
224                 reset-names = "dma";
225                 #dma-cells = <1>;
226         };
227
228         ahb@6000c000 {
229                 compatible = "nvidia,tegra20-ahb";
230                 reg = <0x6000c000 0x110>; /* AHB Arbitration + Gizmo Controller */
231         };
232
233         gpio: gpio@6000d000 {
234                 compatible = "nvidia,tegra20-gpio";
235                 reg = <0x6000d000 0x1000>;
236                 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
237                              <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
238                              <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
239                              <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
240                              <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
241                              <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
242                              <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
243                 #gpio-cells = <2>;
244                 gpio-controller;
245                 #interrupt-cells = <2>;
246                 interrupt-controller;
247                 /*
248                 gpio-ranges = <&pinmux 0 0 224>;
249                 */
250         };
251
252         apbmisc@70000800 {
253                 compatible = "nvidia,tegra20-apbmisc";
254                 reg = <0x70000800 0x64   /* Chip revision */
255                        0x70000008 0x04>; /* Strapping options */
256         };
257
258         pinmux: pinmux@70000014 {
259                 compatible = "nvidia,tegra20-pinmux";
260                 reg = <0x70000014 0x10   /* Tri-state registers */
261                        0x70000080 0x20   /* Mux registers */
262                        0x700000a0 0x14   /* Pull-up/down registers */
263                        0x70000868 0xa8>; /* Pad control registers */
264         };
265
266         das@70000c00 {
267                 compatible = "nvidia,tegra20-das";
268                 reg = <0x70000c00 0x80>;
269         };
270
271         tegra_ac97: ac97@70002000 {
272                 compatible = "nvidia,tegra20-ac97";
273                 reg = <0x70002000 0x200>;
274                 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
275                 clocks = <&tegra_car TEGRA20_CLK_AC97>;
276                 resets = <&tegra_car 3>;
277                 reset-names = "ac97";
278                 dmas = <&apbdma 12>, <&apbdma 12>;
279                 dma-names = "rx", "tx";
280                 status = "disabled";
281         };
282
283         tegra_i2s1: i2s@70002800 {
284                 compatible = "nvidia,tegra20-i2s";
285                 reg = <0x70002800 0x200>;
286                 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
287                 clocks = <&tegra_car TEGRA20_CLK_I2S1>;
288                 resets = <&tegra_car 11>;
289                 reset-names = "i2s";
290                 dmas = <&apbdma 2>, <&apbdma 2>;
291                 dma-names = "rx", "tx";
292                 status = "disabled";
293         };
294
295         tegra_i2s2: i2s@70002a00 {
296                 compatible = "nvidia,tegra20-i2s";
297                 reg = <0x70002a00 0x200>;
298                 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
299                 clocks = <&tegra_car TEGRA20_CLK_I2S2>;
300                 resets = <&tegra_car 18>;
301                 reset-names = "i2s";
302                 dmas = <&apbdma 1>, <&apbdma 1>;
303                 dma-names = "rx", "tx";
304                 status = "disabled";
305         };
306
307         /*
308          * There are two serial driver i.e. 8250 based simple serial
309          * driver and APB DMA based serial driver for higher baudrate
310          * and performace. To enable the 8250 based driver, the compatible
311          * is "nvidia,tegra20-uart" and to enable the APB DMA based serial
312          * driver, the compatible is "nvidia,tegra20-hsuart".
313          */
314         uarta: serial@70006000 {
315                 compatible = "nvidia,tegra20-uart";
316                 reg = <0x70006000 0x40>;
317                 reg-shift = <2>;
318                 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
319                 clocks = <&tegra_car TEGRA20_CLK_UARTA>;
320                 resets = <&tegra_car 6>;
321                 reset-names = "serial";
322                 dmas = <&apbdma 8>, <&apbdma 8>;
323                 dma-names = "rx", "tx";
324                 status = "disabled";
325         };
326
327         uartb: serial@70006040 {
328                 compatible = "nvidia,tegra20-uart";
329                 reg = <0x70006040 0x40>;
330                 reg-shift = <2>;
331                 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
332                 clocks = <&tegra_car TEGRA20_CLK_UARTB>;
333                 resets = <&tegra_car 7>;
334                 reset-names = "serial";
335                 dmas = <&apbdma 9>, <&apbdma 9>;
336                 dma-names = "rx", "tx";
337                 status = "disabled";
338         };
339
340         uartc: serial@70006200 {
341                 compatible = "nvidia,tegra20-uart";
342                 reg = <0x70006200 0x100>;
343                 reg-shift = <2>;
344                 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
345                 clocks = <&tegra_car TEGRA20_CLK_UARTC>;
346                 resets = <&tegra_car 55>;
347                 reset-names = "serial";
348                 dmas = <&apbdma 10>, <&apbdma 10>;
349                 dma-names = "rx", "tx";
350                 status = "disabled";
351         };
352
353         uartd: serial@70006300 {
354                 compatible = "nvidia,tegra20-uart";
355                 reg = <0x70006300 0x100>;
356                 reg-shift = <2>;
357                 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
358                 clocks = <&tegra_car TEGRA20_CLK_UARTD>;
359                 resets = <&tegra_car 65>;
360                 reset-names = "serial";
361                 dmas = <&apbdma 19>, <&apbdma 19>;
362                 dma-names = "rx", "tx";
363                 status = "disabled";
364         };
365
366         uarte: serial@70006400 {
367                 compatible = "nvidia,tegra20-uart";
368                 reg = <0x70006400 0x100>;
369                 reg-shift = <2>;
370                 interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
371                 clocks = <&tegra_car TEGRA20_CLK_UARTE>;
372                 resets = <&tegra_car 66>;
373                 reset-names = "serial";
374                 dmas = <&apbdma 20>, <&apbdma 20>;
375                 dma-names = "rx", "tx";
376                 status = "disabled";
377         };
378
379         nand: nand-controller@70008000 {
380                 #address-cells = <1>;
381                 #size-cells = <0>;
382                 compatible = "nvidia,tegra20-nand";
383                 reg = <0x70008000 0x100>;
384         };
385
386         pwm: pwm@7000a000 {
387                 compatible = "nvidia,tegra20-pwm";
388                 reg = <0x7000a000 0x100>;
389                 #pwm-cells = <2>;
390                 clocks = <&tegra_car TEGRA20_CLK_PWM>;
391                 resets = <&tegra_car 17>;
392                 reset-names = "pwm";
393                 status = "disabled";
394         };
395
396         rtc@7000e000 {
397                 compatible = "nvidia,tegra20-rtc";
398                 reg = <0x7000e000 0x100>;
399                 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
400                 clocks = <&tegra_car TEGRA20_CLK_RTC>;
401         };
402
403         i2c@7000c000 {
404                 compatible = "nvidia,tegra20-i2c";
405                 reg = <0x7000c000 0x100>;
406                 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
407                 #address-cells = <1>;
408                 #size-cells = <0>;
409                 clocks = <&tegra_car TEGRA20_CLK_I2C1>,
410                          <&tegra_car TEGRA20_CLK_PLL_P_OUT3>;
411                 clock-names = "div-clk", "fast-clk";
412                 resets = <&tegra_car 12>;
413                 reset-names = "i2c";
414                 dmas = <&apbdma 21>, <&apbdma 21>;
415                 dma-names = "rx", "tx";
416                 status = "disabled";
417         };
418
419         spi@7000c380 {
420                 compatible = "nvidia,tegra20-sflash";
421                 reg = <0x7000c380 0x80>;
422                 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
423                 #address-cells = <1>;
424                 #size-cells = <0>;
425                 clocks = <&tegra_car TEGRA20_CLK_SPI>;
426                 resets = <&tegra_car 43>;
427                 reset-names = "spi";
428                 dmas = <&apbdma 11>, <&apbdma 11>;
429                 dma-names = "rx", "tx";
430                 status = "disabled";
431         };
432
433         i2c@7000c400 {
434                 compatible = "nvidia,tegra20-i2c";
435                 reg = <0x7000c400 0x100>;
436                 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
437                 #address-cells = <1>;
438                 #size-cells = <0>;
439                 clocks = <&tegra_car TEGRA20_CLK_I2C2>,
440                          <&tegra_car TEGRA20_CLK_PLL_P_OUT3>;
441                 clock-names = "div-clk", "fast-clk";
442                 resets = <&tegra_car 54>;
443                 reset-names = "i2c";
444                 dmas = <&apbdma 22>, <&apbdma 22>;
445                 dma-names = "rx", "tx";
446                 status = "disabled";
447         };
448
449         i2c@7000c500 {
450                 compatible = "nvidia,tegra20-i2c";
451                 reg = <0x7000c500 0x100>;
452                 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
453                 #address-cells = <1>;
454                 #size-cells = <0>;
455                 clocks = <&tegra_car TEGRA20_CLK_I2C3>,
456                          <&tegra_car TEGRA20_CLK_PLL_P_OUT3>;
457                 clock-names = "div-clk", "fast-clk";
458                 resets = <&tegra_car 67>;
459                 reset-names = "i2c";
460                 dmas = <&apbdma 23>, <&apbdma 23>;
461                 dma-names = "rx", "tx";
462                 status = "disabled";
463         };
464
465         i2c@7000d000 {
466                 compatible = "nvidia,tegra20-i2c-dvc";
467                 reg = <0x7000d000 0x200>;
468                 interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
469                 #address-cells = <1>;
470                 #size-cells = <0>;
471                 clocks = <&tegra_car TEGRA20_CLK_DVC>,
472                          <&tegra_car TEGRA20_CLK_PLL_P_OUT3>;
473                 clock-names = "div-clk", "fast-clk";
474                 resets = <&tegra_car 47>;
475                 reset-names = "i2c";
476                 dmas = <&apbdma 24>, <&apbdma 24>;
477                 dma-names = "rx", "tx";
478                 status = "disabled";
479         };
480
481         spi@7000d400 {
482                 compatible = "nvidia,tegra20-slink";
483                 reg = <0x7000d400 0x200>;
484                 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
485                 #address-cells = <1>;
486                 #size-cells = <0>;
487                 clocks = <&tegra_car TEGRA20_CLK_SBC1>;
488                 resets = <&tegra_car 41>;
489                 reset-names = "spi";
490                 dmas = <&apbdma 15>, <&apbdma 15>;
491                 dma-names = "rx", "tx";
492                 status = "disabled";
493         };
494
495         spi@7000d600 {
496                 compatible = "nvidia,tegra20-slink";
497                 reg = <0x7000d600 0x200>;
498                 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
499                 #address-cells = <1>;
500                 #size-cells = <0>;
501                 clocks = <&tegra_car TEGRA20_CLK_SBC2>;
502                 resets = <&tegra_car 44>;
503                 reset-names = "spi";
504                 dmas = <&apbdma 16>, <&apbdma 16>;
505                 dma-names = "rx", "tx";
506                 status = "disabled";
507         };
508
509         spi@7000d800 {
510                 compatible = "nvidia,tegra20-slink";
511                 reg = <0x7000d800 0x200>;
512                 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
513                 #address-cells = <1>;
514                 #size-cells = <0>;
515                 clocks = <&tegra_car TEGRA20_CLK_SBC3>;
516                 resets = <&tegra_car 46>;
517                 reset-names = "spi";
518                 dmas = <&apbdma 17>, <&apbdma 17>;
519                 dma-names = "rx", "tx";
520                 status = "disabled";
521         };
522
523         spi@7000da00 {
524                 compatible = "nvidia,tegra20-slink";
525                 reg = <0x7000da00 0x200>;
526                 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
527                 #address-cells = <1>;
528                 #size-cells = <0>;
529                 clocks = <&tegra_car TEGRA20_CLK_SBC4>;
530                 resets = <&tegra_car 68>;
531                 reset-names = "spi";
532                 dmas = <&apbdma 18>, <&apbdma 18>;
533                 dma-names = "rx", "tx";
534                 status = "disabled";
535         };
536
537         kbc@7000e200 {
538                 compatible = "nvidia,tegra20-kbc";
539                 reg = <0x7000e200 0x100>;
540                 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
541                 clocks = <&tegra_car TEGRA20_CLK_KBC>;
542                 resets = <&tegra_car 36>;
543                 reset-names = "kbc";
544                 status = "disabled";
545         };
546
547         pmc@7000e400 {
548                 compatible = "nvidia,tegra20-pmc";
549                 reg = <0x7000e400 0x400>;
550                 clocks = <&tegra_car TEGRA20_CLK_PCLK>, <&clk32k_in>;
551                 clock-names = "pclk", "clk32k_in";
552         };
553
554         memory-controller@7000f000 {
555                 compatible = "nvidia,tegra20-mc";
556                 reg = <0x7000f000 0x024
557                        0x7000f03c 0x3c4>;
558                 interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
559         };
560
561         iommu@7000f024 {
562                 compatible = "nvidia,tegra20-gart";
563                 reg = <0x7000f024 0x00000018    /* controller registers */
564                        0x58000000 0x02000000>;  /* GART aperture */
565         };
566
567         memory-controller@7000f400 {
568                 compatible = "nvidia,tegra20-emc";
569                 reg = <0x7000f400 0x200>;
570                 #address-cells = <1>;
571                 #size-cells = <0>;
572         };
573
574         fuse@7000f800 {
575                 compatible = "nvidia,tegra20-efuse";
576                 reg = <0x7000f800 0x400>;
577                 clocks = <&tegra_car TEGRA20_CLK_FUSE>;
578                 clock-names = "fuse";
579                 resets = <&tegra_car 39>;
580                 reset-names = "fuse";
581         };
582
583         pcie-controller@80003000 {
584                 compatible = "nvidia,tegra20-pcie";
585                 device_type = "pci";
586                 reg = <0x80003000 0x00000800   /* PADS registers */
587                        0x80003800 0x00000200   /* AFI registers */
588                        0x90000000 0x10000000>; /* configuration space */
589                 reg-names = "pads", "afi", "cs";
590                 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH   /* controller interrupt */
591                               GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */
592                 interrupt-names = "intr", "msi";
593
594                 #interrupt-cells = <1>;
595                 interrupt-map-mask = <0 0 0 0>;
596                 interrupt-map = <0 0 0 0 &intc GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
597
598                 bus-range = <0x00 0xff>;
599                 #address-cells = <3>;
600                 #size-cells = <2>;
601
602                 ranges = <0x82000000 0 0x80000000 0x80000000 0 0x00001000   /* port 0 registers */
603                           0x82000000 0 0x80001000 0x80001000 0 0x00001000   /* port 1 registers */
604                           0x81000000 0 0          0x82000000 0 0x00010000   /* downstream I/O */
605                           0x82000000 0 0xa0000000 0xa0000000 0 0x08000000   /* non-prefetchable memory */
606                           0xc2000000 0 0xa8000000 0xa8000000 0 0x18000000>; /* prefetchable memory */
607
608                 clocks = <&tegra_car TEGRA20_CLK_PEX>,
609                          <&tegra_car TEGRA20_CLK_AFI>,
610                          <&tegra_car TEGRA20_CLK_PLL_E>;
611                 clock-names = "pex", "afi", "pll_e";
612                 resets = <&tegra_car 70>,
613                          <&tegra_car 72>,
614                          <&tegra_car 74>;
615                 reset-names = "pex", "afi", "pcie_x";
616                 status = "disabled";
617
618                 pci@1,0 {
619                         device_type = "pci";
620                         assigned-addresses = <0x82000800 0 0x80000000 0 0x1000>;
621                         reg = <0x000800 0 0 0 0>;
622                         status = "disabled";
623
624                         #address-cells = <3>;
625                         #size-cells = <2>;
626                         ranges;
627
628                         nvidia,num-lanes = <2>;
629                 };
630
631                 pci@2,0 {
632                         device_type = "pci";
633                         assigned-addresses = <0x82001000 0 0x80001000 0 0x1000>;
634                         reg = <0x001000 0 0 0 0>;
635                         status = "disabled";
636
637                         #address-cells = <3>;
638                         #size-cells = <2>;
639                         ranges;
640
641                         nvidia,num-lanes = <2>;
642                 };
643         };
644
645         usb@c5000000 {
646                 compatible = "nvidia,tegra20-ehci", "usb-ehci";
647                 reg = <0xc5000000 0x4000>;
648                 interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
649                 phy_type = "utmi";
650                 nvidia,has-legacy-mode;
651                 clocks = <&tegra_car TEGRA20_CLK_USBD>;
652                 resets = <&tegra_car 22>;
653                 reset-names = "usb";
654                 nvidia,needs-double-reset;
655                 nvidia,phy = <&phy1>;
656                 status = "disabled";
657         };
658
659         phy1: usb-phy@c5000000 {
660                 compatible = "nvidia,tegra20-usb-phy";
661                 reg = <0xc5000000 0x4000 0xc5000000 0x4000>;
662                 phy_type = "utmi";
663                 clocks = <&tegra_car TEGRA20_CLK_USBD>,
664                          <&tegra_car TEGRA20_CLK_PLL_U>,
665                          <&tegra_car TEGRA20_CLK_CLK_M>,
666                          <&tegra_car TEGRA20_CLK_USBD>;
667                 clock-names = "reg", "pll_u", "timer", "utmi-pads";
668                 resets = <&tegra_car 22>, <&tegra_car 22>;
669                 reset-names = "usb", "utmi-pads";
670                 nvidia,has-legacy-mode;
671                 nvidia,hssync-start-delay = <9>;
672                 nvidia,idle-wait-delay = <17>;
673                 nvidia,elastic-limit = <16>;
674                 nvidia,term-range-adj = <6>;
675                 nvidia,xcvr-setup = <9>;
676                 nvidia,xcvr-lsfslew = <1>;
677                 nvidia,xcvr-lsrslew = <1>;
678                 nvidia,has-utmi-pad-registers;
679                 status = "disabled";
680         };
681
682         usb@c5004000 {
683                 compatible = "nvidia,tegra20-ehci", "usb-ehci";
684                 reg = <0xc5004000 0x4000>;
685                 interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
686                 phy_type = "ulpi";
687                 clocks = <&tegra_car TEGRA20_CLK_USB2>;
688                 resets = <&tegra_car 58>;
689                 reset-names = "usb";
690                 nvidia,phy = <&phy2>;
691                 status = "disabled";
692         };
693
694         phy2: usb-phy@c5004000 {
695                 compatible = "nvidia,tegra20-usb-phy";
696                 reg = <0xc5004000 0x4000>;
697                 phy_type = "ulpi";
698                 clocks = <&tegra_car TEGRA20_CLK_USB2>,
699                          <&tegra_car TEGRA20_CLK_PLL_U>,
700                          <&tegra_car TEGRA20_CLK_CDEV2>;
701                 clock-names = "reg", "pll_u", "ulpi-link";
702                 resets = <&tegra_car 58>, <&tegra_car 22>;
703                 reset-names = "usb", "utmi-pads";
704                 status = "disabled";
705         };
706
707         usb@c5008000 {
708                 compatible = "nvidia,tegra20-ehci", "usb-ehci";
709                 reg = <0xc5008000 0x4000>;
710                 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
711                 phy_type = "utmi";
712                 clocks = <&tegra_car TEGRA20_CLK_USB3>;
713                 resets = <&tegra_car 59>;
714                 reset-names = "usb";
715                 nvidia,phy = <&phy3>;
716                 status = "disabled";
717         };
718
719         phy3: usb-phy@c5008000 {
720                 compatible = "nvidia,tegra20-usb-phy";
721                 reg = <0xc5008000 0x4000 0xc5000000 0x4000>;
722                 phy_type = "utmi";
723                 clocks = <&tegra_car TEGRA20_CLK_USB3>,
724                          <&tegra_car TEGRA20_CLK_PLL_U>,
725                          <&tegra_car TEGRA20_CLK_CLK_M>,
726                          <&tegra_car TEGRA20_CLK_USBD>;
727                 clock-names = "reg", "pll_u", "timer", "utmi-pads";
728                 resets = <&tegra_car 59>, <&tegra_car 22>;
729                 reset-names = "usb", "utmi-pads";
730                 nvidia,hssync-start-delay = <9>;
731                 nvidia,idle-wait-delay = <17>;
732                 nvidia,elastic-limit = <16>;
733                 nvidia,term-range-adj = <6>;
734                 nvidia,xcvr-setup = <9>;
735                 nvidia,xcvr-lsfslew = <2>;
736                 nvidia,xcvr-lsrslew = <2>;
737                 status = "disabled";
738         };
739
740         sdhci@c8000000 {
741                 compatible = "nvidia,tegra20-sdhci";
742                 reg = <0xc8000000 0x200>;
743                 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
744                 clocks = <&tegra_car TEGRA20_CLK_SDMMC1>;
745                 resets = <&tegra_car 14>;
746                 reset-names = "sdhci";
747                 status = "disabled";
748         };
749
750         sdhci@c8000200 {
751                 compatible = "nvidia,tegra20-sdhci";
752                 reg = <0xc8000200 0x200>;
753                 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
754                 clocks = <&tegra_car TEGRA20_CLK_SDMMC2>;
755                 resets = <&tegra_car 9>;
756                 reset-names = "sdhci";
757                 status = "disabled";
758         };
759
760         sdhci@c8000400 {
761                 compatible = "nvidia,tegra20-sdhci";
762                 reg = <0xc8000400 0x200>;
763                 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
764                 clocks = <&tegra_car TEGRA20_CLK_SDMMC3>;
765                 resets = <&tegra_car 69>;
766                 reset-names = "sdhci";
767                 status = "disabled";
768         };
769
770         sdhci@c8000600 {
771                 compatible = "nvidia,tegra20-sdhci";
772                 reg = <0xc8000600 0x200>;
773                 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
774                 clocks = <&tegra_car TEGRA20_CLK_SDMMC4>;
775                 resets = <&tegra_car 15>;
776                 reset-names = "sdhci";
777                 status = "disabled";
778         };
779
780         cpus {
781                 #address-cells = <1>;
782                 #size-cells = <0>;
783
784                 cpu@0 {
785                         device_type = "cpu";
786                         compatible = "arm,cortex-a9";
787                         reg = <0>;
788                 };
789
790                 cpu@1 {
791                         device_type = "cpu";
792                         compatible = "arm,cortex-a9";
793                         reg = <1>;
794                 };
795         };
796
797         pmu {
798                 compatible = "arm,cortex-a9-pmu";
799                 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>,
800                              <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
801         };
802 };