xref: /openbmc/linux/arch/arm64/boot/dts/rockchip/rk3368-orion-r68-meta.dts (revision 7ae9fb1b7ecbb5d85d07857943f677fd1a559b18)
14ee99cebSKlaus Goger// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
26dcf4eabSMatthias Brugger/*
36dcf4eabSMatthias Brugger * Copyright (c) 2016 Matthias Brugger <mbrugger@suse.com>
46dcf4eabSMatthias Brugger */
56dcf4eabSMatthias Brugger
66dcf4eabSMatthias Brugger/dts-v1/;
76dcf4eabSMatthias Brugger#include <dt-bindings/input/input.h>
86dcf4eabSMatthias Brugger#include "rk3368.dtsi"
96dcf4eabSMatthias Brugger
106dcf4eabSMatthias Brugger/ {
116dcf4eabSMatthias Brugger	model = "Rockchip Orion R68";
126dcf4eabSMatthias Brugger	compatible = "tronsmart,orion-r68-meta", "rockchip,rk3368";
136dcf4eabSMatthias Brugger
14751a78a8SHeiko Stuebner	aliases {
15751a78a8SHeiko Stuebner		mmc0 = &sdmmc;
16751a78a8SHeiko Stuebner		mmc1 = &emmc;
17751a78a8SHeiko Stuebner	};
18751a78a8SHeiko Stuebner
196dcf4eabSMatthias Brugger	chosen {
206dcf4eabSMatthias Brugger		stdout-path = "serial2:115200n8";
216dcf4eabSMatthias Brugger	};
226dcf4eabSMatthias Brugger
236dcf4eabSMatthias Brugger	memory {
246dcf4eabSMatthias Brugger		device_type = "memory";
256dcf4eabSMatthias Brugger		reg = <0x0 0x0 0x0 0x80000000>;
266dcf4eabSMatthias Brugger	};
276dcf4eabSMatthias Brugger
286dcf4eabSMatthias Brugger	emmc_pwrseq: emmc-pwrseq {
296dcf4eabSMatthias Brugger		compatible = "mmc-pwrseq-emmc";
306dcf4eabSMatthias Brugger		pinctrl-0 = <&emmc_reset>;
316dcf4eabSMatthias Brugger		pinctrl-names = "default";
324eb45558SAndy Yan		reset-gpios = <&gpio2 RK_PA3 GPIO_ACTIVE_HIGH>;
336dcf4eabSMatthias Brugger	};
346dcf4eabSMatthias Brugger
356dcf4eabSMatthias Brugger	ext_gmac: external-gmac-clock {
366dcf4eabSMatthias Brugger		compatible = "fixed-clock";
376dcf4eabSMatthias Brugger		#clock-cells = <0>;
386dcf4eabSMatthias Brugger		clock-frequency = <125000000>;
396dcf4eabSMatthias Brugger		clock-output-names = "ext_gmac";
406dcf4eabSMatthias Brugger	};
416dcf4eabSMatthias Brugger
426dcf4eabSMatthias Brugger	keys: gpio-keys {
436dcf4eabSMatthias Brugger		compatible = "gpio-keys";
446dcf4eabSMatthias Brugger		pinctrl-names = "default";
456dcf4eabSMatthias Brugger		pinctrl-0 = <&pwr_key>;
466dcf4eabSMatthias Brugger
47517ed0ffSKrzysztof Kozlowski		key-power {
486dcf4eabSMatthias Brugger			wakeup-source;
494eb45558SAndy Yan			gpios = <&gpio0 RK_PA5 GPIO_ACTIVE_HIGH>;
506dcf4eabSMatthias Brugger			label = "GPIO Power";
516dcf4eabSMatthias Brugger			linux,code = <KEY_POWER>;
526dcf4eabSMatthias Brugger		};
536dcf4eabSMatthias Brugger	};
546dcf4eabSMatthias Brugger
556dcf4eabSMatthias Brugger	leds: gpio-leds {
566dcf4eabSMatthias Brugger		compatible = "gpio-leds";
576dcf4eabSMatthias Brugger
58e916d85bSJohan Jonker		red_led: led-0 {
594eb45558SAndy Yan			gpios = <&gpio3 RK_PD5 GPIO_ACTIVE_HIGH>;
606dcf4eabSMatthias Brugger			label = "orion:red:led";
616dcf4eabSMatthias Brugger			pinctrl-names = "default";
626dcf4eabSMatthias Brugger			pinctrl-0 = <&led_ctl>;
636dcf4eabSMatthias Brugger			default-state = "on";
646dcf4eabSMatthias Brugger		};
656dcf4eabSMatthias Brugger
66e916d85bSJohan Jonker		blue_led: led-1 {
674eb45558SAndy Yan			gpios = <&gpio0 RK_PB4 GPIO_ACTIVE_HIGH>;
686dcf4eabSMatthias Brugger			label = "orion:blue:led";
696dcf4eabSMatthias Brugger			pinctrl-names = "default";
706dcf4eabSMatthias Brugger			pinctrl-0 = <&stby_pwren>;
716dcf4eabSMatthias Brugger			default-state = "off";
726dcf4eabSMatthias Brugger		};
736dcf4eabSMatthias Brugger	};
746dcf4eabSMatthias Brugger
756dcf4eabSMatthias Brugger	vcc_18: vcc18-regulator {
766dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
776dcf4eabSMatthias Brugger		regulator-name = "vcc_18";
786dcf4eabSMatthias Brugger		regulator-min-microvolt = <1800000>;
796dcf4eabSMatthias Brugger		regulator-max-microvolt = <1800000>;
806dcf4eabSMatthias Brugger		regulator-always-on;
816dcf4eabSMatthias Brugger		regulator-boot-on;
826dcf4eabSMatthias Brugger		vin-supply = <&vcc_sys>;
836dcf4eabSMatthias Brugger	};
846dcf4eabSMatthias Brugger
856dcf4eabSMatthias Brugger	/* supplies both host and otg */
866dcf4eabSMatthias Brugger	vcc_host: vcc-host-regulator {
876dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
884eb45558SAndy Yan		gpio = <&gpio0 RK_PA4 GPIO_ACTIVE_LOW>;
896dcf4eabSMatthias Brugger		pinctrl-names = "default";
906dcf4eabSMatthias Brugger		pinctrl-0 = <&host_vbus_drv>;
916dcf4eabSMatthias Brugger		regulator-name = "vcc_host";
926dcf4eabSMatthias Brugger		regulator-always-on;
936dcf4eabSMatthias Brugger		regulator-boot-on;
946dcf4eabSMatthias Brugger		vin-supply = <&vcc_sys>;
956dcf4eabSMatthias Brugger	};
966dcf4eabSMatthias Brugger
976dcf4eabSMatthias Brugger	vcc_io: vcc-io-regulator {
986dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
996dcf4eabSMatthias Brugger		regulator-name = "vcc_io";
1006dcf4eabSMatthias Brugger		regulator-min-microvolt = <3300000>;
1016dcf4eabSMatthias Brugger		regulator-max-microvolt = <3300000>;
1026dcf4eabSMatthias Brugger		regulator-always-on;
1036dcf4eabSMatthias Brugger		regulator-boot-on;
1046dcf4eabSMatthias Brugger		vin-supply = <&vcc_sys>;
1056dcf4eabSMatthias Brugger	};
1066dcf4eabSMatthias Brugger
1076dcf4eabSMatthias Brugger	vcc_lan: vcc-lan-regulator {
1086dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1096dcf4eabSMatthias Brugger		regulator-name = "vcc_lan";
1106dcf4eabSMatthias Brugger		regulator-min-microvolt = <3300000>;
1116dcf4eabSMatthias Brugger		regulator-max-microvolt = <3300000>;
1126dcf4eabSMatthias Brugger		regulator-always-on;
1136dcf4eabSMatthias Brugger		regulator-boot-on;
1146dcf4eabSMatthias Brugger		vin-supply = <&vcc_io>;
1156dcf4eabSMatthias Brugger	};
1166dcf4eabSMatthias Brugger
1176dcf4eabSMatthias Brugger	vcc_sd: vcc-sd-regulator {
1186dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1196dcf4eabSMatthias Brugger		regulator-name = "vcc_sd";
1204eb45558SAndy Yan		gpio = <&gpio3 RK_PB3 GPIO_ACTIVE_LOW>;
1216dcf4eabSMatthias Brugger		regulator-min-microvolt = <1800000>;
1226dcf4eabSMatthias Brugger		regulator-max-microvolt = <3300000>;
1236dcf4eabSMatthias Brugger		vin-supply = <&vcc_io>;
1246dcf4eabSMatthias Brugger	};
1256dcf4eabSMatthias Brugger
1266dcf4eabSMatthias Brugger	vcc_sys: vcc-sys-regulator {
1276dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1286dcf4eabSMatthias Brugger		regulator-name = "vcc_sys";
1296dcf4eabSMatthias Brugger		regulator-min-microvolt = <5000000>;
1306dcf4eabSMatthias Brugger		regulator-max-microvolt = <5000000>;
1316dcf4eabSMatthias Brugger		regulator-always-on;
1326dcf4eabSMatthias Brugger		regulator-boot-on;
1336dcf4eabSMatthias Brugger	};
1346dcf4eabSMatthias Brugger
1356dcf4eabSMatthias Brugger	vccio_sd: vcc-io-sd-regulator {
1366dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1376dcf4eabSMatthias Brugger		regulator-name = "vccio_sd";
1386dcf4eabSMatthias Brugger		regulator-min-microvolt = <1800000>;
1396dcf4eabSMatthias Brugger		regulator-max-microvolt = <3300000>;
1406dcf4eabSMatthias Brugger		regulator-always-on;
1416dcf4eabSMatthias Brugger		regulator-boot-on;
1426dcf4eabSMatthias Brugger		vin-supply = <&vcc_io>;
1436dcf4eabSMatthias Brugger	};
1446dcf4eabSMatthias Brugger
1456dcf4eabSMatthias Brugger	vccio_wl: vccio-wl-regulator {
1466dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1476dcf4eabSMatthias Brugger		regulator-name = "vccio_wl";
1486dcf4eabSMatthias Brugger		regulator-min-microvolt = <3300000>;
1496dcf4eabSMatthias Brugger		regulator-max-microvolt = <3300000>;
1506dcf4eabSMatthias Brugger		regulator-always-on;
1516dcf4eabSMatthias Brugger		regulator-boot-on;
1526dcf4eabSMatthias Brugger		vin-supply = <&vcc_io>;
1536dcf4eabSMatthias Brugger	};
1546dcf4eabSMatthias Brugger
1556dcf4eabSMatthias Brugger	vdd_10: vdd-10-regulator {
1566dcf4eabSMatthias Brugger		compatible = "regulator-fixed";
1576dcf4eabSMatthias Brugger		regulator-name = "vdd_10";
1586dcf4eabSMatthias Brugger		regulator-min-microvolt = <1000000>;
1596dcf4eabSMatthias Brugger		regulator-max-microvolt = <1000000>;
1606dcf4eabSMatthias Brugger		regulator-always-on;
1616dcf4eabSMatthias Brugger		regulator-boot-on;
1626dcf4eabSMatthias Brugger		vin-supply = <&vcc_sys>;
1636dcf4eabSMatthias Brugger	};
1646dcf4eabSMatthias Brugger};
1656dcf4eabSMatthias Brugger
1666dcf4eabSMatthias Brugger&emmc {
1676dcf4eabSMatthias Brugger	bus-width = <8>;
1686dcf4eabSMatthias Brugger	cap-mmc-highspeed;
1696dcf4eabSMatthias Brugger	mmc-pwrseq = <&emmc_pwrseq>;
1706dcf4eabSMatthias Brugger	mmc-hs200-1_2v;
1716dcf4eabSMatthias Brugger	mmc-hs200-1_8v;
1726dcf4eabSMatthias Brugger	non-removable;
1736dcf4eabSMatthias Brugger	pinctrl-names = "default";
1746dcf4eabSMatthias Brugger	pinctrl-0 = <&emmc_clk &emmc_cmd &emmc_bus8>;
1756dcf4eabSMatthias Brugger	status = "okay";
1766dcf4eabSMatthias Brugger};
1776dcf4eabSMatthias Brugger
1786dcf4eabSMatthias Brugger&gmac {
1796dcf4eabSMatthias Brugger	assigned-clocks = <&cru SCLK_MAC>;
1806dcf4eabSMatthias Brugger	assigned-clock-parents = <&ext_gmac>;
1816dcf4eabSMatthias Brugger	clock_in_out = "input";
1826dcf4eabSMatthias Brugger	phy-supply = <&vcc_lan>;
1836dcf4eabSMatthias Brugger	phy-mode = "rgmii";
1846dcf4eabSMatthias Brugger	pinctrl-names = "default";
1856dcf4eabSMatthias Brugger	pinctrl-0 = <&rgmii_pins>;
1864eb45558SAndy Yan	snps,reset-gpio = <&gpio3 RK_PB4 GPIO_ACTIVE_HIGH>;
1876dcf4eabSMatthias Brugger	snps,reset-active-low;
1886dcf4eabSMatthias Brugger	snps,reset-delays-us = <0 10000 1000000>;
1896dcf4eabSMatthias Brugger	tx_delay = <0x30>;
1906dcf4eabSMatthias Brugger	rx_delay = <0x10>;
1919caff35dSAdrian Schmutzler	status = "okay";
1926dcf4eabSMatthias Brugger};
1936dcf4eabSMatthias Brugger
1946dcf4eabSMatthias Brugger&i2c0 {
1956dcf4eabSMatthias Brugger	status = "okay";
1966dcf4eabSMatthias Brugger
1976dcf4eabSMatthias Brugger	vdd_cpu: syr827@40 {
1986dcf4eabSMatthias Brugger		compatible = "silergy,syr827";
1996dcf4eabSMatthias Brugger		reg = <0x40>;
2006dcf4eabSMatthias Brugger		fcs,suspend-voltage-selector = <1>;
2016dcf4eabSMatthias Brugger		regulator-name = "vdd_cpu";
2026dcf4eabSMatthias Brugger		regulator-enable-ramp-delay = <300>;
2036dcf4eabSMatthias Brugger		regulator-min-microvolt = <712500>;
2046dcf4eabSMatthias Brugger		regulator-max-microvolt = <1500000>;
2056dcf4eabSMatthias Brugger		regulator-ramp-delay = <8000>;
2066dcf4eabSMatthias Brugger		regulator-always-on;
2076dcf4eabSMatthias Brugger		regulator-boot-on;
2086dcf4eabSMatthias Brugger		vin-supply = <&vcc_sys>;
2096dcf4eabSMatthias Brugger	};
2106dcf4eabSMatthias Brugger
211*67a9aeefSSebastian Reichel	hym8563: rtc@51 {
2126dcf4eabSMatthias Brugger		compatible = "haoyu,hym8563";
2136dcf4eabSMatthias Brugger		reg = <0x51>;
2146dcf4eabSMatthias Brugger		#clock-cells = <0>;
2156dcf4eabSMatthias Brugger		clock-output-names = "xin32k";
2166dcf4eabSMatthias Brugger		/* rtc_int is not connected */
2176dcf4eabSMatthias Brugger	};
2186dcf4eabSMatthias Brugger};
2196dcf4eabSMatthias Brugger
2206dcf4eabSMatthias Brugger&pinctrl {
2216dcf4eabSMatthias Brugger	pcfg_pull_none_drv_8ma: pcfg-pull-none-drv-8ma {
2226dcf4eabSMatthias Brugger		bias-disable;
2236dcf4eabSMatthias Brugger		drive-strength = <8>;
2246dcf4eabSMatthias Brugger	};
2256dcf4eabSMatthias Brugger
2266dcf4eabSMatthias Brugger	pcfg_pull_up_drv_8ma: pcfg-pull-up-drv-8ma {
2276dcf4eabSMatthias Brugger		bias-pull-up;
2286dcf4eabSMatthias Brugger		drive-strength = <8>;
2296dcf4eabSMatthias Brugger	};
2306dcf4eabSMatthias Brugger
2316dcf4eabSMatthias Brugger	emmc {
2326dcf4eabSMatthias Brugger		emmc_bus8: emmc-bus8 {
233d64420e8SHeiko Stuebner			rockchip,pins = <1 RK_PC2 2 &pcfg_pull_up_drv_8ma>,
234d64420e8SHeiko Stuebner					<1 RK_PC3 2 &pcfg_pull_up_drv_8ma>,
235d64420e8SHeiko Stuebner					<1 RK_PC4 2 &pcfg_pull_up_drv_8ma>,
236d64420e8SHeiko Stuebner					<1 RK_PC5 2 &pcfg_pull_up_drv_8ma>,
237d64420e8SHeiko Stuebner					<1 RK_PC6 2 &pcfg_pull_up_drv_8ma>,
238d64420e8SHeiko Stuebner					<1 RK_PC7 2 &pcfg_pull_up_drv_8ma>,
239d64420e8SHeiko Stuebner					<1 RK_PD0 2 &pcfg_pull_up_drv_8ma>,
240d64420e8SHeiko Stuebner					<1 RK_PD1 2 &pcfg_pull_up_drv_8ma>;
2416dcf4eabSMatthias Brugger		};
2426dcf4eabSMatthias Brugger
2436dcf4eabSMatthias Brugger		emmc-clk {
244d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PA4 2 &pcfg_pull_none_drv_8ma>;
2456dcf4eabSMatthias Brugger		};
2466dcf4eabSMatthias Brugger
2476dcf4eabSMatthias Brugger		emmc-cmd {
248d64420e8SHeiko Stuebner			rockchip,pins = <1 RK_PD2 2 &pcfg_pull_up_drv_8ma>;
2496dcf4eabSMatthias Brugger		};
2506dcf4eabSMatthias Brugger
2516dcf4eabSMatthias Brugger		emmc_reset: emmc-reset {
252d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>;
2536dcf4eabSMatthias Brugger		};
2546dcf4eabSMatthias Brugger	};
2556dcf4eabSMatthias Brugger
2566dcf4eabSMatthias Brugger	keys {
2576dcf4eabSMatthias Brugger		pwr_key: pwr-key {
258d64420e8SHeiko Stuebner			rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_down>;
2596dcf4eabSMatthias Brugger		};
2606dcf4eabSMatthias Brugger	};
2616dcf4eabSMatthias Brugger
2626dcf4eabSMatthias Brugger	leds {
2636dcf4eabSMatthias Brugger		stby_pwren: stby-pwren {
264d64420e8SHeiko Stuebner			rockchip,pins = <0 RK_PB4 RK_FUNC_GPIO &pcfg_pull_none>;
2656dcf4eabSMatthias Brugger		};
2666dcf4eabSMatthias Brugger
2676dcf4eabSMatthias Brugger		led_ctl: led-ctl {
268d64420e8SHeiko Stuebner			rockchip,pins = <3 RK_PD5 RK_FUNC_GPIO &pcfg_pull_none>;
2696dcf4eabSMatthias Brugger		};
2706dcf4eabSMatthias Brugger	};
2716dcf4eabSMatthias Brugger
2726dcf4eabSMatthias Brugger	sdmmc {
2736dcf4eabSMatthias Brugger		sdmmc_clk: sdmmc-clk {
274d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PB1 1 &pcfg_pull_none_drv_8ma>;
2756dcf4eabSMatthias Brugger		};
2766dcf4eabSMatthias Brugger
2776dcf4eabSMatthias Brugger		sdmmc_cmd: sdmmc-cmd {
278d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PB2 1 &pcfg_pull_up_drv_8ma>;
2796dcf4eabSMatthias Brugger		};
2806dcf4eabSMatthias Brugger
2816dcf4eabSMatthias Brugger		sdmmc_cd: sdmmc-cd {
282d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PB3 1 &pcfg_pull_up_drv_8ma>;
2836dcf4eabSMatthias Brugger		};
2846dcf4eabSMatthias Brugger
2856dcf4eabSMatthias Brugger		sdmmc_bus1: sdmmc-bus1 {
286d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PA5 1 &pcfg_pull_up_drv_8ma>;
2876dcf4eabSMatthias Brugger		};
2886dcf4eabSMatthias Brugger
2896dcf4eabSMatthias Brugger		sdmmc_bus4: sdmmc-bus4 {
290d64420e8SHeiko Stuebner			rockchip,pins = <2 RK_PA5 1 &pcfg_pull_up_drv_8ma>,
291d64420e8SHeiko Stuebner					<2 RK_PA6 1 &pcfg_pull_up_drv_8ma>,
292d64420e8SHeiko Stuebner					<2 RK_PA7 1 &pcfg_pull_up_drv_8ma>,
293d64420e8SHeiko Stuebner					<2 RK_PB0 1 &pcfg_pull_up_drv_8ma>;
2946dcf4eabSMatthias Brugger		};
2956dcf4eabSMatthias Brugger	};
2966dcf4eabSMatthias Brugger
2976dcf4eabSMatthias Brugger	usb {
2986dcf4eabSMatthias Brugger		host_vbus_drv: host-vbus-drv {
299d64420e8SHeiko Stuebner			rockchip,pins = <0 RK_PA4 RK_FUNC_GPIO &pcfg_pull_none>;
3006dcf4eabSMatthias Brugger		};
3016dcf4eabSMatthias Brugger	};
3026dcf4eabSMatthias Brugger};
3036dcf4eabSMatthias Brugger
3046dcf4eabSMatthias Brugger&saradc {
3056dcf4eabSMatthias Brugger	vref-supply = <&vcc_18>;
3066dcf4eabSMatthias Brugger	status = "okay";
3076dcf4eabSMatthias Brugger};
3086dcf4eabSMatthias Brugger
3096dcf4eabSMatthias Brugger&sdmmc {
3106dcf4eabSMatthias Brugger	bus-width = <4>;
3116dcf4eabSMatthias Brugger	clock-frequency = <50000000>;
312c4959069SJaehoon Chung	max-frequency = <50000000>;
3136dcf4eabSMatthias Brugger	cap-sd-highspeed;
3146dcf4eabSMatthias Brugger	card-detect-delay = <200>;
3156dcf4eabSMatthias Brugger	pinctrl-names = "default";
3166dcf4eabSMatthias Brugger	pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_cd &sdmmc_bus4>;
3176dcf4eabSMatthias Brugger	vmmc-supply = <&vcc_sd>;
3186dcf4eabSMatthias Brugger	vqmmc-supply = <&vccio_sd>;
3196dcf4eabSMatthias Brugger	status = "okay";
3206dcf4eabSMatthias Brugger};
3216dcf4eabSMatthias Brugger
3226dcf4eabSMatthias Brugger&uart2 {
3236dcf4eabSMatthias Brugger	status = "okay";
3246dcf4eabSMatthias Brugger};
3256dcf4eabSMatthias Brugger
3266dcf4eabSMatthias Brugger&uart4 {
3276dcf4eabSMatthias Brugger	pinctrl-names = "default";
3286dcf4eabSMatthias Brugger	pinctrl-0 = <&uart4_xfer>;
3296dcf4eabSMatthias Brugger	status = "okay";
3306dcf4eabSMatthias Brugger};
3316dcf4eabSMatthias Brugger
3326dcf4eabSMatthias Brugger&usb_host0_ehci {
3336dcf4eabSMatthias Brugger	status = "okay";
3346dcf4eabSMatthias Brugger};
3356dcf4eabSMatthias Brugger
3366dcf4eabSMatthias Brugger&usb_otg {
3376dcf4eabSMatthias Brugger	status = "okay";
3386dcf4eabSMatthias Brugger};
3396dcf4eabSMatthias Brugger
3406dcf4eabSMatthias Brugger&wdt {
3416dcf4eabSMatthias Brugger	status = "okay";
3426dcf4eabSMatthias Brugger};
343