GNU Linux-libre 4.19.268-gnu1
[releases.git] / arch / arm64 / boot / dts / nvidia / tegra210.dtsi
1 // SPDX-License-Identifier: GPL-2.0
2 #include <dt-bindings/clock/tegra210-car.h>
3 #include <dt-bindings/gpio/tegra-gpio.h>
4 #include <dt-bindings/memory/tegra210-mc.h>
5 #include <dt-bindings/pinctrl/pinctrl-tegra.h>
6 #include <dt-bindings/interrupt-controller/arm-gic.h>
7 #include <dt-bindings/thermal/tegra124-soctherm.h>
8
9 / {
10         compatible = "nvidia,tegra210";
11         interrupt-parent = <&lic>;
12         #address-cells = <2>;
13         #size-cells = <2>;
14
15         pcie@1003000 {
16                 compatible = "nvidia,tegra210-pcie";
17                 device_type = "pci";
18                 reg = <0x0 0x01003000 0x0 0x00000800   /* PADS registers */
19                        0x0 0x01003800 0x0 0x00000800   /* AFI registers */
20                        0x0 0x02000000 0x0 0x10000000>; /* configuration space */
21                 reg-names = "pads", "afi", "cs";
22                 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */
23                              <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */
24                 interrupt-names = "intr", "msi";
25
26                 #interrupt-cells = <1>;
27                 interrupt-map-mask = <0 0 0 0>;
28                 interrupt-map = <0 0 0 0 &gic GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
29
30                 bus-range = <0x00 0xff>;
31                 #address-cells = <3>;
32                 #size-cells = <2>;
33
34                 ranges = <0x82000000 0 0x01000000 0x0 0x01000000 0 0x00001000   /* port 0 configuration space */
35                           0x82000000 0 0x01001000 0x0 0x01001000 0 0x00001000   /* port 1 configuration space */
36                           0x81000000 0 0x0        0x0 0x12000000 0 0x00010000   /* downstream I/O (64 KiB) */
37                           0x82000000 0 0x13000000 0x0 0x13000000 0 0x0d000000   /* non-prefetchable memory (208 MiB) */
38                           0xc2000000 0 0x20000000 0x0 0x20000000 0 0x20000000>; /* prefetchable memory (512 MiB) */
39
40                 clocks = <&tegra_car TEGRA210_CLK_PCIE>,
41                          <&tegra_car TEGRA210_CLK_AFI>,
42                          <&tegra_car TEGRA210_CLK_PLL_E>,
43                          <&tegra_car TEGRA210_CLK_CML0>;
44                 clock-names = "pex", "afi", "pll_e", "cml";
45                 resets = <&tegra_car 70>,
46                          <&tegra_car 72>,
47                          <&tegra_car 74>;
48                 reset-names = "pex", "afi", "pcie_x";
49                 status = "disabled";
50
51                 pci@1,0 {
52                         device_type = "pci";
53                         assigned-addresses = <0x82000800 0 0x01000000 0 0x1000>;
54                         reg = <0x000800 0 0 0 0>;
55                         bus-range = <0x00 0xff>;
56                         status = "disabled";
57
58                         #address-cells = <3>;
59                         #size-cells = <2>;
60                         ranges;
61
62                         nvidia,num-lanes = <4>;
63                 };
64
65                 pci@2,0 {
66                         device_type = "pci";
67                         assigned-addresses = <0x82001000 0 0x01001000 0 0x1000>;
68                         reg = <0x001000 0 0 0 0>;
69                         bus-range = <0x00 0xff>;
70                         status = "disabled";
71
72                         #address-cells = <3>;
73                         #size-cells = <2>;
74                         ranges;
75
76                         nvidia,num-lanes = <1>;
77                 };
78         };
79
80         host1x@50000000 {
81                 compatible = "nvidia,tegra210-host1x", "simple-bus";
82                 reg = <0x0 0x50000000 0x0 0x00034000>;
83                 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */
84                              <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */
85                 clocks = <&tegra_car TEGRA210_CLK_HOST1X>;
86                 clock-names = "host1x";
87                 resets = <&tegra_car 28>;
88                 reset-names = "host1x";
89
90                 #address-cells = <2>;
91                 #size-cells = <2>;
92
93                 ranges = <0x0 0x54000000 0x0 0x54000000 0x0 0x01000000>;
94
95                 iommus = <&mc TEGRA_SWGROUP_HC>;
96
97                 dpaux1: dpaux@54040000 {
98                         compatible = "nvidia,tegra210-dpaux";
99                         reg = <0x0 0x54040000 0x0 0x00040000>;
100                         interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
101                         clocks = <&tegra_car TEGRA210_CLK_DPAUX1>,
102                                  <&tegra_car TEGRA210_CLK_PLL_DP>;
103                         clock-names = "dpaux", "parent";
104                         resets = <&tegra_car 207>;
105                         reset-names = "dpaux";
106                         power-domains = <&pd_sor>;
107                         status = "disabled";
108
109                         state_dpaux1_aux: pinmux-aux {
110                                 groups = "dpaux-io";
111                                 function = "aux";
112                         };
113
114                         state_dpaux1_i2c: pinmux-i2c {
115                                 groups = "dpaux-io";
116                                 function = "i2c";
117                         };
118
119                         state_dpaux1_off: pinmux-off {
120                                 groups = "dpaux-io";
121                                 function = "off";
122                         };
123
124                         i2c-bus {
125                                 #address-cells = <1>;
126                                 #size-cells = <0>;
127                         };
128                 };
129
130                 vi@54080000 {
131                         compatible = "nvidia,tegra210-vi";
132                         reg = <0x0 0x54080000 0x0 0x00040000>;
133                         interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
134                         status = "disabled";
135                 };
136
137                 tsec@54100000 {
138                         compatible = "nvidia,tegra210-tsec";
139                         reg = <0x0 0x54100000 0x0 0x00040000>;
140                 };
141
142                 dc@54200000 {
143                         compatible = "nvidia,tegra210-dc";
144                         reg = <0x0 0x54200000 0x0 0x00040000>;
145                         interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
146                         clocks = <&tegra_car TEGRA210_CLK_DISP1>,
147                                  <&tegra_car TEGRA210_CLK_PLL_P>;
148                         clock-names = "dc", "parent";
149                         resets = <&tegra_car 27>;
150                         reset-names = "dc";
151
152                         iommus = <&mc TEGRA_SWGROUP_DC>;
153
154                         nvidia,head = <0>;
155                 };
156
157                 dc@54240000 {
158                         compatible = "nvidia,tegra210-dc";
159                         reg = <0x0 0x54240000 0x0 0x00040000>;
160                         interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
161                         clocks = <&tegra_car TEGRA210_CLK_DISP2>,
162                                  <&tegra_car TEGRA210_CLK_PLL_P>;
163                         clock-names = "dc", "parent";
164                         resets = <&tegra_car 26>;
165                         reset-names = "dc";
166
167                         iommus = <&mc TEGRA_SWGROUP_DCB>;
168
169                         nvidia,head = <1>;
170                 };
171
172                 dsi@54300000 {
173                         compatible = "nvidia,tegra210-dsi";
174                         reg = <0x0 0x54300000 0x0 0x00040000>;
175                         clocks = <&tegra_car TEGRA210_CLK_DSIA>,
176                                  <&tegra_car TEGRA210_CLK_DSIALP>,
177                                  <&tegra_car TEGRA210_CLK_PLL_D_OUT0>;
178                         clock-names = "dsi", "lp", "parent";
179                         resets = <&tegra_car 48>;
180                         reset-names = "dsi";
181                         power-domains = <&pd_sor>;
182                         nvidia,mipi-calibrate = <&mipi 0x0c0>; /* DSIA & DSIB pads */
183
184                         status = "disabled";
185
186                         #address-cells = <1>;
187                         #size-cells = <0>;
188                 };
189
190                 vic@54340000 {
191                         compatible = "nvidia,tegra210-vic";
192                         reg = <0x0 0x54340000 0x0 0x00040000>;
193                         interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
194                         clocks = <&tegra_car TEGRA210_CLK_VIC03>;
195                         clock-names = "vic";
196                         resets = <&tegra_car 178>;
197                         reset-names = "vic";
198
199                         iommus = <&mc TEGRA_SWGROUP_VIC>;
200                         power-domains = <&pd_vic>;
201                 };
202
203                 nvjpg@54380000 {
204                         compatible = "nvidia,tegra210-nvjpg";
205                         reg = <0x0 0x54380000 0x0 0x00040000>;
206                         status = "disabled";
207                 };
208
209                 dsi@54400000 {
210                         compatible = "nvidia,tegra210-dsi";
211                         reg = <0x0 0x54400000 0x0 0x00040000>;
212                         clocks = <&tegra_car TEGRA210_CLK_DSIB>,
213                                  <&tegra_car TEGRA210_CLK_DSIBLP>,
214                                  <&tegra_car TEGRA210_CLK_PLL_D_OUT0>;
215                         clock-names = "dsi", "lp", "parent";
216                         resets = <&tegra_car 82>;
217                         reset-names = "dsi";
218                         power-domains = <&pd_sor>;
219                         nvidia,mipi-calibrate = <&mipi 0x300>; /* DSIC & DSID pads */
220
221                         status = "disabled";
222
223                         #address-cells = <1>;
224                         #size-cells = <0>;
225                 };
226
227                 nvdec@54480000 {
228                         compatible = "nvidia,tegra210-nvdec";
229                         reg = <0x0 0x54480000 0x0 0x00040000>;
230                         status = "disabled";
231                 };
232
233                 nvenc@544c0000 {
234                         compatible = "nvidia,tegra210-nvenc";
235                         reg = <0x0 0x544c0000 0x0 0x00040000>;
236                         status = "disabled";
237                 };
238
239                 tsec@54500000 {
240                         compatible = "nvidia,tegra210-tsec";
241                         reg = <0x0 0x54500000 0x0 0x00040000>;
242                         status = "disabled";
243                 };
244
245                 sor@54540000 {
246                         compatible = "nvidia,tegra210-sor";
247                         reg = <0x0 0x54540000 0x0 0x00040000>;
248                         interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
249                         clocks = <&tegra_car TEGRA210_CLK_SOR0>,
250                                  <&tegra_car TEGRA210_CLK_PLL_D_OUT0>,
251                                  <&tegra_car TEGRA210_CLK_PLL_DP>,
252                                  <&tegra_car TEGRA210_CLK_SOR_SAFE>;
253                         clock-names = "sor", "parent", "dp", "safe";
254                         resets = <&tegra_car 182>;
255                         reset-names = "sor";
256                         pinctrl-0 = <&state_dpaux_aux>;
257                         pinctrl-1 = <&state_dpaux_i2c>;
258                         pinctrl-2 = <&state_dpaux_off>;
259                         pinctrl-names = "aux", "i2c", "off";
260                         power-domains = <&pd_sor>;
261                         status = "disabled";
262                 };
263
264                 sor@54580000 {
265                         compatible = "nvidia,tegra210-sor1";
266                         reg = <0x0 0x54580000 0x0 0x00040000>;
267                         interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
268                         clocks = <&tegra_car TEGRA210_CLK_SOR1>,
269                                  <&tegra_car TEGRA210_CLK_SOR1_OUT>,
270                                  <&tegra_car TEGRA210_CLK_PLL_D2_OUT0>,
271                                  <&tegra_car TEGRA210_CLK_PLL_DP>,
272                                  <&tegra_car TEGRA210_CLK_SOR_SAFE>;
273                         clock-names = "sor", "out", "parent", "dp", "safe";
274                         resets = <&tegra_car 183>;
275                         reset-names = "sor";
276                         pinctrl-0 = <&state_dpaux1_aux>;
277                         pinctrl-1 = <&state_dpaux1_i2c>;
278                         pinctrl-2 = <&state_dpaux1_off>;
279                         pinctrl-names = "aux", "i2c", "off";
280                         power-domains = <&pd_sor>;
281                         status = "disabled";
282                 };
283
284                 dpaux: dpaux@545c0000 {
285                         compatible = "nvidia,tegra124-dpaux";
286                         reg = <0x0 0x545c0000 0x0 0x00040000>;
287                         interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
288                         clocks = <&tegra_car TEGRA210_CLK_DPAUX>,
289                                  <&tegra_car TEGRA210_CLK_PLL_DP>;
290                         clock-names = "dpaux", "parent";
291                         resets = <&tegra_car 181>;
292                         reset-names = "dpaux";
293                         power-domains = <&pd_sor>;
294                         status = "disabled";
295
296                         state_dpaux_aux: pinmux-aux {
297                                 groups = "dpaux-io";
298                                 function = "aux";
299                         };
300
301                         state_dpaux_i2c: pinmux-i2c {
302                                 groups = "dpaux-io";
303                                 function = "i2c";
304                         };
305
306                         state_dpaux_off: pinmux-off {
307                                 groups = "dpaux-io";
308                                 function = "off";
309                         };
310
311                         i2c-bus {
312                                 #address-cells = <1>;
313                                 #size-cells = <0>;
314                         };
315                 };
316
317                 isp@54600000 {
318                         compatible = "nvidia,tegra210-isp";
319                         reg = <0x0 0x54600000 0x0 0x00040000>;
320                         interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
321                         status = "disabled";
322                 };
323
324                 isp@54680000 {
325                         compatible = "nvidia,tegra210-isp";
326                         reg = <0x0 0x54680000 0x0 0x00040000>;
327                         interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
328                         status = "disabled";
329                 };
330
331                 i2c@546c0000 {
332                         compatible = "nvidia,tegra210-i2c-vi";
333                         reg = <0x0 0x546c0000 0x0 0x00040000>;
334                         interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
335                         status = "disabled";
336                 };
337         };
338
339         gic: interrupt-controller@50041000 {
340                 compatible = "arm,gic-400";
341                 #interrupt-cells = <3>;
342                 interrupt-controller;
343                 reg = <0x0 0x50041000 0x0 0x1000>,
344                       <0x0 0x50042000 0x0 0x2000>,
345                       <0x0 0x50044000 0x0 0x2000>,
346                       <0x0 0x50046000 0x0 0x2000>;
347                 interrupts = <GIC_PPI 9
348                         (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
349                 interrupt-parent = <&gic>;
350         };
351
352         gpu@57000000 {
353                 compatible = "nvidia,gm20b";
354                 reg = <0x0 0x57000000 0x0 0x01000000>,
355                       <0x0 0x58000000 0x0 0x01000000>;
356                 interrupts = <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>,
357                              <GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>;
358                 interrupt-names = "stall", "nonstall";
359                 clocks = <&tegra_car TEGRA210_CLK_GPU>,
360                          <&tegra_car TEGRA210_CLK_PLL_P_OUT5>,
361                          <&tegra_car TEGRA210_CLK_PLL_G_REF>;
362                 clock-names = "gpu", "pwr", "ref";
363                 resets = <&tegra_car 184>;
364                 reset-names = "gpu";
365
366                 iommus = <&mc TEGRA_SWGROUP_GPU>;
367
368                 status = "disabled";
369         };
370
371         lic: interrupt-controller@60004000 {
372                 compatible = "nvidia,tegra210-ictlr";
373                 reg = <0x0 0x60004000 0x0 0x40>, /* primary controller */
374                       <0x0 0x60004100 0x0 0x40>, /* secondary controller */
375                       <0x0 0x60004200 0x0 0x40>, /* tertiary controller */
376                       <0x0 0x60004300 0x0 0x40>, /* quaternary controller */
377                       <0x0 0x60004400 0x0 0x40>, /* quinary controller */
378                       <0x0 0x60004500 0x0 0x40>; /* senary controller */
379                 interrupt-controller;
380                 #interrupt-cells = <3>;
381                 interrupt-parent = <&gic>;
382         };
383
384         timer@60005000 {
385                 compatible = "nvidia,tegra210-timer", "nvidia,tegra20-timer";
386                 reg = <0x0 0x60005000 0x0 0x400>;
387                 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
388                              <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
389                              <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
390                              <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
391                              <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
392                              <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
393                 clocks = <&tegra_car TEGRA210_CLK_TIMER>;
394                 clock-names = "timer";
395         };
396
397         tegra_car: clock@60006000 {
398                 compatible = "nvidia,tegra210-car";
399                 reg = <0x0 0x60006000 0x0 0x1000>;
400                 #clock-cells = <1>;
401                 #reset-cells = <1>;
402         };
403
404         flow-controller@60007000 {
405                 compatible = "nvidia,tegra210-flowctrl";
406                 reg = <0x0 0x60007000 0x0 0x1000>;
407         };
408
409         gpio: gpio@6000d000 {
410                 compatible = "nvidia,tegra210-gpio", "nvidia,tegra30-gpio";
411                 reg = <0x0 0x6000d000 0x0 0x1000>;
412                 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
413                              <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
414                              <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
415                              <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
416                              <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
417                              <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
418                              <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
419                              <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>;
420                 #gpio-cells = <2>;
421                 gpio-controller;
422                 #interrupt-cells = <2>;
423                 interrupt-controller;
424         };
425
426         apbdma: dma@60020000 {
427                 compatible = "nvidia,tegra210-apbdma", "nvidia,tegra148-apbdma";
428                 reg = <0x0 0x60020000 0x0 0x1400>;
429                 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
430                              <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
431                              <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
432                              <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
433                              <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
434                              <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
435                              <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
436                              <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
437                              <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
438                              <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
439                              <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
440                              <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
441                              <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
442                              <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
443                              <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
444                              <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
445                              <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
446                              <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
447                              <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
448                              <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
449                              <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
450                              <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
451                              <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
452                              <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
453                              <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
454                              <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
455                              <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
456                              <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
457                              <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
458                              <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
459                              <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
460                              <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
461                 clocks = <&tegra_car TEGRA210_CLK_APBDMA>;
462                 clock-names = "dma";
463                 resets = <&tegra_car 34>;
464                 reset-names = "dma";
465                 #dma-cells = <1>;
466         };
467
468         apbmisc@70000800 {
469                 compatible = "nvidia,tegra210-apbmisc", "nvidia,tegra20-apbmisc";
470                 reg = <0x0 0x70000800 0x0 0x64>,   /* Chip revision */
471                       <0x0 0x7000e864 0x0 0x04>;   /* Strapping options */
472         };
473
474         pinmux: pinmux@700008d4 {
475                 compatible = "nvidia,tegra210-pinmux";
476                 reg = <0x0 0x700008d4 0x0 0x29c>, /* Pad control registers */
477                       <0x0 0x70003000 0x0 0x294>; /* Mux registers */
478         };
479
480         /*
481          * There are two serial driver i.e. 8250 based simple serial
482          * driver and APB DMA based serial driver for higher baudrate
483          * and performance. To enable the 8250 based driver, the compatible
484          * is "nvidia,tegra124-uart", "nvidia,tegra20-uart" and to enable
485          * the APB DMA based serial driver, the compatible is
486          * "nvidia,tegra124-hsuart", "nvidia,tegra30-hsuart".
487          */
488         uarta: serial@70006000 {
489                 compatible = "nvidia,tegra210-uart", "nvidia,tegra20-uart";
490                 reg = <0x0 0x70006000 0x0 0x40>;
491                 reg-shift = <2>;
492                 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
493                 clocks = <&tegra_car TEGRA210_CLK_UARTA>;
494                 clock-names = "serial";
495                 resets = <&tegra_car 6>;
496                 reset-names = "serial";
497                 dmas = <&apbdma 8>, <&apbdma 8>;
498                 dma-names = "rx", "tx";
499                 status = "disabled";
500         };
501
502         uartb: serial@70006040 {
503                 compatible = "nvidia,tegra210-uart", "nvidia,tegra20-uart";
504                 reg = <0x0 0x70006040 0x0 0x40>;
505                 reg-shift = <2>;
506                 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
507                 clocks = <&tegra_car TEGRA210_CLK_UARTB>;
508                 clock-names = "serial";
509                 resets = <&tegra_car 7>;
510                 reset-names = "serial";
511                 dmas = <&apbdma 9>, <&apbdma 9>;
512                 dma-names = "rx", "tx";
513                 status = "disabled";
514         };
515
516         uartc: serial@70006200 {
517                 compatible = "nvidia,tegra210-uart", "nvidia,tegra20-uart";
518                 reg = <0x0 0x70006200 0x0 0x40>;
519                 reg-shift = <2>;
520                 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
521                 clocks = <&tegra_car TEGRA210_CLK_UARTC>;
522                 clock-names = "serial";
523                 resets = <&tegra_car 55>;
524                 reset-names = "serial";
525                 dmas = <&apbdma 10>, <&apbdma 10>;
526                 dma-names = "rx", "tx";
527                 status = "disabled";
528         };
529
530         uartd: serial@70006300 {
531                 compatible = "nvidia,tegra210-uart", "nvidia,tegra20-uart";
532                 reg = <0x0 0x70006300 0x0 0x40>;
533                 reg-shift = <2>;
534                 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
535                 clocks = <&tegra_car TEGRA210_CLK_UARTD>;
536                 clock-names = "serial";
537                 resets = <&tegra_car 65>;
538                 reset-names = "serial";
539                 dmas = <&apbdma 19>, <&apbdma 19>;
540                 dma-names = "rx", "tx";
541                 status = "disabled";
542         };
543
544         pwm: pwm@7000a000 {
545                 compatible = "nvidia,tegra210-pwm", "nvidia,tegra20-pwm";
546                 reg = <0x0 0x7000a000 0x0 0x100>;
547                 #pwm-cells = <2>;
548                 clocks = <&tegra_car TEGRA210_CLK_PWM>;
549                 clock-names = "pwm";
550                 resets = <&tegra_car 17>;
551                 reset-names = "pwm";
552                 status = "disabled";
553         };
554
555         i2c@7000c000 {
556                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
557                 reg = <0x0 0x7000c000 0x0 0x100>;
558                 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
559                 #address-cells = <1>;
560                 #size-cells = <0>;
561                 clocks = <&tegra_car TEGRA210_CLK_I2C1>;
562                 clock-names = "div-clk";
563                 resets = <&tegra_car 12>;
564                 reset-names = "i2c";
565                 dmas = <&apbdma 21>, <&apbdma 21>;
566                 dma-names = "rx", "tx";
567                 status = "disabled";
568         };
569
570         i2c@7000c400 {
571                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
572                 reg = <0x0 0x7000c400 0x0 0x100>;
573                 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
574                 #address-cells = <1>;
575                 #size-cells = <0>;
576                 clocks = <&tegra_car TEGRA210_CLK_I2C2>;
577                 clock-names = "div-clk";
578                 resets = <&tegra_car 54>;
579                 reset-names = "i2c";
580                 dmas = <&apbdma 22>, <&apbdma 22>;
581                 dma-names = "rx", "tx";
582                 status = "disabled";
583         };
584
585         i2c@7000c500 {
586                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
587                 reg = <0x0 0x7000c500 0x0 0x100>;
588                 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
589                 #address-cells = <1>;
590                 #size-cells = <0>;
591                 clocks = <&tegra_car TEGRA210_CLK_I2C3>;
592                 clock-names = "div-clk";
593                 resets = <&tegra_car 67>;
594                 reset-names = "i2c";
595                 dmas = <&apbdma 23>, <&apbdma 23>;
596                 dma-names = "rx", "tx";
597                 status = "disabled";
598         };
599
600         i2c@7000c700 {
601                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
602                 reg = <0x0 0x7000c700 0x0 0x100>;
603                 interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
604                 #address-cells = <1>;
605                 #size-cells = <0>;
606                 clocks = <&tegra_car TEGRA210_CLK_I2C4>;
607                 clock-names = "div-clk";
608                 resets = <&tegra_car 103>;
609                 reset-names = "i2c";
610                 dmas = <&apbdma 26>, <&apbdma 26>;
611                 dma-names = "rx", "tx";
612                 pinctrl-0 = <&state_dpaux1_i2c>;
613                 pinctrl-1 = <&state_dpaux1_off>;
614                 pinctrl-names = "default", "idle";
615                 status = "disabled";
616         };
617
618         i2c@7000d000 {
619                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
620                 reg = <0x0 0x7000d000 0x0 0x100>;
621                 interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
622                 #address-cells = <1>;
623                 #size-cells = <0>;
624                 clocks = <&tegra_car TEGRA210_CLK_I2C5>;
625                 clock-names = "div-clk";
626                 resets = <&tegra_car 47>;
627                 reset-names = "i2c";
628                 dmas = <&apbdma 24>, <&apbdma 24>;
629                 dma-names = "rx", "tx";
630                 status = "disabled";
631         };
632
633         i2c@7000d100 {
634                 compatible = "nvidia,tegra210-i2c", "nvidia,tegra114-i2c";
635                 reg = <0x0 0x7000d100 0x0 0x100>;
636                 interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
637                 #address-cells = <1>;
638                 #size-cells = <0>;
639                 clocks = <&tegra_car TEGRA210_CLK_I2C6>;
640                 clock-names = "div-clk";
641                 resets = <&tegra_car 166>;
642                 reset-names = "i2c";
643                 dmas = <&apbdma 30>, <&apbdma 30>;
644                 dma-names = "rx", "tx";
645                 pinctrl-0 = <&state_dpaux_i2c>;
646                 pinctrl-1 = <&state_dpaux_off>;
647                 pinctrl-names = "default", "idle";
648                 status = "disabled";
649         };
650
651         spi@7000d400 {
652                 compatible = "nvidia,tegra210-spi", "nvidia,tegra114-spi";
653                 reg = <0x0 0x7000d400 0x0 0x200>;
654                 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
655                 #address-cells = <1>;
656                 #size-cells = <0>;
657                 clocks = <&tegra_car TEGRA210_CLK_SBC1>;
658                 clock-names = "spi";
659                 resets = <&tegra_car 41>;
660                 reset-names = "spi";
661                 dmas = <&apbdma 15>, <&apbdma 15>;
662                 dma-names = "rx", "tx";
663                 status = "disabled";
664         };
665
666         spi@7000d600 {
667                 compatible = "nvidia,tegra210-spi", "nvidia,tegra114-spi";
668                 reg = <0x0 0x7000d600 0x0 0x200>;
669                 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
670                 #address-cells = <1>;
671                 #size-cells = <0>;
672                 clocks = <&tegra_car TEGRA210_CLK_SBC2>;
673                 clock-names = "spi";
674                 resets = <&tegra_car 44>;
675                 reset-names = "spi";
676                 dmas = <&apbdma 16>, <&apbdma 16>;
677                 dma-names = "rx", "tx";
678                 status = "disabled";
679         };
680
681         spi@7000d800 {
682                 compatible = "nvidia,tegra210-spi", "nvidia,tegra114-spi";
683                 reg = <0x0 0x7000d800 0x0 0x200>;
684                 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
685                 #address-cells = <1>;
686                 #size-cells = <0>;
687                 clocks = <&tegra_car TEGRA210_CLK_SBC3>;
688                 clock-names = "spi";
689                 resets = <&tegra_car 46>;
690                 reset-names = "spi";
691                 dmas = <&apbdma 17>, <&apbdma 17>;
692                 dma-names = "rx", "tx";
693                 status = "disabled";
694         };
695
696         spi@7000da00 {
697                 compatible = "nvidia,tegra210-spi", "nvidia,tegra114-spi";
698                 reg = <0x0 0x7000da00 0x0 0x200>;
699                 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
700                 #address-cells = <1>;
701                 #size-cells = <0>;
702                 clocks = <&tegra_car TEGRA210_CLK_SBC4>;
703                 clock-names = "spi";
704                 resets = <&tegra_car 68>;
705                 reset-names = "spi";
706                 dmas = <&apbdma 18>, <&apbdma 18>;
707                 dma-names = "rx", "tx";
708                 status = "disabled";
709         };
710
711         rtc@7000e000 {
712                 compatible = "nvidia,tegra210-rtc", "nvidia,tegra20-rtc";
713                 reg = <0x0 0x7000e000 0x0 0x100>;
714                 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
715                 clocks = <&tegra_car TEGRA210_CLK_RTC>;
716                 clock-names = "rtc";
717         };
718
719         pmc: pmc@7000e400 {
720                 compatible = "nvidia,tegra210-pmc";
721                 reg = <0x0 0x7000e400 0x0 0x400>;
722                 clocks = <&tegra_car TEGRA210_CLK_PCLK>, <&clk32k_in>;
723                 clock-names = "pclk", "clk32k_in";
724
725                 powergates {
726                         pd_audio: aud {
727                                 clocks = <&tegra_car TEGRA210_CLK_APE>,
728                                          <&tegra_car TEGRA210_CLK_APB2APE>;
729                                 resets = <&tegra_car 198>;
730                                 #power-domain-cells = <0>;
731                         };
732
733                         pd_sor: sor {
734                                 clocks = <&tegra_car TEGRA210_CLK_SOR0>,
735                                          <&tegra_car TEGRA210_CLK_SOR1>,
736                                          <&tegra_car TEGRA210_CLK_CSI>,
737                                          <&tegra_car TEGRA210_CLK_DSIA>,
738                                          <&tegra_car TEGRA210_CLK_DSIB>,
739                                          <&tegra_car TEGRA210_CLK_DPAUX>,
740                                          <&tegra_car TEGRA210_CLK_DPAUX1>,
741                                          <&tegra_car TEGRA210_CLK_MIPI_CAL>;
742                                 resets = <&tegra_car TEGRA210_CLK_SOR0>,
743                                          <&tegra_car TEGRA210_CLK_SOR1>,
744                                          <&tegra_car TEGRA210_CLK_CSI>,
745                                          <&tegra_car TEGRA210_CLK_DSIA>,
746                                          <&tegra_car TEGRA210_CLK_DSIB>,
747                                          <&tegra_car TEGRA210_CLK_DPAUX>,
748                                          <&tegra_car TEGRA210_CLK_DPAUX1>,
749                                          <&tegra_car TEGRA210_CLK_MIPI_CAL>;
750                                 #power-domain-cells = <0>;
751                         };
752
753                         pd_xusbss: xusba {
754                                 clocks = <&tegra_car TEGRA210_CLK_XUSB_SS>;
755                                 resets = <&tegra_car TEGRA210_CLK_XUSB_SS>;
756                                 #power-domain-cells = <0>;
757                         };
758
759                         pd_xusbdev: xusbb {
760                                 clocks = <&tegra_car TEGRA210_CLK_XUSB_DEV>;
761                                 resets = <&tegra_car 95>;
762                                 #power-domain-cells = <0>;
763                         };
764
765                         pd_xusbhost: xusbc {
766                                 clocks = <&tegra_car TEGRA210_CLK_XUSB_HOST>;
767                                 resets = <&tegra_car TEGRA210_CLK_XUSB_HOST>;
768                                 #power-domain-cells = <0>;
769                         };
770
771                         pd_vic: vic {
772                                 clocks = <&tegra_car TEGRA210_CLK_VIC03>;
773                                 clock-names = "vic";
774                                 resets = <&tegra_car 178>;
775                                 reset-names = "vic";
776                                 #power-domain-cells = <0>;
777                         };
778                 };
779         };
780
781         fuse@7000f800 {
782                 compatible = "nvidia,tegra210-efuse";
783                 reg = <0x0 0x7000f800 0x0 0x400>;
784                 clocks = <&tegra_car TEGRA210_CLK_FUSE>;
785                 clock-names = "fuse";
786                 resets = <&tegra_car 39>;
787                 reset-names = "fuse";
788         };
789
790         mc: memory-controller@70019000 {
791                 compatible = "nvidia,tegra210-mc";
792                 reg = <0x0 0x70019000 0x0 0x1000>;
793                 clocks = <&tegra_car TEGRA210_CLK_MC>;
794                 clock-names = "mc";
795
796                 interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
797
798                 #iommu-cells = <1>;
799         };
800
801         sata@70020000 {
802                 compatible = "nvidia,tegra210-ahci";
803                 reg = <0x0 0x70027000 0x0 0x2000>, /* AHCI */
804                       <0x0 0x70020000 0x0 0x7000>, /* SATA */
805                       <0x0 0x70001100 0x0 0x1000>; /* SATA AUX */
806                 interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
807                 clocks = <&tegra_car TEGRA210_CLK_SATA>,
808                          <&tegra_car TEGRA210_CLK_SATA_OOB>;
809                 clock-names = "sata", "sata-oob";
810                 resets = <&tegra_car 124>,
811                          <&tegra_car 123>,
812                          <&tegra_car 129>;
813                 reset-names = "sata", "sata-oob", "sata-cold";
814                 status = "disabled";
815         };
816
817         hda@70030000 {
818                 compatible = "nvidia,tegra210-hda", "nvidia,tegra30-hda";
819                 reg = <0x0 0x70030000 0x0 0x10000>;
820                 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
821                 clocks = <&tegra_car TEGRA210_CLK_HDA>,
822                          <&tegra_car TEGRA210_CLK_HDA2HDMI>,
823                          <&tegra_car TEGRA210_CLK_HDA2CODEC_2X>;
824                 clock-names = "hda", "hda2hdmi", "hda2codec_2x";
825                 resets = <&tegra_car 125>, /* hda */
826                          <&tegra_car 128>, /* hda2hdmi */
827                          <&tegra_car 111>; /* hda2codec_2x */
828                 reset-names = "hda", "hda2hdmi", "hda2codec_2x";
829                 power-domains = <&pd_sor>;
830                 status = "disabled";
831         };
832
833         usb@70090000 {
834                 compatible = "nvidia,tegra210-xusb";
835                 reg = <0x0 0x70090000 0x0 0x8000>,
836                       <0x0 0x70098000 0x0 0x1000>,
837                       <0x0 0x70099000 0x0 0x1000>;
838                 reg-names = "hcd", "fpci", "ipfs";
839
840                 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
841                              <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
842
843                 clocks = <&tegra_car TEGRA210_CLK_XUSB_HOST>,
844                          <&tegra_car TEGRA210_CLK_XUSB_HOST_SRC>,
845                          <&tegra_car TEGRA210_CLK_XUSB_FALCON_SRC>,
846                          <&tegra_car TEGRA210_CLK_XUSB_SS>,
847                          <&tegra_car TEGRA210_CLK_XUSB_SS_DIV2>,
848                          <&tegra_car TEGRA210_CLK_XUSB_SS_SRC>,
849                          <&tegra_car TEGRA210_CLK_XUSB_HS_SRC>,
850                          <&tegra_car TEGRA210_CLK_XUSB_FS_SRC>,
851                          <&tegra_car TEGRA210_CLK_PLL_U_480M>,
852                          <&tegra_car TEGRA210_CLK_CLK_M>,
853                          <&tegra_car TEGRA210_CLK_PLL_E>;
854                 clock-names = "xusb_host", "xusb_host_src",
855                               "xusb_falcon_src", "xusb_ss",
856                               "xusb_ss_div2", "xusb_ss_src",
857                               "xusb_hs_src", "xusb_fs_src",
858                               "pll_u_480m", "clk_m", "pll_e";
859                 resets = <&tegra_car 89>, <&tegra_car 156>,
860                          <&tegra_car 143>;
861                 reset-names = "xusb_host", "xusb_ss", "xusb_src";
862
863                 nvidia,xusb-padctl = <&padctl>;
864
865                 status = "disabled";
866         };
867
868         padctl: padctl@7009f000 {
869                 compatible = "nvidia,tegra210-xusb-padctl";
870                 reg = <0x0 0x7009f000 0x0 0x1000>;
871                 resets = <&tegra_car 142>;
872                 reset-names = "padctl";
873
874                 status = "disabled";
875
876                 pads {
877                         usb2 {
878                                 clocks = <&tegra_car TEGRA210_CLK_USB2_TRK>;
879                                 clock-names = "trk";
880                                 status = "disabled";
881
882                                 lanes {
883                                         usb2-0 {
884                                                 status = "disabled";
885                                                 #phy-cells = <0>;
886                                         };
887
888                                         usb2-1 {
889                                                 status = "disabled";
890                                                 #phy-cells = <0>;
891                                         };
892
893                                         usb2-2 {
894                                                 status = "disabled";
895                                                 #phy-cells = <0>;
896                                         };
897
898                                         usb2-3 {
899                                                 status = "disabled";
900                                                 #phy-cells = <0>;
901                                         };
902                                 };
903                         };
904
905                         hsic {
906                                 clocks = <&tegra_car TEGRA210_CLK_HSIC_TRK>;
907                                 clock-names = "trk";
908                                 status = "disabled";
909
910                                 lanes {
911                                         hsic-0 {
912                                                 status = "disabled";
913                                                 #phy-cells = <0>;
914                                         };
915
916                                         hsic-1 {
917                                                 status = "disabled";
918                                                 #phy-cells = <0>;
919                                         };
920                                 };
921                         };
922
923                         pcie {
924                                 clocks = <&tegra_car TEGRA210_CLK_PLL_E>;
925                                 clock-names = "pll";
926                                 resets = <&tegra_car 205>;
927                                 reset-names = "phy";
928                                 status = "disabled";
929
930                                 lanes {
931                                         pcie-0 {
932                                                 status = "disabled";
933                                                 #phy-cells = <0>;
934                                         };
935
936                                         pcie-1 {
937                                                 status = "disabled";
938                                                 #phy-cells = <0>;
939                                         };
940
941                                         pcie-2 {
942                                                 status = "disabled";
943                                                 #phy-cells = <0>;
944                                         };
945
946                                         pcie-3 {
947                                                 status = "disabled";
948                                                 #phy-cells = <0>;
949                                         };
950
951                                         pcie-4 {
952                                                 status = "disabled";
953                                                 #phy-cells = <0>;
954                                         };
955
956                                         pcie-5 {
957                                                 status = "disabled";
958                                                 #phy-cells = <0>;
959                                         };
960
961                                         pcie-6 {
962                                                 status = "disabled";
963                                                 #phy-cells = <0>;
964                                         };
965                                 };
966                         };
967
968                         sata {
969                                 clocks = <&tegra_car TEGRA210_CLK_PLL_E>;
970                                 clock-names = "pll";
971                                 resets = <&tegra_car 204>;
972                                 reset-names = "phy";
973                                 status = "disabled";
974
975                                 lanes {
976                                         sata-0 {
977                                                 status = "disabled";
978                                                 #phy-cells = <0>;
979                                         };
980                                 };
981                         };
982                 };
983
984                 ports {
985                         usb2-0 {
986                                 status = "disabled";
987                         };
988
989                         usb2-1 {
990                                 status = "disabled";
991                         };
992
993                         usb2-2 {
994                                 status = "disabled";
995                         };
996
997                         usb2-3 {
998                                 status = "disabled";
999                         };
1000
1001                         hsic-0 {
1002                                 status = "disabled";
1003                         };
1004
1005                         usb3-0 {
1006                                 status = "disabled";
1007                         };
1008
1009                         usb3-1 {
1010                                 status = "disabled";
1011                         };
1012
1013                         usb3-2 {
1014                                 status = "disabled";
1015                         };
1016
1017                         usb3-3 {
1018                                 status = "disabled";
1019                         };
1020                 };
1021         };
1022
1023         sdhci@700b0000 {
1024                 compatible = "nvidia,tegra210-sdhci", "nvidia,tegra124-sdhci";
1025                 reg = <0x0 0x700b0000 0x0 0x200>;
1026                 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
1027                 clocks = <&tegra_car TEGRA210_CLK_SDMMC1>;
1028                 clock-names = "sdhci";
1029                 resets = <&tegra_car 14>;
1030                 reset-names = "sdhci";
1031                 status = "disabled";
1032         };
1033
1034         sdhci@700b0200 {
1035                 compatible = "nvidia,tegra210-sdhci", "nvidia,tegra124-sdhci";
1036                 reg = <0x0 0x700b0200 0x0 0x200>;
1037                 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
1038                 clocks = <&tegra_car TEGRA210_CLK_SDMMC2>;
1039                 clock-names = "sdhci";
1040                 resets = <&tegra_car 9>;
1041                 reset-names = "sdhci";
1042                 status = "disabled";
1043         };
1044
1045         sdhci@700b0400 {
1046                 compatible = "nvidia,tegra210-sdhci", "nvidia,tegra124-sdhci";
1047                 reg = <0x0 0x700b0400 0x0 0x200>;
1048                 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
1049                 clocks = <&tegra_car TEGRA210_CLK_SDMMC3>;
1050                 clock-names = "sdhci";
1051                 resets = <&tegra_car 69>;
1052                 reset-names = "sdhci";
1053                 status = "disabled";
1054         };
1055
1056         sdhci@700b0600 {
1057                 compatible = "nvidia,tegra210-sdhci", "nvidia,tegra124-sdhci";
1058                 reg = <0x0 0x700b0600 0x0 0x200>;
1059                 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
1060                 clocks = <&tegra_car TEGRA210_CLK_SDMMC4>;
1061                 clock-names = "sdhci";
1062                 resets = <&tegra_car 15>;
1063                 reset-names = "sdhci";
1064                 status = "disabled";
1065         };
1066
1067         mipi: mipi@700e3000 {
1068                 compatible = "nvidia,tegra210-mipi";
1069                 reg = <0x0 0x700e3000 0x0 0x100>;
1070                 clocks = <&tegra_car TEGRA210_CLK_MIPI_CAL>;
1071                 clock-names = "mipi-cal";
1072                 power-domains = <&pd_sor>;
1073                 #nvidia,mipi-calibrate-cells = <1>;
1074         };
1075
1076         aconnect@702c0000 {
1077                 compatible = "nvidia,tegra210-aconnect";
1078                 clocks = <&tegra_car TEGRA210_CLK_APE>,
1079                          <&tegra_car TEGRA210_CLK_APB2APE>;
1080                 clock-names = "ape", "apb2ape";
1081                 power-domains = <&pd_audio>;
1082                 #address-cells = <1>;
1083                 #size-cells = <1>;
1084                 ranges = <0x702c0000 0x0 0x702c0000 0x00040000>;
1085                 status = "disabled";
1086
1087                 adma: dma@702e2000 {
1088                         compatible = "nvidia,tegra210-adma";
1089                         reg = <0x702e2000 0x2000>;
1090                         interrupt-parent = <&agic>;
1091                         interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>,
1092                                      <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>,
1093                                      <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>,
1094                                      <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>,
1095                                      <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>,
1096                                      <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>,
1097                                      <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>,
1098                                      <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>,
1099                                      <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
1100                                      <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
1101                                      <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
1102                                      <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
1103                                      <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>,
1104                                      <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>,
1105                                      <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>,
1106                                      <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
1107                                      <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
1108                                      <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
1109                                      <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
1110                                      <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>,
1111                                      <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
1112                                      <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
1113                         #dma-cells = <1>;
1114                         clocks = <&tegra_car TEGRA210_CLK_D_AUDIO>;
1115                         clock-names = "d_audio";
1116                         status = "disabled";
1117                 };
1118
1119                 agic: agic@702f9000 {
1120                         compatible = "nvidia,tegra210-agic";
1121                         #interrupt-cells = <3>;
1122                         interrupt-controller;
1123                         reg = <0x702f9000 0x1000>,
1124                               <0x702fa000 0x2000>;
1125                         interrupts = <GIC_SPI 102 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
1126                         clocks = <&tegra_car TEGRA210_CLK_APE>;
1127                         clock-names = "clk";
1128                         status = "disabled";
1129                 };
1130         };
1131
1132         spi@70410000 {
1133                 compatible = "nvidia,tegra210-qspi";
1134                 reg = <0x0 0x70410000 0x0 0x1000>;
1135                 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
1136                 #address-cells = <1>;
1137                 #size-cells = <0>;
1138                 clocks = <&tegra_car TEGRA210_CLK_QSPI>;
1139                 clock-names = "qspi";
1140                 resets = <&tegra_car 211>;
1141                 reset-names = "qspi";
1142                 dmas = <&apbdma 5>, <&apbdma 5>;
1143                 dma-names = "rx", "tx";
1144                 status = "disabled";
1145         };
1146
1147         usb@7d000000 {
1148                 compatible = "nvidia,tegra210-ehci", "nvidia,tegra30-ehci", "usb-ehci";
1149                 reg = <0x0 0x7d000000 0x0 0x4000>;
1150                 interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
1151                 phy_type = "utmi";
1152                 clocks = <&tegra_car TEGRA210_CLK_USBD>;
1153                 clock-names = "usb";
1154                 resets = <&tegra_car 22>;
1155                 reset-names = "usb";
1156                 nvidia,phy = <&phy1>;
1157                 status = "disabled";
1158         };
1159
1160         phy1: usb-phy@7d000000 {
1161                 compatible = "nvidia,tegra210-usb-phy", "nvidia,tegra30-usb-phy";
1162                 reg = <0x0 0x7d000000 0x0 0x4000>,
1163                       <0x0 0x7d000000 0x0 0x4000>;
1164                 phy_type = "utmi";
1165                 clocks = <&tegra_car TEGRA210_CLK_USBD>,
1166                          <&tegra_car TEGRA210_CLK_PLL_U>,
1167                          <&tegra_car TEGRA210_CLK_USBD>;
1168                 clock-names = "reg", "pll_u", "utmi-pads";
1169                 resets = <&tegra_car 22>, <&tegra_car 22>;
1170                 reset-names = "usb", "utmi-pads";
1171                 nvidia,hssync-start-delay = <0>;
1172                 nvidia,idle-wait-delay = <17>;
1173                 nvidia,elastic-limit = <16>;
1174                 nvidia,term-range-adj = <6>;
1175                 nvidia,xcvr-setup = <9>;
1176                 nvidia,xcvr-lsfslew = <0>;
1177                 nvidia,xcvr-lsrslew = <3>;
1178                 nvidia,hssquelch-level = <2>;
1179                 nvidia,hsdiscon-level = <5>;
1180                 nvidia,xcvr-hsslew = <12>;
1181                 nvidia,has-utmi-pad-registers;
1182                 status = "disabled";
1183         };
1184
1185         usb@7d004000 {
1186                 compatible = "nvidia,tegra210-ehci", "nvidia,tegra30-ehci", "usb-ehci";
1187                 reg = <0x0 0x7d004000 0x0 0x4000>;
1188                 interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
1189                 phy_type = "utmi";
1190                 clocks = <&tegra_car TEGRA210_CLK_USB2>;
1191                 clock-names = "usb";
1192                 resets = <&tegra_car 58>;
1193                 reset-names = "usb";
1194                 nvidia,phy = <&phy2>;
1195                 status = "disabled";
1196         };
1197
1198         phy2: usb-phy@7d004000 {
1199                 compatible = "nvidia,tegra210-usb-phy", "nvidia,tegra30-usb-phy";
1200                 reg = <0x0 0x7d004000 0x0 0x4000>,
1201                       <0x0 0x7d000000 0x0 0x4000>;
1202                 phy_type = "utmi";
1203                 clocks = <&tegra_car TEGRA210_CLK_USB2>,
1204                          <&tegra_car TEGRA210_CLK_PLL_U>,
1205                          <&tegra_car TEGRA210_CLK_USBD>;
1206                 clock-names = "reg", "pll_u", "utmi-pads";
1207                 resets = <&tegra_car 58>, <&tegra_car 22>;
1208                 reset-names = "usb", "utmi-pads";
1209                 nvidia,hssync-start-delay = <0>;
1210                 nvidia,idle-wait-delay = <17>;
1211                 nvidia,elastic-limit = <16>;
1212                 nvidia,term-range-adj = <6>;
1213                 nvidia,xcvr-setup = <9>;
1214                 nvidia,xcvr-lsfslew = <0>;
1215                 nvidia,xcvr-lsrslew = <3>;
1216                 nvidia,hssquelch-level = <2>;
1217                 nvidia,hsdiscon-level = <5>;
1218                 nvidia,xcvr-hsslew = <12>;
1219                 status = "disabled";
1220         };
1221
1222         cpus {
1223                 #address-cells = <1>;
1224                 #size-cells = <0>;
1225
1226                 cpu@0 {
1227                         device_type = "cpu";
1228                         compatible = "arm,cortex-a57";
1229                         reg = <0>;
1230                 };
1231
1232                 cpu@1 {
1233                         device_type = "cpu";
1234                         compatible = "arm,cortex-a57";
1235                         reg = <1>;
1236                 };
1237
1238                 cpu@2 {
1239                         device_type = "cpu";
1240                         compatible = "arm,cortex-a57";
1241                         reg = <2>;
1242                 };
1243
1244                 cpu@3 {
1245                         device_type = "cpu";
1246                         compatible = "arm,cortex-a57";
1247                         reg = <3>;
1248                 };
1249         };
1250
1251         timer {
1252                 compatible = "arm,armv8-timer";
1253                 interrupts = <GIC_PPI 13
1254                                 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
1255                              <GIC_PPI 14
1256                                 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
1257                              <GIC_PPI 11
1258                                 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
1259                              <GIC_PPI 10
1260                                 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
1261                 interrupt-parent = <&gic>;
1262         };
1263
1264         soctherm: thermal-sensor@700e2000 {
1265                 compatible = "nvidia,tegra210-soctherm";
1266                 reg = <0x0 0x700e2000 0x0 0x600 /* SOC_THERM reg_base */
1267                         0x0 0x60006000 0x0 0x400>; /* CAR reg_base */
1268                 reg-names = "soctherm-reg", "car-reg";
1269                 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
1270                 clocks = <&tegra_car TEGRA210_CLK_TSENSOR>,
1271                         <&tegra_car TEGRA210_CLK_SOC_THERM>;
1272                 clock-names = "tsensor", "soctherm";
1273                 resets = <&tegra_car 78>;
1274                 reset-names = "soctherm";
1275                 #thermal-sensor-cells = <1>;
1276
1277                 throttle-cfgs {
1278                         throttle_heavy: heavy {
1279                                 nvidia,priority = <100>;
1280                                 nvidia,cpu-throt-percent = <85>;
1281
1282                                 #cooling-cells = <2>;
1283                         };
1284                 };
1285         };
1286
1287         thermal-zones {
1288                 cpu {
1289                         polling-delay-passive = <1000>;
1290                         polling-delay = <0>;
1291
1292                         thermal-sensors =
1293                                 <&soctherm TEGRA124_SOCTHERM_SENSOR_CPU>;
1294
1295                         trips {
1296                                 cpu-shutdown-trip {
1297                                         temperature = <102500>;
1298                                         hysteresis = <0>;
1299                                         type = "critical";
1300                                 };
1301
1302                                 cpu_throttle_trip: throttle-trip {
1303                                         temperature = <98500>;
1304                                         hysteresis = <1000>;
1305                                         type = "hot";
1306                                 };
1307                         };
1308
1309                         cooling-maps {
1310                                 map0 {
1311                                         trip = <&cpu_throttle_trip>;
1312                                         cooling-device = <&throttle_heavy 1 1>;
1313                                 };
1314                         };
1315                 };
1316                 mem {
1317                         polling-delay-passive = <0>;
1318                         polling-delay = <0>;
1319
1320                         thermal-sensors =
1321                                 <&soctherm TEGRA124_SOCTHERM_SENSOR_MEM>;
1322
1323                         trips {
1324                                 mem-shutdown-trip {
1325                                         temperature = <103000>;
1326                                         hysteresis = <0>;
1327                                         type = "critical";
1328                                 };
1329                         };
1330
1331                         cooling-maps {
1332                                 /*
1333                                  * There are currently no cooling maps,
1334                                  * because there are no cooling devices.
1335                                  */
1336                         };
1337                 };
1338                 gpu {
1339                         polling-delay-passive = <1000>;
1340                         polling-delay = <0>;
1341
1342                         thermal-sensors =
1343                                 <&soctherm TEGRA124_SOCTHERM_SENSOR_GPU>;
1344
1345                         trips {
1346                                 gpu-shutdown-trip {
1347                                         temperature = <103000>;
1348                                         hysteresis = <0>;
1349                                         type = "critical";
1350                                 };
1351
1352                                 gpu_throttle_trip: throttle-trip {
1353                                         temperature = <100000>;
1354                                         hysteresis = <1000>;
1355                                         type = "hot";
1356                                 };
1357                         };
1358
1359                         cooling-maps {
1360                                 map0 {
1361                                         trip = <&gpu_throttle_trip>;
1362                                         cooling-device = <&throttle_heavy 1 1>;
1363                                 };
1364                         };
1365                 };
1366                 pllx {
1367                         polling-delay-passive = <0>;
1368                         polling-delay = <0>;
1369
1370                         thermal-sensors =
1371                                 <&soctherm TEGRA124_SOCTHERM_SENSOR_PLLX>;
1372
1373                         trips {
1374                                 pllx-shutdown-trip {
1375                                         temperature = <103000>;
1376                                         hysteresis = <0>;
1377                                         type = "critical";
1378                                 };
1379                         };
1380
1381                         cooling-maps {
1382                                 /*
1383                                  * There are currently no cooling maps,
1384                                  * because there are no cooling devices.
1385                                  */
1386                         };
1387                 };
1388         };
1389 };