xref: /freebsd/sys/contrib/device-tree/src/arm/nvidia/tegra114.dtsi (revision aa1a8ff2d6dbc51ef058f46f3db5a8bb77967145)
1*f126890aSEmmanuel Vadot// SPDX-License-Identifier: GPL-2.0
2*f126890aSEmmanuel Vadot#include <dt-bindings/clock/tegra114-car.h>
3*f126890aSEmmanuel Vadot#include <dt-bindings/gpio/tegra-gpio.h>
4*f126890aSEmmanuel Vadot#include <dt-bindings/memory/tegra114-mc.h>
5*f126890aSEmmanuel Vadot#include <dt-bindings/pinctrl/pinctrl-tegra.h>
6*f126890aSEmmanuel Vadot#include <dt-bindings/interrupt-controller/arm-gic.h>
7*f126890aSEmmanuel Vadot#include <dt-bindings/soc/tegra-pmc.h>
8*f126890aSEmmanuel Vadot
9*f126890aSEmmanuel Vadot/ {
10*f126890aSEmmanuel Vadot	compatible = "nvidia,tegra114";
11*f126890aSEmmanuel Vadot	interrupt-parent = <&lic>;
12*f126890aSEmmanuel Vadot	#address-cells = <1>;
13*f126890aSEmmanuel Vadot	#size-cells = <1>;
14*f126890aSEmmanuel Vadot
15*f126890aSEmmanuel Vadot	memory@80000000 {
16*f126890aSEmmanuel Vadot		device_type = "memory";
17*f126890aSEmmanuel Vadot		reg = <0x80000000 0x0>;
18*f126890aSEmmanuel Vadot	};
19*f126890aSEmmanuel Vadot
20*f126890aSEmmanuel Vadot	sram@40000000 {
21*f126890aSEmmanuel Vadot		compatible = "mmio-sram";
22*f126890aSEmmanuel Vadot		reg = <0x40000000 0x40000>;
23*f126890aSEmmanuel Vadot		#address-cells = <1>;
24*f126890aSEmmanuel Vadot		#size-cells = <1>;
25*f126890aSEmmanuel Vadot		ranges = <0 0x40000000 0x40000>;
26*f126890aSEmmanuel Vadot
27*f126890aSEmmanuel Vadot		vde_pool: sram@400 {
28*f126890aSEmmanuel Vadot			reg = <0x400 0x3fc00>;
29*f126890aSEmmanuel Vadot			pool;
30*f126890aSEmmanuel Vadot		};
31*f126890aSEmmanuel Vadot	};
32*f126890aSEmmanuel Vadot
33*f126890aSEmmanuel Vadot	host1x@50000000 {
34*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-host1x";
35*f126890aSEmmanuel Vadot		reg = <0x50000000 0x00028000>;
36*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */
37*f126890aSEmmanuel Vadot			     <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */
38*f126890aSEmmanuel Vadot		interrupt-names = "syncpt", "host1x";
39*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_HOST1X>;
40*f126890aSEmmanuel Vadot		clock-names = "host1x";
41*f126890aSEmmanuel Vadot		resets = <&tegra_car 28>, <&mc TEGRA114_MC_RESET_HC>;
42*f126890aSEmmanuel Vadot		reset-names = "host1x", "mc";
43*f126890aSEmmanuel Vadot		iommus = <&mc TEGRA_SWGROUP_HC>;
44*f126890aSEmmanuel Vadot
45*f126890aSEmmanuel Vadot		#address-cells = <1>;
46*f126890aSEmmanuel Vadot		#size-cells = <1>;
47*f126890aSEmmanuel Vadot
48*f126890aSEmmanuel Vadot		ranges = <0x54000000 0x54000000 0x01000000>;
49*f126890aSEmmanuel Vadot
50*f126890aSEmmanuel Vadot		gr2d@54140000 {
51*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-gr2d";
52*f126890aSEmmanuel Vadot			reg = <0x54140000 0x00040000>;
53*f126890aSEmmanuel Vadot			interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
54*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_GR2D>;
55*f126890aSEmmanuel Vadot			resets = <&tegra_car 21>, <&mc TEGRA114_MC_RESET_2D>;
56*f126890aSEmmanuel Vadot			reset-names = "2d", "mc";
57*f126890aSEmmanuel Vadot
58*f126890aSEmmanuel Vadot			iommus = <&mc TEGRA_SWGROUP_G2>;
59*f126890aSEmmanuel Vadot		};
60*f126890aSEmmanuel Vadot
61*f126890aSEmmanuel Vadot		gr3d@54180000 {
62*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-gr3d";
63*f126890aSEmmanuel Vadot			reg = <0x54180000 0x00040000>;
64*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_GR3D>;
65*f126890aSEmmanuel Vadot			resets = <&tegra_car 24>, <&mc TEGRA114_MC_RESET_3D>;
66*f126890aSEmmanuel Vadot			reset-names = "3d", "mc";
67*f126890aSEmmanuel Vadot
68*f126890aSEmmanuel Vadot			iommus = <&mc TEGRA_SWGROUP_NV>;
69*f126890aSEmmanuel Vadot		};
70*f126890aSEmmanuel Vadot
71*f126890aSEmmanuel Vadot		dc@54200000 {
72*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-dc";
73*f126890aSEmmanuel Vadot			reg = <0x54200000 0x00040000>;
74*f126890aSEmmanuel Vadot			interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
75*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_DISP1>,
76*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_PLL_P>;
77*f126890aSEmmanuel Vadot			clock-names = "dc", "parent";
78*f126890aSEmmanuel Vadot			resets = <&tegra_car 27>;
79*f126890aSEmmanuel Vadot			reset-names = "dc";
80*f126890aSEmmanuel Vadot
81*f126890aSEmmanuel Vadot			iommus = <&mc TEGRA_SWGROUP_DC>;
82*f126890aSEmmanuel Vadot
83*f126890aSEmmanuel Vadot			nvidia,head = <0>;
84*f126890aSEmmanuel Vadot
85*f126890aSEmmanuel Vadot			rgb {
86*f126890aSEmmanuel Vadot				status = "disabled";
87*f126890aSEmmanuel Vadot			};
88*f126890aSEmmanuel Vadot		};
89*f126890aSEmmanuel Vadot
90*f126890aSEmmanuel Vadot		dc@54240000 {
91*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-dc";
92*f126890aSEmmanuel Vadot			reg = <0x54240000 0x00040000>;
93*f126890aSEmmanuel Vadot			interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
94*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_DISP2>,
95*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_PLL_P>;
96*f126890aSEmmanuel Vadot			clock-names = "dc", "parent";
97*f126890aSEmmanuel Vadot			resets = <&tegra_car 26>;
98*f126890aSEmmanuel Vadot			reset-names = "dc";
99*f126890aSEmmanuel Vadot
100*f126890aSEmmanuel Vadot			iommus = <&mc TEGRA_SWGROUP_DCB>;
101*f126890aSEmmanuel Vadot
102*f126890aSEmmanuel Vadot			nvidia,head = <1>;
103*f126890aSEmmanuel Vadot
104*f126890aSEmmanuel Vadot			rgb {
105*f126890aSEmmanuel Vadot				status = "disabled";
106*f126890aSEmmanuel Vadot			};
107*f126890aSEmmanuel Vadot		};
108*f126890aSEmmanuel Vadot
109*f126890aSEmmanuel Vadot		hdmi@54280000 {
110*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-hdmi";
111*f126890aSEmmanuel Vadot			reg = <0x54280000 0x00040000>;
112*f126890aSEmmanuel Vadot			interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
113*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_HDMI>,
114*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_PLL_D2_OUT0>;
115*f126890aSEmmanuel Vadot			clock-names = "hdmi", "parent";
116*f126890aSEmmanuel Vadot			resets = <&tegra_car 51>;
117*f126890aSEmmanuel Vadot			reset-names = "hdmi";
118*f126890aSEmmanuel Vadot			status = "disabled";
119*f126890aSEmmanuel Vadot		};
120*f126890aSEmmanuel Vadot
121*f126890aSEmmanuel Vadot		dsia: dsi@54300000 {
122*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-dsi";
123*f126890aSEmmanuel Vadot			reg = <0x54300000 0x00040000>;
124*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_DSIA>,
125*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_DSIALP>,
126*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_PLL_D_OUT0>;
127*f126890aSEmmanuel Vadot			clock-names = "dsi", "lp", "parent";
128*f126890aSEmmanuel Vadot			resets = <&tegra_car 48>;
129*f126890aSEmmanuel Vadot			reset-names = "dsi";
130*f126890aSEmmanuel Vadot			nvidia,mipi-calibrate = <&mipi 0x060>; /* DSIA & DSIB pads */
131*f126890aSEmmanuel Vadot			status = "disabled";
132*f126890aSEmmanuel Vadot
133*f126890aSEmmanuel Vadot			#address-cells = <1>;
134*f126890aSEmmanuel Vadot			#size-cells = <0>;
135*f126890aSEmmanuel Vadot		};
136*f126890aSEmmanuel Vadot
137*f126890aSEmmanuel Vadot		dsib: dsi@54400000 {
138*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-dsi";
139*f126890aSEmmanuel Vadot			reg = <0x54400000 0x00040000>;
140*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_DSIB>,
141*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_DSIBLP>,
142*f126890aSEmmanuel Vadot				 <&tegra_car TEGRA114_CLK_PLL_D2_OUT0>;
143*f126890aSEmmanuel Vadot			clock-names = "dsi", "lp", "parent";
144*f126890aSEmmanuel Vadot			resets = <&tegra_car 82>;
145*f126890aSEmmanuel Vadot			reset-names = "dsi";
146*f126890aSEmmanuel Vadot			nvidia,mipi-calibrate = <&mipi 0x180>; /* DSIC & DSID pads */
147*f126890aSEmmanuel Vadot			status = "disabled";
148*f126890aSEmmanuel Vadot
149*f126890aSEmmanuel Vadot			#address-cells = <1>;
150*f126890aSEmmanuel Vadot			#size-cells = <0>;
151*f126890aSEmmanuel Vadot		};
152*f126890aSEmmanuel Vadot	};
153*f126890aSEmmanuel Vadot
154*f126890aSEmmanuel Vadot	gic: interrupt-controller@50041000 {
155*f126890aSEmmanuel Vadot		compatible = "arm,cortex-a15-gic";
156*f126890aSEmmanuel Vadot		#interrupt-cells = <3>;
157*f126890aSEmmanuel Vadot		interrupt-controller;
158*f126890aSEmmanuel Vadot		reg = <0x50041000 0x1000>,
159*f126890aSEmmanuel Vadot		      <0x50042000 0x1000>,
160*f126890aSEmmanuel Vadot		      <0x50044000 0x2000>,
161*f126890aSEmmanuel Vadot		      <0x50046000 0x2000>;
162*f126890aSEmmanuel Vadot		interrupts = <GIC_PPI 9
163*f126890aSEmmanuel Vadot			(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
164*f126890aSEmmanuel Vadot		interrupt-parent = <&gic>;
165*f126890aSEmmanuel Vadot	};
166*f126890aSEmmanuel Vadot
167*f126890aSEmmanuel Vadot	lic: interrupt-controller@60004000 {
168*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-ictlr", "nvidia,tegra30-ictlr";
169*f126890aSEmmanuel Vadot		reg = <0x60004000 0x100>,
170*f126890aSEmmanuel Vadot		      <0x60004100 0x50>,
171*f126890aSEmmanuel Vadot		      <0x60004200 0x50>,
172*f126890aSEmmanuel Vadot		      <0x60004300 0x50>,
173*f126890aSEmmanuel Vadot		      <0x60004400 0x50>;
174*f126890aSEmmanuel Vadot		interrupt-controller;
175*f126890aSEmmanuel Vadot		#interrupt-cells = <3>;
176*f126890aSEmmanuel Vadot		interrupt-parent = <&gic>;
177*f126890aSEmmanuel Vadot	};
178*f126890aSEmmanuel Vadot
179*f126890aSEmmanuel Vadot	timer@60005000 {
180*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-timer", "nvidia,tegra30-timer";
181*f126890aSEmmanuel Vadot		reg = <0x60005000 0x400>;
182*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
183*f126890aSEmmanuel Vadot			     <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
184*f126890aSEmmanuel Vadot			     <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
185*f126890aSEmmanuel Vadot			     <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
186*f126890aSEmmanuel Vadot			     <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
187*f126890aSEmmanuel Vadot			     <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
188*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_TIMER>;
189*f126890aSEmmanuel Vadot	};
190*f126890aSEmmanuel Vadot
191*f126890aSEmmanuel Vadot	tegra_car: clock@60006000 {
192*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-car";
193*f126890aSEmmanuel Vadot		reg = <0x60006000 0x1000>;
194*f126890aSEmmanuel Vadot		#clock-cells = <1>;
195*f126890aSEmmanuel Vadot		#reset-cells = <1>;
196*f126890aSEmmanuel Vadot	};
197*f126890aSEmmanuel Vadot
198*f126890aSEmmanuel Vadot	flow-controller@60007000 {
199*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-flowctrl";
200*f126890aSEmmanuel Vadot		reg = <0x60007000 0x1000>;
201*f126890aSEmmanuel Vadot	};
202*f126890aSEmmanuel Vadot
203*f126890aSEmmanuel Vadot	apbdma: dma@6000a000 {
204*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-apbdma";
205*f126890aSEmmanuel Vadot		reg = <0x6000a000 0x1400>;
206*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
207*f126890aSEmmanuel Vadot			     <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
208*f126890aSEmmanuel Vadot			     <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
209*f126890aSEmmanuel Vadot			     <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
210*f126890aSEmmanuel Vadot			     <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
211*f126890aSEmmanuel Vadot			     <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
212*f126890aSEmmanuel Vadot			     <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
213*f126890aSEmmanuel Vadot			     <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
214*f126890aSEmmanuel Vadot			     <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
215*f126890aSEmmanuel Vadot			     <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
216*f126890aSEmmanuel Vadot			     <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
217*f126890aSEmmanuel Vadot			     <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
218*f126890aSEmmanuel Vadot			     <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
219*f126890aSEmmanuel Vadot			     <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
220*f126890aSEmmanuel Vadot			     <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
221*f126890aSEmmanuel Vadot			     <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
222*f126890aSEmmanuel Vadot			     <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
223*f126890aSEmmanuel Vadot			     <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
224*f126890aSEmmanuel Vadot			     <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
225*f126890aSEmmanuel Vadot			     <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
226*f126890aSEmmanuel Vadot			     <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
227*f126890aSEmmanuel Vadot			     <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
228*f126890aSEmmanuel Vadot			     <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
229*f126890aSEmmanuel Vadot			     <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
230*f126890aSEmmanuel Vadot			     <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
231*f126890aSEmmanuel Vadot			     <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
232*f126890aSEmmanuel Vadot			     <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
233*f126890aSEmmanuel Vadot			     <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
234*f126890aSEmmanuel Vadot			     <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
235*f126890aSEmmanuel Vadot			     <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
236*f126890aSEmmanuel Vadot			     <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
237*f126890aSEmmanuel Vadot			     <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
238*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_APBDMA>;
239*f126890aSEmmanuel Vadot		resets = <&tegra_car 34>;
240*f126890aSEmmanuel Vadot		reset-names = "dma";
241*f126890aSEmmanuel Vadot		#dma-cells = <1>;
242*f126890aSEmmanuel Vadot	};
243*f126890aSEmmanuel Vadot
244*f126890aSEmmanuel Vadot	ahb: ahb@6000c000 {
245*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-ahb", "nvidia,tegra30-ahb";
246*f126890aSEmmanuel Vadot		reg = <0x6000c000 0x150>;
247*f126890aSEmmanuel Vadot	};
248*f126890aSEmmanuel Vadot
249*f126890aSEmmanuel Vadot	gpio: gpio@6000d000 {
250*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-gpio", "nvidia,tegra30-gpio";
251*f126890aSEmmanuel Vadot		reg = <0x6000d000 0x1000>;
252*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>,
253*f126890aSEmmanuel Vadot			     <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>,
254*f126890aSEmmanuel Vadot			     <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>,
255*f126890aSEmmanuel Vadot			     <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>,
256*f126890aSEmmanuel Vadot			     <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
257*f126890aSEmmanuel Vadot			     <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
258*f126890aSEmmanuel Vadot			     <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
259*f126890aSEmmanuel Vadot			     <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>;
260*f126890aSEmmanuel Vadot		#gpio-cells = <2>;
261*f126890aSEmmanuel Vadot		gpio-controller;
262*f126890aSEmmanuel Vadot		#interrupt-cells = <2>;
263*f126890aSEmmanuel Vadot		interrupt-controller;
264*f126890aSEmmanuel Vadot		gpio-ranges = <&pinmux 0 0 246>;
265*f126890aSEmmanuel Vadot	};
266*f126890aSEmmanuel Vadot
267*f126890aSEmmanuel Vadot	vde@6001a000 {
268*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-vde";
269*f126890aSEmmanuel Vadot		reg = <0x6001a000 0x1000>, /* Syntax Engine */
270*f126890aSEmmanuel Vadot		      <0x6001b000 0x1000>, /* Video Bitstream Engine */
271*f126890aSEmmanuel Vadot		      <0x6001c000  0x100>, /* Macroblock Engine */
272*f126890aSEmmanuel Vadot		      <0x6001c200  0x100>, /* Post-processing Engine */
273*f126890aSEmmanuel Vadot		      <0x6001c400  0x100>, /* Motion Compensation Engine */
274*f126890aSEmmanuel Vadot		      <0x6001c600  0x100>, /* Transform Engine */
275*f126890aSEmmanuel Vadot		      <0x6001c800  0x100>, /* Pixel prediction block */
276*f126890aSEmmanuel Vadot		      <0x6001ca00  0x100>, /* Video DMA */
277*f126890aSEmmanuel Vadot		      <0x6001d800  0x400>; /* Video frame controls */
278*f126890aSEmmanuel Vadot		reg-names = "sxe", "bsev", "mbe", "ppe", "mce",
279*f126890aSEmmanuel Vadot			    "tfe", "ppb", "vdma", "frameid";
280*f126890aSEmmanuel Vadot		iram = <&vde_pool>; /* IRAM region */
281*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI  9 IRQ_TYPE_LEVEL_HIGH>, /* Sync token interrupt */
282*f126890aSEmmanuel Vadot			     <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>, /* BSE-V interrupt */
283*f126890aSEmmanuel Vadot			     <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>; /* SXE interrupt */
284*f126890aSEmmanuel Vadot		interrupt-names = "sync-token", "bsev", "sxe";
285*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_VDE>;
286*f126890aSEmmanuel Vadot		reset-names = "vde", "mc";
287*f126890aSEmmanuel Vadot		resets = <&tegra_car 61>, <&mc TEGRA114_MC_RESET_VDE>;
288*f126890aSEmmanuel Vadot		iommus = <&mc TEGRA_SWGROUP_VDE>;
289*f126890aSEmmanuel Vadot	};
290*f126890aSEmmanuel Vadot
291*f126890aSEmmanuel Vadot	apbmisc@70000800 {
292*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-apbmisc", "nvidia,tegra20-apbmisc";
293*f126890aSEmmanuel Vadot		reg = <0x70000800 0x64>, /* Chip revision */
294*f126890aSEmmanuel Vadot		      <0x70000008 0x04>; /* Strapping options */
295*f126890aSEmmanuel Vadot	};
296*f126890aSEmmanuel Vadot
297*f126890aSEmmanuel Vadot	pinmux: pinmux@70000868 {
298*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-pinmux";
299*f126890aSEmmanuel Vadot		reg = <0x70000868 0x148>, /* Pad control registers */
300*f126890aSEmmanuel Vadot		      <0x70003000 0x40c>; /* Mux registers */
301*f126890aSEmmanuel Vadot	};
302*f126890aSEmmanuel Vadot
303*f126890aSEmmanuel Vadot	/*
304*f126890aSEmmanuel Vadot	 * There are two serial driver i.e. 8250 based simple serial
305*f126890aSEmmanuel Vadot	 * driver and APB DMA based serial driver for higher baudrate
306*f126890aSEmmanuel Vadot	 * and performace. To enable the 8250 based driver, the compatible
307*f126890aSEmmanuel Vadot	 * is "nvidia,tegra114-uart", "nvidia,tegra20-uart" and to enable
308*f126890aSEmmanuel Vadot	 * the APB DMA based serial driver, the compatible is
309*f126890aSEmmanuel Vadot	 * "nvidia,tegra114-hsuart", "nvidia,tegra30-hsuart".
310*f126890aSEmmanuel Vadot	 */
311*f126890aSEmmanuel Vadot	uarta: serial@70006000 {
312*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-uart", "nvidia,tegra20-uart";
313*f126890aSEmmanuel Vadot		reg = <0x70006000 0x40>;
314*f126890aSEmmanuel Vadot		reg-shift = <2>;
315*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
316*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_UARTA>;
317*f126890aSEmmanuel Vadot		resets = <&tegra_car 6>;
318*f126890aSEmmanuel Vadot		dmas = <&apbdma 8>, <&apbdma 8>;
319*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
320*f126890aSEmmanuel Vadot		status = "disabled";
321*f126890aSEmmanuel Vadot	};
322*f126890aSEmmanuel Vadot
323*f126890aSEmmanuel Vadot	uartb: serial@70006040 {
324*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-uart", "nvidia,tegra20-uart";
325*f126890aSEmmanuel Vadot		reg = <0x70006040 0x40>;
326*f126890aSEmmanuel Vadot		reg-shift = <2>;
327*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
328*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_UARTB>;
329*f126890aSEmmanuel Vadot		resets = <&tegra_car 7>;
330*f126890aSEmmanuel Vadot		dmas = <&apbdma 9>, <&apbdma 9>;
331*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
332*f126890aSEmmanuel Vadot		status = "disabled";
333*f126890aSEmmanuel Vadot	};
334*f126890aSEmmanuel Vadot
335*f126890aSEmmanuel Vadot	uartc: serial@70006200 {
336*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-uart", "nvidia,tegra20-uart";
337*f126890aSEmmanuel Vadot		reg = <0x70006200 0x100>;
338*f126890aSEmmanuel Vadot		reg-shift = <2>;
339*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
340*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_UARTC>;
341*f126890aSEmmanuel Vadot		resets = <&tegra_car 55>;
342*f126890aSEmmanuel Vadot		dmas = <&apbdma 10>, <&apbdma 10>;
343*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
344*f126890aSEmmanuel Vadot		status = "disabled";
345*f126890aSEmmanuel Vadot	};
346*f126890aSEmmanuel Vadot
347*f126890aSEmmanuel Vadot	uartd: serial@70006300 {
348*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-uart", "nvidia,tegra20-uart";
349*f126890aSEmmanuel Vadot		reg = <0x70006300 0x100>;
350*f126890aSEmmanuel Vadot		reg-shift = <2>;
351*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
352*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_UARTD>;
353*f126890aSEmmanuel Vadot		resets = <&tegra_car 65>;
354*f126890aSEmmanuel Vadot		dmas = <&apbdma 19>, <&apbdma 19>;
355*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
356*f126890aSEmmanuel Vadot		status = "disabled";
357*f126890aSEmmanuel Vadot	};
358*f126890aSEmmanuel Vadot
359*f126890aSEmmanuel Vadot	pwm: pwm@7000a000 {
360*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-pwm", "nvidia,tegra20-pwm";
361*f126890aSEmmanuel Vadot		reg = <0x7000a000 0x100>;
362*f126890aSEmmanuel Vadot		#pwm-cells = <2>;
363*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_PWM>;
364*f126890aSEmmanuel Vadot		resets = <&tegra_car 17>;
365*f126890aSEmmanuel Vadot		reset-names = "pwm";
366*f126890aSEmmanuel Vadot		status = "disabled";
367*f126890aSEmmanuel Vadot	};
368*f126890aSEmmanuel Vadot
369*f126890aSEmmanuel Vadot	i2c@7000c000 {
370*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-i2c";
371*f126890aSEmmanuel Vadot		reg = <0x7000c000 0x100>;
372*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
373*f126890aSEmmanuel Vadot		#address-cells = <1>;
374*f126890aSEmmanuel Vadot		#size-cells = <0>;
375*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_I2C1>;
376*f126890aSEmmanuel Vadot		clock-names = "div-clk";
377*f126890aSEmmanuel Vadot		resets = <&tegra_car 12>;
378*f126890aSEmmanuel Vadot		reset-names = "i2c";
379*f126890aSEmmanuel Vadot		dmas = <&apbdma 21>, <&apbdma 21>;
380*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
381*f126890aSEmmanuel Vadot		status = "disabled";
382*f126890aSEmmanuel Vadot	};
383*f126890aSEmmanuel Vadot
384*f126890aSEmmanuel Vadot	i2c@7000c400 {
385*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-i2c";
386*f126890aSEmmanuel Vadot		reg = <0x7000c400 0x100>;
387*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
388*f126890aSEmmanuel Vadot		#address-cells = <1>;
389*f126890aSEmmanuel Vadot		#size-cells = <0>;
390*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_I2C2>;
391*f126890aSEmmanuel Vadot		clock-names = "div-clk";
392*f126890aSEmmanuel Vadot		resets = <&tegra_car 54>;
393*f126890aSEmmanuel Vadot		reset-names = "i2c";
394*f126890aSEmmanuel Vadot		dmas = <&apbdma 22>, <&apbdma 22>;
395*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
396*f126890aSEmmanuel Vadot		status = "disabled";
397*f126890aSEmmanuel Vadot	};
398*f126890aSEmmanuel Vadot
399*f126890aSEmmanuel Vadot	i2c@7000c500 {
400*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-i2c";
401*f126890aSEmmanuel Vadot		reg = <0x7000c500 0x100>;
402*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
403*f126890aSEmmanuel Vadot		#address-cells = <1>;
404*f126890aSEmmanuel Vadot		#size-cells = <0>;
405*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_I2C3>;
406*f126890aSEmmanuel Vadot		clock-names = "div-clk";
407*f126890aSEmmanuel Vadot		resets = <&tegra_car 67>;
408*f126890aSEmmanuel Vadot		reset-names = "i2c";
409*f126890aSEmmanuel Vadot		dmas = <&apbdma 23>, <&apbdma 23>;
410*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
411*f126890aSEmmanuel Vadot		status = "disabled";
412*f126890aSEmmanuel Vadot	};
413*f126890aSEmmanuel Vadot
414*f126890aSEmmanuel Vadot	i2c@7000c700 {
415*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-i2c";
416*f126890aSEmmanuel Vadot		reg = <0x7000c700 0x100>;
417*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
418*f126890aSEmmanuel Vadot		#address-cells = <1>;
419*f126890aSEmmanuel Vadot		#size-cells = <0>;
420*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_I2C4>;
421*f126890aSEmmanuel Vadot		clock-names = "div-clk";
422*f126890aSEmmanuel Vadot		resets = <&tegra_car 103>;
423*f126890aSEmmanuel Vadot		reset-names = "i2c";
424*f126890aSEmmanuel Vadot		dmas = <&apbdma 26>, <&apbdma 26>;
425*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
426*f126890aSEmmanuel Vadot		status = "disabled";
427*f126890aSEmmanuel Vadot	};
428*f126890aSEmmanuel Vadot
429*f126890aSEmmanuel Vadot	i2c@7000d000 {
430*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-i2c";
431*f126890aSEmmanuel Vadot		reg = <0x7000d000 0x100>;
432*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
433*f126890aSEmmanuel Vadot		#address-cells = <1>;
434*f126890aSEmmanuel Vadot		#size-cells = <0>;
435*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_I2C5>;
436*f126890aSEmmanuel Vadot		clock-names = "div-clk";
437*f126890aSEmmanuel Vadot		resets = <&tegra_car 47>;
438*f126890aSEmmanuel Vadot		reset-names = "i2c";
439*f126890aSEmmanuel Vadot		dmas = <&apbdma 24>, <&apbdma 24>;
440*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
441*f126890aSEmmanuel Vadot		status = "disabled";
442*f126890aSEmmanuel Vadot	};
443*f126890aSEmmanuel Vadot
444*f126890aSEmmanuel Vadot	spi@7000d400 {
445*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
446*f126890aSEmmanuel Vadot		reg = <0x7000d400 0x200>;
447*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
448*f126890aSEmmanuel Vadot		#address-cells = <1>;
449*f126890aSEmmanuel Vadot		#size-cells = <0>;
450*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC1>;
451*f126890aSEmmanuel Vadot		clock-names = "spi";
452*f126890aSEmmanuel Vadot		resets = <&tegra_car 41>;
453*f126890aSEmmanuel Vadot		reset-names = "spi";
454*f126890aSEmmanuel Vadot		dmas = <&apbdma 15>, <&apbdma 15>;
455*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
456*f126890aSEmmanuel Vadot		status = "disabled";
457*f126890aSEmmanuel Vadot	};
458*f126890aSEmmanuel Vadot
459*f126890aSEmmanuel Vadot	spi@7000d600 {
460*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
461*f126890aSEmmanuel Vadot		reg = <0x7000d600 0x200>;
462*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
463*f126890aSEmmanuel Vadot		#address-cells = <1>;
464*f126890aSEmmanuel Vadot		#size-cells = <0>;
465*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC2>;
466*f126890aSEmmanuel Vadot		clock-names = "spi";
467*f126890aSEmmanuel Vadot		resets = <&tegra_car 44>;
468*f126890aSEmmanuel Vadot		reset-names = "spi";
469*f126890aSEmmanuel Vadot		dmas = <&apbdma 16>, <&apbdma 16>;
470*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
471*f126890aSEmmanuel Vadot		status = "disabled";
472*f126890aSEmmanuel Vadot	};
473*f126890aSEmmanuel Vadot
474*f126890aSEmmanuel Vadot	spi@7000d800 {
475*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
476*f126890aSEmmanuel Vadot		reg = <0x7000d800 0x200>;
477*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
478*f126890aSEmmanuel Vadot		#address-cells = <1>;
479*f126890aSEmmanuel Vadot		#size-cells = <0>;
480*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC3>;
481*f126890aSEmmanuel Vadot		clock-names = "spi";
482*f126890aSEmmanuel Vadot		resets = <&tegra_car 46>;
483*f126890aSEmmanuel Vadot		reset-names = "spi";
484*f126890aSEmmanuel Vadot		dmas = <&apbdma 17>, <&apbdma 17>;
485*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
486*f126890aSEmmanuel Vadot		status = "disabled";
487*f126890aSEmmanuel Vadot	};
488*f126890aSEmmanuel Vadot
489*f126890aSEmmanuel Vadot	spi@7000da00 {
490*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
491*f126890aSEmmanuel Vadot		reg = <0x7000da00 0x200>;
492*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
493*f126890aSEmmanuel Vadot		#address-cells = <1>;
494*f126890aSEmmanuel Vadot		#size-cells = <0>;
495*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC4>;
496*f126890aSEmmanuel Vadot		clock-names = "spi";
497*f126890aSEmmanuel Vadot		resets = <&tegra_car 68>;
498*f126890aSEmmanuel Vadot		reset-names = "spi";
499*f126890aSEmmanuel Vadot		dmas = <&apbdma 18>, <&apbdma 18>;
500*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
501*f126890aSEmmanuel Vadot		status = "disabled";
502*f126890aSEmmanuel Vadot	};
503*f126890aSEmmanuel Vadot
504*f126890aSEmmanuel Vadot	spi@7000dc00 {
505*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
506*f126890aSEmmanuel Vadot		reg = <0x7000dc00 0x200>;
507*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
508*f126890aSEmmanuel Vadot		#address-cells = <1>;
509*f126890aSEmmanuel Vadot		#size-cells = <0>;
510*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC5>;
511*f126890aSEmmanuel Vadot		clock-names = "spi";
512*f126890aSEmmanuel Vadot		resets = <&tegra_car 104>;
513*f126890aSEmmanuel Vadot		reset-names = "spi";
514*f126890aSEmmanuel Vadot		dmas = <&apbdma 27>, <&apbdma 27>;
515*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
516*f126890aSEmmanuel Vadot		status = "disabled";
517*f126890aSEmmanuel Vadot	};
518*f126890aSEmmanuel Vadot
519*f126890aSEmmanuel Vadot	spi@7000de00 {
520*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-spi";
521*f126890aSEmmanuel Vadot		reg = <0x7000de00 0x200>;
522*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
523*f126890aSEmmanuel Vadot		#address-cells = <1>;
524*f126890aSEmmanuel Vadot		#size-cells = <0>;
525*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SBC6>;
526*f126890aSEmmanuel Vadot		clock-names = "spi";
527*f126890aSEmmanuel Vadot		resets = <&tegra_car 105>;
528*f126890aSEmmanuel Vadot		reset-names = "spi";
529*f126890aSEmmanuel Vadot		dmas = <&apbdma 28>, <&apbdma 28>;
530*f126890aSEmmanuel Vadot		dma-names = "rx", "tx";
531*f126890aSEmmanuel Vadot		status = "disabled";
532*f126890aSEmmanuel Vadot	};
533*f126890aSEmmanuel Vadot
534*f126890aSEmmanuel Vadot	rtc@7000e000 {
535*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-rtc", "nvidia,tegra20-rtc";
536*f126890aSEmmanuel Vadot		reg = <0x7000e000 0x100>;
537*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
538*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_RTC>;
539*f126890aSEmmanuel Vadot	};
540*f126890aSEmmanuel Vadot
541*f126890aSEmmanuel Vadot	kbc@7000e200 {
542*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-kbc";
543*f126890aSEmmanuel Vadot		reg = <0x7000e200 0x100>;
544*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
545*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_KBC>;
546*f126890aSEmmanuel Vadot		resets = <&tegra_car 36>;
547*f126890aSEmmanuel Vadot		reset-names = "kbc";
548*f126890aSEmmanuel Vadot		status = "disabled";
549*f126890aSEmmanuel Vadot	};
550*f126890aSEmmanuel Vadot
551*f126890aSEmmanuel Vadot	tegra_pmc: pmc@7000e400 {
552*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-pmc";
553*f126890aSEmmanuel Vadot		reg = <0x7000e400 0x400>;
554*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_PCLK>, <&clk32k_in>;
555*f126890aSEmmanuel Vadot		clock-names = "pclk", "clk32k_in";
556*f126890aSEmmanuel Vadot		#clock-cells = <1>;
557*f126890aSEmmanuel Vadot	};
558*f126890aSEmmanuel Vadot
559*f126890aSEmmanuel Vadot	fuse@7000f800 {
560*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-efuse";
561*f126890aSEmmanuel Vadot		reg = <0x7000f800 0x400>;
562*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_FUSE>;
563*f126890aSEmmanuel Vadot		clock-names = "fuse";
564*f126890aSEmmanuel Vadot		resets = <&tegra_car 39>;
565*f126890aSEmmanuel Vadot		reset-names = "fuse";
566*f126890aSEmmanuel Vadot	};
567*f126890aSEmmanuel Vadot
568*f126890aSEmmanuel Vadot	mc: memory-controller@70019000 {
569*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-mc";
570*f126890aSEmmanuel Vadot		reg = <0x70019000 0x1000>;
571*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_MC>;
572*f126890aSEmmanuel Vadot		clock-names = "mc";
573*f126890aSEmmanuel Vadot
574*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
575*f126890aSEmmanuel Vadot
576*f126890aSEmmanuel Vadot		#reset-cells = <1>;
577*f126890aSEmmanuel Vadot		#iommu-cells = <1>;
578*f126890aSEmmanuel Vadot	};
579*f126890aSEmmanuel Vadot
580*f126890aSEmmanuel Vadot	ahub@70080000 {
581*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-ahub";
582*f126890aSEmmanuel Vadot		reg = <0x70080000 0x200>,
583*f126890aSEmmanuel Vadot		      <0x70080200 0x100>,
584*f126890aSEmmanuel Vadot		      <0x70081000 0x200>;
585*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
586*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_D_AUDIO>,
587*f126890aSEmmanuel Vadot			 <&tegra_car TEGRA114_CLK_APBIF>;
588*f126890aSEmmanuel Vadot		clock-names = "d_audio", "apbif";
589*f126890aSEmmanuel Vadot		resets = <&tegra_car 106>, /* d_audio */
590*f126890aSEmmanuel Vadot			 <&tegra_car 107>, /* apbif */
591*f126890aSEmmanuel Vadot			 <&tegra_car 30>,  /* i2s0 */
592*f126890aSEmmanuel Vadot			 <&tegra_car 11>,  /* i2s1 */
593*f126890aSEmmanuel Vadot			 <&tegra_car 18>,  /* i2s2 */
594*f126890aSEmmanuel Vadot			 <&tegra_car 101>, /* i2s3 */
595*f126890aSEmmanuel Vadot			 <&tegra_car 102>, /* i2s4 */
596*f126890aSEmmanuel Vadot			 <&tegra_car 108>, /* dam0 */
597*f126890aSEmmanuel Vadot			 <&tegra_car 109>, /* dam1 */
598*f126890aSEmmanuel Vadot			 <&tegra_car 110>, /* dam2 */
599*f126890aSEmmanuel Vadot			 <&tegra_car 10>,  /* spdif */
600*f126890aSEmmanuel Vadot			 <&tegra_car 153>, /* amx */
601*f126890aSEmmanuel Vadot			 <&tegra_car 154>; /* adx */
602*f126890aSEmmanuel Vadot		reset-names = "d_audio", "apbif", "i2s0", "i2s1", "i2s2",
603*f126890aSEmmanuel Vadot			      "i2s3", "i2s4", "dam0", "dam1", "dam2",
604*f126890aSEmmanuel Vadot			      "spdif", "amx", "adx";
605*f126890aSEmmanuel Vadot		dmas = <&apbdma 1>, <&apbdma 1>,
606*f126890aSEmmanuel Vadot		       <&apbdma 2>, <&apbdma 2>,
607*f126890aSEmmanuel Vadot		       <&apbdma 3>, <&apbdma 3>,
608*f126890aSEmmanuel Vadot		       <&apbdma 4>, <&apbdma 4>,
609*f126890aSEmmanuel Vadot		       <&apbdma 6>, <&apbdma 6>,
610*f126890aSEmmanuel Vadot		       <&apbdma 7>, <&apbdma 7>,
611*f126890aSEmmanuel Vadot		       <&apbdma 12>, <&apbdma 12>,
612*f126890aSEmmanuel Vadot		       <&apbdma 13>, <&apbdma 13>,
613*f126890aSEmmanuel Vadot		       <&apbdma 14>, <&apbdma 14>,
614*f126890aSEmmanuel Vadot		       <&apbdma 29>, <&apbdma 29>;
615*f126890aSEmmanuel Vadot		dma-names = "rx0", "tx0", "rx1", "tx1", "rx2", "tx2",
616*f126890aSEmmanuel Vadot			    "rx3", "tx3", "rx4", "tx4", "rx5", "tx5",
617*f126890aSEmmanuel Vadot			    "rx6", "tx6", "rx7", "tx7", "rx8", "tx8",
618*f126890aSEmmanuel Vadot			    "rx9", "tx9";
619*f126890aSEmmanuel Vadot		ranges;
620*f126890aSEmmanuel Vadot		#address-cells = <1>;
621*f126890aSEmmanuel Vadot		#size-cells = <1>;
622*f126890aSEmmanuel Vadot
623*f126890aSEmmanuel Vadot		tegra_i2s0: i2s@70080300 {
624*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-i2s", "nvidia,tegra30-i2s";
625*f126890aSEmmanuel Vadot			reg = <0x70080300 0x100>;
626*f126890aSEmmanuel Vadot			nvidia,ahub-cif-ids = <4 4>;
627*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_I2S0>;
628*f126890aSEmmanuel Vadot			resets = <&tegra_car 30>;
629*f126890aSEmmanuel Vadot			reset-names = "i2s";
630*f126890aSEmmanuel Vadot			status = "disabled";
631*f126890aSEmmanuel Vadot		};
632*f126890aSEmmanuel Vadot
633*f126890aSEmmanuel Vadot		tegra_i2s1: i2s@70080400 {
634*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-i2s", "nvidia,tegra30-i2s";
635*f126890aSEmmanuel Vadot			reg = <0x70080400 0x100>;
636*f126890aSEmmanuel Vadot			nvidia,ahub-cif-ids = <5 5>;
637*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_I2S1>;
638*f126890aSEmmanuel Vadot			resets = <&tegra_car 11>;
639*f126890aSEmmanuel Vadot			reset-names = "i2s";
640*f126890aSEmmanuel Vadot			status = "disabled";
641*f126890aSEmmanuel Vadot		};
642*f126890aSEmmanuel Vadot
643*f126890aSEmmanuel Vadot		tegra_i2s2: i2s@70080500 {
644*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-i2s", "nvidia,tegra30-i2s";
645*f126890aSEmmanuel Vadot			reg = <0x70080500 0x100>;
646*f126890aSEmmanuel Vadot			nvidia,ahub-cif-ids = <6 6>;
647*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_I2S2>;
648*f126890aSEmmanuel Vadot			resets = <&tegra_car 18>;
649*f126890aSEmmanuel Vadot			reset-names = "i2s";
650*f126890aSEmmanuel Vadot			status = "disabled";
651*f126890aSEmmanuel Vadot		};
652*f126890aSEmmanuel Vadot
653*f126890aSEmmanuel Vadot		tegra_i2s3: i2s@70080600 {
654*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-i2s", "nvidia,tegra30-i2s";
655*f126890aSEmmanuel Vadot			reg = <0x70080600 0x100>;
656*f126890aSEmmanuel Vadot			nvidia,ahub-cif-ids = <7 7>;
657*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_I2S3>;
658*f126890aSEmmanuel Vadot			resets = <&tegra_car 101>;
659*f126890aSEmmanuel Vadot			reset-names = "i2s";
660*f126890aSEmmanuel Vadot			status = "disabled";
661*f126890aSEmmanuel Vadot		};
662*f126890aSEmmanuel Vadot
663*f126890aSEmmanuel Vadot		tegra_i2s4: i2s@70080700 {
664*f126890aSEmmanuel Vadot			compatible = "nvidia,tegra114-i2s", "nvidia,tegra30-i2s";
665*f126890aSEmmanuel Vadot			reg = <0x70080700 0x100>;
666*f126890aSEmmanuel Vadot			nvidia,ahub-cif-ids = <8 8>;
667*f126890aSEmmanuel Vadot			clocks = <&tegra_car TEGRA114_CLK_I2S4>;
668*f126890aSEmmanuel Vadot			resets = <&tegra_car 102>;
669*f126890aSEmmanuel Vadot			reset-names = "i2s";
670*f126890aSEmmanuel Vadot			status = "disabled";
671*f126890aSEmmanuel Vadot		};
672*f126890aSEmmanuel Vadot	};
673*f126890aSEmmanuel Vadot
674*f126890aSEmmanuel Vadot	mipi: mipi@700e3000 {
675*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-mipi";
676*f126890aSEmmanuel Vadot		reg = <0x700e3000 0x100>;
677*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_MIPI_CAL>;
678*f126890aSEmmanuel Vadot		#nvidia,mipi-calibrate-cells = <1>;
679*f126890aSEmmanuel Vadot	};
680*f126890aSEmmanuel Vadot
681*f126890aSEmmanuel Vadot	mmc@78000000 {
682*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-sdhci";
683*f126890aSEmmanuel Vadot		reg = <0x78000000 0x200>;
684*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
685*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SDMMC1>;
686*f126890aSEmmanuel Vadot		clock-names = "sdhci";
687*f126890aSEmmanuel Vadot		resets = <&tegra_car 14>;
688*f126890aSEmmanuel Vadot		reset-names = "sdhci";
689*f126890aSEmmanuel Vadot		status = "disabled";
690*f126890aSEmmanuel Vadot	};
691*f126890aSEmmanuel Vadot
692*f126890aSEmmanuel Vadot	mmc@78000200 {
693*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-sdhci";
694*f126890aSEmmanuel Vadot		reg = <0x78000200 0x200>;
695*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
696*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SDMMC2>;
697*f126890aSEmmanuel Vadot		clock-names = "sdhci";
698*f126890aSEmmanuel Vadot		resets = <&tegra_car 9>;
699*f126890aSEmmanuel Vadot		reset-names = "sdhci";
700*f126890aSEmmanuel Vadot		status = "disabled";
701*f126890aSEmmanuel Vadot	};
702*f126890aSEmmanuel Vadot
703*f126890aSEmmanuel Vadot	mmc@78000400 {
704*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-sdhci";
705*f126890aSEmmanuel Vadot		reg = <0x78000400 0x200>;
706*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
707*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SDMMC3>;
708*f126890aSEmmanuel Vadot		clock-names = "sdhci";
709*f126890aSEmmanuel Vadot		resets = <&tegra_car 69>;
710*f126890aSEmmanuel Vadot		reset-names = "sdhci";
711*f126890aSEmmanuel Vadot		status = "disabled";
712*f126890aSEmmanuel Vadot	};
713*f126890aSEmmanuel Vadot
714*f126890aSEmmanuel Vadot	mmc@78000600 {
715*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-sdhci";
716*f126890aSEmmanuel Vadot		reg = <0x78000600 0x200>;
717*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
718*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_SDMMC4>;
719*f126890aSEmmanuel Vadot		clock-names = "sdhci";
720*f126890aSEmmanuel Vadot		resets = <&tegra_car 15>;
721*f126890aSEmmanuel Vadot		reset-names = "sdhci";
722*f126890aSEmmanuel Vadot		status = "disabled";
723*f126890aSEmmanuel Vadot	};
724*f126890aSEmmanuel Vadot
725*f126890aSEmmanuel Vadot	usb@7d000000 {
726*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-ehci", "nvidia,tegra30-ehci";
727*f126890aSEmmanuel Vadot		reg = <0x7d000000 0x4000>;
728*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
729*f126890aSEmmanuel Vadot		phy_type = "utmi";
730*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_USBD>;
731*f126890aSEmmanuel Vadot		resets = <&tegra_car 22>;
732*f126890aSEmmanuel Vadot		reset-names = "usb";
733*f126890aSEmmanuel Vadot		nvidia,phy = <&phy1>;
734*f126890aSEmmanuel Vadot		status = "disabled";
735*f126890aSEmmanuel Vadot	};
736*f126890aSEmmanuel Vadot
737*f126890aSEmmanuel Vadot	phy1: usb-phy@7d000000 {
738*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-usb-phy", "nvidia,tegra30-usb-phy";
739*f126890aSEmmanuel Vadot		reg = <0x7d000000 0x4000>,
740*f126890aSEmmanuel Vadot		      <0x7d000000 0x4000>;
741*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
742*f126890aSEmmanuel Vadot		phy_type = "utmi";
743*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_USBD>,
744*f126890aSEmmanuel Vadot			 <&tegra_car TEGRA114_CLK_PLL_U>,
745*f126890aSEmmanuel Vadot			 <&tegra_car TEGRA114_CLK_USBD>;
746*f126890aSEmmanuel Vadot		clock-names = "reg", "pll_u", "utmi-pads";
747*f126890aSEmmanuel Vadot		resets = <&tegra_car 22>, <&tegra_car 22>;
748*f126890aSEmmanuel Vadot		reset-names = "usb", "utmi-pads";
749*f126890aSEmmanuel Vadot		#phy-cells = <0>;
750*f126890aSEmmanuel Vadot		nvidia,hssync-start-delay = <0>;
751*f126890aSEmmanuel Vadot		nvidia,idle-wait-delay = <17>;
752*f126890aSEmmanuel Vadot		nvidia,elastic-limit = <16>;
753*f126890aSEmmanuel Vadot		nvidia,term-range-adj = <6>;
754*f126890aSEmmanuel Vadot		nvidia,xcvr-setup = <9>;
755*f126890aSEmmanuel Vadot		nvidia,xcvr-lsfslew = <0>;
756*f126890aSEmmanuel Vadot		nvidia,xcvr-lsrslew = <3>;
757*f126890aSEmmanuel Vadot		nvidia,hssquelch-level = <2>;
758*f126890aSEmmanuel Vadot		nvidia,hsdiscon-level = <5>;
759*f126890aSEmmanuel Vadot		nvidia,xcvr-hsslew = <12>;
760*f126890aSEmmanuel Vadot		nvidia,has-utmi-pad-registers;
761*f126890aSEmmanuel Vadot		nvidia,pmc = <&tegra_pmc 0>;
762*f126890aSEmmanuel Vadot		status = "disabled";
763*f126890aSEmmanuel Vadot	};
764*f126890aSEmmanuel Vadot
765*f126890aSEmmanuel Vadot	usb@7d008000 {
766*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-ehci", "nvidia,tegra30-ehci";
767*f126890aSEmmanuel Vadot		reg = <0x7d008000 0x4000>;
768*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
769*f126890aSEmmanuel Vadot		phy_type = "utmi";
770*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_USB3>;
771*f126890aSEmmanuel Vadot		resets = <&tegra_car 59>;
772*f126890aSEmmanuel Vadot		reset-names = "usb";
773*f126890aSEmmanuel Vadot		nvidia,phy = <&phy3>;
774*f126890aSEmmanuel Vadot		status = "disabled";
775*f126890aSEmmanuel Vadot	};
776*f126890aSEmmanuel Vadot
777*f126890aSEmmanuel Vadot	phy3: usb-phy@7d008000 {
778*f126890aSEmmanuel Vadot		compatible = "nvidia,tegra114-usb-phy", "nvidia,tegra30-usb-phy";
779*f126890aSEmmanuel Vadot		reg = <0x7d008000 0x4000>,
780*f126890aSEmmanuel Vadot		      <0x7d000000 0x4000>;
781*f126890aSEmmanuel Vadot		interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
782*f126890aSEmmanuel Vadot		phy_type = "utmi";
783*f126890aSEmmanuel Vadot		clocks = <&tegra_car TEGRA114_CLK_USB3>,
784*f126890aSEmmanuel Vadot			 <&tegra_car TEGRA114_CLK_PLL_U>,
785*f126890aSEmmanuel Vadot			 <&tegra_car TEGRA114_CLK_USBD>;
786*f126890aSEmmanuel Vadot		clock-names = "reg", "pll_u", "utmi-pads";
787*f126890aSEmmanuel Vadot		resets = <&tegra_car 59>, <&tegra_car 22>;
788*f126890aSEmmanuel Vadot		reset-names = "usb", "utmi-pads";
789*f126890aSEmmanuel Vadot		#phy-cells = <0>;
790*f126890aSEmmanuel Vadot		nvidia,hssync-start-delay = <0>;
791*f126890aSEmmanuel Vadot		nvidia,idle-wait-delay = <17>;
792*f126890aSEmmanuel Vadot		nvidia,elastic-limit = <16>;
793*f126890aSEmmanuel Vadot		nvidia,term-range-adj = <6>;
794*f126890aSEmmanuel Vadot		nvidia,xcvr-setup = <9>;
795*f126890aSEmmanuel Vadot		nvidia,xcvr-lsfslew = <0>;
796*f126890aSEmmanuel Vadot		nvidia,xcvr-lsrslew = <3>;
797*f126890aSEmmanuel Vadot		nvidia,hssquelch-level = <2>;
798*f126890aSEmmanuel Vadot		nvidia,hsdiscon-level = <5>;
799*f126890aSEmmanuel Vadot		nvidia,xcvr-hsslew = <12>;
800*f126890aSEmmanuel Vadot		nvidia,pmc = <&tegra_pmc 2>;
801*f126890aSEmmanuel Vadot		status = "disabled";
802*f126890aSEmmanuel Vadot	};
803*f126890aSEmmanuel Vadot
804*f126890aSEmmanuel Vadot	cpus {
805*f126890aSEmmanuel Vadot		#address-cells = <1>;
806*f126890aSEmmanuel Vadot		#size-cells = <0>;
807*f126890aSEmmanuel Vadot
808*f126890aSEmmanuel Vadot		cpu@0 {
809*f126890aSEmmanuel Vadot			device_type = "cpu";
810*f126890aSEmmanuel Vadot			compatible = "arm,cortex-a15";
811*f126890aSEmmanuel Vadot			reg = <0>;
812*f126890aSEmmanuel Vadot		};
813*f126890aSEmmanuel Vadot
814*f126890aSEmmanuel Vadot		cpu@1 {
815*f126890aSEmmanuel Vadot			device_type = "cpu";
816*f126890aSEmmanuel Vadot			compatible = "arm,cortex-a15";
817*f126890aSEmmanuel Vadot			reg = <1>;
818*f126890aSEmmanuel Vadot		};
819*f126890aSEmmanuel Vadot
820*f126890aSEmmanuel Vadot		cpu@2 {
821*f126890aSEmmanuel Vadot			device_type = "cpu";
822*f126890aSEmmanuel Vadot			compatible = "arm,cortex-a15";
823*f126890aSEmmanuel Vadot			reg = <2>;
824*f126890aSEmmanuel Vadot		};
825*f126890aSEmmanuel Vadot
826*f126890aSEmmanuel Vadot		cpu@3 {
827*f126890aSEmmanuel Vadot			device_type = "cpu";
828*f126890aSEmmanuel Vadot			compatible = "arm,cortex-a15";
829*f126890aSEmmanuel Vadot			reg = <3>;
830*f126890aSEmmanuel Vadot		};
831*f126890aSEmmanuel Vadot	};
832*f126890aSEmmanuel Vadot
833*f126890aSEmmanuel Vadot	timer {
834*f126890aSEmmanuel Vadot		compatible = "arm,armv7-timer";
835*f126890aSEmmanuel Vadot		interrupts =
836*f126890aSEmmanuel Vadot			<GIC_PPI 13
837*f126890aSEmmanuel Vadot				(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
838*f126890aSEmmanuel Vadot			<GIC_PPI 14
839*f126890aSEmmanuel Vadot				(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
840*f126890aSEmmanuel Vadot			<GIC_PPI 11
841*f126890aSEmmanuel Vadot				(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
842*f126890aSEmmanuel Vadot			<GIC_PPI 10
843*f126890aSEmmanuel Vadot				(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
844*f126890aSEmmanuel Vadot		interrupt-parent = <&gic>;
845*f126890aSEmmanuel Vadot	};
846*f126890aSEmmanuel Vadot};
847