xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/rk3066a-rayeager.dts (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2*4882a593Smuzhiyun/*
3*4882a593Smuzhiyun * Copyright (c) 2014, 2015 FUKAUMI Naoki <naobsd@gmail.com>
4*4882a593Smuzhiyun */
5*4882a593Smuzhiyun
6*4882a593Smuzhiyun/dts-v1/;
7*4882a593Smuzhiyun#include <dt-bindings/input/input.h>
8*4882a593Smuzhiyun#include "rk3066a.dtsi"
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun/ {
11*4882a593Smuzhiyun	model = "Rayeager PX2";
12*4882a593Smuzhiyun	compatible = "chipspark,rayeager-px2", "rockchip,rk3066a";
13*4882a593Smuzhiyun
14*4882a593Smuzhiyun	memory@60000000 {
15*4882a593Smuzhiyun		device_type = "memory";
16*4882a593Smuzhiyun		reg = <0x60000000 0x40000000>;
17*4882a593Smuzhiyun	};
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun	ir: ir-receiver {
20*4882a593Smuzhiyun		compatible = "gpio-ir-receiver";
21*4882a593Smuzhiyun		gpios = <&gpio6 RK_PA1 GPIO_ACTIVE_LOW>;
22*4882a593Smuzhiyun		pinctrl-names = "default";
23*4882a593Smuzhiyun		pinctrl-0 = <&ir_int>;
24*4882a593Smuzhiyun	};
25*4882a593Smuzhiyun
26*4882a593Smuzhiyun	vdd_logic: vdd-logic {
27*4882a593Smuzhiyun		compatible = "pwm-regulator";
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun		pwms = <&pwm3 0 25000>;
30*4882a593Smuzhiyun		pwm-dutycycle-range = <100 0>;
31*4882a593Smuzhiyun
32*4882a593Smuzhiyun		regulator-name = "vdd_logic";
33*4882a593Smuzhiyun		regulator-always-on;
34*4882a593Smuzhiyun		regulator-boot-on;
35*4882a593Smuzhiyun		regulator-min-microvolt = <925000>;
36*4882a593Smuzhiyun		regulator-max-microvolt = <1400000>;
37*4882a593Smuzhiyun		status = "okay";
38*4882a593Smuzhiyun	};
39*4882a593Smuzhiyun
40*4882a593Smuzhiyun	keys: gpio-keys {
41*4882a593Smuzhiyun		compatible = "gpio-keys";
42*4882a593Smuzhiyun
43*4882a593Smuzhiyun		power {
44*4882a593Smuzhiyun			wakeup-source;
45*4882a593Smuzhiyun			gpios = <&gpio6 RK_PA2 GPIO_ACTIVE_LOW>;
46*4882a593Smuzhiyun			label = "GPIO Power";
47*4882a593Smuzhiyun			linux,code = <KEY_POWER>;
48*4882a593Smuzhiyun			pinctrl-names = "default";
49*4882a593Smuzhiyun			pinctrl-0 = <&pwr_key>;
50*4882a593Smuzhiyun		};
51*4882a593Smuzhiyun	};
52*4882a593Smuzhiyun
53*4882a593Smuzhiyun	sdio_pwrseq: sdio-pwrseq {
54*4882a593Smuzhiyun		compatible = "mmc-pwrseq-simple";
55*4882a593Smuzhiyun		clock-names = "ext_clock";
56*4882a593Smuzhiyun		pinctrl-names = "default";
57*4882a593Smuzhiyun		pinctrl-0 = <&wifi_reg_on>;
58*4882a593Smuzhiyun
59*4882a593Smuzhiyun		/*
60*4882a593Smuzhiyun		 * On the module itself this is one of these (depending
61*4882a593Smuzhiyun		 * on the actual card populated):
62*4882a593Smuzhiyun		 * - SDIO_RESET_L_WL_REG_ON
63*4882a593Smuzhiyun		 * - PDN (power down when low)
64*4882a593Smuzhiyun		 */
65*4882a593Smuzhiyun		reset-gpios = <&gpio3 24 GPIO_ACTIVE_LOW>; /* GPIO3_D0 */
66*4882a593Smuzhiyun	};
67*4882a593Smuzhiyun
68*4882a593Smuzhiyun	wireless-wlan {
69*4882a593Smuzhiyun		compatible = "wlan-platdata";
70*4882a593Smuzhiyun		rockchip,grf = <&grf>;
71*4882a593Smuzhiyun		wifi_chip_type = "ap6330";
72*4882a593Smuzhiyun		sdio_vref = <1800>;
73*4882a593Smuzhiyun
74*4882a593Smuzhiyun		pinctrl-names = "default";
75*4882a593Smuzhiyun		pinctrl-0 = <&wifi_host_wake>;
76*4882a593Smuzhiyun		WIFI,host_wake_irq = <&gpio3 26 GPIO_ACTIVE_HIGH>; /* GPIO3_D2 */
77*4882a593Smuzhiyun		status = "okay";
78*4882a593Smuzhiyun	};
79*4882a593Smuzhiyun
80*4882a593Smuzhiyun	wireless-bluetooth {
81*4882a593Smuzhiyun		compatible = "bluetooth-platdata";
82*4882a593Smuzhiyun		clock-names = "ext_clock";
83*4882a593Smuzhiyun		//wifi-bt-power-toggle;
84*4882a593Smuzhiyun		uart_rts_gpios = <&gpio1 3 GPIO_ACTIVE_LOW>; /* GPIO2_C3 */
85*4882a593Smuzhiyun		pinctrl-names = "default", "rts_gpio";
86*4882a593Smuzhiyun		pinctrl-0 = <&uart0_rts>;
87*4882a593Smuzhiyun		pinctrl-1 = <&uart0_gpios>;
88*4882a593Smuzhiyun		//BT,power_gpio  = <&gpio3 19 GPIO_ACTIVE_HIGH>; /* GPIOx_xx */
89*4882a593Smuzhiyun		BT,reset_gpio    = <&gpio3 25 GPIO_ACTIVE_HIGH>; /* GPIO3_D1 */
90*4882a593Smuzhiyun		BT,wake_gpio     = <&gpio3 22 GPIO_ACTIVE_HIGH>; /* GPIO3_C6 */
91*4882a593Smuzhiyun		BT,wake_host_irq = <&gpio3 23 GPIO_ACTIVE_HIGH>; /* GPIO3_C7 */
92*4882a593Smuzhiyun		status = "okay";
93*4882a593Smuzhiyun	};
94*4882a593Smuzhiyun
95*4882a593Smuzhiyun
96*4882a593Smuzhiyun	vdd_log: vdd-log {
97*4882a593Smuzhiyun		compatible = "pwm-regulator";
98*4882a593Smuzhiyun		pwms = <&pwm3 0 1000>;
99*4882a593Smuzhiyun		regulator-name = "vdd_log";
100*4882a593Smuzhiyun		regulator-min-microvolt = <1200000>;
101*4882a593Smuzhiyun		regulator-max-microvolt = <1200000>;
102*4882a593Smuzhiyun		regulator-always-on;
103*4882a593Smuzhiyun		voltage-table = <1000000 100>,
104*4882a593Smuzhiyun				<1200000 42>;
105*4882a593Smuzhiyun		status = "okay";
106*4882a593Smuzhiyun	};
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun	vsys: vsys-regulator {
109*4882a593Smuzhiyun		compatible = "regulator-fixed";
110*4882a593Smuzhiyun		regulator-name = "vsys";
111*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
112*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
113*4882a593Smuzhiyun		regulator-always-on;
114*4882a593Smuzhiyun		regulator-boot-on;
115*4882a593Smuzhiyun	};
116*4882a593Smuzhiyun
117*4882a593Smuzhiyun	/* input for 5V_STDBY is VSYS or DC5V, selectable by jumper J4 */
118*4882a593Smuzhiyun	vcc_stdby: 5v-stdby-regulator {
119*4882a593Smuzhiyun		compatible = "regulator-fixed";
120*4882a593Smuzhiyun		regulator-name = "5v_stdby";
121*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
122*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
123*4882a593Smuzhiyun		regulator-always-on;
124*4882a593Smuzhiyun		regulator-boot-on;
125*4882a593Smuzhiyun	};
126*4882a593Smuzhiyun
127*4882a593Smuzhiyun	vcc_emmc: emmc-regulator {
128*4882a593Smuzhiyun		compatible = "regulator-fixed";
129*4882a593Smuzhiyun		regulator-name = "emmc_vccq";
130*4882a593Smuzhiyun		regulator-min-microvolt = <3000000>;
131*4882a593Smuzhiyun		regulator-max-microvolt = <3000000>;
132*4882a593Smuzhiyun		vin-supply = <&vsys>;
133*4882a593Smuzhiyun	};
134*4882a593Smuzhiyun
135*4882a593Smuzhiyun	vcc_sata: sata-regulator {
136*4882a593Smuzhiyun		compatible = "regulator-fixed";
137*4882a593Smuzhiyun		enable-active-high;
138*4882a593Smuzhiyun		gpio = <&gpio4 RK_PC6 GPIO_ACTIVE_HIGH>;
139*4882a593Smuzhiyun		pinctrl-names = "default";
140*4882a593Smuzhiyun		pinctrl-0 = <&sata_pwr>;
141*4882a593Smuzhiyun		regulator-name = "usb_5v";
142*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
143*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
144*4882a593Smuzhiyun		regulator-always-on;
145*4882a593Smuzhiyun		vin-supply = <&vcc_stdby>;
146*4882a593Smuzhiyun	};
147*4882a593Smuzhiyun
148*4882a593Smuzhiyun	vcc_sd: sdmmc-regulator {
149*4882a593Smuzhiyun		compatible = "regulator-fixed";
150*4882a593Smuzhiyun		gpio = <&gpio3 RK_PA7 GPIO_ACTIVE_LOW>;
151*4882a593Smuzhiyun		pinctrl-names = "default";
152*4882a593Smuzhiyun		pinctrl-0 = <&sdmmc_pwr>;
153*4882a593Smuzhiyun		regulator-name = "vcc_sd";
154*4882a593Smuzhiyun		regulator-min-microvolt = <3300000>;
155*4882a593Smuzhiyun		regulator-max-microvolt = <3300000>;
156*4882a593Smuzhiyun		startup-delay-us = <100000>;
157*4882a593Smuzhiyun		vin-supply = <&vcc_io>;
158*4882a593Smuzhiyun	};
159*4882a593Smuzhiyun
160*4882a593Smuzhiyun	vcc_host: usb-host-regulator {
161*4882a593Smuzhiyun		compatible = "regulator-fixed";
162*4882a593Smuzhiyun		enable-active-high;
163*4882a593Smuzhiyun		gpio = <&gpio0 RK_PA6 GPIO_ACTIVE_HIGH>;
164*4882a593Smuzhiyun		pinctrl-names = "default";
165*4882a593Smuzhiyun		pinctrl-0 = <&host_drv>;
166*4882a593Smuzhiyun		regulator-name = "host-pwr";
167*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
168*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
169*4882a593Smuzhiyun		regulator-always-on;
170*4882a593Smuzhiyun		vin-supply = <&vcc_stdby>;
171*4882a593Smuzhiyun	};
172*4882a593Smuzhiyun
173*4882a593Smuzhiyun	vcc_otg: usb-otg-regulator {
174*4882a593Smuzhiyun		compatible = "regulator-fixed";
175*4882a593Smuzhiyun		enable-active-high;
176*4882a593Smuzhiyun		gpio = <&gpio0 RK_PA5 GPIO_ACTIVE_HIGH>;
177*4882a593Smuzhiyun		pinctrl-names = "default";
178*4882a593Smuzhiyun		pinctrl-0 = <&otg_drv>;
179*4882a593Smuzhiyun		regulator-name = "vcc_otg";
180*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
181*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
182*4882a593Smuzhiyun		regulator-always-on;
183*4882a593Smuzhiyun		vin-supply = <&vcc_stdby>;
184*4882a593Smuzhiyun	};
185*4882a593Smuzhiyun
186*4882a593Smuzhiyun	hdmi_sound: hdmi-sound {
187*4882a593Smuzhiyun		compatible = "simple-audio-card";
188*4882a593Smuzhiyun		simple-audio-card,format = "i2s";
189*4882a593Smuzhiyun		simple-audio-card,mclk-fs = <256>;
190*4882a593Smuzhiyun		simple-audio-card,name = "rockchip,hdmi";
191*4882a593Smuzhiyun		simple-audio-card,cpu {
192*4882a593Smuzhiyun			sound-dai = <&i2s0>;
193*4882a593Smuzhiyun		};
194*4882a593Smuzhiyun		simple-audio-card,codec {
195*4882a593Smuzhiyun			sound-dai = <&hdmi>;
196*4882a593Smuzhiyun		};
197*4882a593Smuzhiyun	};
198*4882a593Smuzhiyun};
199*4882a593Smuzhiyun
200*4882a593Smuzhiyun&cpu0 {
201*4882a593Smuzhiyun	cpu-supply = <&vdd_arm>;
202*4882a593Smuzhiyun};
203*4882a593Smuzhiyun
204*4882a593Smuzhiyun&cpu1 {
205*4882a593Smuzhiyun	cpu-supply = <&vdd_arm>;
206*4882a593Smuzhiyun};
207*4882a593Smuzhiyun
208*4882a593Smuzhiyun&cpu0_opp_table {
209*4882a593Smuzhiyun	opp-816000000 {
210*4882a593Smuzhiyun		status = "okay";
211*4882a593Smuzhiyun	};
212*4882a593Smuzhiyun};
213*4882a593Smuzhiyun
214*4882a593Smuzhiyun&gpu_opp_table {
215*4882a593Smuzhiyun	opp-300000000 {
216*4882a593Smuzhiyun		status = "okay";
217*4882a593Smuzhiyun	};
218*4882a593Smuzhiyun};
219*4882a593Smuzhiyun
220*4882a593Smuzhiyun&emac {
221*4882a593Smuzhiyun	pinctrl-names = "default";
222*4882a593Smuzhiyun	pinctrl-0 = <&emac_xfer>, <&emac_mdio>, <&rmii_rst>;
223*4882a593Smuzhiyun	phy = <&phy0>;
224*4882a593Smuzhiyun	phy-supply = <&vcc_rmii>;
225*4882a593Smuzhiyun	phy-reset-gpios = <&gpio1 30 GPIO_ACTIVE_LOW>; /* PHY_RST */
226*4882a593Smuzhiyun	phy-reset-duration = <10>; /* millisecond */
227*4882a593Smuzhiyun	status = "okay";
228*4882a593Smuzhiyun
229*4882a593Smuzhiyun	phy0: ethernet-phy@0 {
230*4882a593Smuzhiyun		reg = <0>;
231*4882a593Smuzhiyun		reset-gpios = <&gpio1 RK_PD6 GPIO_ACTIVE_LOW>;
232*4882a593Smuzhiyun	};
233*4882a593Smuzhiyun};
234*4882a593Smuzhiyun
235*4882a593Smuzhiyun&emmc {
236*4882a593Smuzhiyun	bus-width = <8>;
237*4882a593Smuzhiyun	cap-mmc-highspeed;
238*4882a593Smuzhiyun	no-sdio;
239*4882a593Smuzhiyun	no-sd;
240*4882a593Smuzhiyun	non-removable;
241*4882a593Smuzhiyun	pinctrl-names = "default";
242*4882a593Smuzhiyun	pinctrl-0 = <&emmc_clk>, <&emmc_cmd>, <&emmc_rst>;
243*4882a593Smuzhiyun	vmmc-supply = <&vcc_emmc>;
244*4882a593Smuzhiyun	vqmmc-supply = <&vcc_emmc>;
245*4882a593Smuzhiyun	status = "okay";
246*4882a593Smuzhiyun};
247*4882a593Smuzhiyun
248*4882a593Smuzhiyun&gpu {
249*4882a593Smuzhiyun	status = "okay";
250*4882a593Smuzhiyun};
251*4882a593Smuzhiyun
252*4882a593Smuzhiyun&hdmi {
253*4882a593Smuzhiyun	#sound-dai-cells = <0>;
254*4882a593Smuzhiyun	status = "okay";
255*4882a593Smuzhiyun};
256*4882a593Smuzhiyun
257*4882a593Smuzhiyun&i2c0 {
258*4882a593Smuzhiyun	clock-frequency = <400000>;
259*4882a593Smuzhiyun	status = "okay";
260*4882a593Smuzhiyun
261*4882a593Smuzhiyun	ak8963: ak8963@d {
262*4882a593Smuzhiyun		compatible = "asahi-kasei,ak8975";
263*4882a593Smuzhiyun		reg = <0x0d>;
264*4882a593Smuzhiyun		interrupt-parent = <&gpio4>;
265*4882a593Smuzhiyun		interrupts = <RK_PC1 IRQ_TYPE_EDGE_RISING>;
266*4882a593Smuzhiyun		pinctrl-names = "default";
267*4882a593Smuzhiyun		pinctrl-0 = <&comp_int>;
268*4882a593Smuzhiyun	};
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun	mma8452: mma8452@1d {
271*4882a593Smuzhiyun		compatible = "fsl,mma8452";
272*4882a593Smuzhiyun		reg = <0x1d>;
273*4882a593Smuzhiyun		interrupt-parent = <&gpio4>;
274*4882a593Smuzhiyun		interrupts = <RK_PC0 IRQ_TYPE_EDGE_RISING>;
275*4882a593Smuzhiyun		pinctrl-names = "default";
276*4882a593Smuzhiyun		pinctrl-0 = <&gsensor_int>;
277*4882a593Smuzhiyun	};
278*4882a593Smuzhiyun};
279*4882a593Smuzhiyun
280*4882a593Smuzhiyun&i2c1 {
281*4882a593Smuzhiyun	clock-frequency = <400000>;
282*4882a593Smuzhiyun	status = "okay";
283*4882a593Smuzhiyun
284*4882a593Smuzhiyun	tps: tps@2d {
285*4882a593Smuzhiyun		reg = <0x2d>;
286*4882a593Smuzhiyun		interrupt-parent = <&gpio6>;
287*4882a593Smuzhiyun		interrupts = <RK_PA4 IRQ_TYPE_EDGE_RISING>;
288*4882a593Smuzhiyun		pinctrl-names = "default";
289*4882a593Smuzhiyun		pinctrl-0 = <&pmic_int>, <&pwr_hold>;
290*4882a593Smuzhiyun
291*4882a593Smuzhiyun		vcc1-supply = <&vsys>;
292*4882a593Smuzhiyun		vcc2-supply = <&vsys>;
293*4882a593Smuzhiyun		vcc3-supply = <&vsys>;
294*4882a593Smuzhiyun		vcc4-supply = <&vsys>;
295*4882a593Smuzhiyun		vcc5-supply = <&vcc_io>;
296*4882a593Smuzhiyun		vcc6-supply = <&vcc_io>;
297*4882a593Smuzhiyun		vcc7-supply = <&vsys>;
298*4882a593Smuzhiyun		vccio-supply = <&vsys>;
299*4882a593Smuzhiyun
300*4882a593Smuzhiyun		regulators {
301*4882a593Smuzhiyun			vcc_rtc: regulator@0 {
302*4882a593Smuzhiyun				regulator-name = "vcc_rtc";
303*4882a593Smuzhiyun				regulator-always-on;
304*4882a593Smuzhiyun			};
305*4882a593Smuzhiyun
306*4882a593Smuzhiyun			vcc_io: regulator@1 {
307*4882a593Smuzhiyun				regulator-name = "vcc_io";
308*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
309*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
310*4882a593Smuzhiyun				regulator-always-on;
311*4882a593Smuzhiyun			};
312*4882a593Smuzhiyun
313*4882a593Smuzhiyun			vdd_arm: regulator@2 {
314*4882a593Smuzhiyun				regulator-name = "vdd_arm";
315*4882a593Smuzhiyun				regulator-min-microvolt = <600000>;
316*4882a593Smuzhiyun				regulator-max-microvolt = <1500000>;
317*4882a593Smuzhiyun				regulator-always-on;
318*4882a593Smuzhiyun				regulator-boot-on;
319*4882a593Smuzhiyun			};
320*4882a593Smuzhiyun
321*4882a593Smuzhiyun			vcc_ddr: regulator@3 {
322*4882a593Smuzhiyun				regulator-name = "vcc_ddr";
323*4882a593Smuzhiyun				regulator-min-microvolt = <600000>;
324*4882a593Smuzhiyun				regulator-max-microvolt = <1500000>;
325*4882a593Smuzhiyun				regulator-always-on;
326*4882a593Smuzhiyun				regulator-boot-on;
327*4882a593Smuzhiyun			};
328*4882a593Smuzhiyun
329*4882a593Smuzhiyun			vcc18: regulator@5 {
330*4882a593Smuzhiyun				regulator-name = "vcc18";
331*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
332*4882a593Smuzhiyun				regulator-max-microvolt = <1800000>;
333*4882a593Smuzhiyun				regulator-always-on;
334*4882a593Smuzhiyun			};
335*4882a593Smuzhiyun
336*4882a593Smuzhiyun			vdd_11: regulator@6 {
337*4882a593Smuzhiyun				regulator-name = "vdd_11";
338*4882a593Smuzhiyun				regulator-min-microvolt = <1100000>;
339*4882a593Smuzhiyun				regulator-max-microvolt = <1100000>;
340*4882a593Smuzhiyun				regulator-always-on;
341*4882a593Smuzhiyun			};
342*4882a593Smuzhiyun
343*4882a593Smuzhiyun			vcc_25: regulator@7 {
344*4882a593Smuzhiyun				regulator-name = "vcc_25";
345*4882a593Smuzhiyun				regulator-min-microvolt = <2500000>;
346*4882a593Smuzhiyun				regulator-max-microvolt = <2500000>;
347*4882a593Smuzhiyun				regulator-always-on;
348*4882a593Smuzhiyun			};
349*4882a593Smuzhiyun
350*4882a593Smuzhiyun			vccio_wl: regulator@8 {
351*4882a593Smuzhiyun				regulator-name = "vccio_wl";
352*4882a593Smuzhiyun				regulator-min-microvolt = <2800000>;
353*4882a593Smuzhiyun				regulator-max-microvolt = <2800000>;
354*4882a593Smuzhiyun			};
355*4882a593Smuzhiyun
356*4882a593Smuzhiyun			vcc25_hdmi: regulator@9 {
357*4882a593Smuzhiyun				regulator-name = "vcc25_hdmi";
358*4882a593Smuzhiyun				regulator-min-microvolt = <2500000>;
359*4882a593Smuzhiyun				regulator-max-microvolt = <2500000>;
360*4882a593Smuzhiyun				regulator-always-on;
361*4882a593Smuzhiyun				regulator-boot-on;
362*4882a593Smuzhiyun			};
363*4882a593Smuzhiyun
364*4882a593Smuzhiyun			vcca_33: regulator@10 {
365*4882a593Smuzhiyun				regulator-name = "vcca_33";
366*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
367*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
368*4882a593Smuzhiyun			};
369*4882a593Smuzhiyun
370*4882a593Smuzhiyun			vcc_rmii: regulator@11 {
371*4882a593Smuzhiyun				regulator-name = "vcc_rmii";
372*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
373*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
374*4882a593Smuzhiyun			};
375*4882a593Smuzhiyun
376*4882a593Smuzhiyun			vcc28_cif: regulator@12 {
377*4882a593Smuzhiyun				regulator-name = "vcc28_cif";
378*4882a593Smuzhiyun				regulator-min-microvolt = <2800000>;
379*4882a593Smuzhiyun				regulator-max-microvolt = <2800000>;
380*4882a593Smuzhiyun			};
381*4882a593Smuzhiyun		};
382*4882a593Smuzhiyun	};
383*4882a593Smuzhiyun};
384*4882a593Smuzhiyun
385*4882a593Smuzhiyun#include "tps65910.dtsi"
386*4882a593Smuzhiyun
387*4882a593Smuzhiyun&i2c2 {
388*4882a593Smuzhiyun	status = "okay";
389*4882a593Smuzhiyun};
390*4882a593Smuzhiyun
391*4882a593Smuzhiyun&i2c3 {
392*4882a593Smuzhiyun	status = "okay";
393*4882a593Smuzhiyun};
394*4882a593Smuzhiyun
395*4882a593Smuzhiyun&i2c4 {
396*4882a593Smuzhiyun	status = "okay";
397*4882a593Smuzhiyun};
398*4882a593Smuzhiyun
399*4882a593Smuzhiyun&i2s0 {
400*4882a593Smuzhiyun	#sound-dai-cells = <0>;
401*4882a593Smuzhiyun	status = "okay";
402*4882a593Smuzhiyun};
403*4882a593Smuzhiyun
404*4882a593Smuzhiyun&mmc0 {
405*4882a593Smuzhiyun	bus-width = <4>;
406*4882a593Smuzhiyun	disable-wp;
407*4882a593Smuzhiyun	no-mmc;
408*4882a593Smuzhiyun	no-sdio;
409*4882a593Smuzhiyun	pinctrl-names = "default";
410*4882a593Smuzhiyun	pinctrl-0 = <&sd0_clk>, <&sd0_cmd>, <&sd0_cd>, <&sd0_bus4>;
411*4882a593Smuzhiyun	vmmc-supply = <&vcc_sd>;
412*4882a593Smuzhiyun	cap-mmc-highspeed;
413*4882a593Smuzhiyun	cap-sd-highspeed;
414*4882a593Smuzhiyun	status = "okay";
415*4882a593Smuzhiyun};
416*4882a593Smuzhiyun
417*4882a593Smuzhiyun&mmc1 {
418*4882a593Smuzhiyun	max-frequency = <50000000>;
419*4882a593Smuzhiyun	cap-sd-highspeed;
420*4882a593Smuzhiyun	keep-power-in-suspend;
421*4882a593Smuzhiyun	mmc-pwrseq = <&sdio_pwrseq>;
422*4882a593Smuzhiyun	sd-uhs-sdr104;
423*4882a593Smuzhiyun
424*4882a593Smuzhiyun	bus-width = <4>;
425*4882a593Smuzhiyun	non-removable;
426*4882a593Smuzhiyun	no-mmc;
427*4882a593Smuzhiyun	no-sd;
428*4882a593Smuzhiyun	pinctrl-names = "default";
429*4882a593Smuzhiyun	pinctrl-0 = <&sd1_clk>, <&sd1_cmd>, <&sd1_bus4>;
430*4882a593Smuzhiyun	vmmc-supply = <&vccio_wl>;
431*4882a593Smuzhiyun	status = "okay";
432*4882a593Smuzhiyun};
433*4882a593Smuzhiyun
434*4882a593Smuzhiyun&pinctrl {
435*4882a593Smuzhiyun	pcfg_output_high: pcfg-output-high {
436*4882a593Smuzhiyun		output-high;
437*4882a593Smuzhiyun	};
438*4882a593Smuzhiyun
439*4882a593Smuzhiyun	ak8963 {
440*4882a593Smuzhiyun		comp_int: comp-int {
441*4882a593Smuzhiyun			rockchip,pins = <4 RK_PC1 RK_FUNC_GPIO &pcfg_pull_default>;
442*4882a593Smuzhiyun		};
443*4882a593Smuzhiyun	};
444*4882a593Smuzhiyun
445*4882a593Smuzhiyun	emac {
446*4882a593Smuzhiyun		rmii_rst: rmii-rst {
447*4882a593Smuzhiyun			rockchip,pins = <1 RK_PD6 RK_FUNC_GPIO &pcfg_output_high>;
448*4882a593Smuzhiyun		};
449*4882a593Smuzhiyun	};
450*4882a593Smuzhiyun
451*4882a593Smuzhiyun	ir {
452*4882a593Smuzhiyun		ir_int: ir-int {
453*4882a593Smuzhiyun			rockchip,pins = <6 RK_PA1 RK_FUNC_GPIO &pcfg_pull_default>;
454*4882a593Smuzhiyun		};
455*4882a593Smuzhiyun	};
456*4882a593Smuzhiyun
457*4882a593Smuzhiyun	keys {
458*4882a593Smuzhiyun		pwr_key: pwr-key {
459*4882a593Smuzhiyun			rockchip,pins = <6 RK_PA2 RK_FUNC_GPIO &pcfg_pull_default>;
460*4882a593Smuzhiyun		};
461*4882a593Smuzhiyun	};
462*4882a593Smuzhiyun
463*4882a593Smuzhiyun	mma8452 {
464*4882a593Smuzhiyun		gsensor_int: gsensor-int {
465*4882a593Smuzhiyun			rockchip,pins = <4 RK_PC0 RK_FUNC_GPIO &pcfg_pull_default>;
466*4882a593Smuzhiyun		};
467*4882a593Smuzhiyun	};
468*4882a593Smuzhiyun
469*4882a593Smuzhiyun	mmc {
470*4882a593Smuzhiyun		sdmmc_pwr: sdmmc-pwr {
471*4882a593Smuzhiyun			rockchip,pins = <3 RK_PA7 RK_FUNC_GPIO &pcfg_pull_default>;
472*4882a593Smuzhiyun		};
473*4882a593Smuzhiyun	};
474*4882a593Smuzhiyun
475*4882a593Smuzhiyun	usb_host {
476*4882a593Smuzhiyun		host_drv: host-drv {
477*4882a593Smuzhiyun			rockchip,pins = <0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_default>;
478*4882a593Smuzhiyun		};
479*4882a593Smuzhiyun
480*4882a593Smuzhiyun		hub_rst: hub-rst {
481*4882a593Smuzhiyun			rockchip,pins = <1 RK_PD7 RK_FUNC_GPIO &pcfg_output_high>;
482*4882a593Smuzhiyun		};
483*4882a593Smuzhiyun
484*4882a593Smuzhiyun		sata_pwr: sata-pwr {
485*4882a593Smuzhiyun			rockchip,pins = <4 RK_PC6 RK_FUNC_GPIO &pcfg_pull_default>;
486*4882a593Smuzhiyun		};
487*4882a593Smuzhiyun
488*4882a593Smuzhiyun		sata_reset: sata-reset {
489*4882a593Smuzhiyun			rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_output_high>;
490*4882a593Smuzhiyun		};
491*4882a593Smuzhiyun	};
492*4882a593Smuzhiyun
493*4882a593Smuzhiyun	usb_otg {
494*4882a593Smuzhiyun		otg_drv: otg-drv {
495*4882a593Smuzhiyun			rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_default>;
496*4882a593Smuzhiyun		};
497*4882a593Smuzhiyun	};
498*4882a593Smuzhiyun
499*4882a593Smuzhiyun	tps {
500*4882a593Smuzhiyun		pmic_int: pmic-int {
501*4882a593Smuzhiyun			rockchip,pins = <6 RK_PA4 RK_FUNC_GPIO &pcfg_pull_default>;
502*4882a593Smuzhiyun		};
503*4882a593Smuzhiyun
504*4882a593Smuzhiyun		pwr_hold: pwr-hold {
505*4882a593Smuzhiyun			rockchip,pins = <6 RK_PB0 RK_FUNC_GPIO &pcfg_output_high>;
506*4882a593Smuzhiyun		};
507*4882a593Smuzhiyun	};
508*4882a593Smuzhiyun
509*4882a593Smuzhiyun	wireless-bluetooth {
510*4882a593Smuzhiyun		uart0_gpios: uart0-gpios {
511*4882a593Smuzhiyun			rockchip,pins = <1 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
512*4882a593Smuzhiyun		};
513*4882a593Smuzhiyun
514*4882a593Smuzhiyun		wifi_reg_on: wifi-reg-on {
515*4882a593Smuzhiyun			rockchip,pins = <3 RK_PD0 RK_FUNC_GPIO &pcfg_pull_none>;
516*4882a593Smuzhiyun		};
517*4882a593Smuzhiyun
518*4882a593Smuzhiyun		wifi_host_wake: wifi-host-wake {
519*4882a593Smuzhiyun			rockchip,pins = <1 RK_PD2 RK_FUNC_GPIO &pcfg_pull_none>;
520*4882a593Smuzhiyun		};
521*4882a593Smuzhiyun	};
522*4882a593Smuzhiyun};
523*4882a593Smuzhiyun
524*4882a593Smuzhiyun&pwm1 {
525*4882a593Smuzhiyun	status = "okay";
526*4882a593Smuzhiyun};
527*4882a593Smuzhiyun
528*4882a593Smuzhiyun&pwm2 {
529*4882a593Smuzhiyun	status = "okay";
530*4882a593Smuzhiyun};
531*4882a593Smuzhiyun
532*4882a593Smuzhiyun&pwm3 {
533*4882a593Smuzhiyun	status = "okay";
534*4882a593Smuzhiyun};
535*4882a593Smuzhiyun
536*4882a593Smuzhiyun&saradc {
537*4882a593Smuzhiyun	vref-supply = <&vcc_25>;
538*4882a593Smuzhiyun	status = "okay";
539*4882a593Smuzhiyun};
540*4882a593Smuzhiyun
541*4882a593Smuzhiyun&spi0 {
542*4882a593Smuzhiyun	status = "okay";
543*4882a593Smuzhiyun};
544*4882a593Smuzhiyun
545*4882a593Smuzhiyun&uart0 {
546*4882a593Smuzhiyun	pinctrl-names = "default";
547*4882a593Smuzhiyun	pinctrl-0 = <&uart0_xfer>, <&uart0_cts>;
548*4882a593Smuzhiyun	status = "okay";
549*4882a593Smuzhiyun};
550*4882a593Smuzhiyun
551*4882a593Smuzhiyun&uart2 {
552*4882a593Smuzhiyun	status = "okay";
553*4882a593Smuzhiyun};
554*4882a593Smuzhiyun
555*4882a593Smuzhiyun&uart3 {
556*4882a593Smuzhiyun	pinctrl-names = "default";
557*4882a593Smuzhiyun	pinctrl-0 = <&uart3_xfer>, <&uart3_cts>, <&uart3_rts>;
558*4882a593Smuzhiyun	status = "okay";
559*4882a593Smuzhiyun};
560*4882a593Smuzhiyun
561*4882a593Smuzhiyun&usb_host {
562*4882a593Smuzhiyun	pinctrl-names = "default";
563*4882a593Smuzhiyun	pinctrl-0 = <&hub_rst>, <&sata_reset>;
564*4882a593Smuzhiyun	status = "okay";
565*4882a593Smuzhiyun};
566*4882a593Smuzhiyun
567*4882a593Smuzhiyun&usbphy {
568*4882a593Smuzhiyun	status = "okay";
569*4882a593Smuzhiyun};
570*4882a593Smuzhiyun
571*4882a593Smuzhiyun&usb_otg {
572*4882a593Smuzhiyun	status = "okay";
573*4882a593Smuzhiyun};
574*4882a593Smuzhiyun
575*4882a593Smuzhiyun&vop0 {
576*4882a593Smuzhiyun	status = "okay";
577*4882a593Smuzhiyun};
578*4882a593Smuzhiyun
579*4882a593Smuzhiyun&wdt {
580*4882a593Smuzhiyun	status = "okay";
581*4882a593Smuzhiyun};
582