162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
262306a36Sopenharmony_ci// Copyright (c) 2019 Jernej Skrabec <jernej.skrabec@siol.net>
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci/dts-v1/;
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#include "sun50i-h6.dtsi"
762306a36Sopenharmony_ci#include "sun50i-h6-cpu-opp.dtsi"
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h>
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci/ {
1262306a36Sopenharmony_ci	aliases {
1362306a36Sopenharmony_ci		serial0 = &uart0;
1462306a36Sopenharmony_ci	};
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci	chosen {
1762306a36Sopenharmony_ci		stdout-path = "serial0:115200n8";
1862306a36Sopenharmony_ci	};
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	connector {
2162306a36Sopenharmony_ci		compatible = "hdmi-connector";
2262306a36Sopenharmony_ci		ddc-en-gpios = <&pio 7 2 GPIO_ACTIVE_HIGH>; /* PH2 */
2362306a36Sopenharmony_ci		type = "a";
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci		port {
2662306a36Sopenharmony_ci			hdmi_con_in: endpoint {
2762306a36Sopenharmony_ci				remote-endpoint = <&hdmi_out_con>;
2862306a36Sopenharmony_ci			};
2962306a36Sopenharmony_ci		};
3062306a36Sopenharmony_ci	};
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	/* used for FD650 LED display driver */
3362306a36Sopenharmony_ci	i2c {
3462306a36Sopenharmony_ci		compatible = "i2c-gpio";
3562306a36Sopenharmony_ci		sda-gpios = <&pio 7 6 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN)>; /* PH6 */
3662306a36Sopenharmony_ci		scl-gpios = <&pio 7 5 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN)>; /* PH5 */
3762306a36Sopenharmony_ci		i2c-gpio,delay-us = <5>;
3862306a36Sopenharmony_ci	};
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci	reg_vcc1v8: regulator-vcc1v8 {
4162306a36Sopenharmony_ci		compatible = "regulator-fixed";
4262306a36Sopenharmony_ci		regulator-name = "vcc1v8";
4362306a36Sopenharmony_ci		regulator-min-microvolt = <1800000>;
4462306a36Sopenharmony_ci		regulator-max-microvolt = <1800000>;
4562306a36Sopenharmony_ci	};
4662306a36Sopenharmony_ci
4762306a36Sopenharmony_ci	reg_vcc3v3: regulator-vcc3v3 {
4862306a36Sopenharmony_ci		compatible = "regulator-fixed";
4962306a36Sopenharmony_ci		regulator-name = "vcc3v3";
5062306a36Sopenharmony_ci		regulator-min-microvolt = <3300000>;
5162306a36Sopenharmony_ci		regulator-max-microvolt = <3300000>;
5262306a36Sopenharmony_ci	};
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci	reg_vdd_cpu_gpu: regulator-vdd-cpu-gpu {
5562306a36Sopenharmony_ci		compatible = "regulator-fixed";
5662306a36Sopenharmony_ci		regulator-name = "vdd-cpu-gpu";
5762306a36Sopenharmony_ci		regulator-min-microvolt = <1135000>;
5862306a36Sopenharmony_ci		regulator-max-microvolt = <1135000>;
5962306a36Sopenharmony_ci	};
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci	sound-spdif {
6262306a36Sopenharmony_ci		compatible = "simple-audio-card";
6362306a36Sopenharmony_ci		simple-audio-card,name = "sun50i-h6-spdif";
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci		simple-audio-card,cpu {
6662306a36Sopenharmony_ci			sound-dai = <&spdif>;
6762306a36Sopenharmony_ci		};
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci		simple-audio-card,codec {
7062306a36Sopenharmony_ci			sound-dai = <&spdif_out>;
7162306a36Sopenharmony_ci		};
7262306a36Sopenharmony_ci	};
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ci	spdif_out: spdif-out {
7562306a36Sopenharmony_ci		#sound-dai-cells = <0>;
7662306a36Sopenharmony_ci		compatible = "linux,spdif-dit";
7762306a36Sopenharmony_ci	};
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci	wifi_pwrseq: wifi-pwrseq {
8062306a36Sopenharmony_ci		compatible = "mmc-pwrseq-simple";
8162306a36Sopenharmony_ci		clocks = <&rtc CLK_OSC32K_FANOUT>;
8262306a36Sopenharmony_ci		clock-names = "ext_clock";
8362306a36Sopenharmony_ci		reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
8462306a36Sopenharmony_ci	};
8562306a36Sopenharmony_ci};
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci&cpu0 {
8862306a36Sopenharmony_ci	cpu-supply = <&reg_vdd_cpu_gpu>;
8962306a36Sopenharmony_ci};
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci&de {
9262306a36Sopenharmony_ci	status = "okay";
9362306a36Sopenharmony_ci};
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci&dwc3 {
9662306a36Sopenharmony_ci	status = "okay";
9762306a36Sopenharmony_ci};
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci&ehci0 {
10062306a36Sopenharmony_ci	status = "okay";
10162306a36Sopenharmony_ci};
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ci&ehci3 {
10462306a36Sopenharmony_ci	status = "okay";
10562306a36Sopenharmony_ci};
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci&gpu {
10862306a36Sopenharmony_ci	mali-supply = <&reg_vdd_cpu_gpu>;
10962306a36Sopenharmony_ci	status = "okay";
11062306a36Sopenharmony_ci};
11162306a36Sopenharmony_ci
11262306a36Sopenharmony_ci&hdmi {
11362306a36Sopenharmony_ci	status = "okay";
11462306a36Sopenharmony_ci};
11562306a36Sopenharmony_ci
11662306a36Sopenharmony_ci&hdmi_out {
11762306a36Sopenharmony_ci	hdmi_out_con: endpoint {
11862306a36Sopenharmony_ci		remote-endpoint = <&hdmi_con_in>;
11962306a36Sopenharmony_ci	};
12062306a36Sopenharmony_ci};
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_ci&mmc0 {
12362306a36Sopenharmony_ci	pinctrl-names = "default";
12462306a36Sopenharmony_ci	pinctrl-0 = <&mmc0_pins>;
12562306a36Sopenharmony_ci	vmmc-supply = <&reg_vcc3v3>;
12662306a36Sopenharmony_ci	cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>;
12762306a36Sopenharmony_ci	bus-width = <4>;
12862306a36Sopenharmony_ci	status = "okay";
12962306a36Sopenharmony_ci};
13062306a36Sopenharmony_ci
13162306a36Sopenharmony_ci&mmc1 {
13262306a36Sopenharmony_ci	vmmc-supply = <&reg_vcc3v3>;
13362306a36Sopenharmony_ci	vqmmc-supply = <&reg_vcc1v8>;
13462306a36Sopenharmony_ci	mmc-pwrseq = <&wifi_pwrseq>;
13562306a36Sopenharmony_ci	bus-width = <4>;
13662306a36Sopenharmony_ci	non-removable;
13762306a36Sopenharmony_ci	status = "okay";
13862306a36Sopenharmony_ci};
13962306a36Sopenharmony_ci
14062306a36Sopenharmony_ci&mmc2 {
14162306a36Sopenharmony_ci	vmmc-supply = <&reg_vcc3v3>;
14262306a36Sopenharmony_ci	vqmmc-supply = <&reg_vcc1v8>;
14362306a36Sopenharmony_ci	bus-width = <8>;
14462306a36Sopenharmony_ci	non-removable;
14562306a36Sopenharmony_ci	cap-mmc-hw-reset;
14662306a36Sopenharmony_ci	mmc-hs200-1_8v;
14762306a36Sopenharmony_ci	status = "okay";
14862306a36Sopenharmony_ci};
14962306a36Sopenharmony_ci
15062306a36Sopenharmony_ci&ohci0 {
15162306a36Sopenharmony_ci	status = "okay";
15262306a36Sopenharmony_ci};
15362306a36Sopenharmony_ci
15462306a36Sopenharmony_ci&ohci3 {
15562306a36Sopenharmony_ci	status = "okay";
15662306a36Sopenharmony_ci};
15762306a36Sopenharmony_ci
15862306a36Sopenharmony_ci&pio {
15962306a36Sopenharmony_ci	vcc-pc-supply = <&reg_vcc1v8>;
16062306a36Sopenharmony_ci	vcc-pd-supply = <&reg_vcc3v3>;
16162306a36Sopenharmony_ci	vcc-pg-supply = <&reg_vcc1v8>;
16262306a36Sopenharmony_ci};
16362306a36Sopenharmony_ci
16462306a36Sopenharmony_ci&r_ir {
16562306a36Sopenharmony_ci	status = "okay";
16662306a36Sopenharmony_ci};
16762306a36Sopenharmony_ci
16862306a36Sopenharmony_ci&spdif {
16962306a36Sopenharmony_ci	pinctrl-names = "default";
17062306a36Sopenharmony_ci	pinctrl-0 = <&spdif_tx_pin>;
17162306a36Sopenharmony_ci	status = "okay";
17262306a36Sopenharmony_ci};
17362306a36Sopenharmony_ci
17462306a36Sopenharmony_ci&uart0 {
17562306a36Sopenharmony_ci	pinctrl-names = "default";
17662306a36Sopenharmony_ci	pinctrl-0 = <&uart0_ph_pins>;
17762306a36Sopenharmony_ci	status = "okay";
17862306a36Sopenharmony_ci};
17962306a36Sopenharmony_ci
18062306a36Sopenharmony_ci&usb2otg {
18162306a36Sopenharmony_ci	dr_mode = "host";
18262306a36Sopenharmony_ci	status = "okay";
18362306a36Sopenharmony_ci};
18462306a36Sopenharmony_ci
18562306a36Sopenharmony_ci&usb2phy {
18662306a36Sopenharmony_ci	status = "okay";
18762306a36Sopenharmony_ci};
18862306a36Sopenharmony_ci
18962306a36Sopenharmony_ci&usb3phy {
19062306a36Sopenharmony_ci	status = "okay";
19162306a36Sopenharmony_ci};
192