xref: /OK3568_Linux_fs/u-boot/arch/arm/dts/rk3188.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/*
2*4882a593Smuzhiyun * Copyright (c) 2013 MundoReader S.L.
3*4882a593Smuzhiyun * Author: Heiko Stuebner <heiko@sntech.de>
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * SPDX-License-Identifier:     GPL-2.0+ or X11
6*4882a593Smuzhiyun */
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun#include <dt-bindings/gpio/gpio.h>
9*4882a593Smuzhiyun#include <dt-bindings/pinctrl/rockchip.h>
10*4882a593Smuzhiyun#include <dt-bindings/clock/rk3188-cru.h>
11*4882a593Smuzhiyun#include "rk3xxx.dtsi"
12*4882a593Smuzhiyun
13*4882a593Smuzhiyun/ {
14*4882a593Smuzhiyun	compatible = "rockchip,rk3188";
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun	cpus {
17*4882a593Smuzhiyun		#address-cells = <1>;
18*4882a593Smuzhiyun		#size-cells = <0>;
19*4882a593Smuzhiyun		enable-method = "rockchip,rk3066-smp";
20*4882a593Smuzhiyun
21*4882a593Smuzhiyun		cpu0: cpu@0 {
22*4882a593Smuzhiyun			device_type = "cpu";
23*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
24*4882a593Smuzhiyun			next-level-cache = <&L2>;
25*4882a593Smuzhiyun			reg = <0x0>;
26*4882a593Smuzhiyun			operating-points = <
27*4882a593Smuzhiyun				/* kHz    uV */
28*4882a593Smuzhiyun				1608000 1350000
29*4882a593Smuzhiyun				1416000 1250000
30*4882a593Smuzhiyun				1200000 1150000
31*4882a593Smuzhiyun				1008000 1075000
32*4882a593Smuzhiyun				 816000  975000
33*4882a593Smuzhiyun				 600000  950000
34*4882a593Smuzhiyun				 504000  925000
35*4882a593Smuzhiyun				 312000  875000
36*4882a593Smuzhiyun			>;
37*4882a593Smuzhiyun			clock-latency = <40000>;
38*4882a593Smuzhiyun			clocks = <&cru ARMCLK>;
39*4882a593Smuzhiyun		};
40*4882a593Smuzhiyun		cpu@1 {
41*4882a593Smuzhiyun			device_type = "cpu";
42*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
43*4882a593Smuzhiyun			next-level-cache = <&L2>;
44*4882a593Smuzhiyun			reg = <0x1>;
45*4882a593Smuzhiyun		};
46*4882a593Smuzhiyun		cpu@2 {
47*4882a593Smuzhiyun			device_type = "cpu";
48*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
49*4882a593Smuzhiyun			next-level-cache = <&L2>;
50*4882a593Smuzhiyun			reg = <0x2>;
51*4882a593Smuzhiyun		};
52*4882a593Smuzhiyun		cpu@3 {
53*4882a593Smuzhiyun			device_type = "cpu";
54*4882a593Smuzhiyun			compatible = "arm,cortex-a9";
55*4882a593Smuzhiyun			next-level-cache = <&L2>;
56*4882a593Smuzhiyun			reg = <0x3>;
57*4882a593Smuzhiyun		};
58*4882a593Smuzhiyun	};
59*4882a593Smuzhiyun
60*4882a593Smuzhiyun	sram: sram@10080000 {
61*4882a593Smuzhiyun		compatible = "mmio-sram";
62*4882a593Smuzhiyun		reg = <0x10080000 0x8000>;
63*4882a593Smuzhiyun		#address-cells = <1>;
64*4882a593Smuzhiyun		#size-cells = <1>;
65*4882a593Smuzhiyun		ranges = <0 0x10080000 0x8000>;
66*4882a593Smuzhiyun
67*4882a593Smuzhiyun		smp-sram@0 {
68*4882a593Smuzhiyun			compatible = "rockchip,rk3066-smp-sram";
69*4882a593Smuzhiyun			reg = <0x0 0x50>;
70*4882a593Smuzhiyun		};
71*4882a593Smuzhiyun	};
72*4882a593Smuzhiyun
73*4882a593Smuzhiyun	i2s0: i2s@1011a000 {
74*4882a593Smuzhiyun		compatible = "rockchip,rk3188-i2s", "rockchip,rk3066-i2s";
75*4882a593Smuzhiyun		reg = <0x1011a000 0x2000>;
76*4882a593Smuzhiyun		interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
77*4882a593Smuzhiyun		#address-cells = <1>;
78*4882a593Smuzhiyun		#size-cells = <0>;
79*4882a593Smuzhiyun		pinctrl-names = "default";
80*4882a593Smuzhiyun		pinctrl-0 = <&i2s0_bus>;
81*4882a593Smuzhiyun		dmas = <&dmac1_s 6>, <&dmac1_s 7>;
82*4882a593Smuzhiyun		dma-names = "tx", "rx";
83*4882a593Smuzhiyun		clock-names = "i2s_hclk", "i2s_clk";
84*4882a593Smuzhiyun		clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
85*4882a593Smuzhiyun		rockchip,playback-channels = <2>;
86*4882a593Smuzhiyun		rockchip,capture-channels = <2>;
87*4882a593Smuzhiyun		status = "disabled";
88*4882a593Smuzhiyun	};
89*4882a593Smuzhiyun
90*4882a593Smuzhiyun	spdif: sound@1011e000 {
91*4882a593Smuzhiyun		compatible = "rockchip,rk3188-spdif", "rockchip,rk3066-spdif";
92*4882a593Smuzhiyun		reg = <0x1011e000 0x2000>;
93*4882a593Smuzhiyun		#sound-dai-cells = <0>;
94*4882a593Smuzhiyun		clock-names = "hclk", "mclk";
95*4882a593Smuzhiyun		clocks = <&cru HCLK_SPDIF>, <&cru SCLK_SPDIF>;
96*4882a593Smuzhiyun		dmas = <&dmac1_s 8>;
97*4882a593Smuzhiyun		dma-names = "tx";
98*4882a593Smuzhiyun		interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
99*4882a593Smuzhiyun		pinctrl-names = "default";
100*4882a593Smuzhiyun		pinctrl-0 = <&spdif_tx>;
101*4882a593Smuzhiyun		status = "disabled";
102*4882a593Smuzhiyun	};
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun	cru: clock-controller@20000000 {
105*4882a593Smuzhiyun		compatible = "rockchip,rk3188-cru";
106*4882a593Smuzhiyun		reg = <0x20000000 0x1000>;
107*4882a593Smuzhiyun		rockchip,grf = <&grf>;
108*4882a593Smuzhiyun
109*4882a593Smuzhiyun		#clock-cells = <1>;
110*4882a593Smuzhiyun		#reset-cells = <1>;
111*4882a593Smuzhiyun	};
112*4882a593Smuzhiyun
113*4882a593Smuzhiyun	efuse: efuse@20010000 {
114*4882a593Smuzhiyun		compatible = "rockchip,rockchip-efuse";
115*4882a593Smuzhiyun		reg = <0x20010000 0x4000>;
116*4882a593Smuzhiyun		#address-cells = <1>;
117*4882a593Smuzhiyun		#size-cells = <1>;
118*4882a593Smuzhiyun		clocks = <&cru PCLK_EFUSE>;
119*4882a593Smuzhiyun		clock-names = "pclk_efuse";
120*4882a593Smuzhiyun
121*4882a593Smuzhiyun		cpu_leakage: cpu_leakage@17 {
122*4882a593Smuzhiyun			reg = <0x17 0x1>;
123*4882a593Smuzhiyun		};
124*4882a593Smuzhiyun	};
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun	saradc: saradc@2006c000 {
127*4882a593Smuzhiyun		compatible = "rockchip,saradc";
128*4882a593Smuzhiyun		reg = <0x2006c000 0x100>;
129*4882a593Smuzhiyun		interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
130*4882a593Smuzhiyun		#io-channel-cells = <1>;
131*4882a593Smuzhiyun		clocks = <&cru SCLK_SARADC>, <&cru PCLK_SARADC>;
132*4882a593Smuzhiyun		clock-names = "saradc", "pclk_saradc";
133*4882a593Smuzhiyun		status = "disabled";
134*4882a593Smuzhiyun	};
135*4882a593Smuzhiyun
136*4882a593Smuzhiyun	timer3: timer@2000e000 {
137*4882a593Smuzhiyun		compatible = "rockchip,rk3188-timer", "rockchip,rk3288-timer";
138*4882a593Smuzhiyun		reg = <0x2000e000 0x20>;
139*4882a593Smuzhiyun		interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
140*4882a593Smuzhiyun	};
141*4882a593Smuzhiyun
142*4882a593Smuzhiyun	usbphy: phy {
143*4882a593Smuzhiyun		compatible = "rockchip,rk3188-usb-phy", "rockchip,rk3288-usb-phy";
144*4882a593Smuzhiyun		rockchip,grf = <&grf>;
145*4882a593Smuzhiyun		#address-cells = <1>;
146*4882a593Smuzhiyun		#size-cells = <0>;
147*4882a593Smuzhiyun		status = "disabled";
148*4882a593Smuzhiyun
149*4882a593Smuzhiyun		usbphy0: usb-phy@10c {
150*4882a593Smuzhiyun			#phy-cells = <0>;
151*4882a593Smuzhiyun			reg = <0x10c>;
152*4882a593Smuzhiyun			clocks = <&cru SCLK_OTGPHY0>;
153*4882a593Smuzhiyun			clock-names = "phyclk";
154*4882a593Smuzhiyun			#clock-cells = <0>;
155*4882a593Smuzhiyun		};
156*4882a593Smuzhiyun
157*4882a593Smuzhiyun		usbphy1: usb-phy@11c {
158*4882a593Smuzhiyun			#phy-cells = <0>;
159*4882a593Smuzhiyun			reg = <0x11c>;
160*4882a593Smuzhiyun			clocks = <&cru SCLK_OTGPHY1>;
161*4882a593Smuzhiyun			clock-names = "phyclk";
162*4882a593Smuzhiyun			#clock-cells = <0>;
163*4882a593Smuzhiyun		};
164*4882a593Smuzhiyun	};
165*4882a593Smuzhiyun
166*4882a593Smuzhiyun	pinctrl: pinctrl {
167*4882a593Smuzhiyun		compatible = "rockchip,rk3188-pinctrl";
168*4882a593Smuzhiyun		rockchip,grf = <&grf>;
169*4882a593Smuzhiyun		rockchip,pmu = <&pmu>;
170*4882a593Smuzhiyun
171*4882a593Smuzhiyun		#address-cells = <1>;
172*4882a593Smuzhiyun		#size-cells = <1>;
173*4882a593Smuzhiyun		ranges;
174*4882a593Smuzhiyun
175*4882a593Smuzhiyun		gpio0: gpio0@2000a000 {
176*4882a593Smuzhiyun			compatible = "rockchip,gpio-bank";
177*4882a593Smuzhiyun			reg = <0x2000a000 0x100>;
178*4882a593Smuzhiyun			interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
179*4882a593Smuzhiyun			clocks = <&cru PCLK_GPIO0>;
180*4882a593Smuzhiyun
181*4882a593Smuzhiyun			gpio-controller;
182*4882a593Smuzhiyun			#gpio-cells = <2>;
183*4882a593Smuzhiyun
184*4882a593Smuzhiyun			interrupt-controller;
185*4882a593Smuzhiyun			#interrupt-cells = <2>;
186*4882a593Smuzhiyun		};
187*4882a593Smuzhiyun
188*4882a593Smuzhiyun		gpio1: gpio1@2003c000 {
189*4882a593Smuzhiyun			compatible = "rockchip,gpio-bank";
190*4882a593Smuzhiyun			reg = <0x2003c000 0x100>;
191*4882a593Smuzhiyun			interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
192*4882a593Smuzhiyun			clocks = <&cru PCLK_GPIO1>;
193*4882a593Smuzhiyun
194*4882a593Smuzhiyun			gpio-controller;
195*4882a593Smuzhiyun			#gpio-cells = <2>;
196*4882a593Smuzhiyun
197*4882a593Smuzhiyun			interrupt-controller;
198*4882a593Smuzhiyun			#interrupt-cells = <2>;
199*4882a593Smuzhiyun		};
200*4882a593Smuzhiyun
201*4882a593Smuzhiyun		gpio2: gpio2@2003e000 {
202*4882a593Smuzhiyun			compatible = "rockchip,gpio-bank";
203*4882a593Smuzhiyun			reg = <0x2003e000 0x100>;
204*4882a593Smuzhiyun			interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
205*4882a593Smuzhiyun			clocks = <&cru PCLK_GPIO2>;
206*4882a593Smuzhiyun
207*4882a593Smuzhiyun			gpio-controller;
208*4882a593Smuzhiyun			#gpio-cells = <2>;
209*4882a593Smuzhiyun
210*4882a593Smuzhiyun			interrupt-controller;
211*4882a593Smuzhiyun			#interrupt-cells = <2>;
212*4882a593Smuzhiyun		};
213*4882a593Smuzhiyun
214*4882a593Smuzhiyun		gpio3: gpio3@20080000 {
215*4882a593Smuzhiyun			compatible = "rockchip,gpio-bank";
216*4882a593Smuzhiyun			reg = <0x20080000 0x100>;
217*4882a593Smuzhiyun			interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
218*4882a593Smuzhiyun			clocks = <&cru PCLK_GPIO3>;
219*4882a593Smuzhiyun
220*4882a593Smuzhiyun			gpio-controller;
221*4882a593Smuzhiyun			#gpio-cells = <2>;
222*4882a593Smuzhiyun
223*4882a593Smuzhiyun			interrupt-controller;
224*4882a593Smuzhiyun			#interrupt-cells = <2>;
225*4882a593Smuzhiyun		};
226*4882a593Smuzhiyun
227*4882a593Smuzhiyun		pcfg_pull_up: pcfg_pull_up {
228*4882a593Smuzhiyun			bias-pull-up;
229*4882a593Smuzhiyun		};
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun		pcfg_pull_down: pcfg_pull_down {
232*4882a593Smuzhiyun			bias-pull-down;
233*4882a593Smuzhiyun		};
234*4882a593Smuzhiyun
235*4882a593Smuzhiyun		pcfg_pull_none: pcfg_pull_none {
236*4882a593Smuzhiyun			bias-disable;
237*4882a593Smuzhiyun		};
238*4882a593Smuzhiyun
239*4882a593Smuzhiyun		emmc {
240*4882a593Smuzhiyun			emmc_clk: emmc-clk {
241*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 24 RK_FUNC_2 &pcfg_pull_none>;
242*4882a593Smuzhiyun			};
243*4882a593Smuzhiyun
244*4882a593Smuzhiyun			emmc_cmd: emmc-cmd {
245*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 26 RK_FUNC_2 &pcfg_pull_up>;
246*4882a593Smuzhiyun			};
247*4882a593Smuzhiyun
248*4882a593Smuzhiyun			emmc_rst: emmc-rst {
249*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 27 RK_FUNC_2 &pcfg_pull_none>;
250*4882a593Smuzhiyun			};
251*4882a593Smuzhiyun
252*4882a593Smuzhiyun			/*
253*4882a593Smuzhiyun			 * The data pins are shared between nandc and emmc and
254*4882a593Smuzhiyun			 * not accessible through pinctrl. Also they should've
255*4882a593Smuzhiyun			 * been already set correctly by firmware, as
256*4882a593Smuzhiyun			 * flash/emmc is the boot-device.
257*4882a593Smuzhiyun			 */
258*4882a593Smuzhiyun		};
259*4882a593Smuzhiyun
260*4882a593Smuzhiyun		emac {
261*4882a593Smuzhiyun			emac_xfer: emac-xfer {
262*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 16 RK_FUNC_2 &pcfg_pull_none>, /* tx_en */
263*4882a593Smuzhiyun						<RK_GPIO3 17 RK_FUNC_2 &pcfg_pull_none>, /* txd1 */
264*4882a593Smuzhiyun						<RK_GPIO3 18 RK_FUNC_2 &pcfg_pull_none>, /* txd0 */
265*4882a593Smuzhiyun						<RK_GPIO3 19 RK_FUNC_2 &pcfg_pull_none>, /* rxd0 */
266*4882a593Smuzhiyun						<RK_GPIO3 20 RK_FUNC_2 &pcfg_pull_none>, /* rxd1 */
267*4882a593Smuzhiyun						<RK_GPIO3 21 RK_FUNC_2 &pcfg_pull_none>, /* mac_clk */
268*4882a593Smuzhiyun						<RK_GPIO3 22 RK_FUNC_2 &pcfg_pull_none>, /* rx_err */
269*4882a593Smuzhiyun						<RK_GPIO3 23 RK_FUNC_2 &pcfg_pull_none>; /* crs_dvalid */
270*4882a593Smuzhiyun			};
271*4882a593Smuzhiyun
272*4882a593Smuzhiyun			emac_mdio: emac-mdio {
273*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 24 RK_FUNC_2 &pcfg_pull_none>,
274*4882a593Smuzhiyun						<RK_GPIO3 25 RK_FUNC_2 &pcfg_pull_none>;
275*4882a593Smuzhiyun			};
276*4882a593Smuzhiyun		};
277*4882a593Smuzhiyun
278*4882a593Smuzhiyun		i2c0 {
279*4882a593Smuzhiyun			i2c0_xfer: i2c0-xfer {
280*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 24 RK_FUNC_1 &pcfg_pull_none>,
281*4882a593Smuzhiyun						<RK_GPIO1 25 RK_FUNC_1 &pcfg_pull_none>;
282*4882a593Smuzhiyun			};
283*4882a593Smuzhiyun		};
284*4882a593Smuzhiyun
285*4882a593Smuzhiyun		i2c1 {
286*4882a593Smuzhiyun			i2c1_xfer: i2c1-xfer {
287*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 26 RK_FUNC_1 &pcfg_pull_none>,
288*4882a593Smuzhiyun						<RK_GPIO1 27 RK_FUNC_1 &pcfg_pull_none>;
289*4882a593Smuzhiyun			};
290*4882a593Smuzhiyun		};
291*4882a593Smuzhiyun
292*4882a593Smuzhiyun		i2c2 {
293*4882a593Smuzhiyun			i2c2_xfer: i2c2-xfer {
294*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 28 RK_FUNC_1 &pcfg_pull_none>,
295*4882a593Smuzhiyun						<RK_GPIO1 29 RK_FUNC_1 &pcfg_pull_none>;
296*4882a593Smuzhiyun			};
297*4882a593Smuzhiyun		};
298*4882a593Smuzhiyun
299*4882a593Smuzhiyun		i2c3 {
300*4882a593Smuzhiyun			i2c3_xfer: i2c3-xfer {
301*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 14 RK_FUNC_2 &pcfg_pull_none>,
302*4882a593Smuzhiyun						<RK_GPIO3 15 RK_FUNC_2 &pcfg_pull_none>;
303*4882a593Smuzhiyun			};
304*4882a593Smuzhiyun		};
305*4882a593Smuzhiyun
306*4882a593Smuzhiyun		i2c4 {
307*4882a593Smuzhiyun			i2c4_xfer: i2c4-xfer {
308*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 30 RK_FUNC_1 &pcfg_pull_none>,
309*4882a593Smuzhiyun						<RK_GPIO1 31 RK_FUNC_1 &pcfg_pull_none>;
310*4882a593Smuzhiyun			};
311*4882a593Smuzhiyun		};
312*4882a593Smuzhiyun
313*4882a593Smuzhiyun		pwm0 {
314*4882a593Smuzhiyun			pwm0_out: pwm0-out {
315*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 27 RK_FUNC_1 &pcfg_pull_none>;
316*4882a593Smuzhiyun			};
317*4882a593Smuzhiyun		};
318*4882a593Smuzhiyun
319*4882a593Smuzhiyun		pwm1 {
320*4882a593Smuzhiyun			pwm1_out: pwm1-out {
321*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 28 RK_FUNC_1 &pcfg_pull_none>;
322*4882a593Smuzhiyun			};
323*4882a593Smuzhiyun		};
324*4882a593Smuzhiyun
325*4882a593Smuzhiyun		pwm2 {
326*4882a593Smuzhiyun			pwm2_out: pwm2-out {
327*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 29 RK_FUNC_1 &pcfg_pull_none>;
328*4882a593Smuzhiyun			};
329*4882a593Smuzhiyun		};
330*4882a593Smuzhiyun
331*4882a593Smuzhiyun		pwm3 {
332*4882a593Smuzhiyun			pwm3_out: pwm3-out {
333*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 30 RK_FUNC_1 &pcfg_pull_none>;
334*4882a593Smuzhiyun			};
335*4882a593Smuzhiyun		};
336*4882a593Smuzhiyun
337*4882a593Smuzhiyun		spi0 {
338*4882a593Smuzhiyun			spi0_clk: spi0-clk {
339*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 6 RK_FUNC_2 &pcfg_pull_up>;
340*4882a593Smuzhiyun			};
341*4882a593Smuzhiyun			spi0_cs0: spi0-cs0 {
342*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 7 RK_FUNC_2 &pcfg_pull_up>;
343*4882a593Smuzhiyun			};
344*4882a593Smuzhiyun			spi0_tx: spi0-tx {
345*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 5 RK_FUNC_2 &pcfg_pull_up>;
346*4882a593Smuzhiyun			};
347*4882a593Smuzhiyun			spi0_rx: spi0-rx {
348*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 4 RK_FUNC_2 &pcfg_pull_up>;
349*4882a593Smuzhiyun			};
350*4882a593Smuzhiyun			spi0_cs1: spi0-cs1 {
351*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 15 RK_FUNC_1 &pcfg_pull_up>;
352*4882a593Smuzhiyun			};
353*4882a593Smuzhiyun		};
354*4882a593Smuzhiyun
355*4882a593Smuzhiyun		spi1 {
356*4882a593Smuzhiyun			spi1_clk: spi1-clk {
357*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 30 RK_FUNC_1 &pcfg_pull_up>;
358*4882a593Smuzhiyun			};
359*4882a593Smuzhiyun			spi1_cs0: spi1-cs0 {
360*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 31 RK_FUNC_1 &pcfg_pull_up>;
361*4882a593Smuzhiyun			};
362*4882a593Smuzhiyun			spi1_rx: spi1-rx {
363*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 28 RK_FUNC_1 &pcfg_pull_up>;
364*4882a593Smuzhiyun			};
365*4882a593Smuzhiyun			spi1_tx: spi1-tx {
366*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO0 29 RK_FUNC_1 &pcfg_pull_up>;
367*4882a593Smuzhiyun			};
368*4882a593Smuzhiyun			spi1_cs1: spi1-cs1 {
369*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 14 RK_FUNC_2 &pcfg_pull_up>;
370*4882a593Smuzhiyun			};
371*4882a593Smuzhiyun		};
372*4882a593Smuzhiyun
373*4882a593Smuzhiyun		uart0 {
374*4882a593Smuzhiyun			uart0_xfer: uart0-xfer {
375*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 0 RK_FUNC_1 &pcfg_pull_up>,
376*4882a593Smuzhiyun						<RK_GPIO1 1 RK_FUNC_1 &pcfg_pull_none>;
377*4882a593Smuzhiyun			};
378*4882a593Smuzhiyun
379*4882a593Smuzhiyun			uart0_cts: uart0-cts {
380*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 2 RK_FUNC_1 &pcfg_pull_none>;
381*4882a593Smuzhiyun			};
382*4882a593Smuzhiyun
383*4882a593Smuzhiyun			uart0_rts: uart0-rts {
384*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 3 RK_FUNC_1 &pcfg_pull_none>;
385*4882a593Smuzhiyun			};
386*4882a593Smuzhiyun		};
387*4882a593Smuzhiyun
388*4882a593Smuzhiyun		uart1 {
389*4882a593Smuzhiyun			uart1_xfer: uart1-xfer {
390*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 4 RK_FUNC_1 &pcfg_pull_up>,
391*4882a593Smuzhiyun						<RK_GPIO1 5 RK_FUNC_1 &pcfg_pull_none>;
392*4882a593Smuzhiyun			};
393*4882a593Smuzhiyun
394*4882a593Smuzhiyun			uart1_cts: uart1-cts {
395*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 6 RK_FUNC_1 &pcfg_pull_none>;
396*4882a593Smuzhiyun			};
397*4882a593Smuzhiyun
398*4882a593Smuzhiyun			uart1_rts: uart1-rts {
399*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 7 RK_FUNC_1 &pcfg_pull_none>;
400*4882a593Smuzhiyun			};
401*4882a593Smuzhiyun		};
402*4882a593Smuzhiyun
403*4882a593Smuzhiyun		uart2 {
404*4882a593Smuzhiyun			uart2_xfer: uart2-xfer {
405*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 8 RK_FUNC_1 &pcfg_pull_up>,
406*4882a593Smuzhiyun						<RK_GPIO1 9 RK_FUNC_1 &pcfg_pull_none>;
407*4882a593Smuzhiyun			};
408*4882a593Smuzhiyun			/* no rts / cts for uart2 */
409*4882a593Smuzhiyun		};
410*4882a593Smuzhiyun
411*4882a593Smuzhiyun		uart3 {
412*4882a593Smuzhiyun			uart3_xfer: uart3-xfer {
413*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 10 RK_FUNC_1 &pcfg_pull_up>,
414*4882a593Smuzhiyun						<RK_GPIO1 11 RK_FUNC_1 &pcfg_pull_none>;
415*4882a593Smuzhiyun			};
416*4882a593Smuzhiyun
417*4882a593Smuzhiyun			uart3_cts: uart3-cts {
418*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 12 RK_FUNC_1 &pcfg_pull_none>;
419*4882a593Smuzhiyun			};
420*4882a593Smuzhiyun
421*4882a593Smuzhiyun			uart3_rts: uart3-rts {
422*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 13 RK_FUNC_1 &pcfg_pull_none>;
423*4882a593Smuzhiyun			};
424*4882a593Smuzhiyun		};
425*4882a593Smuzhiyun
426*4882a593Smuzhiyun		sd0 {
427*4882a593Smuzhiyun			sd0_clk: sd0-clk {
428*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 2 RK_FUNC_1 &pcfg_pull_none>;
429*4882a593Smuzhiyun			};
430*4882a593Smuzhiyun
431*4882a593Smuzhiyun			sd0_cmd: sd0-cmd {
432*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 3 RK_FUNC_1 &pcfg_pull_none>;
433*4882a593Smuzhiyun			};
434*4882a593Smuzhiyun
435*4882a593Smuzhiyun			sd0_cd: sd0-cd {
436*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 8 RK_FUNC_1 &pcfg_pull_none>;
437*4882a593Smuzhiyun			};
438*4882a593Smuzhiyun
439*4882a593Smuzhiyun			sd0_wp: sd0-wp {
440*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 9 RK_FUNC_1 &pcfg_pull_none>;
441*4882a593Smuzhiyun			};
442*4882a593Smuzhiyun
443*4882a593Smuzhiyun			sd0_pwr: sd0-pwr {
444*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 1 RK_FUNC_1 &pcfg_pull_none>;
445*4882a593Smuzhiyun			};
446*4882a593Smuzhiyun
447*4882a593Smuzhiyun			sd0_bus1: sd0-bus-width1 {
448*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 4 RK_FUNC_1 &pcfg_pull_none>;
449*4882a593Smuzhiyun			};
450*4882a593Smuzhiyun
451*4882a593Smuzhiyun			sd0_bus4: sd0-bus-width4 {
452*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 4 RK_FUNC_1 &pcfg_pull_none>,
453*4882a593Smuzhiyun						<RK_GPIO3 5 RK_FUNC_1 &pcfg_pull_none>,
454*4882a593Smuzhiyun						<RK_GPIO3 6 RK_FUNC_1 &pcfg_pull_none>,
455*4882a593Smuzhiyun						<RK_GPIO3 7 RK_FUNC_1 &pcfg_pull_none>;
456*4882a593Smuzhiyun			};
457*4882a593Smuzhiyun		};
458*4882a593Smuzhiyun
459*4882a593Smuzhiyun		sd1 {
460*4882a593Smuzhiyun			sd1_clk: sd1-clk {
461*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 21 RK_FUNC_1 &pcfg_pull_none>;
462*4882a593Smuzhiyun			};
463*4882a593Smuzhiyun
464*4882a593Smuzhiyun			sd1_cmd: sd1-cmd {
465*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 16 RK_FUNC_1 &pcfg_pull_none>;
466*4882a593Smuzhiyun			};
467*4882a593Smuzhiyun
468*4882a593Smuzhiyun			sd1_cd: sd1-cd {
469*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 22 RK_FUNC_1 &pcfg_pull_none>;
470*4882a593Smuzhiyun			};
471*4882a593Smuzhiyun
472*4882a593Smuzhiyun			sd1_wp: sd1-wp {
473*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 23 RK_FUNC_1 &pcfg_pull_none>;
474*4882a593Smuzhiyun			};
475*4882a593Smuzhiyun
476*4882a593Smuzhiyun			sd1_bus1: sd1-bus-width1 {
477*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 17 RK_FUNC_1 &pcfg_pull_none>;
478*4882a593Smuzhiyun			};
479*4882a593Smuzhiyun
480*4882a593Smuzhiyun			sd1_bus4: sd1-bus-width4 {
481*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO3 17 RK_FUNC_1 &pcfg_pull_none>,
482*4882a593Smuzhiyun						<RK_GPIO3 18 RK_FUNC_1 &pcfg_pull_none>,
483*4882a593Smuzhiyun						<RK_GPIO3 19 RK_FUNC_1 &pcfg_pull_none>,
484*4882a593Smuzhiyun						<RK_GPIO3 20 RK_FUNC_1 &pcfg_pull_none>;
485*4882a593Smuzhiyun			};
486*4882a593Smuzhiyun		};
487*4882a593Smuzhiyun
488*4882a593Smuzhiyun		i2s0 {
489*4882a593Smuzhiyun			i2s0_bus: i2s0-bus {
490*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 16 RK_FUNC_1 &pcfg_pull_none>,
491*4882a593Smuzhiyun						<RK_GPIO1 17 RK_FUNC_1 &pcfg_pull_none>,
492*4882a593Smuzhiyun						<RK_GPIO1 18 RK_FUNC_1 &pcfg_pull_none>,
493*4882a593Smuzhiyun						<RK_GPIO1 19 RK_FUNC_1 &pcfg_pull_none>,
494*4882a593Smuzhiyun						<RK_GPIO1 20 RK_FUNC_1 &pcfg_pull_none>,
495*4882a593Smuzhiyun						<RK_GPIO1 21 RK_FUNC_1 &pcfg_pull_none>;
496*4882a593Smuzhiyun			};
497*4882a593Smuzhiyun		};
498*4882a593Smuzhiyun
499*4882a593Smuzhiyun		spdif {
500*4882a593Smuzhiyun			spdif_tx: spdif-tx {
501*4882a593Smuzhiyun				rockchip,pins = <RK_GPIO1 14 RK_FUNC_1 &pcfg_pull_none>;
502*4882a593Smuzhiyun			};
503*4882a593Smuzhiyun		};
504*4882a593Smuzhiyun	};
505*4882a593Smuzhiyun};
506*4882a593Smuzhiyun
507*4882a593Smuzhiyun&emac {
508*4882a593Smuzhiyun	compatible = "rockchip,rk3188-emac";
509*4882a593Smuzhiyun};
510*4882a593Smuzhiyun
511*4882a593Smuzhiyun&global_timer {
512*4882a593Smuzhiyun	interrupts = <GIC_PPI 11 0xf04>;
513*4882a593Smuzhiyun};
514*4882a593Smuzhiyun
515*4882a593Smuzhiyun&grf {
516*4882a593Smuzhiyun	compatible = "rockchip,rk3188-grf", "syscon";
517*4882a593Smuzhiyun};
518*4882a593Smuzhiyun
519*4882a593Smuzhiyun&local_timer {
520*4882a593Smuzhiyun	interrupts = <GIC_PPI 13 0xf04>;
521*4882a593Smuzhiyun};
522*4882a593Smuzhiyun
523*4882a593Smuzhiyun&i2c0 {
524*4882a593Smuzhiyun	compatible = "rockchip,rk3188-i2c";
525*4882a593Smuzhiyun	pinctrl-names = "default";
526*4882a593Smuzhiyun	pinctrl-0 = <&i2c0_xfer>;
527*4882a593Smuzhiyun};
528*4882a593Smuzhiyun
529*4882a593Smuzhiyun&i2c1 {
530*4882a593Smuzhiyun	compatible = "rockchip,rk3188-i2c";
531*4882a593Smuzhiyun	pinctrl-names = "default";
532*4882a593Smuzhiyun	pinctrl-0 = <&i2c1_xfer>;
533*4882a593Smuzhiyun};
534*4882a593Smuzhiyun
535*4882a593Smuzhiyun&i2c2 {
536*4882a593Smuzhiyun	compatible = "rockchip,rk3188-i2c";
537*4882a593Smuzhiyun	pinctrl-names = "default";
538*4882a593Smuzhiyun	pinctrl-0 = <&i2c2_xfer>;
539*4882a593Smuzhiyun};
540*4882a593Smuzhiyun
541*4882a593Smuzhiyun&i2c3 {
542*4882a593Smuzhiyun	compatible = "rockchip,rk3188-i2c";
543*4882a593Smuzhiyun	pinctrl-names = "default";
544*4882a593Smuzhiyun	pinctrl-0 = <&i2c3_xfer>;
545*4882a593Smuzhiyun};
546*4882a593Smuzhiyun
547*4882a593Smuzhiyun&i2c4 {
548*4882a593Smuzhiyun	compatible = "rockchip,rk3188-i2c";
549*4882a593Smuzhiyun	pinctrl-names = "default";
550*4882a593Smuzhiyun	pinctrl-0 = <&i2c4_xfer>;
551*4882a593Smuzhiyun};
552*4882a593Smuzhiyun
553*4882a593Smuzhiyun&pmu {
554*4882a593Smuzhiyun	compatible = "rockchip,rk3188-pmu", "syscon";
555*4882a593Smuzhiyun};
556*4882a593Smuzhiyun
557*4882a593Smuzhiyun&pwm0 {
558*4882a593Smuzhiyun	pinctrl-names = "active";
559*4882a593Smuzhiyun	pinctrl-0 = <&pwm0_out>;
560*4882a593Smuzhiyun};
561*4882a593Smuzhiyun
562*4882a593Smuzhiyun&pwm1 {
563*4882a593Smuzhiyun	pinctrl-names = "active";
564*4882a593Smuzhiyun	pinctrl-0 = <&pwm1_out>;
565*4882a593Smuzhiyun};
566*4882a593Smuzhiyun
567*4882a593Smuzhiyun&pwm2 {
568*4882a593Smuzhiyun	pinctrl-names = "active";
569*4882a593Smuzhiyun	pinctrl-0 = <&pwm2_out>;
570*4882a593Smuzhiyun};
571*4882a593Smuzhiyun
572*4882a593Smuzhiyun&pwm3 {
573*4882a593Smuzhiyun	pinctrl-names = "active";
574*4882a593Smuzhiyun	pinctrl-0 = <&pwm3_out>;
575*4882a593Smuzhiyun};
576*4882a593Smuzhiyun
577*4882a593Smuzhiyun&spi0 {
578*4882a593Smuzhiyun	compatible = "rockchip,rk3188-spi", "rockchip,rk3066-spi";
579*4882a593Smuzhiyun	pinctrl-names = "default";
580*4882a593Smuzhiyun	pinctrl-0 = <&spi0_clk &spi0_tx &spi0_rx &spi0_cs0>;
581*4882a593Smuzhiyun};
582*4882a593Smuzhiyun
583*4882a593Smuzhiyun&spi1 {
584*4882a593Smuzhiyun	compatible = "rockchip,rk3188-spi", "rockchip,rk3066-spi";
585*4882a593Smuzhiyun	pinctrl-names = "default";
586*4882a593Smuzhiyun	pinctrl-0 = <&spi1_clk &spi1_tx &spi1_rx &spi1_cs0>;
587*4882a593Smuzhiyun};
588*4882a593Smuzhiyun
589*4882a593Smuzhiyun&uart0 {
590*4882a593Smuzhiyun	compatible = "rockchip,rk3188-uart", "snps,dw-apb-uart";
591*4882a593Smuzhiyun	pinctrl-names = "default";
592*4882a593Smuzhiyun	pinctrl-0 = <&uart0_xfer>;
593*4882a593Smuzhiyun};
594*4882a593Smuzhiyun
595*4882a593Smuzhiyun&uart1 {
596*4882a593Smuzhiyun	compatible = "rockchip,rk3188-uart", "snps,dw-apb-uart";
597*4882a593Smuzhiyun	pinctrl-names = "default";
598*4882a593Smuzhiyun	pinctrl-0 = <&uart1_xfer>;
599*4882a593Smuzhiyun};
600*4882a593Smuzhiyun
601*4882a593Smuzhiyun&uart2 {
602*4882a593Smuzhiyun	compatible = "rockchip,rk3188-uart", "snps,dw-apb-uart";
603*4882a593Smuzhiyun	pinctrl-names = "default";
604*4882a593Smuzhiyun	pinctrl-0 = <&uart2_xfer>;
605*4882a593Smuzhiyun};
606*4882a593Smuzhiyun
607*4882a593Smuzhiyun&uart3 {
608*4882a593Smuzhiyun	compatible = "rockchip,rk3188-uart", "snps,dw-apb-uart";
609*4882a593Smuzhiyun	pinctrl-names = "default";
610*4882a593Smuzhiyun	pinctrl-0 = <&uart3_xfer>;
611*4882a593Smuzhiyun};
612*4882a593Smuzhiyun
613*4882a593Smuzhiyun&wdt {
614*4882a593Smuzhiyun	compatible = "rockchip,rk3188-wdt", "snps,dw-wdt";
615*4882a593Smuzhiyun};
616