xref: /linux/scripts/dtc/include-prefixes/arm64/rockchip/rk3576-nanopi-m5.dts (revision 115e74a29b530d121891238e9551c4bcdf7b04b5)
1*96cbdfddSJohn Clark// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2*96cbdfddSJohn Clark/*
3*96cbdfddSJohn Clark * Copyright (c) 2025 FriendlyElec Computer Tech. Co., Ltd.
4*96cbdfddSJohn Clark * Copyright (c) 2025 John Clark <inindev@gmail.com>
5*96cbdfddSJohn Clark */
6*96cbdfddSJohn Clark
7*96cbdfddSJohn Clark/dts-v1/;
8*96cbdfddSJohn Clark
9*96cbdfddSJohn Clark#include <dt-bindings/gpio/gpio.h>
10*96cbdfddSJohn Clark#include <dt-bindings/input/input.h>
11*96cbdfddSJohn Clark#include <dt-bindings/leds/common.h>
12*96cbdfddSJohn Clark#include <dt-bindings/pinctrl/rockchip.h>
13*96cbdfddSJohn Clark#include <dt-bindings/pwm/pwm.h>
14*96cbdfddSJohn Clark#include <dt-bindings/soc/rockchip,vop2.h>
15*96cbdfddSJohn Clark#include <dt-bindings/usb/pd.h>
16*96cbdfddSJohn Clark#include "rk3576.dtsi"
17*96cbdfddSJohn Clark
18*96cbdfddSJohn Clark/ {
19*96cbdfddSJohn Clark	model = "FriendlyElec NanoPi M5";
20*96cbdfddSJohn Clark	compatible = "friendlyarm,nanopi-m5", "rockchip,rk3576";
21*96cbdfddSJohn Clark
22*96cbdfddSJohn Clark	aliases {
23*96cbdfddSJohn Clark		ethernet0 = &gmac0;
24*96cbdfddSJohn Clark		ethernet1 = &gmac1;
25*96cbdfddSJohn Clark		mmc0 = &sdmmc;
26*96cbdfddSJohn Clark	};
27*96cbdfddSJohn Clark
28*96cbdfddSJohn Clark	chosen {
29*96cbdfddSJohn Clark		stdout-path = "serial0:1500000n8";
30*96cbdfddSJohn Clark	};
31*96cbdfddSJohn Clark
32*96cbdfddSJohn Clark	hdmi-con {
33*96cbdfddSJohn Clark		compatible = "hdmi-connector";
34*96cbdfddSJohn Clark		hdmi-pwr-supply = <&vcc5v_hdmi_tx>;
35*96cbdfddSJohn Clark		type = "a";
36*96cbdfddSJohn Clark
37*96cbdfddSJohn Clark		port {
38*96cbdfddSJohn Clark			hdmi_con_in: endpoint {
39*96cbdfddSJohn Clark				remote-endpoint = <&hdmi_out_con>;
40*96cbdfddSJohn Clark			};
41*96cbdfddSJohn Clark		};
42*96cbdfddSJohn Clark	};
43*96cbdfddSJohn Clark
44*96cbdfddSJohn Clark	keys {
45*96cbdfddSJohn Clark		compatible = "gpio-keys";
46*96cbdfddSJohn Clark
47*96cbdfddSJohn Clark		usr_button: key-1 {
48*96cbdfddSJohn Clark			debounce-interval = <50>;
49*96cbdfddSJohn Clark			gpios = <&gpio1 RK_PA0 GPIO_ACTIVE_LOW>;
50*96cbdfddSJohn Clark			label = "user";
51*96cbdfddSJohn Clark			linux,code = <BTN_1>;
52*96cbdfddSJohn Clark			pinctrl-names = "default";
53*96cbdfddSJohn Clark			pinctrl-0 = <&usr_button_l>;
54*96cbdfddSJohn Clark			wakeup-source;
55*96cbdfddSJohn Clark		};
56*96cbdfddSJohn Clark	};
57*96cbdfddSJohn Clark
58*96cbdfddSJohn Clark	leds {
59*96cbdfddSJohn Clark		compatible = "gpio-leds";
60*96cbdfddSJohn Clark
61*96cbdfddSJohn Clark		led_sys: led-0 {
62*96cbdfddSJohn Clark			color = <LED_COLOR_ID_RED>;
63*96cbdfddSJohn Clark			function = LED_FUNCTION_HEARTBEAT;
64*96cbdfddSJohn Clark			gpios = <&gpio2 RK_PB3 GPIO_ACTIVE_HIGH>;
65*96cbdfddSJohn Clark			label = "sys";
66*96cbdfddSJohn Clark			linux,default-trigger = "heartbeat";
67*96cbdfddSJohn Clark			pinctrl-names = "default";
68*96cbdfddSJohn Clark			pinctrl-0 = <&led_sys_h>;
69*96cbdfddSJohn Clark		};
70*96cbdfddSJohn Clark
71*96cbdfddSJohn Clark		led1: led-1 {
72*96cbdfddSJohn Clark			color = <LED_COLOR_ID_GREEN>;
73*96cbdfddSJohn Clark			function = LED_FUNCTION_LAN;
74*96cbdfddSJohn Clark			gpios = <&gpio4 RK_PC5 GPIO_ACTIVE_HIGH>;
75*96cbdfddSJohn Clark			label = "led1";
76*96cbdfddSJohn Clark			linux,default-trigger = "netdev";
77*96cbdfddSJohn Clark			pinctrl-names = "default";
78*96cbdfddSJohn Clark			pinctrl-0 = <&led1_h>;
79*96cbdfddSJohn Clark		};
80*96cbdfddSJohn Clark
81*96cbdfddSJohn Clark		led2: led-2 {
82*96cbdfddSJohn Clark			color = <LED_COLOR_ID_GREEN>;
83*96cbdfddSJohn Clark			function = LED_FUNCTION_LAN;
84*96cbdfddSJohn Clark			gpios = <&gpio2 RK_PB0 GPIO_ACTIVE_HIGH>;
85*96cbdfddSJohn Clark			label = "led2";
86*96cbdfddSJohn Clark			linux,default-trigger = "netdev";
87*96cbdfddSJohn Clark			pinctrl-names = "default";
88*96cbdfddSJohn Clark			pinctrl-0 = <&led2_h>;
89*96cbdfddSJohn Clark		};
90*96cbdfddSJohn Clark	};
91*96cbdfddSJohn Clark
92*96cbdfddSJohn Clark	usb3_port2_5v: regulator-usb3-port2-5v {
93*96cbdfddSJohn Clark		compatible = "regulator-fixed";
94*96cbdfddSJohn Clark		enable-active-high;
95*96cbdfddSJohn Clark		gpios = <&gpio0 RK_PC7 GPIO_ACTIVE_HIGH>;
96*96cbdfddSJohn Clark		pinctrl-names = "default";
97*96cbdfddSJohn Clark		pinctrl-0 = <&usb3_host_pwren_h>;
98*96cbdfddSJohn Clark		regulator-min-microvolt = <5000000>;
99*96cbdfddSJohn Clark		regulator-max-microvolt = <5000000>;
100*96cbdfddSJohn Clark		regulator-name = "usb3_port2_5v";
101*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
102*96cbdfddSJohn Clark	};
103*96cbdfddSJohn Clark
104*96cbdfddSJohn Clark	vcc12v_dcin: regulator-vcc12v-dcin {
105*96cbdfddSJohn Clark		compatible = "regulator-fixed";
106*96cbdfddSJohn Clark		regulator-always-on;
107*96cbdfddSJohn Clark		regulator-boot-on;
108*96cbdfddSJohn Clark		regulator-min-microvolt = <12000000>;
109*96cbdfddSJohn Clark		regulator-max-microvolt = <12000000>;
110*96cbdfddSJohn Clark		regulator-name = "vcc12v_dcin";
111*96cbdfddSJohn Clark	};
112*96cbdfddSJohn Clark
113*96cbdfddSJohn Clark	vcc3v3_m2_keym: regulator-vcc3v3-m2-keym {
114*96cbdfddSJohn Clark		compatible = "regulator-fixed";
115*96cbdfddSJohn Clark		enable-active-high;
116*96cbdfddSJohn Clark		gpios = <&gpio0 RK_PD3 GPIO_ACTIVE_HIGH>;
117*96cbdfddSJohn Clark		pinctrl-names = "default";
118*96cbdfddSJohn Clark		pinctrl-0 = <&pcie0_pwren_h>;
119*96cbdfddSJohn Clark		regulator-min-microvolt = <3300000>;
120*96cbdfddSJohn Clark		regulator-max-microvolt = <3300000>;
121*96cbdfddSJohn Clark		regulator-name = "vcc3v3_m2_keym";
122*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
123*96cbdfddSJohn Clark	};
124*96cbdfddSJohn Clark
125*96cbdfddSJohn Clark	vcc3v3_sd_s0: regulator-vcc3v3-sd-s0 {
126*96cbdfddSJohn Clark		compatible = "regulator-fixed";
127*96cbdfddSJohn Clark		enable-active-high;
128*96cbdfddSJohn Clark		gpios = <&gpio0 RK_PB6 GPIO_ACTIVE_HIGH>;
129*96cbdfddSJohn Clark		pinctrl-names = "default";
130*96cbdfddSJohn Clark		pinctrl-0 = <&sdmmc0_pwren_h>;
131*96cbdfddSJohn Clark		regulator-boot-on;
132*96cbdfddSJohn Clark		regulator-min-microvolt = <3300000>;
133*96cbdfddSJohn Clark		regulator-max-microvolt = <3300000>;
134*96cbdfddSJohn Clark		regulator-name = "vcc3v3_sd_s0";
135*96cbdfddSJohn Clark		vin-supply = <&vcc_3v3_s3>;
136*96cbdfddSJohn Clark	};
137*96cbdfddSJohn Clark
138*96cbdfddSJohn Clark	vcc5v0_sys_s5: regulator-vcc5v0-sys-s5 {
139*96cbdfddSJohn Clark		compatible = "regulator-fixed";
140*96cbdfddSJohn Clark		regulator-always-on;
141*96cbdfddSJohn Clark		regulator-boot-on;
142*96cbdfddSJohn Clark		regulator-min-microvolt = <5000000>;
143*96cbdfddSJohn Clark		regulator-max-microvolt = <5000000>;
144*96cbdfddSJohn Clark		regulator-name = "vcc5v0_sys_s5";
145*96cbdfddSJohn Clark		vin-supply = <&vcc12v_dcin>;
146*96cbdfddSJohn Clark	};
147*96cbdfddSJohn Clark
148*96cbdfddSJohn Clark	vcc5v0_usb_otg0: regulator-vcc5v0-usb-otg0 {
149*96cbdfddSJohn Clark		compatible = "regulator-fixed";
150*96cbdfddSJohn Clark		enable-active-high;
151*96cbdfddSJohn Clark		gpios = <&gpio0 RK_PD1 GPIO_ACTIVE_HIGH>;
152*96cbdfddSJohn Clark		pinctrl-names = "default";
153*96cbdfddSJohn Clark		pinctrl-0 = <&usb_otg0_pwren_h>;
154*96cbdfddSJohn Clark		regulator-min-microvolt = <5000000>;
155*96cbdfddSJohn Clark		regulator-max-microvolt = <5000000>;
156*96cbdfddSJohn Clark		regulator-name = "vcc5v0_usb_otg0";
157*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
158*96cbdfddSJohn Clark	};
159*96cbdfddSJohn Clark
160*96cbdfddSJohn Clark	vcc5v_hdmi_tx: regulator-vcc5v-hdmi-tx {
161*96cbdfddSJohn Clark		compatible = "regulator-fixed";
162*96cbdfddSJohn Clark		regulator-always-on;
163*96cbdfddSJohn Clark		regulator-min-microvolt = <5000000>;
164*96cbdfddSJohn Clark		regulator-max-microvolt = <5000000>;
165*96cbdfddSJohn Clark		regulator-name = "vcc5v_hdmi_tx";
166*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
167*96cbdfddSJohn Clark	};
168*96cbdfddSJohn Clark
169*96cbdfddSJohn Clark	vcc_1v1_nldo_s3: regulator-vcc-1v1-nldo-s3 {
170*96cbdfddSJohn Clark		compatible = "regulator-fixed";
171*96cbdfddSJohn Clark		regulator-always-on;
172*96cbdfddSJohn Clark		regulator-boot-on;
173*96cbdfddSJohn Clark		regulator-min-microvolt = <1100000>;
174*96cbdfddSJohn Clark		regulator-max-microvolt = <1100000>;
175*96cbdfddSJohn Clark		regulator-name = "vcc_1v1_nldo_s3";
176*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
177*96cbdfddSJohn Clark	};
178*96cbdfddSJohn Clark
179*96cbdfddSJohn Clark	vcc_2v0_pldo_s3: regulator-vcc-2v0-pldo-s3 {
180*96cbdfddSJohn Clark		compatible = "regulator-fixed";
181*96cbdfddSJohn Clark		regulator-always-on;
182*96cbdfddSJohn Clark		regulator-boot-on;
183*96cbdfddSJohn Clark		regulator-min-microvolt = <2000000>;
184*96cbdfddSJohn Clark		regulator-max-microvolt = <2000000>;
185*96cbdfddSJohn Clark		regulator-name = "vcc_2v0_pldo_s3";
186*96cbdfddSJohn Clark		vin-supply = <&vcc5v0_sys_s5>;
187*96cbdfddSJohn Clark	};
188*96cbdfddSJohn Clark
189*96cbdfddSJohn Clark	vcc_3v3_s0: regulator-vcc-3v3-s0 {
190*96cbdfddSJohn Clark		compatible = "regulator-fixed";
191*96cbdfddSJohn Clark		regulator-always-on;
192*96cbdfddSJohn Clark		regulator-boot-on;
193*96cbdfddSJohn Clark		regulator-min-microvolt = <3300000>;
194*96cbdfddSJohn Clark		regulator-max-microvolt = <3300000>;
195*96cbdfddSJohn Clark		regulator-name = "vcc_3v3_s0";
196*96cbdfddSJohn Clark		vin-supply = <&vcc_3v3_s3>;
197*96cbdfddSJohn Clark	};
198*96cbdfddSJohn Clark
199*96cbdfddSJohn Clark	sound {
200*96cbdfddSJohn Clark		compatible = "simple-audio-card";
201*96cbdfddSJohn Clark		pinctrl-names = "default";
202*96cbdfddSJohn Clark		pinctrl-0 = <&hp_det_l>;
203*96cbdfddSJohn Clark
204*96cbdfddSJohn Clark		simple-audio-card,format = "i2s";
205*96cbdfddSJohn Clark		simple-audio-card,hp-det-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_LOW>;
206*96cbdfddSJohn Clark		simple-audio-card,mclk-fs = <256>;
207*96cbdfddSJohn Clark		simple-audio-card,name = "realtek,rt5616-codec";
208*96cbdfddSJohn Clark
209*96cbdfddSJohn Clark		simple-audio-card,routing =
210*96cbdfddSJohn Clark			"Headphones", "HPOL",
211*96cbdfddSJohn Clark			"Headphones", "HPOR",
212*96cbdfddSJohn Clark			"IN1P", "Microphone Jack";
213*96cbdfddSJohn Clark		simple-audio-card,widgets =
214*96cbdfddSJohn Clark			"Headphone", "Headphone Jack",
215*96cbdfddSJohn Clark			"Microphone", "Microphone Jack";
216*96cbdfddSJohn Clark
217*96cbdfddSJohn Clark		simple-audio-card,codec {
218*96cbdfddSJohn Clark			sound-dai = <&rt5616>;
219*96cbdfddSJohn Clark		};
220*96cbdfddSJohn Clark
221*96cbdfddSJohn Clark		simple-audio-card,cpu {
222*96cbdfddSJohn Clark			sound-dai = <&sai2>;
223*96cbdfddSJohn Clark		};
224*96cbdfddSJohn Clark	};
225*96cbdfddSJohn Clark};
226*96cbdfddSJohn Clark
227*96cbdfddSJohn Clark&combphy0_ps {
228*96cbdfddSJohn Clark	status = "okay";
229*96cbdfddSJohn Clark};
230*96cbdfddSJohn Clark
231*96cbdfddSJohn Clark&combphy1_psu {
232*96cbdfddSJohn Clark	status = "okay";
233*96cbdfddSJohn Clark};
234*96cbdfddSJohn Clark
235*96cbdfddSJohn Clark&cpu_b0 {
236*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_big_s0>;
237*96cbdfddSJohn Clark};
238*96cbdfddSJohn Clark
239*96cbdfddSJohn Clark&cpu_b1 {
240*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_big_s0>;
241*96cbdfddSJohn Clark};
242*96cbdfddSJohn Clark
243*96cbdfddSJohn Clark&cpu_b2 {
244*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_big_s0>;
245*96cbdfddSJohn Clark};
246*96cbdfddSJohn Clark
247*96cbdfddSJohn Clark&cpu_b3 {
248*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_big_s0>;
249*96cbdfddSJohn Clark};
250*96cbdfddSJohn Clark
251*96cbdfddSJohn Clark&cpu_l0 {
252*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_lit_s0>;
253*96cbdfddSJohn Clark};
254*96cbdfddSJohn Clark
255*96cbdfddSJohn Clark&cpu_l1 {
256*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_lit_s0>;
257*96cbdfddSJohn Clark};
258*96cbdfddSJohn Clark
259*96cbdfddSJohn Clark&cpu_l2 {
260*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_lit_s0>;
261*96cbdfddSJohn Clark};
262*96cbdfddSJohn Clark
263*96cbdfddSJohn Clark&cpu_l3 {
264*96cbdfddSJohn Clark	cpu-supply = <&vdd_cpu_lit_s0>;
265*96cbdfddSJohn Clark};
266*96cbdfddSJohn Clark
267*96cbdfddSJohn Clark&fspi1m1_pins {
268*96cbdfddSJohn Clark	/* gpio1_d5, gpio1_c4-c7 (clk, d0-d4) are for spi nor flash */
269*96cbdfddSJohn Clark	/* gpio1_d0-d4 muxed to sai2 audio functions */
270*96cbdfddSJohn Clark	rockchip,pins =
271*96cbdfddSJohn Clark		<1 RK_PD5 3 &pcfg_pull_none>,
272*96cbdfddSJohn Clark		<1 RK_PC4 3 &pcfg_pull_none>,
273*96cbdfddSJohn Clark		<1 RK_PC5 3 &pcfg_pull_none>,
274*96cbdfddSJohn Clark		<1 RK_PC6 3 &pcfg_pull_none>,
275*96cbdfddSJohn Clark		<1 RK_PC7 3 &pcfg_pull_none>;
276*96cbdfddSJohn Clark};
277*96cbdfddSJohn Clark
278*96cbdfddSJohn Clark&gmac0 {
279*96cbdfddSJohn Clark	clock_in_out = "output";
280*96cbdfddSJohn Clark	phy-handle = <&rgmii_phy0>;
281*96cbdfddSJohn Clark	phy-mode = "rgmii-id";
282*96cbdfddSJohn Clark	phy-supply = <&vcc_3v3_s3>;
283*96cbdfddSJohn Clark	pinctrl-names = "default";
284*96cbdfddSJohn Clark	pinctrl-0 = <&eth0m0_miim>,
285*96cbdfddSJohn Clark		    <&eth0m0_tx_bus2>,
286*96cbdfddSJohn Clark		    <&eth0m0_rx_bus2>,
287*96cbdfddSJohn Clark		    <&eth0m0_rgmii_clk>,
288*96cbdfddSJohn Clark		    <&eth0m0_rgmii_bus>;
289*96cbdfddSJohn Clark	status = "okay";
290*96cbdfddSJohn Clark};
291*96cbdfddSJohn Clark
292*96cbdfddSJohn Clark&gmac1 {
293*96cbdfddSJohn Clark	clock_in_out = "output";
294*96cbdfddSJohn Clark	phy-handle = <&rgmii_phy1>;
295*96cbdfddSJohn Clark	phy-mode = "rgmii-id";
296*96cbdfddSJohn Clark	phy-supply = <&vcc_3v3_s3>;
297*96cbdfddSJohn Clark	pinctrl-names = "default";
298*96cbdfddSJohn Clark	pinctrl-0 = <&eth1m0_miim>,
299*96cbdfddSJohn Clark		    <&eth1m0_tx_bus2>,
300*96cbdfddSJohn Clark		    <&eth1m0_rx_bus2>,
301*96cbdfddSJohn Clark		    <&eth1m0_rgmii_clk>,
302*96cbdfddSJohn Clark		    <&eth1m0_rgmii_bus>;
303*96cbdfddSJohn Clark	status = "okay";
304*96cbdfddSJohn Clark};
305*96cbdfddSJohn Clark
306*96cbdfddSJohn Clark&gpu {
307*96cbdfddSJohn Clark	mali-supply = <&vdd_gpu_s0>;
308*96cbdfddSJohn Clark	status = "okay";
309*96cbdfddSJohn Clark};
310*96cbdfddSJohn Clark
311*96cbdfddSJohn Clark&hdmi {
312*96cbdfddSJohn Clark	status = "okay";
313*96cbdfddSJohn Clark};
314*96cbdfddSJohn Clark
315*96cbdfddSJohn Clark&hdmi_in {
316*96cbdfddSJohn Clark	hdmi_in_vp0: endpoint {
317*96cbdfddSJohn Clark		remote-endpoint = <&vp0_out_hdmi>;
318*96cbdfddSJohn Clark	};
319*96cbdfddSJohn Clark};
320*96cbdfddSJohn Clark
321*96cbdfddSJohn Clark&hdmi_out {
322*96cbdfddSJohn Clark	hdmi_out_con: endpoint {
323*96cbdfddSJohn Clark		remote-endpoint = <&hdmi_con_in>;
324*96cbdfddSJohn Clark	};
325*96cbdfddSJohn Clark};
326*96cbdfddSJohn Clark
327*96cbdfddSJohn Clark&hdptxphy {
328*96cbdfddSJohn Clark	status = "okay";
329*96cbdfddSJohn Clark};
330*96cbdfddSJohn Clark
331*96cbdfddSJohn Clark&i2c1 {
332*96cbdfddSJohn Clark	status = "okay";
333*96cbdfddSJohn Clark
334*96cbdfddSJohn Clark	pmic@23 {
335*96cbdfddSJohn Clark		compatible = "rockchip,rk806";
336*96cbdfddSJohn Clark		reg = <0x23>;
337*96cbdfddSJohn Clark		#gpio-cells = <2>;
338*96cbdfddSJohn Clark		gpio-controller;
339*96cbdfddSJohn Clark		interrupt-parent = <&gpio0>;
340*96cbdfddSJohn Clark		interrupts = <6 IRQ_TYPE_LEVEL_LOW>;
341*96cbdfddSJohn Clark		pinctrl-names = "default";
342*96cbdfddSJohn Clark		pinctrl-0 = <&pmic_pins>, <&rk806_dvs1_null>,
343*96cbdfddSJohn Clark			    <&rk806_dvs2_null>, <&rk806_dvs3_null>;
344*96cbdfddSJohn Clark		system-power-controller;
345*96cbdfddSJohn Clark
346*96cbdfddSJohn Clark		vcc1-supply = <&vcc5v0_sys_s5>;
347*96cbdfddSJohn Clark		vcc2-supply = <&vcc5v0_sys_s5>;
348*96cbdfddSJohn Clark		vcc3-supply = <&vcc5v0_sys_s5>;
349*96cbdfddSJohn Clark		vcc4-supply = <&vcc5v0_sys_s5>;
350*96cbdfddSJohn Clark		vcc5-supply = <&vcc5v0_sys_s5>;
351*96cbdfddSJohn Clark		vcc6-supply = <&vcc5v0_sys_s5>;
352*96cbdfddSJohn Clark		vcc7-supply = <&vcc5v0_sys_s5>;
353*96cbdfddSJohn Clark		vcc8-supply = <&vcc5v0_sys_s5>;
354*96cbdfddSJohn Clark		vcc9-supply = <&vcc5v0_sys_s5>;
355*96cbdfddSJohn Clark		vcc10-supply = <&vcc5v0_sys_s5>;
356*96cbdfddSJohn Clark		vcc11-supply = <&vcc_2v0_pldo_s3>;
357*96cbdfddSJohn Clark		vcc12-supply = <&vcc5v0_sys_s5>;
358*96cbdfddSJohn Clark		vcc13-supply = <&vcc_1v1_nldo_s3>;
359*96cbdfddSJohn Clark		vcc14-supply = <&vcc_1v1_nldo_s3>;
360*96cbdfddSJohn Clark		vcca-supply = <&vcc5v0_sys_s5>;
361*96cbdfddSJohn Clark
362*96cbdfddSJohn Clark		rk806_dvs1_null: dvs1-null-pins {
363*96cbdfddSJohn Clark			pins = "gpio_pwrctrl1";
364*96cbdfddSJohn Clark			function = "pin_fun0";
365*96cbdfddSJohn Clark		};
366*96cbdfddSJohn Clark
367*96cbdfddSJohn Clark		rk806_dvs1_slp: dvs1-slp-pins {
368*96cbdfddSJohn Clark			pins = "gpio_pwrctrl1";
369*96cbdfddSJohn Clark			function = "pin_fun1";
370*96cbdfddSJohn Clark		};
371*96cbdfddSJohn Clark
372*96cbdfddSJohn Clark		rk806_dvs1_pwrdn: dvs1-pwrdn-pins {
373*96cbdfddSJohn Clark			pins = "gpio_pwrctrl1";
374*96cbdfddSJohn Clark			function = "pin_fun2";
375*96cbdfddSJohn Clark		};
376*96cbdfddSJohn Clark
377*96cbdfddSJohn Clark		rk806_dvs1_rst: dvs1-rst-pins {
378*96cbdfddSJohn Clark			pins = "gpio_pwrctrl1";
379*96cbdfddSJohn Clark			function = "pin_fun3";
380*96cbdfddSJohn Clark		};
381*96cbdfddSJohn Clark
382*96cbdfddSJohn Clark		rk806_dvs2_null: dvs2-null-pins {
383*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
384*96cbdfddSJohn Clark			function = "pin_fun0";
385*96cbdfddSJohn Clark		};
386*96cbdfddSJohn Clark
387*96cbdfddSJohn Clark		rk806_dvs2_slp: dvs2-slp-pins {
388*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
389*96cbdfddSJohn Clark			function = "pin_fun1";
390*96cbdfddSJohn Clark		};
391*96cbdfddSJohn Clark
392*96cbdfddSJohn Clark		rk806_dvs2_pwrdn: dvs2-pwrdn-pins {
393*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
394*96cbdfddSJohn Clark			function = "pin_fun2";
395*96cbdfddSJohn Clark		};
396*96cbdfddSJohn Clark
397*96cbdfddSJohn Clark		rk806_dvs2_rst: dvs2-rst-pins {
398*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
399*96cbdfddSJohn Clark			function = "pin_fun3";
400*96cbdfddSJohn Clark		};
401*96cbdfddSJohn Clark
402*96cbdfddSJohn Clark		rk806_dvs2_dvs: dvs2-dvs-pins {
403*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
404*96cbdfddSJohn Clark			function = "pin_fun4";
405*96cbdfddSJohn Clark		};
406*96cbdfddSJohn Clark
407*96cbdfddSJohn Clark		rk806_dvs2_gpio: dvs2-gpio-pins {
408*96cbdfddSJohn Clark			pins = "gpio_pwrctrl2";
409*96cbdfddSJohn Clark			function = "pin_fun5";
410*96cbdfddSJohn Clark		};
411*96cbdfddSJohn Clark
412*96cbdfddSJohn Clark		rk806_dvs3_null: dvs3-null-pins {
413*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
414*96cbdfddSJohn Clark			function = "pin_fun0";
415*96cbdfddSJohn Clark		};
416*96cbdfddSJohn Clark
417*96cbdfddSJohn Clark		rk806_dvs3_slp: dvs3-slp-pins {
418*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
419*96cbdfddSJohn Clark			function = "pin_fun1";
420*96cbdfddSJohn Clark		};
421*96cbdfddSJohn Clark
422*96cbdfddSJohn Clark		rk806_dvs3_pwrdn: dvs3-pwrdn-pins {
423*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
424*96cbdfddSJohn Clark			function = "pin_fun2";
425*96cbdfddSJohn Clark		};
426*96cbdfddSJohn Clark
427*96cbdfddSJohn Clark		rk806_dvs3_rst: dvs3-rst-pins {
428*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
429*96cbdfddSJohn Clark			function = "pin_fun3";
430*96cbdfddSJohn Clark		};
431*96cbdfddSJohn Clark
432*96cbdfddSJohn Clark		rk806_dvs3_dvs: dvs3-dvs-pins {
433*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
434*96cbdfddSJohn Clark			function = "pin_fun4";
435*96cbdfddSJohn Clark		};
436*96cbdfddSJohn Clark
437*96cbdfddSJohn Clark		rk806_dvs3_gpio: dvs3-gpio-pins {
438*96cbdfddSJohn Clark			pins = "gpio_pwrctrl3";
439*96cbdfddSJohn Clark			function = "pin_fun5";
440*96cbdfddSJohn Clark		};
441*96cbdfddSJohn Clark
442*96cbdfddSJohn Clark		regulators {
443*96cbdfddSJohn Clark			vdd_cpu_big_s0: dcdc-reg1 {
444*96cbdfddSJohn Clark				regulator-always-on;
445*96cbdfddSJohn Clark				regulator-boot-on;
446*96cbdfddSJohn Clark				regulator-enable-ramp-delay = <400>;
447*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
448*96cbdfddSJohn Clark				regulator-max-microvolt = <950000>;
449*96cbdfddSJohn Clark				regulator-name = "vdd_cpu_big_s0";
450*96cbdfddSJohn Clark				regulator-ramp-delay = <12500>;
451*96cbdfddSJohn Clark
452*96cbdfddSJohn Clark				regulator-state-mem {
453*96cbdfddSJohn Clark					regulator-off-in-suspend;
454*96cbdfddSJohn Clark				};
455*96cbdfddSJohn Clark			};
456*96cbdfddSJohn Clark
457*96cbdfddSJohn Clark			vdd_npu_s0: dcdc-reg2 {
458*96cbdfddSJohn Clark				regulator-boot-on;
459*96cbdfddSJohn Clark				regulator-enable-ramp-delay = <400>;
460*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
461*96cbdfddSJohn Clark				regulator-max-microvolt = <950000>;
462*96cbdfddSJohn Clark				regulator-name = "vdd_npu_s0";
463*96cbdfddSJohn Clark				regulator-ramp-delay = <12500>;
464*96cbdfddSJohn Clark
465*96cbdfddSJohn Clark				regulator-state-mem {
466*96cbdfddSJohn Clark					regulator-off-in-suspend;
467*96cbdfddSJohn Clark				};
468*96cbdfddSJohn Clark			};
469*96cbdfddSJohn Clark
470*96cbdfddSJohn Clark			vdd_cpu_lit_s0: dcdc-reg3 {
471*96cbdfddSJohn Clark				regulator-always-on;
472*96cbdfddSJohn Clark				regulator-boot-on;
473*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
474*96cbdfddSJohn Clark				regulator-max-microvolt = <950000>;
475*96cbdfddSJohn Clark				regulator-name = "vdd_cpu_lit_s0";
476*96cbdfddSJohn Clark				regulator-ramp-delay = <12500>;
477*96cbdfddSJohn Clark
478*96cbdfddSJohn Clark				regulator-state-mem {
479*96cbdfddSJohn Clark					regulator-off-in-suspend;
480*96cbdfddSJohn Clark					regulator-suspend-microvolt = <750000>;
481*96cbdfddSJohn Clark				};
482*96cbdfddSJohn Clark			};
483*96cbdfddSJohn Clark
484*96cbdfddSJohn Clark			vcc_3v3_s3: dcdc-reg4 {
485*96cbdfddSJohn Clark				regulator-always-on;
486*96cbdfddSJohn Clark				regulator-boot-on;
487*96cbdfddSJohn Clark				regulator-min-microvolt = <3300000>;
488*96cbdfddSJohn Clark				regulator-max-microvolt = <3300000>;
489*96cbdfddSJohn Clark				regulator-name = "vcc_3v3_s3";
490*96cbdfddSJohn Clark
491*96cbdfddSJohn Clark				regulator-state-mem {
492*96cbdfddSJohn Clark					regulator-on-in-suspend;
493*96cbdfddSJohn Clark					regulator-suspend-microvolt = <3300000>;
494*96cbdfddSJohn Clark				};
495*96cbdfddSJohn Clark			};
496*96cbdfddSJohn Clark
497*96cbdfddSJohn Clark			vdd_gpu_s0: dcdc-reg5 {
498*96cbdfddSJohn Clark				regulator-boot-on;
499*96cbdfddSJohn Clark				regulator-enable-ramp-delay = <400>;
500*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
501*96cbdfddSJohn Clark				regulator-max-microvolt = <900000>;
502*96cbdfddSJohn Clark				regulator-name = "vdd_gpu_s0";
503*96cbdfddSJohn Clark				regulator-ramp-delay = <12500>;
504*96cbdfddSJohn Clark
505*96cbdfddSJohn Clark				regulator-state-mem {
506*96cbdfddSJohn Clark					regulator-off-in-suspend;
507*96cbdfddSJohn Clark					regulator-suspend-microvolt = <850000>;
508*96cbdfddSJohn Clark				};
509*96cbdfddSJohn Clark			};
510*96cbdfddSJohn Clark
511*96cbdfddSJohn Clark			vddq_ddr_s0: dcdc-reg6 {
512*96cbdfddSJohn Clark				regulator-always-on;
513*96cbdfddSJohn Clark				regulator-boot-on;
514*96cbdfddSJohn Clark				regulator-name = "vddq_ddr_s0";
515*96cbdfddSJohn Clark
516*96cbdfddSJohn Clark				regulator-state-mem {
517*96cbdfddSJohn Clark					regulator-off-in-suspend;
518*96cbdfddSJohn Clark				};
519*96cbdfddSJohn Clark			};
520*96cbdfddSJohn Clark
521*96cbdfddSJohn Clark			vdd_logic_s0: dcdc-reg7 {
522*96cbdfddSJohn Clark				regulator-always-on;
523*96cbdfddSJohn Clark				regulator-boot-on;
524*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
525*96cbdfddSJohn Clark				regulator-max-microvolt = <800000>;
526*96cbdfddSJohn Clark				regulator-name = "vdd_logic_s0";
527*96cbdfddSJohn Clark
528*96cbdfddSJohn Clark				regulator-state-mem {
529*96cbdfddSJohn Clark					regulator-off-in-suspend;
530*96cbdfddSJohn Clark				};
531*96cbdfddSJohn Clark			};
532*96cbdfddSJohn Clark
533*96cbdfddSJohn Clark			vcc_1v8_s3: dcdc-reg8 {
534*96cbdfddSJohn Clark				regulator-always-on;
535*96cbdfddSJohn Clark				regulator-boot-on;
536*96cbdfddSJohn Clark				regulator-min-microvolt = <1800000>;
537*96cbdfddSJohn Clark				regulator-max-microvolt = <1800000>;
538*96cbdfddSJohn Clark				regulator-name = "vcc_1v8_s3";
539*96cbdfddSJohn Clark
540*96cbdfddSJohn Clark				regulator-state-mem {
541*96cbdfddSJohn Clark					regulator-on-in-suspend;
542*96cbdfddSJohn Clark					regulator-suspend-microvolt = <1800000>;
543*96cbdfddSJohn Clark				};
544*96cbdfddSJohn Clark			};
545*96cbdfddSJohn Clark
546*96cbdfddSJohn Clark			vdd2_ddr_s3: dcdc-reg9 {
547*96cbdfddSJohn Clark				regulator-always-on;
548*96cbdfddSJohn Clark				regulator-boot-on;
549*96cbdfddSJohn Clark				regulator-name = "vdd2_ddr_s3";
550*96cbdfddSJohn Clark
551*96cbdfddSJohn Clark				regulator-state-mem {
552*96cbdfddSJohn Clark					regulator-on-in-suspend;
553*96cbdfddSJohn Clark				};
554*96cbdfddSJohn Clark			};
555*96cbdfddSJohn Clark
556*96cbdfddSJohn Clark			vdd_ddr_s0: dcdc-reg10 {
557*96cbdfddSJohn Clark				regulator-always-on;
558*96cbdfddSJohn Clark				regulator-boot-on;
559*96cbdfddSJohn Clark				regulator-min-microvolt = <550000>;
560*96cbdfddSJohn Clark				regulator-max-microvolt = <1200000>;
561*96cbdfddSJohn Clark				regulator-name = "vdd_ddr_s0";
562*96cbdfddSJohn Clark
563*96cbdfddSJohn Clark				regulator-state-mem {
564*96cbdfddSJohn Clark					regulator-off-in-suspend;
565*96cbdfddSJohn Clark				};
566*96cbdfddSJohn Clark			};
567*96cbdfddSJohn Clark
568*96cbdfddSJohn Clark			vcca_1v8_s0: pldo-reg1 {
569*96cbdfddSJohn Clark				regulator-always-on;
570*96cbdfddSJohn Clark				regulator-boot-on;
571*96cbdfddSJohn Clark				regulator-min-microvolt = <1800000>;
572*96cbdfddSJohn Clark				regulator-max-microvolt = <1800000>;
573*96cbdfddSJohn Clark				regulator-name = "vcca_1v8_s0";
574*96cbdfddSJohn Clark
575*96cbdfddSJohn Clark				regulator-state-mem {
576*96cbdfddSJohn Clark					regulator-off-in-suspend;
577*96cbdfddSJohn Clark				};
578*96cbdfddSJohn Clark			};
579*96cbdfddSJohn Clark
580*96cbdfddSJohn Clark			vcca1v8_pldo2_s0: pldo-reg2 {
581*96cbdfddSJohn Clark				regulator-always-on;
582*96cbdfddSJohn Clark				regulator-boot-on;
583*96cbdfddSJohn Clark				regulator-min-microvolt = <1800000>;
584*96cbdfddSJohn Clark				regulator-max-microvolt = <1800000>;
585*96cbdfddSJohn Clark				regulator-name = "vcca1v8_pldo2_s0";
586*96cbdfddSJohn Clark
587*96cbdfddSJohn Clark				regulator-state-mem {
588*96cbdfddSJohn Clark					regulator-off-in-suspend;
589*96cbdfddSJohn Clark				};
590*96cbdfddSJohn Clark			};
591*96cbdfddSJohn Clark
592*96cbdfddSJohn Clark			vdda_1v2_s0: pldo-reg3 {
593*96cbdfddSJohn Clark				regulator-always-on;
594*96cbdfddSJohn Clark				regulator-boot-on;
595*96cbdfddSJohn Clark				regulator-min-microvolt = <1200000>;
596*96cbdfddSJohn Clark				regulator-max-microvolt = <1200000>;
597*96cbdfddSJohn Clark				regulator-name = "vdda_1v2_s0";
598*96cbdfddSJohn Clark
599*96cbdfddSJohn Clark				regulator-state-mem {
600*96cbdfddSJohn Clark					regulator-off-in-suspend;
601*96cbdfddSJohn Clark				};
602*96cbdfddSJohn Clark			};
603*96cbdfddSJohn Clark
604*96cbdfddSJohn Clark			vcca_3v3_s0: pldo-reg4 {
605*96cbdfddSJohn Clark				regulator-always-on;
606*96cbdfddSJohn Clark				regulator-boot-on;
607*96cbdfddSJohn Clark				regulator-min-microvolt = <3300000>;
608*96cbdfddSJohn Clark				regulator-max-microvolt = <3300000>;
609*96cbdfddSJohn Clark				regulator-name = "vcca_3v3_s0";
610*96cbdfddSJohn Clark
611*96cbdfddSJohn Clark				regulator-state-mem {
612*96cbdfddSJohn Clark					regulator-off-in-suspend;
613*96cbdfddSJohn Clark				};
614*96cbdfddSJohn Clark			};
615*96cbdfddSJohn Clark
616*96cbdfddSJohn Clark			vccio_sd_s0: pldo-reg5 {
617*96cbdfddSJohn Clark				regulator-always-on;
618*96cbdfddSJohn Clark				regulator-boot-on;
619*96cbdfddSJohn Clark				regulator-min-microvolt = <1800000>;
620*96cbdfddSJohn Clark				regulator-max-microvolt = <3300000>;
621*96cbdfddSJohn Clark				regulator-name = "vccio_sd_s0";
622*96cbdfddSJohn Clark
623*96cbdfddSJohn Clark				regulator-state-mem {
624*96cbdfddSJohn Clark					regulator-off-in-suspend;
625*96cbdfddSJohn Clark				};
626*96cbdfddSJohn Clark			};
627*96cbdfddSJohn Clark
628*96cbdfddSJohn Clark			vcca1v8_pldo6_s3: pldo-reg6 {
629*96cbdfddSJohn Clark				regulator-always-on;
630*96cbdfddSJohn Clark				regulator-boot-on;
631*96cbdfddSJohn Clark				regulator-min-microvolt = <1800000>;
632*96cbdfddSJohn Clark				regulator-max-microvolt = <1800000>;
633*96cbdfddSJohn Clark				regulator-name = "vcca1v8_pldo6_s3";
634*96cbdfddSJohn Clark
635*96cbdfddSJohn Clark				regulator-state-mem {
636*96cbdfddSJohn Clark					regulator-on-in-suspend;
637*96cbdfddSJohn Clark					regulator-suspend-microvolt = <1800000>;
638*96cbdfddSJohn Clark				};
639*96cbdfddSJohn Clark			};
640*96cbdfddSJohn Clark
641*96cbdfddSJohn Clark			vdd_0v75_s3: nldo-reg1 {
642*96cbdfddSJohn Clark				regulator-always-on;
643*96cbdfddSJohn Clark				regulator-boot-on;
644*96cbdfddSJohn Clark				regulator-min-microvolt = <750000>;
645*96cbdfddSJohn Clark				regulator-max-microvolt = <750000>;
646*96cbdfddSJohn Clark				regulator-name = "vdd_0v75_s3";
647*96cbdfddSJohn Clark
648*96cbdfddSJohn Clark				regulator-state-mem {
649*96cbdfddSJohn Clark					regulator-on-in-suspend;
650*96cbdfddSJohn Clark					regulator-suspend-microvolt = <750000>;
651*96cbdfddSJohn Clark				};
652*96cbdfddSJohn Clark			};
653*96cbdfddSJohn Clark
654*96cbdfddSJohn Clark			vdda_ddr_pll_s0: nldo-reg2 {
655*96cbdfddSJohn Clark				regulator-always-on;
656*96cbdfddSJohn Clark				regulator-boot-on;
657*96cbdfddSJohn Clark				regulator-min-microvolt = <850000>;
658*96cbdfddSJohn Clark				regulator-max-microvolt = <850000>;
659*96cbdfddSJohn Clark				regulator-name = "vdda_ddr_pll_s0";
660*96cbdfddSJohn Clark
661*96cbdfddSJohn Clark				regulator-state-mem {
662*96cbdfddSJohn Clark					regulator-off-in-suspend;
663*96cbdfddSJohn Clark				};
664*96cbdfddSJohn Clark			};
665*96cbdfddSJohn Clark
666*96cbdfddSJohn Clark			vdda0v75_hdmi_s0: nldo-reg3 {
667*96cbdfddSJohn Clark				regulator-always-on;
668*96cbdfddSJohn Clark				regulator-boot-on;
669*96cbdfddSJohn Clark				regulator-min-microvolt = <837500>;
670*96cbdfddSJohn Clark				regulator-max-microvolt = <837500>;
671*96cbdfddSJohn Clark				regulator-name = "vdda0v75_hdmi_s0";
672*96cbdfddSJohn Clark
673*96cbdfddSJohn Clark				regulator-state-mem {
674*96cbdfddSJohn Clark					regulator-off-in-suspend;
675*96cbdfddSJohn Clark				};
676*96cbdfddSJohn Clark			};
677*96cbdfddSJohn Clark
678*96cbdfddSJohn Clark			vdda_0v85_s0: nldo-reg4 {
679*96cbdfddSJohn Clark				regulator-always-on;
680*96cbdfddSJohn Clark				regulator-boot-on;
681*96cbdfddSJohn Clark				regulator-min-microvolt = <850000>;
682*96cbdfddSJohn Clark				regulator-max-microvolt = <850000>;
683*96cbdfddSJohn Clark				regulator-name = "vdda_0v85_s0";
684*96cbdfddSJohn Clark
685*96cbdfddSJohn Clark				regulator-state-mem {
686*96cbdfddSJohn Clark					regulator-off-in-suspend;
687*96cbdfddSJohn Clark				};
688*96cbdfddSJohn Clark			};
689*96cbdfddSJohn Clark
690*96cbdfddSJohn Clark			vdda_0v75_s0: nldo-reg5 {
691*96cbdfddSJohn Clark				regulator-always-on;
692*96cbdfddSJohn Clark				regulator-boot-on;
693*96cbdfddSJohn Clark				regulator-min-microvolt = <750000>;
694*96cbdfddSJohn Clark				regulator-max-microvolt = <750000>;
695*96cbdfddSJohn Clark				regulator-name = "vdda_0v75_s0";
696*96cbdfddSJohn Clark
697*96cbdfddSJohn Clark				regulator-state-mem {
698*96cbdfddSJohn Clark					regulator-off-in-suspend;
699*96cbdfddSJohn Clark				};
700*96cbdfddSJohn Clark			};
701*96cbdfddSJohn Clark		};
702*96cbdfddSJohn Clark	};
703*96cbdfddSJohn Clark};
704*96cbdfddSJohn Clark
705*96cbdfddSJohn Clark&i2c2 {
706*96cbdfddSJohn Clark	status = "okay";
707*96cbdfddSJohn Clark
708*96cbdfddSJohn Clark	hym8563: rtc@51 {
709*96cbdfddSJohn Clark		compatible = "haoyu,hym8563";
710*96cbdfddSJohn Clark		reg = <0x51>;
711*96cbdfddSJohn Clark		#clock-cells = <0>;
712*96cbdfddSJohn Clark		clock-output-names = "hym8563";
713*96cbdfddSJohn Clark		interrupt-parent = <&gpio0>;
714*96cbdfddSJohn Clark		interrupts = <RK_PA5 IRQ_TYPE_LEVEL_LOW>;
715*96cbdfddSJohn Clark		pinctrl-names = "default";
716*96cbdfddSJohn Clark		pinctrl-0 = <&hym8563_int>;
717*96cbdfddSJohn Clark		wakeup-source;
718*96cbdfddSJohn Clark	};
719*96cbdfddSJohn Clark};
720*96cbdfddSJohn Clark
721*96cbdfddSJohn Clark&i2c5 {
722*96cbdfddSJohn Clark	clock-frequency = <200000>;
723*96cbdfddSJohn Clark	pinctrl-names = "default";
724*96cbdfddSJohn Clark	pinctrl-0 = <&i2c5m3_xfer>;
725*96cbdfddSJohn Clark	status = "okay";
726*96cbdfddSJohn Clark
727*96cbdfddSJohn Clark	rt5616: audio-codec@1b {
728*96cbdfddSJohn Clark		compatible = "realtek,rt5616";
729*96cbdfddSJohn Clark		reg = <0x1b>;
730*96cbdfddSJohn Clark		assigned-clocks = <&cru CLK_SAI2_MCLKOUT>;
731*96cbdfddSJohn Clark		assigned-clock-rates = <12288000>;
732*96cbdfddSJohn Clark		clocks = <&cru CLK_SAI2_MCLKOUT>;
733*96cbdfddSJohn Clark		clock-names = "mclk";
734*96cbdfddSJohn Clark		#sound-dai-cells = <0>;
735*96cbdfddSJohn Clark	};
736*96cbdfddSJohn Clark};
737*96cbdfddSJohn Clark
738*96cbdfddSJohn Clark&mdio0 {
739*96cbdfddSJohn Clark	rgmii_phy0: phy@1 {
740*96cbdfddSJohn Clark		compatible = "ethernet-phy-ieee802.3-c22";
741*96cbdfddSJohn Clark		reg = <0x1>;
742*96cbdfddSJohn Clark		clocks = <&cru REFCLKO25M_GMAC0_OUT>;
743*96cbdfddSJohn Clark		interrupt-parent = <&gpio2>;
744*96cbdfddSJohn Clark		interrupts = <RK_PB1 IRQ_TYPE_LEVEL_LOW>;
745*96cbdfddSJohn Clark		pinctrl-names = "default";
746*96cbdfddSJohn Clark		pinctrl-0 = <&gmac0_int>, <&gmac0_rst>;
747*96cbdfddSJohn Clark		reset-assert-us = <20000>;
748*96cbdfddSJohn Clark		reset-deassert-us = <100000>;
749*96cbdfddSJohn Clark		reset-gpios = <&gpio2 RK_PB5 GPIO_ACTIVE_LOW>;
750*96cbdfddSJohn Clark	};
751*96cbdfddSJohn Clark};
752*96cbdfddSJohn Clark
753*96cbdfddSJohn Clark&mdio1 {
754*96cbdfddSJohn Clark	rgmii_phy1: phy@1 {
755*96cbdfddSJohn Clark		compatible = "ethernet-phy-ieee802.3-c22";
756*96cbdfddSJohn Clark		reg = <0x1>;
757*96cbdfddSJohn Clark		clocks = <&cru REFCLKO25M_GMAC1_OUT>;
758*96cbdfddSJohn Clark		interrupt-parent = <&gpio3>;
759*96cbdfddSJohn Clark		interrupts = <RK_PA2 IRQ_TYPE_LEVEL_LOW>;
760*96cbdfddSJohn Clark		pinctrl-names = "default";
761*96cbdfddSJohn Clark		pinctrl-0 = <&gmac1_int>, <&gmac1_rst>;
762*96cbdfddSJohn Clark		reset-assert-us = <20000>;
763*96cbdfddSJohn Clark		reset-deassert-us = <100000>;
764*96cbdfddSJohn Clark		reset-gpios = <&gpio3 RK_PA3 GPIO_ACTIVE_LOW>;
765*96cbdfddSJohn Clark	};
766*96cbdfddSJohn Clark};
767*96cbdfddSJohn Clark
768*96cbdfddSJohn Clark&pcie0 {
769*96cbdfddSJohn Clark	pinctrl-names = "default";
770*96cbdfddSJohn Clark	pinctrl-0 = <&pcie0_perstn>;
771*96cbdfddSJohn Clark	reset-gpios = <&gpio2 RK_PB4 GPIO_ACTIVE_HIGH>;
772*96cbdfddSJohn Clark	vpcie3v3-supply = <&vcc3v3_m2_keym>;
773*96cbdfddSJohn Clark	status = "okay";
774*96cbdfddSJohn Clark};
775*96cbdfddSJohn Clark
776*96cbdfddSJohn Clark&pinctrl {
777*96cbdfddSJohn Clark	gmac {
778*96cbdfddSJohn Clark		gmac0_int: gmac0-int {
779*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PB1 RK_FUNC_GPIO &pcfg_pull_up>;
780*96cbdfddSJohn Clark		};
781*96cbdfddSJohn Clark		gmac0_rst: gmac0-rst {
782*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>;
783*96cbdfddSJohn Clark		};
784*96cbdfddSJohn Clark		gmac1_int: gmac1-int {
785*96cbdfddSJohn Clark			rockchip,pins = <3 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>;
786*96cbdfddSJohn Clark		};
787*96cbdfddSJohn Clark		gmac1_rst: gmac1-rst {
788*96cbdfddSJohn Clark			rockchip,pins = <3 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
789*96cbdfddSJohn Clark		};
790*96cbdfddSJohn Clark	};
791*96cbdfddSJohn Clark
792*96cbdfddSJohn Clark	hym8563 {
793*96cbdfddSJohn Clark		hym8563_int: hym8563-int {
794*96cbdfddSJohn Clark			rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>;
795*96cbdfddSJohn Clark		};
796*96cbdfddSJohn Clark	};
797*96cbdfddSJohn Clark
798*96cbdfddSJohn Clark	keys {
799*96cbdfddSJohn Clark		usr_button_l: usr-button-l {
800*96cbdfddSJohn Clark			rockchip,pins = <1 RK_PA0 RK_FUNC_GPIO &pcfg_pull_up>;
801*96cbdfddSJohn Clark		};
802*96cbdfddSJohn Clark	};
803*96cbdfddSJohn Clark
804*96cbdfddSJohn Clark	leds {
805*96cbdfddSJohn Clark		led_sys_h: led-sys-h {
806*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PB3 RK_FUNC_GPIO &pcfg_pull_none>;
807*96cbdfddSJohn Clark		};
808*96cbdfddSJohn Clark		led1_h: led1-h {
809*96cbdfddSJohn Clark			rockchip,pins = <4 RK_PC5 RK_FUNC_GPIO &pcfg_pull_none>;
810*96cbdfddSJohn Clark		};
811*96cbdfddSJohn Clark		led2_h: led2-h {
812*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
813*96cbdfddSJohn Clark		};
814*96cbdfddSJohn Clark	};
815*96cbdfddSJohn Clark
816*96cbdfddSJohn Clark	pcie {
817*96cbdfddSJohn Clark		pcie0_pwren_h: pcie0-pwren-h {
818*96cbdfddSJohn Clark			rockchip,pins = <0 RK_PD3 RK_FUNC_GPIO &pcfg_pull_none>;
819*96cbdfddSJohn Clark		};
820*96cbdfddSJohn Clark		pcie0_perstn: pcie0-perstn {
821*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PB4 RK_FUNC_GPIO &pcfg_pull_up>;
822*96cbdfddSJohn Clark		};
823*96cbdfddSJohn Clark	};
824*96cbdfddSJohn Clark
825*96cbdfddSJohn Clark	sdmmc {
826*96cbdfddSJohn Clark		sdmmc0_pwren_h: sdmmc0-pwren-h {
827*96cbdfddSJohn Clark			rockchip,pins = <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_up>;
828*96cbdfddSJohn Clark		};
829*96cbdfddSJohn Clark	};
830*96cbdfddSJohn Clark
831*96cbdfddSJohn Clark	sound {
832*96cbdfddSJohn Clark		hp_det_l: hp-det-l {
833*96cbdfddSJohn Clark			rockchip,pins = <2 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>;
834*96cbdfddSJohn Clark		};
835*96cbdfddSJohn Clark	};
836*96cbdfddSJohn Clark
837*96cbdfddSJohn Clark	usb {
838*96cbdfddSJohn Clark		usb3_host_pwren_h: usb3-host-pwren-h {
839*96cbdfddSJohn Clark			rockchip,pins = <0 RK_PC7 RK_FUNC_GPIO &pcfg_pull_none>;
840*96cbdfddSJohn Clark		};
841*96cbdfddSJohn Clark		usb_otg0_pwren_h: usb-otg0-pwren-h {
842*96cbdfddSJohn Clark			rockchip,pins = <0 RK_PD1 RK_FUNC_GPIO &pcfg_pull_none>;
843*96cbdfddSJohn Clark		};
844*96cbdfddSJohn Clark	};
845*96cbdfddSJohn Clark};
846*96cbdfddSJohn Clark
847*96cbdfddSJohn Clark&sai2 {
848*96cbdfddSJohn Clark	status = "okay";
849*96cbdfddSJohn Clark};
850*96cbdfddSJohn Clark
851*96cbdfddSJohn Clark&saradc {
852*96cbdfddSJohn Clark	vref-supply = <&vcca_1v8_s0>;
853*96cbdfddSJohn Clark	status = "okay";
854*96cbdfddSJohn Clark};
855*96cbdfddSJohn Clark
856*96cbdfddSJohn Clark&sdmmc {
857*96cbdfddSJohn Clark	bus-width = <4>;
858*96cbdfddSJohn Clark	cap-mmc-highspeed;
859*96cbdfddSJohn Clark	cap-sd-highspeed;
860*96cbdfddSJohn Clark	disable-wp;
861*96cbdfddSJohn Clark	no-mmc;
862*96cbdfddSJohn Clark	no-sdio;
863*96cbdfddSJohn Clark	pinctrl-names = "default";
864*96cbdfddSJohn Clark	pinctrl-0 = <&sdmmc0_clk>, <&sdmmc0_cmd>, <&sdmmc0_det>, <&sdmmc0_bus4>;
865*96cbdfddSJohn Clark	sd-uhs-sdr104;
866*96cbdfddSJohn Clark	vmmc-supply = <&vcc_3v3_s3>;
867*96cbdfddSJohn Clark	vqmmc-supply = <&vcc3v3_sd_s0>;
868*96cbdfddSJohn Clark	status = "okay";
869*96cbdfddSJohn Clark};
870*96cbdfddSJohn Clark
871*96cbdfddSJohn Clark&sfc1 {
872*96cbdfddSJohn Clark	pinctrl-names = "default";
873*96cbdfddSJohn Clark	pinctrl-0 = <&fspi1m1_csn0>, <&fspi1m1_pins>;
874*96cbdfddSJohn Clark	status = "okay";
875*96cbdfddSJohn Clark
876*96cbdfddSJohn Clark	flash@0 {
877*96cbdfddSJohn Clark		compatible = "jedec,spi-nor";
878*96cbdfddSJohn Clark		reg = <0>;
879*96cbdfddSJohn Clark		m25p,fast-read;
880*96cbdfddSJohn Clark		spi-max-frequency = <50000000>;
881*96cbdfddSJohn Clark		spi-rx-bus-width = <4>;
882*96cbdfddSJohn Clark		spi-tx-bus-width = <1>;
883*96cbdfddSJohn Clark		vcc-supply = <&vcc_1v8_s3>;
884*96cbdfddSJohn Clark	};
885*96cbdfddSJohn Clark};
886*96cbdfddSJohn Clark
887*96cbdfddSJohn Clark&u2phy0 {
888*96cbdfddSJohn Clark	status = "okay";
889*96cbdfddSJohn Clark};
890*96cbdfddSJohn Clark
891*96cbdfddSJohn Clark&u2phy0_otg {
892*96cbdfddSJohn Clark	phy-supply = <&vcc5v0_usb_otg0>;
893*96cbdfddSJohn Clark	status = "okay";
894*96cbdfddSJohn Clark};
895*96cbdfddSJohn Clark
896*96cbdfddSJohn Clark&u2phy1 {
897*96cbdfddSJohn Clark	status = "okay";
898*96cbdfddSJohn Clark};
899*96cbdfddSJohn Clark
900*96cbdfddSJohn Clark&u2phy1_otg {
901*96cbdfddSJohn Clark	phy-supply = <&usb3_port2_5v>;
902*96cbdfddSJohn Clark	status = "okay";
903*96cbdfddSJohn Clark};
904*96cbdfddSJohn Clark
905*96cbdfddSJohn Clark&uart0 {
906*96cbdfddSJohn Clark	status = "okay";
907*96cbdfddSJohn Clark};
908*96cbdfddSJohn Clark
909*96cbdfddSJohn Clark&usbdp_phy {
910*96cbdfddSJohn Clark	status = "okay";
911*96cbdfddSJohn Clark};
912*96cbdfddSJohn Clark
913*96cbdfddSJohn Clark&usb_drd0_dwc3 {
914*96cbdfddSJohn Clark	dr_mode = "otg";
915*96cbdfddSJohn Clark	extcon = <&u2phy0>;
916*96cbdfddSJohn Clark	status = "okay";
917*96cbdfddSJohn Clark};
918*96cbdfddSJohn Clark
919*96cbdfddSJohn Clark&usb_drd1_dwc3 {
920*96cbdfddSJohn Clark	dr_mode = "host";
921*96cbdfddSJohn Clark	status = "okay";
922*96cbdfddSJohn Clark};
923*96cbdfddSJohn Clark
924*96cbdfddSJohn Clark&vop {
925*96cbdfddSJohn Clark	status = "okay";
926*96cbdfddSJohn Clark};
927*96cbdfddSJohn Clark
928*96cbdfddSJohn Clark&vop_mmu {
929*96cbdfddSJohn Clark	status = "okay";
930*96cbdfddSJohn Clark};
931*96cbdfddSJohn Clark
932*96cbdfddSJohn Clark&vp0 {
933*96cbdfddSJohn Clark	vp0_out_hdmi: endpoint@ROCKCHIP_VOP2_EP_HDMI0 {
934*96cbdfddSJohn Clark		reg = <ROCKCHIP_VOP2_EP_HDMI0>;
935*96cbdfddSJohn Clark		remote-endpoint = <&hdmi_in_vp0>;
936*96cbdfddSJohn Clark	};
937*96cbdfddSJohn Clark};
938*96cbdfddSJohn Clark
939*96cbdfddSJohn Clark&wdt {
940*96cbdfddSJohn Clark	status = "okay";
941*96cbdfddSJohn Clark};
942