xref: /linux/arch/arm64/boot/dts/rockchip/rk3566-powkiddy-rk2023.dtsi (revision 621cde16e49b3ecf7d59a8106a20aaebfb4a59a9)
1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2
3/dts-v1/;
4
5#include <dt-bindings/gpio/gpio.h>
6#include <dt-bindings/input/linux-event-codes.h>
7#include <dt-bindings/leds/common.h>
8#include <dt-bindings/pinctrl/rockchip.h>
9#include <dt-bindings/soc/rockchip,vop2.h>
10#include "rk3566.dtsi"
11
12/ {
13	chassis-type = "handset";
14
15	aliases {
16		mmc1 = &sdmmc0;
17		mmc2 = &sdmmc1;
18		mmc3 = &sdmmc2;
19	};
20
21	adc-joystick {
22		compatible = "adc-joystick";
23		io-channels = <&adc_mux 0>,
24			      <&adc_mux 1>,
25			      <&adc_mux 2>,
26			      <&adc_mux 3>;
27		pinctrl-0 = <&joy_mux_en>;
28		pinctrl-names = "default";
29		poll-interval = <60>;
30		#address-cells = <1>;
31		#size-cells = <0>;
32
33		axis@0 {
34			reg = <0>;
35			abs-flat = <32>;
36			abs-fuzz = <32>;
37			abs-range = <1023 15>;
38			linux,code = <ABS_X>;
39		};
40
41		axis@1 {
42			reg = <1>;
43			abs-flat = <32>;
44			abs-fuzz = <32>;
45			abs-range = <15 1023>;
46			linux,code = <ABS_RX>;
47		};
48
49		axis@2 {
50			reg = <2>;
51			abs-flat = <32>;
52			abs-fuzz = <32>;
53			abs-range = <15 1023>;
54			linux,code = <ABS_Y>;
55		};
56
57		axis@3 {
58			reg = <3>;
59			abs-flat = <32>;
60			abs-fuzz = <32>;
61			abs-range = <1023 15>;
62			linux,code = <ABS_RY>;
63		};
64	};
65
66	adc_mux: adc-mux {
67		compatible = "io-channel-mux";
68		channels = "left_x", "right_x", "left_y", "right_y";
69		#io-channel-cells = <1>;
70		io-channels = <&saradc 3>;
71		io-channel-names = "parent";
72		mux-controls = <&gpio_mux>;
73		settle-time-us = <100>;
74	};
75
76	backlight: backlight {
77		compatible = "pwm-backlight";
78		power-supply = <&vcc_sys>;
79		pwms = <&pwm4 0 25000 0>;
80	};
81
82	battery: battery {
83		compatible = "simple-battery";
84		charge-full-design-microamp-hours = <3151000>;
85		charge-term-current-microamp = <300000>;
86		constant-charge-current-max-microamp = <2000000>;
87		constant-charge-voltage-max-microvolt = <4250000>;
88		factory-internal-resistance-micro-ohms = <117000>;
89		voltage-max-design-microvolt = <4172000>;
90		voltage-min-design-microvolt = <3400000>;
91
92		ocv-capacity-celsius = <20>;
93		ocv-capacity-table-0 =  <4172000 100>, <4092000 95>, <4035000 90>, <3990000 85>,
94					<3939000 80>, <3895000 75>, <3852000 70>, <3807000 65>,
95					<3762000 60>, <3713000 55>, <3672000 50>, <3647000 45>,
96					<3629000 40>, <3613000 35>, <3598000 30>, <3578000 25>,
97					<3550000 20>, <3519000 15>, <3479000 10>, <3438000 5>,
98					<3400000 0>;
99	};
100
101	gpio_keys_control: gpio-keys-control {
102		compatible = "gpio-keys";
103		pinctrl-0 = <&btn_pins_ctrl>;
104		pinctrl-names = "default";
105
106		button-a {
107			gpios = <&gpio3 RK_PC2 GPIO_ACTIVE_LOW>;
108			label = "EAST";
109			linux,code = <BTN_EAST>;
110		};
111
112		button-b {
113			gpios = <&gpio3 RK_PC3 GPIO_ACTIVE_LOW>;
114			label = "SOUTH";
115			linux,code = <BTN_SOUTH>;
116		};
117
118		button-down {
119			gpios = <&gpio3 RK_PA4 GPIO_ACTIVE_LOW>;
120			label = "DPAD-DOWN";
121			linux,code = <BTN_DPAD_DOWN>;
122		};
123
124		button-l1 {
125			gpios = <&gpio3 RK_PB1 GPIO_ACTIVE_LOW>;
126			label = "TL";
127			linux,code = <BTN_TL>;
128		};
129
130		button-l2 {
131			gpios = <&gpio3 RK_PB2 GPIO_ACTIVE_LOW>;
132			label = "TL2";
133			linux,code = <BTN_TL2>;
134		};
135
136		button-left {
137			gpios = <&gpio3 RK_PA6 GPIO_ACTIVE_LOW>;
138			label = "DPAD-LEFT";
139			linux,code = <BTN_DPAD_LEFT>;
140		};
141
142		button-r1 {
143			gpios = <&gpio3 RK_PB3 GPIO_ACTIVE_LOW>;
144			label = "TR";
145			linux,code = <BTN_TR>;
146		};
147
148		button-r2 {
149			gpios = <&gpio3 RK_PB4 GPIO_ACTIVE_LOW>;
150			label = "TR2";
151			linux,code = <BTN_TR2>;
152		};
153
154		button-right {
155			gpios = <&gpio3 RK_PA5 GPIO_ACTIVE_LOW>;
156			label = "DPAD-RIGHT";
157			linux,code = <BTN_DPAD_RIGHT>;
158		};
159
160		button-select {
161			gpios = <&gpio3 RK_PB6 GPIO_ACTIVE_LOW>;
162			label = "SELECT";
163			linux,code = <BTN_SELECT>;
164		};
165
166		button-start {
167			gpios = <&gpio3 RK_PB5 GPIO_ACTIVE_LOW>;
168			label = "START";
169			linux,code = <BTN_START>;
170		};
171
172		button-thumbl {
173			gpios = <&gpio3 RK_PA1 GPIO_ACTIVE_LOW>;
174			label = "THUMBL";
175			linux,code = <BTN_THUMBL>;
176		};
177
178		button-thumbr {
179			gpios = <&gpio3 RK_PA2 GPIO_ACTIVE_LOW>;
180			label = "THUMBR";
181			linux,code = <BTN_THUMBR>;
182		};
183
184		button-up {
185			gpios = <&gpio3 RK_PA3 GPIO_ACTIVE_LOW>;
186			label = "DPAD-UP";
187			linux,code = <BTN_DPAD_UP>;
188		};
189
190		button-x {
191			gpios = <&gpio3 RK_PC0 GPIO_ACTIVE_LOW>;
192			label = "NORTH";
193			linux,code = <BTN_NORTH>;
194		};
195
196		button-y {
197			gpios = <&gpio3 RK_PC1 GPIO_ACTIVE_LOW>;
198			label = "WEST";
199			linux,code = <BTN_WEST>;
200		};
201	};
202
203	gpio_keys_vol: gpio-keys-vol {
204		compatible = "gpio-keys";
205		autorepeat;
206		pinctrl-0 = <&btn_pins_vol>;
207		pinctrl-names = "default";
208
209		button-vol-down {
210			gpios = <&gpio3 RK_PB0 GPIO_ACTIVE_LOW>;
211			label = "VOLUMEDOWN";
212			linux,code = <KEY_VOLUMEDOWN>;
213		};
214
215		button-vol-up {
216			gpios = <&gpio3 RK_PA7 GPIO_ACTIVE_LOW>;
217			label = "VOLUMEUP";
218			linux,code = <KEY_VOLUMEUP>;
219		};
220	};
221
222	gpio_mux: mux-controller {
223		compatible = "gpio-mux";
224		mux-gpios = <&gpio0 RK_PB6 GPIO_ACTIVE_LOW>,
225			    <&gpio0 RK_PB7 GPIO_ACTIVE_LOW>;
226		#mux-control-cells = <0>;
227	};
228
229	hdmi-con {
230		compatible = "hdmi-connector";
231		ddc-i2c-bus = <&i2c5>;
232		type = "c";
233
234		port {
235			hdmi_con_in: endpoint {
236				remote-endpoint = <&hdmi_out_con>;
237			};
238		};
239	};
240
241	/*
242	 * Device also includes an always on LED that is wired to the 5V input
243	 * voltage and is on when the device is plugged in.
244	 */
245	leds: pwm-leds {
246		compatible = "pwm-leds";
247
248		green_led: led-0 {
249			color = <LED_COLOR_ID_GREEN>;
250			function = LED_FUNCTION_STATUS;
251			max-brightness = <255>;
252			pwms = <&pwm6 0 25000 0>;
253		};
254
255		red_led: led-1 {
256			color = <LED_COLOR_ID_RED>;
257			function = LED_FUNCTION_CHARGING;
258			max-brightness = <255>;
259			pwms = <&pwm7 0 25000 0>;
260		};
261	};
262
263	sdio_pwrseq: sdio-pwrseq {
264		compatible = "mmc-pwrseq-simple";
265		clocks = <&rk817 1>;
266		clock-names = "ext_clock";
267		pinctrl-0 = <&wifi_enable_h>;
268		pinctrl-names = "default";
269		post-power-on-delay-ms = <200>;
270		reset-gpios = <&gpio4 RK_PA2 GPIO_ACTIVE_LOW>;
271	};
272
273	/*
274	 * Channels reversed for speakers. Headphones automatically switch via hardware when
275	 * detected with no ability to control output in software. Headphones appear to be mono
276	 * (each output channel receives all audio). No microphone support on 3.5mm jack.
277	 */
278	sound {
279		compatible = "simple-audio-card";
280		simple-audio-card,name = "rk817_ext";
281		simple-audio-card,format = "i2s";
282		simple-audio-card,mclk-fs = <256>;
283		simple-audio-card,widgets =
284			"Headphone", "Headphones";
285		simple-audio-card,routing =
286			"Headphones", "HPOL",
287			"Headphones", "HPOR";
288
289		simple-audio-card,codec {
290			sound-dai = <&rk817>;
291		};
292
293		simple-audio-card,cpu {
294			sound-dai = <&i2s1_8ch>;
295		};
296	};
297
298	vcc3v3_lcd0_n: regulator-vcc3v3-lcd0 {
299		compatible = "regulator-fixed";
300		gpio = <&gpio0 RK_PC2 GPIO_ACTIVE_HIGH>;
301		enable-active-high;
302		pinctrl-0 = <&vcc_lcd_h>;
303		pinctrl-names = "default";
304		regulator-boot-on;
305		regulator-min-microvolt = <3300000>;
306		regulator-max-microvolt = <3300000>;
307		regulator-name = "vcc3v3_lcd0_n";
308		vin-supply = <&vcc_3v3>;
309		regulator-state-mem {
310			regulator-off-in-suspend;
311		};
312	};
313
314	vcc_sys: regulator-vcc-sys {
315		compatible = "regulator-fixed";
316		regulator-always-on;
317		regulator-boot-on;
318		regulator-min-microvolt = <3800000>;
319		regulator-max-microvolt = <3800000>;
320		regulator-name = "vcc_sys";
321	};
322
323	vcc_wifi: regulator-vcc-wifi {
324		compatible = "regulator-fixed";
325		enable-active-high;
326		gpio = <&gpio0 RK_PA0 GPIO_ACTIVE_HIGH>;
327		pinctrl-0 = <&vcc_wifi_h>;
328		pinctrl-names = "default";
329		regulator-always-on;
330		regulator-boot-on;
331		regulator-min-microvolt = <3300000>;
332		regulator-max-microvolt = <3300000>;
333		regulator-name = "vcc_wifi";
334	};
335};
336
337&combphy1 {
338	status = "okay";
339};
340
341&cpu0 {
342	cpu-supply = <&vdd_cpu>;
343};
344
345&cpu1 {
346	cpu-supply = <&vdd_cpu>;
347};
348
349&cpu2 {
350	cpu-supply = <&vdd_cpu>;
351};
352
353&cpu3 {
354	cpu-supply = <&vdd_cpu>;
355};
356
357&dsi0 {
358	status = "okay";
359	#address-cells = <1>;
360	#size-cells = <0>;
361
362	ports {
363		dsi0_in: port@0 {
364			reg = <0>;
365			dsi0_in_vp1: endpoint {
366				remote-endpoint = <&vp1_out_dsi0>;
367			};
368		};
369
370		dsi0_out: port@1 {
371			reg = <1>;
372			mipi_out_panel: endpoint {
373				remote-endpoint = <&mipi_in_panel>;
374			};
375		};
376	};
377};
378
379&dsi_dphy0 {
380	status = "okay";
381};
382
383&gpu {
384	mali-supply = <&vdd_gpu>;
385	status = "okay";
386};
387
388&hdmi {
389	ddc-i2c-bus = <&i2c5>;
390	pinctrl-0 = <&hdmitxm0_cec>;
391	pinctrl-names = "default";
392	status = "okay";
393};
394
395&hdmi_in {
396	hdmi_in_vp0: endpoint {
397		remote-endpoint = <&vp0_out_hdmi>;
398	};
399};
400
401&hdmi_out {
402	hdmi_out_con: endpoint {
403		remote-endpoint = <&hdmi_con_in>;
404	};
405};
406
407&hdmi_sound {
408	status = "okay";
409};
410
411&i2c0 {
412	status = "okay";
413
414	rk817: pmic@20 {
415		compatible = "rockchip,rk817";
416		reg = <0x20>;
417		interrupt-parent = <&gpio0>;
418		interrupts = <RK_PA3 IRQ_TYPE_LEVEL_LOW>;
419		clock-output-names = "rk808-clkout1", "rk808-clkout2";
420		clock-names = "mclk";
421		clocks = <&cru I2S1_MCLKOUT_TX>;
422		assigned-clocks = <&cru I2S1_MCLKOUT_TX>;
423		assigned-clock-parents = <&cru CLK_I2S1_8CH_TX>;
424		#clock-cells = <1>;
425		#sound-dai-cells = <0>;
426		pinctrl-names = "default";
427		pinctrl-0 = <&i2s1m0_mclk>, <&pmic_int_l>;
428		wakeup-source;
429
430		vcc1-supply = <&vcc_sys>;
431		vcc2-supply = <&vcc_sys>;
432		vcc3-supply = <&vcc_sys>;
433		vcc4-supply = <&vcc_sys>;
434		vcc5-supply = <&vcc_sys>;
435		vcc6-supply = <&vcc_sys>;
436		vcc7-supply = <&vcc_sys>;
437		vcc8-supply = <&vcc_sys>;
438		vcc9-supply = <&dcdc_boost>;
439
440		regulators {
441			vdd_logic: DCDC_REG1 {
442				regulator-always-on;
443				regulator-boot-on;
444				regulator-min-microvolt = <500000>;
445				regulator-max-microvolt = <1350000>;
446				regulator-ramp-delay = <6001>;
447				regulator-initial-mode = <0x2>;
448				regulator-name = "vdd_logic";
449				regulator-state-mem {
450					regulator-off-in-suspend;
451					regulator-suspend-microvolt = <900000>;
452				};
453			};
454
455			vdd_gpu: DCDC_REG2 {
456				regulator-always-on;
457				regulator-boot-on;
458				regulator-min-microvolt = <500000>;
459				regulator-max-microvolt = <1350000>;
460				regulator-ramp-delay = <6001>;
461				regulator-initial-mode = <0x2>;
462				regulator-name = "vdd_gpu";
463				regulator-state-mem {
464					regulator-off-in-suspend;
465				};
466			};
467
468			vcc_ddr: DCDC_REG3 {
469				regulator-always-on;
470				regulator-boot-on;
471				regulator-initial-mode = <0x2>;
472				regulator-name = "vcc_ddr";
473				regulator-state-mem {
474					regulator-on-in-suspend;
475				};
476			};
477
478			vcc_3v3: DCDC_REG4 {
479				regulator-always-on;
480				regulator-boot-on;
481				regulator-min-microvolt = <3300000>;
482				regulator-max-microvolt = <3300000>;
483				regulator-initial-mode = <0x2>;
484				regulator-name = "vcc_3v3";
485				regulator-state-mem {
486					regulator-on-in-suspend;
487					regulator-suspend-microvolt = <3300000>;
488				};
489			};
490
491			vcca1v8_pmu: LDO_REG1 {
492				regulator-always-on;
493				regulator-boot-on;
494				regulator-min-microvolt = <1800000>;
495				regulator-max-microvolt = <1800000>;
496				regulator-name = "vcca1v8_pmu";
497				regulator-state-mem {
498					regulator-on-in-suspend;
499					regulator-suspend-microvolt = <1800000>;
500				};
501			};
502
503			vdda_0v9: LDO_REG2 {
504				regulator-always-on;
505				regulator-boot-on;
506				regulator-min-microvolt = <900000>;
507				regulator-max-microvolt = <900000>;
508				regulator-name = "vdda_0v9";
509				regulator-state-mem {
510					regulator-off-in-suspend;
511				};
512			};
513
514			vdda0v9_pmu: LDO_REG3 {
515				regulator-always-on;
516				regulator-boot-on;
517				regulator-min-microvolt = <900000>;
518				regulator-max-microvolt = <900000>;
519				regulator-name = "vdda0v9_pmu";
520				regulator-state-mem {
521					regulator-on-in-suspend;
522					regulator-suspend-microvolt = <900000>;
523				};
524			};
525
526			vccio_acodec: LDO_REG4 {
527				regulator-always-on;
528				regulator-boot-on;
529				regulator-min-microvolt = <3300000>;
530				regulator-max-microvolt = <3300000>;
531				regulator-name = "vccio_acodec";
532				regulator-state-mem {
533					regulator-off-in-suspend;
534				};
535			};
536
537			vccio_sd: LDO_REG5 {
538				regulator-always-on;
539				regulator-boot-on;
540				regulator-min-microvolt = <1800000>;
541				regulator-max-microvolt = <3300000>;
542				regulator-name = "vccio_sd";
543				regulator-state-mem {
544					regulator-off-in-suspend;
545				};
546			};
547
548			vcc3v3_pmu: LDO_REG6 {
549				regulator-always-on;
550				regulator-boot-on;
551				regulator-min-microvolt = <3300000>;
552				regulator-max-microvolt = <3300000>;
553				regulator-name = "vcc3v3_pmu";
554				regulator-state-mem {
555					regulator-on-in-suspend;
556					regulator-suspend-microvolt = <3300000>;
557				};
558			};
559
560			vcc_1v8: LDO_REG7 {
561				regulator-always-on;
562				regulator-boot-on;
563				regulator-min-microvolt = <1800000>;
564				regulator-max-microvolt = <1800000>;
565				regulator-name = "vcc_1v8";
566				regulator-state-mem {
567					regulator-off-in-suspend;
568				};
569			};
570
571			vcc1v8_dvp: LDO_REG8 {
572				regulator-always-on;
573				regulator-boot-on;
574				regulator-min-microvolt = <1800000>;
575				regulator-max-microvolt = <3300000>;
576				regulator-name = "vcc1v8_dvp";
577				regulator-state-mem {
578					regulator-off-in-suspend;
579				};
580			};
581
582			vcc2v8_dvp: LDO_REG9 {
583				regulator-always-on;
584				regulator-boot-on;
585				regulator-min-microvolt = <2800000>;
586				regulator-max-microvolt = <2800000>;
587				regulator-name = "vcc2v8_dvp";
588				regulator-state-mem {
589					regulator-off-in-suspend;
590				};
591			};
592
593			dcdc_boost: BOOST {
594				regulator-always-on;
595				regulator-boot-on;
596				regulator-min-microvolt = <4700000>;
597				regulator-max-microvolt = <5400000>;
598				regulator-name = "boost";
599				regulator-state-mem {
600					regulator-off-in-suspend;
601				};
602			};
603
604			otg_switch: OTG_SWITCH {
605				regulator-name = "otg_switch";
606				regulator-state-mem {
607					regulator-off-in-suspend;
608				};
609			};
610		};
611
612		rk817_charger: charger {
613			monitored-battery = <&battery>;
614			rockchip,resistor-sense-micro-ohms = <10000>;
615			rockchip,sleep-enter-current-microamp = <300000>;
616			rockchip,sleep-filter-current-microamp = <100000>;
617		};
618	};
619};
620
621&i2c5 {
622	pinctrl-0 = <&i2c5m1_xfer>;
623	pinctrl-names = "default";
624	status = "okay";
625};
626
627&i2s0_8ch {
628	status = "okay";
629};
630
631&i2s1_8ch {
632	pinctrl-0 = <&i2s1m0_sclktx
633		     &i2s1m0_lrcktx
634		     &i2s1m0_sdi0
635		     &i2s1m0_sdo0>;
636	pinctrl-names = "default";
637	rockchip,trcm-sync-tx-only;
638	status = "okay";
639};
640
641&pinctrl {
642	gpio-btns {
643		btn_pins_ctrl: btn-pins-ctrl {
644			rockchip,pins =
645				<3 RK_PA1 RK_FUNC_GPIO &pcfg_pull_up>,
646				<3 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>,
647				<3 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>,
648				<3 RK_PA4 RK_FUNC_GPIO &pcfg_pull_up>,
649				<3 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>,
650				<3 RK_PA6 RK_FUNC_GPIO &pcfg_pull_up>,
651				<3 RK_PB1 RK_FUNC_GPIO &pcfg_pull_up>,
652				<3 RK_PB2 RK_FUNC_GPIO &pcfg_pull_up>,
653				<3 RK_PB3 RK_FUNC_GPIO &pcfg_pull_up>,
654				<3 RK_PB4 RK_FUNC_GPIO &pcfg_pull_up>,
655				<3 RK_PB5 RK_FUNC_GPIO &pcfg_pull_up>,
656				<3 RK_PB6 RK_FUNC_GPIO &pcfg_pull_up>,
657				<3 RK_PC0 RK_FUNC_GPIO &pcfg_pull_up>,
658				<3 RK_PC1 RK_FUNC_GPIO &pcfg_pull_up>,
659				<3 RK_PC2 RK_FUNC_GPIO &pcfg_pull_up>,
660				<3 RK_PC3 RK_FUNC_GPIO &pcfg_pull_up>;
661		};
662
663		btn_pins_vol: btn-pins-vol {
664			rockchip,pins =
665				<3 RK_PA7 RK_FUNC_GPIO &pcfg_pull_up>,
666				<3 RK_PB0 RK_FUNC_GPIO &pcfg_pull_up>;
667		};
668	};
669
670	joy-mux {
671		joy_mux_en: joy-mux-en {
672			rockchip,pins =
673				<0 RK_PB5 RK_FUNC_GPIO &pcfg_output_low>;
674		};
675	};
676
677	gpio-lcd {
678		lcd_rst: lcd-rst {
679			rockchip,pins =
680				<4 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>;
681		};
682	};
683
684	pmic {
685		pmic_int_l: pmic-int-l {
686			rockchip,pins =
687				<0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;
688		};
689	};
690
691	sdio-pwrseq {
692		wifi_enable_h: wifi-enable-h {
693			rockchip,pins =
694				<4 RK_PA2 RK_FUNC_GPIO &pcfg_pull_none>;
695		};
696	};
697
698	vcc3v3-lcd {
699		vcc_lcd_h: vcc-lcd-h {
700			rockchip,pins =
701				<0 RK_PC2 RK_FUNC_GPIO &pcfg_pull_none>;
702		};
703	};
704
705	vcc-wifi {
706		vcc_wifi_h: vcc-wifi-h {
707			rockchip,pins =
708				<0 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>;
709		};
710	};
711};
712
713&pmu_io_domains {
714	status = "okay";
715	pmuio1-supply = <&vcc3v3_pmu>;
716	pmuio2-supply = <&vcc3v3_pmu>;
717	vccio1-supply = <&vccio_acodec>;
718	vccio3-supply = <&vccio_sd>;
719	vccio4-supply = <&vcc_1v8>;
720	vccio5-supply = <&vcc_3v3>;
721	vccio6-supply = <&vcc1v8_dvp>;
722	vccio7-supply = <&vcc_3v3>;
723};
724
725&pwm4 {
726	status = "okay";
727};
728
729&pwm6 {
730	status = "okay";
731};
732
733&pwm7 {
734	status = "okay";
735};
736
737&saradc {
738	vref-supply = <&vcc_1v8>;
739	status = "okay";
740};
741
742&sdmmc0 {
743	bus-width = <4>;
744	cap-sd-highspeed;
745	cd-gpios = <&gpio0 RK_PA4 GPIO_ACTIVE_LOW>;
746	disable-wp;
747	pinctrl-0 = <&sdmmc0_bus4 &sdmmc0_clk &sdmmc0_cmd &sdmmc0_det>;
748	pinctrl-names = "default";
749	sd-uhs-sdr104;
750	vmmc-supply = <&vcc_3v3>;
751	vqmmc-supply = <&vccio_sd>;
752	status = "okay";
753};
754
755&sdmmc1 {
756	bus-width = <4>;
757	cap-sd-highspeed;
758	cd-gpios = <&gpio2 RK_PB2 GPIO_ACTIVE_LOW>;
759	disable-wp;
760	pinctrl-0 = <&sdmmc1_bus4 &sdmmc1_cmd &sdmmc1_clk &sdmmc1_det>;
761	pinctrl-names = "default";
762	sd-uhs-sdr104;
763	vmmc-supply = <&vcc_3v3>;
764	vqmmc-supply = <&vcc1v8_dvp>;
765	status = "okay";
766};
767
768&sdmmc2 {
769	bus-width = <4>;
770	cap-sd-highspeed;
771	cap-sdio-irq;
772	keep-power-in-suspend;
773	mmc-pwrseq = <&sdio_pwrseq>;
774	non-removable;
775	pinctrl-0 = <&sdmmc2m0_bus4 &sdmmc2m0_cmd &sdmmc2m0_clk>;
776	pinctrl-names = "default";
777	vmmc-supply = <&vcc_wifi>;
778	vqmmc-supply = <&vcca1v8_pmu>;
779	status = "okay";
780};
781
782&tsadc {
783	rockchip,hw-tshut-mode = <1>;
784	rockchip,hw-tshut-polarity = <0>;
785	status = "okay";
786};
787
788&uart1 {
789	pinctrl-0 = <&uart1m1_xfer &uart1m1_ctsn &uart1m1_rtsn>;
790	pinctrl-names = "default";
791	uart-has-rtscts;
792	status = "okay";
793
794	bluetooth: bluetooth {
795		compatible = "realtek,rtl8821cs-bt", "realtek,rtl8723bs-bt";
796		device-wake-gpios = <&gpio4 4 GPIO_ACTIVE_HIGH>;
797		enable-gpios = <&gpio4 3 GPIO_ACTIVE_HIGH>;
798		host-wake-gpios = <&gpio4 5 GPIO_ACTIVE_HIGH>;
799	};
800};
801
802&usb_host0_xhci {
803	dr_mode = "peripheral";
804	phys = <&usb2phy0_otg>;
805	phy-names = "usb2-phy";
806	status = "okay";
807};
808
809&usb_host1_ehci {
810	status = "okay";
811};
812
813&usb_host1_ohci {
814	status = "okay";
815};
816
817&usb_host1_xhci {
818	phy-names = "usb2-phy", "usb3-phy";
819	phys = <&usb2phy1_host>, <&combphy1 PHY_TYPE_USB3>;
820	status = "okay";
821};
822
823&usb2phy0 {
824	status = "okay";
825};
826
827&usb2phy0_otg {
828	status = "okay";
829};
830
831&usb2phy1 {
832	status = "okay";
833};
834
835&usb2phy1_host {
836	status = "okay";
837};
838
839&vop {
840	assigned-clocks = <&cru DCLK_VOP0>, <&cru DCLK_VOP1>;
841	assigned-clock-parents = <&pmucru PLL_HPLL>, <&cru PLL_VPLL>;
842	status = "okay";
843};
844
845&vop_mmu {
846	status = "okay";
847};
848
849&vp0 {
850	vp0_out_hdmi: endpoint@ROCKCHIP_VOP2_EP_HDMI0 {
851		reg = <ROCKCHIP_VOP2_EP_HDMI0>;
852		remote-endpoint = <&hdmi_in_vp0>;
853	};
854};
855
856&vp1 {
857	vp1_out_dsi0: endpoint@ROCKCHIP_VOP2_EP_MIPI0 {
858		reg = <ROCKCHIP_VOP2_EP_MIPI0>;
859		remote-endpoint = <&dsi0_in_vp1>;
860	};
861};
862