xref: /OK3568_Linux_fs/u-boot/arch/arm/dts/uniphier-pro4.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/*
2*4882a593Smuzhiyun * Device Tree Source for UniPhier Pro4 SoC
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Copyright (C) 2015-2016 Socionext Inc.
5*4882a593Smuzhiyun *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
6*4882a593Smuzhiyun *
7*4882a593Smuzhiyun * SPDX-License-Identifier: (GPL-2.0+ OR MIT)
8*4882a593Smuzhiyun */
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun/ {
11*4882a593Smuzhiyun	compatible = "socionext,uniphier-pro4";
12*4882a593Smuzhiyun	#address-cells = <1>;
13*4882a593Smuzhiyun	#size-cells = <1>;
14*4882a593Smuzhiyun
15*4882a593Smuzhiyun	cpus {
16*4882a593Smuzhiyun		#address-cells = <1>;
17*4882a593Smuzhiyun		#size-cells = <0>;
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun		cpu@0 {
20*4882a593Smuzhiyun			device_type = "cpu";
21*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
22*4882a593Smuzhiyun			reg = <0>;
23*4882a593Smuzhiyun			enable-method = "psci";
24*4882a593Smuzhiyun			next-level-cache = <&l2>;
25*4882a593Smuzhiyun		};
26*4882a593Smuzhiyun
27*4882a593Smuzhiyun		cpu@1 {
28*4882a593Smuzhiyun			device_type = "cpu";
29*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
30*4882a593Smuzhiyun			reg = <1>;
31*4882a593Smuzhiyun			enable-method = "psci";
32*4882a593Smuzhiyun			next-level-cache = <&l2>;
33*4882a593Smuzhiyun		};
34*4882a593Smuzhiyun	};
35*4882a593Smuzhiyun
36*4882a593Smuzhiyun	psci {
37*4882a593Smuzhiyun		compatible = "arm,psci-0.2";
38*4882a593Smuzhiyun		method = "smc";
39*4882a593Smuzhiyun	};
40*4882a593Smuzhiyun
41*4882a593Smuzhiyun	clocks {
42*4882a593Smuzhiyun		refclk: ref {
43*4882a593Smuzhiyun			compatible = "fixed-clock";
44*4882a593Smuzhiyun			#clock-cells = <0>;
45*4882a593Smuzhiyun			clock-frequency = <25000000>;
46*4882a593Smuzhiyun		};
47*4882a593Smuzhiyun
48*4882a593Smuzhiyun		arm_timer_clk: arm_timer_clk {
49*4882a593Smuzhiyun			#clock-cells = <0>;
50*4882a593Smuzhiyun			compatible = "fixed-clock";
51*4882a593Smuzhiyun			clock-frequency = <50000000>;
52*4882a593Smuzhiyun		};
53*4882a593Smuzhiyun	};
54*4882a593Smuzhiyun
55*4882a593Smuzhiyun	soc {
56*4882a593Smuzhiyun		compatible = "simple-bus";
57*4882a593Smuzhiyun		#address-cells = <1>;
58*4882a593Smuzhiyun		#size-cells = <1>;
59*4882a593Smuzhiyun		ranges;
60*4882a593Smuzhiyun		interrupt-parent = <&intc>;
61*4882a593Smuzhiyun		u-boot,dm-pre-reloc;
62*4882a593Smuzhiyun
63*4882a593Smuzhiyun		l2: l2-cache@500c0000 {
64*4882a593Smuzhiyun			compatible = "socionext,uniphier-system-cache";
65*4882a593Smuzhiyun			reg = <0x500c0000 0x2000>, <0x503c0100 0x4>,
66*4882a593Smuzhiyun			      <0x506c0000 0x400>;
67*4882a593Smuzhiyun			interrupts = <0 174 4>, <0 175 4>;
68*4882a593Smuzhiyun			cache-unified;
69*4882a593Smuzhiyun			cache-size = <(768 * 1024)>;
70*4882a593Smuzhiyun			cache-sets = <256>;
71*4882a593Smuzhiyun			cache-line-size = <128>;
72*4882a593Smuzhiyun			cache-level = <2>;
73*4882a593Smuzhiyun		};
74*4882a593Smuzhiyun
75*4882a593Smuzhiyun		serial0: serial@54006800 {
76*4882a593Smuzhiyun			compatible = "socionext,uniphier-uart";
77*4882a593Smuzhiyun			status = "disabled";
78*4882a593Smuzhiyun			reg = <0x54006800 0x40>;
79*4882a593Smuzhiyun			interrupts = <0 33 4>;
80*4882a593Smuzhiyun			pinctrl-names = "default";
81*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_uart0>;
82*4882a593Smuzhiyun			clocks = <&peri_clk 0>;
83*4882a593Smuzhiyun			clock-frequency = <73728000>;
84*4882a593Smuzhiyun		};
85*4882a593Smuzhiyun
86*4882a593Smuzhiyun		serial1: serial@54006900 {
87*4882a593Smuzhiyun			compatible = "socionext,uniphier-uart";
88*4882a593Smuzhiyun			status = "disabled";
89*4882a593Smuzhiyun			reg = <0x54006900 0x40>;
90*4882a593Smuzhiyun			interrupts = <0 35 4>;
91*4882a593Smuzhiyun			pinctrl-names = "default";
92*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_uart1>;
93*4882a593Smuzhiyun			clocks = <&peri_clk 1>;
94*4882a593Smuzhiyun			clock-frequency = <73728000>;
95*4882a593Smuzhiyun		};
96*4882a593Smuzhiyun
97*4882a593Smuzhiyun		serial2: serial@54006a00 {
98*4882a593Smuzhiyun			compatible = "socionext,uniphier-uart";
99*4882a593Smuzhiyun			status = "disabled";
100*4882a593Smuzhiyun			reg = <0x54006a00 0x40>;
101*4882a593Smuzhiyun			interrupts = <0 37 4>;
102*4882a593Smuzhiyun			pinctrl-names = "default";
103*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_uart2>;
104*4882a593Smuzhiyun			clocks = <&peri_clk 2>;
105*4882a593Smuzhiyun			clock-frequency = <73728000>;
106*4882a593Smuzhiyun		};
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun		serial3: serial@54006b00 {
109*4882a593Smuzhiyun			compatible = "socionext,uniphier-uart";
110*4882a593Smuzhiyun			status = "disabled";
111*4882a593Smuzhiyun			reg = <0x54006b00 0x40>;
112*4882a593Smuzhiyun			interrupts = <0 177 4>;
113*4882a593Smuzhiyun			pinctrl-names = "default";
114*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_uart3>;
115*4882a593Smuzhiyun			clocks = <&peri_clk 3>;
116*4882a593Smuzhiyun			clock-frequency = <73728000>;
117*4882a593Smuzhiyun		};
118*4882a593Smuzhiyun
119*4882a593Smuzhiyun		port0x: gpio@55000008 {
120*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
121*4882a593Smuzhiyun			reg = <0x55000008 0x8>;
122*4882a593Smuzhiyun			gpio-controller;
123*4882a593Smuzhiyun			#gpio-cells = <2>;
124*4882a593Smuzhiyun		};
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun		port1x: gpio@55000010 {
127*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
128*4882a593Smuzhiyun			reg = <0x55000010 0x8>;
129*4882a593Smuzhiyun			gpio-controller;
130*4882a593Smuzhiyun			#gpio-cells = <2>;
131*4882a593Smuzhiyun		};
132*4882a593Smuzhiyun
133*4882a593Smuzhiyun		port2x: gpio@55000018 {
134*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
135*4882a593Smuzhiyun			reg = <0x55000018 0x8>;
136*4882a593Smuzhiyun			gpio-controller;
137*4882a593Smuzhiyun			#gpio-cells = <2>;
138*4882a593Smuzhiyun		};
139*4882a593Smuzhiyun
140*4882a593Smuzhiyun		port3x: gpio@55000020 {
141*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
142*4882a593Smuzhiyun			reg = <0x55000020 0x8>;
143*4882a593Smuzhiyun			gpio-controller;
144*4882a593Smuzhiyun			#gpio-cells = <2>;
145*4882a593Smuzhiyun		};
146*4882a593Smuzhiyun
147*4882a593Smuzhiyun		port4: gpio@55000028 {
148*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
149*4882a593Smuzhiyun			reg = <0x55000028 0x8>;
150*4882a593Smuzhiyun			gpio-controller;
151*4882a593Smuzhiyun			#gpio-cells = <2>;
152*4882a593Smuzhiyun		};
153*4882a593Smuzhiyun
154*4882a593Smuzhiyun		port5x: gpio@55000030 {
155*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
156*4882a593Smuzhiyun			reg = <0x55000030 0x8>;
157*4882a593Smuzhiyun			gpio-controller;
158*4882a593Smuzhiyun			#gpio-cells = <2>;
159*4882a593Smuzhiyun		};
160*4882a593Smuzhiyun
161*4882a593Smuzhiyun		port6x: gpio@55000038 {
162*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
163*4882a593Smuzhiyun			reg = <0x55000038 0x8>;
164*4882a593Smuzhiyun			gpio-controller;
165*4882a593Smuzhiyun			#gpio-cells = <2>;
166*4882a593Smuzhiyun		};
167*4882a593Smuzhiyun
168*4882a593Smuzhiyun		port7x: gpio@55000040 {
169*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
170*4882a593Smuzhiyun			reg = <0x55000040 0x8>;
171*4882a593Smuzhiyun			gpio-controller;
172*4882a593Smuzhiyun			#gpio-cells = <2>;
173*4882a593Smuzhiyun		};
174*4882a593Smuzhiyun
175*4882a593Smuzhiyun		port8x: gpio@55000048 {
176*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
177*4882a593Smuzhiyun			reg = <0x55000048 0x8>;
178*4882a593Smuzhiyun			gpio-controller;
179*4882a593Smuzhiyun			#gpio-cells = <2>;
180*4882a593Smuzhiyun		};
181*4882a593Smuzhiyun
182*4882a593Smuzhiyun		port9x: gpio@55000050 {
183*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
184*4882a593Smuzhiyun			reg = <0x55000050 0x8>;
185*4882a593Smuzhiyun			gpio-controller;
186*4882a593Smuzhiyun			#gpio-cells = <2>;
187*4882a593Smuzhiyun		};
188*4882a593Smuzhiyun
189*4882a593Smuzhiyun		port10x: gpio@55000058 {
190*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
191*4882a593Smuzhiyun			reg = <0x55000058 0x8>;
192*4882a593Smuzhiyun			gpio-controller;
193*4882a593Smuzhiyun			#gpio-cells = <2>;
194*4882a593Smuzhiyun		};
195*4882a593Smuzhiyun
196*4882a593Smuzhiyun		port11x: gpio@55000060 {
197*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
198*4882a593Smuzhiyun			reg = <0x55000060 0x8>;
199*4882a593Smuzhiyun			gpio-controller;
200*4882a593Smuzhiyun			#gpio-cells = <2>;
201*4882a593Smuzhiyun		};
202*4882a593Smuzhiyun
203*4882a593Smuzhiyun		port12x: gpio@55000068 {
204*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
205*4882a593Smuzhiyun			reg = <0x55000068 0x8>;
206*4882a593Smuzhiyun			gpio-controller;
207*4882a593Smuzhiyun			#gpio-cells = <2>;
208*4882a593Smuzhiyun		};
209*4882a593Smuzhiyun
210*4882a593Smuzhiyun		port13x: gpio@55000070 {
211*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
212*4882a593Smuzhiyun			reg = <0x55000070 0x8>;
213*4882a593Smuzhiyun			gpio-controller;
214*4882a593Smuzhiyun			#gpio-cells = <2>;
215*4882a593Smuzhiyun		};
216*4882a593Smuzhiyun
217*4882a593Smuzhiyun		port14x: gpio@55000078 {
218*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
219*4882a593Smuzhiyun			reg = <0x55000078 0x8>;
220*4882a593Smuzhiyun			gpio-controller;
221*4882a593Smuzhiyun			#gpio-cells = <2>;
222*4882a593Smuzhiyun		};
223*4882a593Smuzhiyun
224*4882a593Smuzhiyun		port17x: gpio@550000a0 {
225*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
226*4882a593Smuzhiyun			reg = <0x550000a0 0x8>;
227*4882a593Smuzhiyun			gpio-controller;
228*4882a593Smuzhiyun			#gpio-cells = <2>;
229*4882a593Smuzhiyun		};
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun		port18x: gpio@550000a8 {
232*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
233*4882a593Smuzhiyun			reg = <0x550000a8 0x8>;
234*4882a593Smuzhiyun			gpio-controller;
235*4882a593Smuzhiyun			#gpio-cells = <2>;
236*4882a593Smuzhiyun		};
237*4882a593Smuzhiyun
238*4882a593Smuzhiyun		port19x: gpio@550000b0 {
239*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
240*4882a593Smuzhiyun			reg = <0x550000b0 0x8>;
241*4882a593Smuzhiyun			gpio-controller;
242*4882a593Smuzhiyun			#gpio-cells = <2>;
243*4882a593Smuzhiyun		};
244*4882a593Smuzhiyun
245*4882a593Smuzhiyun		port20x: gpio@550000b8 {
246*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
247*4882a593Smuzhiyun			reg = <0x550000b8 0x8>;
248*4882a593Smuzhiyun			gpio-controller;
249*4882a593Smuzhiyun			#gpio-cells = <2>;
250*4882a593Smuzhiyun		};
251*4882a593Smuzhiyun
252*4882a593Smuzhiyun		port21x: gpio@550000c0 {
253*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
254*4882a593Smuzhiyun			reg = <0x550000c0 0x8>;
255*4882a593Smuzhiyun			gpio-controller;
256*4882a593Smuzhiyun			#gpio-cells = <2>;
257*4882a593Smuzhiyun		};
258*4882a593Smuzhiyun
259*4882a593Smuzhiyun		port22x: gpio@550000c8 {
260*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
261*4882a593Smuzhiyun			reg = <0x550000c8 0x8>;
262*4882a593Smuzhiyun			gpio-controller;
263*4882a593Smuzhiyun			#gpio-cells = <2>;
264*4882a593Smuzhiyun		};
265*4882a593Smuzhiyun
266*4882a593Smuzhiyun		port23x: gpio@550000d0 {
267*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
268*4882a593Smuzhiyun			reg = <0x550000d0 0x8>;
269*4882a593Smuzhiyun			gpio-controller;
270*4882a593Smuzhiyun			#gpio-cells = <2>;
271*4882a593Smuzhiyun		};
272*4882a593Smuzhiyun
273*4882a593Smuzhiyun		port24x: gpio@550000d8 {
274*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
275*4882a593Smuzhiyun			reg = <0x550000d8 0x8>;
276*4882a593Smuzhiyun			gpio-controller;
277*4882a593Smuzhiyun			#gpio-cells = <2>;
278*4882a593Smuzhiyun		};
279*4882a593Smuzhiyun
280*4882a593Smuzhiyun		port25x: gpio@550000e0 {
281*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
282*4882a593Smuzhiyun			reg = <0x550000e0 0x8>;
283*4882a593Smuzhiyun			gpio-controller;
284*4882a593Smuzhiyun			#gpio-cells = <2>;
285*4882a593Smuzhiyun		};
286*4882a593Smuzhiyun
287*4882a593Smuzhiyun		port26x: gpio@550000e8 {
288*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
289*4882a593Smuzhiyun			reg = <0x550000e8 0x8>;
290*4882a593Smuzhiyun			gpio-controller;
291*4882a593Smuzhiyun			#gpio-cells = <2>;
292*4882a593Smuzhiyun		};
293*4882a593Smuzhiyun
294*4882a593Smuzhiyun		port27x: gpio@550000f0 {
295*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
296*4882a593Smuzhiyun			reg = <0x550000f0 0x8>;
297*4882a593Smuzhiyun			gpio-controller;
298*4882a593Smuzhiyun			#gpio-cells = <2>;
299*4882a593Smuzhiyun		};
300*4882a593Smuzhiyun
301*4882a593Smuzhiyun		port28x: gpio@550000f8 {
302*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
303*4882a593Smuzhiyun			reg = <0x550000f8 0x8>;
304*4882a593Smuzhiyun			gpio-controller;
305*4882a593Smuzhiyun			#gpio-cells = <2>;
306*4882a593Smuzhiyun		};
307*4882a593Smuzhiyun
308*4882a593Smuzhiyun		port29x: gpio@55000100 {
309*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
310*4882a593Smuzhiyun			reg = <0x55000100 0x8>;
311*4882a593Smuzhiyun			gpio-controller;
312*4882a593Smuzhiyun			#gpio-cells = <2>;
313*4882a593Smuzhiyun		};
314*4882a593Smuzhiyun
315*4882a593Smuzhiyun		port30x: gpio@55000108 {
316*4882a593Smuzhiyun			compatible = "socionext,uniphier-gpio";
317*4882a593Smuzhiyun			reg = <0x55000108 0x8>;
318*4882a593Smuzhiyun			gpio-controller;
319*4882a593Smuzhiyun			#gpio-cells = <2>;
320*4882a593Smuzhiyun		};
321*4882a593Smuzhiyun
322*4882a593Smuzhiyun		i2c0: i2c@58780000 {
323*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
324*4882a593Smuzhiyun			status = "disabled";
325*4882a593Smuzhiyun			reg = <0x58780000 0x80>;
326*4882a593Smuzhiyun			#address-cells = <1>;
327*4882a593Smuzhiyun			#size-cells = <0>;
328*4882a593Smuzhiyun			interrupts = <0 41 4>;
329*4882a593Smuzhiyun			pinctrl-names = "default";
330*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_i2c0>;
331*4882a593Smuzhiyun			clocks = <&peri_clk 4>;
332*4882a593Smuzhiyun			clock-frequency = <100000>;
333*4882a593Smuzhiyun		};
334*4882a593Smuzhiyun
335*4882a593Smuzhiyun		i2c1: i2c@58781000 {
336*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
337*4882a593Smuzhiyun			status = "disabled";
338*4882a593Smuzhiyun			reg = <0x58781000 0x80>;
339*4882a593Smuzhiyun			#address-cells = <1>;
340*4882a593Smuzhiyun			#size-cells = <0>;
341*4882a593Smuzhiyun			interrupts = <0 42 4>;
342*4882a593Smuzhiyun			pinctrl-names = "default";
343*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_i2c1>;
344*4882a593Smuzhiyun			clocks = <&peri_clk 5>;
345*4882a593Smuzhiyun			clock-frequency = <100000>;
346*4882a593Smuzhiyun		};
347*4882a593Smuzhiyun
348*4882a593Smuzhiyun		i2c2: i2c@58782000 {
349*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
350*4882a593Smuzhiyun			status = "disabled";
351*4882a593Smuzhiyun			reg = <0x58782000 0x80>;
352*4882a593Smuzhiyun			#address-cells = <1>;
353*4882a593Smuzhiyun			#size-cells = <0>;
354*4882a593Smuzhiyun			interrupts = <0 43 4>;
355*4882a593Smuzhiyun			pinctrl-names = "default";
356*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_i2c2>;
357*4882a593Smuzhiyun			clocks = <&peri_clk 6>;
358*4882a593Smuzhiyun			clock-frequency = <100000>;
359*4882a593Smuzhiyun		};
360*4882a593Smuzhiyun
361*4882a593Smuzhiyun		i2c3: i2c@58783000 {
362*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
363*4882a593Smuzhiyun			status = "disabled";
364*4882a593Smuzhiyun			reg = <0x58783000 0x80>;
365*4882a593Smuzhiyun			#address-cells = <1>;
366*4882a593Smuzhiyun			#size-cells = <0>;
367*4882a593Smuzhiyun			interrupts = <0 44 4>;
368*4882a593Smuzhiyun			pinctrl-names = "default";
369*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_i2c3>;
370*4882a593Smuzhiyun			clocks = <&peri_clk 7>;
371*4882a593Smuzhiyun			clock-frequency = <100000>;
372*4882a593Smuzhiyun		};
373*4882a593Smuzhiyun
374*4882a593Smuzhiyun		/* i2c4 does not exist */
375*4882a593Smuzhiyun
376*4882a593Smuzhiyun		/* chip-internal connection for DMD */
377*4882a593Smuzhiyun		i2c5: i2c@58785000 {
378*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
379*4882a593Smuzhiyun			reg = <0x58785000 0x80>;
380*4882a593Smuzhiyun			#address-cells = <1>;
381*4882a593Smuzhiyun			#size-cells = <0>;
382*4882a593Smuzhiyun			interrupts = <0 25 4>;
383*4882a593Smuzhiyun			clocks = <&peri_clk 9>;
384*4882a593Smuzhiyun			clock-frequency = <400000>;
385*4882a593Smuzhiyun		};
386*4882a593Smuzhiyun
387*4882a593Smuzhiyun		/* chip-internal connection for HDMI */
388*4882a593Smuzhiyun		i2c6: i2c@58786000 {
389*4882a593Smuzhiyun			compatible = "socionext,uniphier-fi2c";
390*4882a593Smuzhiyun			reg = <0x58786000 0x80>;
391*4882a593Smuzhiyun			#address-cells = <1>;
392*4882a593Smuzhiyun			#size-cells = <0>;
393*4882a593Smuzhiyun			interrupts = <0 26 4>;
394*4882a593Smuzhiyun			clocks = <&peri_clk 10>;
395*4882a593Smuzhiyun			clock-frequency = <400000>;
396*4882a593Smuzhiyun		};
397*4882a593Smuzhiyun
398*4882a593Smuzhiyun		system_bus: system-bus@58c00000 {
399*4882a593Smuzhiyun			compatible = "socionext,uniphier-system-bus";
400*4882a593Smuzhiyun			status = "disabled";
401*4882a593Smuzhiyun			reg = <0x58c00000 0x400>;
402*4882a593Smuzhiyun			#address-cells = <2>;
403*4882a593Smuzhiyun			#size-cells = <1>;
404*4882a593Smuzhiyun			pinctrl-names = "default";
405*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_system_bus>;
406*4882a593Smuzhiyun		};
407*4882a593Smuzhiyun
408*4882a593Smuzhiyun		smpctrl@59801000 {
409*4882a593Smuzhiyun			compatible = "socionext,uniphier-smpctrl";
410*4882a593Smuzhiyun			reg = <0x59801000 0x400>;
411*4882a593Smuzhiyun		};
412*4882a593Smuzhiyun
413*4882a593Smuzhiyun		mioctrl@59810000 {
414*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-mioctrl",
415*4882a593Smuzhiyun				     "simple-mfd", "syscon";
416*4882a593Smuzhiyun			reg = <0x59810000 0x800>;
417*4882a593Smuzhiyun			u-boot,dm-pre-reloc;
418*4882a593Smuzhiyun
419*4882a593Smuzhiyun			mio_clk: clock {
420*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-mio-clock";
421*4882a593Smuzhiyun				#clock-cells = <1>;
422*4882a593Smuzhiyun			};
423*4882a593Smuzhiyun
424*4882a593Smuzhiyun			mio_rst: reset {
425*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-mio-reset";
426*4882a593Smuzhiyun				#reset-cells = <1>;
427*4882a593Smuzhiyun			};
428*4882a593Smuzhiyun		};
429*4882a593Smuzhiyun
430*4882a593Smuzhiyun		perictrl@59820000 {
431*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-perictrl",
432*4882a593Smuzhiyun				     "simple-mfd", "syscon";
433*4882a593Smuzhiyun			reg = <0x59820000 0x200>;
434*4882a593Smuzhiyun
435*4882a593Smuzhiyun			peri_clk: clock {
436*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-peri-clock";
437*4882a593Smuzhiyun				#clock-cells = <1>;
438*4882a593Smuzhiyun			};
439*4882a593Smuzhiyun
440*4882a593Smuzhiyun			peri_rst: reset {
441*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-peri-reset";
442*4882a593Smuzhiyun				#reset-cells = <1>;
443*4882a593Smuzhiyun			};
444*4882a593Smuzhiyun		};
445*4882a593Smuzhiyun
446*4882a593Smuzhiyun		sd: sdhc@5a400000 {
447*4882a593Smuzhiyun			compatible = "socionext,uniphier-sdhc";
448*4882a593Smuzhiyun			status = "disabled";
449*4882a593Smuzhiyun			reg = <0x5a400000 0x200>;
450*4882a593Smuzhiyun			interrupts = <0 76 4>;
451*4882a593Smuzhiyun			pinctrl-names = "default", "1.8v";
452*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_sd>;
453*4882a593Smuzhiyun			pinctrl-1 = <&pinctrl_sd_1v8>;
454*4882a593Smuzhiyun			clocks = <&mio_clk 0>;
455*4882a593Smuzhiyun			reset-names = "host", "bridge";
456*4882a593Smuzhiyun			resets = <&mio_rst 0>, <&mio_rst 3>;
457*4882a593Smuzhiyun			bus-width = <4>;
458*4882a593Smuzhiyun			cap-sd-highspeed;
459*4882a593Smuzhiyun			sd-uhs-sdr12;
460*4882a593Smuzhiyun			sd-uhs-sdr25;
461*4882a593Smuzhiyun			sd-uhs-sdr50;
462*4882a593Smuzhiyun		};
463*4882a593Smuzhiyun
464*4882a593Smuzhiyun		emmc: sdhc@5a500000 {
465*4882a593Smuzhiyun			compatible = "socionext,uniphier-sdhc";
466*4882a593Smuzhiyun			status = "disabled";
467*4882a593Smuzhiyun			reg = <0x5a500000 0x200>;
468*4882a593Smuzhiyun			interrupts = <0 78 4>;
469*4882a593Smuzhiyun			pinctrl-names = "default", "1.8v";
470*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_emmc>;
471*4882a593Smuzhiyun			pinctrl-1 = <&pinctrl_emmc_1v8>;
472*4882a593Smuzhiyun			clocks = <&mio_clk 1>;
473*4882a593Smuzhiyun			reset-names = "host", "bridge";
474*4882a593Smuzhiyun			resets = <&mio_rst 1>, <&mio_rst 4>;
475*4882a593Smuzhiyun			bus-width = <8>;
476*4882a593Smuzhiyun			non-removable;
477*4882a593Smuzhiyun			cap-mmc-highspeed;
478*4882a593Smuzhiyun			cap-mmc-hw-reset;
479*4882a593Smuzhiyun		};
480*4882a593Smuzhiyun
481*4882a593Smuzhiyun		sd1: sdhc@5a600000 {
482*4882a593Smuzhiyun			compatible = "socionext,uniphier-sdhc";
483*4882a593Smuzhiyun			status = "disabled";
484*4882a593Smuzhiyun			reg = <0x5a600000 0x200>;
485*4882a593Smuzhiyun			interrupts = <0 85 4>;
486*4882a593Smuzhiyun			pinctrl-names = "default", "1.8v";
487*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_sd1>;
488*4882a593Smuzhiyun			pinctrl-1 = <&pinctrl_sd1_1v8>;
489*4882a593Smuzhiyun			clocks = <&mio_clk 2>;
490*4882a593Smuzhiyun			resets = <&mio_rst 2>, <&mio_rst 5>;
491*4882a593Smuzhiyun			bus-width = <4>;
492*4882a593Smuzhiyun			cap-sd-highspeed;
493*4882a593Smuzhiyun			sd-uhs-sdr12;
494*4882a593Smuzhiyun			sd-uhs-sdr25;
495*4882a593Smuzhiyun			sd-uhs-sdr50;
496*4882a593Smuzhiyun		};
497*4882a593Smuzhiyun
498*4882a593Smuzhiyun		usb2: usb@5a800100 {
499*4882a593Smuzhiyun			compatible = "socionext,uniphier-ehci", "generic-ehci";
500*4882a593Smuzhiyun			status = "disabled";
501*4882a593Smuzhiyun			reg = <0x5a800100 0x100>;
502*4882a593Smuzhiyun			interrupts = <0 80 4>;
503*4882a593Smuzhiyun			pinctrl-names = "default";
504*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_usb2>;
505*4882a593Smuzhiyun			clocks = <&mio_clk 7>, <&mio_clk 8>, <&mio_clk 12>;
506*4882a593Smuzhiyun			resets = <&sys_rst 8>, <&mio_rst 7>, <&mio_rst 8>,
507*4882a593Smuzhiyun				 <&mio_rst 12>;
508*4882a593Smuzhiyun		};
509*4882a593Smuzhiyun
510*4882a593Smuzhiyun		usb3: usb@5a810100 {
511*4882a593Smuzhiyun			compatible = "socionext,uniphier-ehci", "generic-ehci";
512*4882a593Smuzhiyun			status = "disabled";
513*4882a593Smuzhiyun			reg = <0x5a810100 0x100>;
514*4882a593Smuzhiyun			interrupts = <0 81 4>;
515*4882a593Smuzhiyun			pinctrl-names = "default";
516*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_usb3>;
517*4882a593Smuzhiyun			clocks = <&mio_clk 7>, <&mio_clk 9>, <&mio_clk 13>;
518*4882a593Smuzhiyun			resets = <&sys_rst 8>, <&mio_rst 7>, <&mio_rst 9>,
519*4882a593Smuzhiyun				 <&mio_rst 13>;
520*4882a593Smuzhiyun		};
521*4882a593Smuzhiyun
522*4882a593Smuzhiyun		soc-glue@5f800000 {
523*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-soc-glue",
524*4882a593Smuzhiyun				     "simple-mfd", "syscon";
525*4882a593Smuzhiyun			reg = <0x5f800000 0x2000>;
526*4882a593Smuzhiyun			u-boot,dm-pre-reloc;
527*4882a593Smuzhiyun
528*4882a593Smuzhiyun			pinctrl: pinctrl {
529*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-pinctrl";
530*4882a593Smuzhiyun				u-boot,dm-pre-reloc;
531*4882a593Smuzhiyun			};
532*4882a593Smuzhiyun		};
533*4882a593Smuzhiyun
534*4882a593Smuzhiyun		aidet: aidet@5fc20000 {
535*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-aidet";
536*4882a593Smuzhiyun			reg = <0x5fc20000 0x200>;
537*4882a593Smuzhiyun			interrupt-controller;
538*4882a593Smuzhiyun			#interrupt-cells = <2>;
539*4882a593Smuzhiyun		};
540*4882a593Smuzhiyun
541*4882a593Smuzhiyun		timer@60000200 {
542*4882a593Smuzhiyun			compatible = "arm,cortex-a9-global-timer";
543*4882a593Smuzhiyun			reg = <0x60000200 0x20>;
544*4882a593Smuzhiyun			interrupts = <1 11 0x304>;
545*4882a593Smuzhiyun			clocks = <&arm_timer_clk>;
546*4882a593Smuzhiyun		};
547*4882a593Smuzhiyun
548*4882a593Smuzhiyun		timer@60000600 {
549*4882a593Smuzhiyun			compatible = "arm,cortex-a9-twd-timer";
550*4882a593Smuzhiyun			reg = <0x60000600 0x20>;
551*4882a593Smuzhiyun			interrupts = <1 13 0x304>;
552*4882a593Smuzhiyun			clocks = <&arm_timer_clk>;
553*4882a593Smuzhiyun		};
554*4882a593Smuzhiyun
555*4882a593Smuzhiyun		intc: interrupt-controller@60001000 {
556*4882a593Smuzhiyun			compatible = "arm,cortex-a9-gic";
557*4882a593Smuzhiyun			reg = <0x60001000 0x1000>,
558*4882a593Smuzhiyun			      <0x60000100 0x100>;
559*4882a593Smuzhiyun			#interrupt-cells = <3>;
560*4882a593Smuzhiyun			interrupt-controller;
561*4882a593Smuzhiyun		};
562*4882a593Smuzhiyun
563*4882a593Smuzhiyun		sysctrl@61840000 {
564*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-sysctrl",
565*4882a593Smuzhiyun				     "simple-mfd", "syscon";
566*4882a593Smuzhiyun			reg = <0x61840000 0x10000>;
567*4882a593Smuzhiyun
568*4882a593Smuzhiyun			sys_clk: clock {
569*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-clock";
570*4882a593Smuzhiyun				#clock-cells = <1>;
571*4882a593Smuzhiyun			};
572*4882a593Smuzhiyun
573*4882a593Smuzhiyun			sys_rst: reset {
574*4882a593Smuzhiyun				compatible = "socionext,uniphier-pro4-reset";
575*4882a593Smuzhiyun				#reset-cells = <1>;
576*4882a593Smuzhiyun			};
577*4882a593Smuzhiyun		};
578*4882a593Smuzhiyun
579*4882a593Smuzhiyun		usb0: usb@65b00000 {
580*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-dwc3";
581*4882a593Smuzhiyun			status = "disabled";
582*4882a593Smuzhiyun			reg = <0x65b00000 0x1000>;
583*4882a593Smuzhiyun			#address-cells = <1>;
584*4882a593Smuzhiyun			#size-cells = <1>;
585*4882a593Smuzhiyun			ranges;
586*4882a593Smuzhiyun			pinctrl-names = "default";
587*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_usb0>;
588*4882a593Smuzhiyun			dwc3@65a00000 {
589*4882a593Smuzhiyun				compatible = "snps,dwc3";
590*4882a593Smuzhiyun				reg = <0x65a00000 0x10000>;
591*4882a593Smuzhiyun				interrupts = <0 134 4>;
592*4882a593Smuzhiyun				dr_mode = "host";
593*4882a593Smuzhiyun				tx-fifo-resize;
594*4882a593Smuzhiyun			};
595*4882a593Smuzhiyun		};
596*4882a593Smuzhiyun
597*4882a593Smuzhiyun		usb1: usb@65d00000 {
598*4882a593Smuzhiyun			compatible = "socionext,uniphier-pro4-dwc3";
599*4882a593Smuzhiyun			status = "disabled";
600*4882a593Smuzhiyun			reg = <0x65d00000 0x1000>;
601*4882a593Smuzhiyun			#address-cells = <1>;
602*4882a593Smuzhiyun			#size-cells = <1>;
603*4882a593Smuzhiyun			ranges;
604*4882a593Smuzhiyun			pinctrl-names = "default";
605*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_usb1>;
606*4882a593Smuzhiyun			dwc3@65c00000 {
607*4882a593Smuzhiyun				compatible = "snps,dwc3";
608*4882a593Smuzhiyun				reg = <0x65c00000 0x10000>;
609*4882a593Smuzhiyun				interrupts = <0 137 4>;
610*4882a593Smuzhiyun				dr_mode = "host";
611*4882a593Smuzhiyun				tx-fifo-resize;
612*4882a593Smuzhiyun			};
613*4882a593Smuzhiyun		};
614*4882a593Smuzhiyun
615*4882a593Smuzhiyun		nand: nand@68000000 {
616*4882a593Smuzhiyun			compatible = "socionext,uniphier-denali-nand-v5a";
617*4882a593Smuzhiyun			status = "disabled";
618*4882a593Smuzhiyun			reg-names = "nand_data", "denali_reg";
619*4882a593Smuzhiyun			reg = <0x68000000 0x20>, <0x68100000 0x1000>;
620*4882a593Smuzhiyun			interrupts = <0 65 4>;
621*4882a593Smuzhiyun			pinctrl-names = "default";
622*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_nand>;
623*4882a593Smuzhiyun			clocks = <&sys_clk 2>;
624*4882a593Smuzhiyun		};
625*4882a593Smuzhiyun	};
626*4882a593Smuzhiyun};
627*4882a593Smuzhiyun
628*4882a593Smuzhiyun#include "uniphier-pinctrl.dtsi"
629