18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Copyright (C) 2020 Krzysztof Kozlowski <krzk@kernel.org>
48c2ecf20Sopenharmony_ci */
58c2ecf20Sopenharmony_ci
68c2ecf20Sopenharmony_ci/dts-v1/;
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_ci#include "imx8mm-var-som.dtsi"
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_ci/ {
118c2ecf20Sopenharmony_ci	model = "Variscite VAR-SOM-MX8MM Symphony evaluation board";
128c2ecf20Sopenharmony_ci	compatible = "variscite,var-som-mx8mm-symphony", "variscite,var-som-mx8mm", "fsl,imx8mm";
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ci	reg_usdhc2_vmmc: regulator-usdhc2-vmmc {
158c2ecf20Sopenharmony_ci		compatible = "regulator-fixed";
168c2ecf20Sopenharmony_ci		pinctrl-names = "default";
178c2ecf20Sopenharmony_ci		pinctrl-0 = <&pinctrl_reg_usdhc2_vmmc>;
188c2ecf20Sopenharmony_ci		regulator-name = "VSD_3V3";
198c2ecf20Sopenharmony_ci		regulator-min-microvolt = <3300000>;
208c2ecf20Sopenharmony_ci		regulator-max-microvolt = <3300000>;
218c2ecf20Sopenharmony_ci		gpio = <&gpio2 19 GPIO_ACTIVE_HIGH>;
228c2ecf20Sopenharmony_ci		enable-active-high;
238c2ecf20Sopenharmony_ci	};
248c2ecf20Sopenharmony_ci
258c2ecf20Sopenharmony_ci	reg_usb_otg2_vbus: regulator-usb-otg2-vbus {
268c2ecf20Sopenharmony_ci		compatible = "regulator-fixed";
278c2ecf20Sopenharmony_ci		pinctrl-names = "default";
288c2ecf20Sopenharmony_ci		pinctrl-0 = <&pinctrl_reg_usb_otg2_vbus>;
298c2ecf20Sopenharmony_ci		regulator-name = "usb_otg2_vbus";
308c2ecf20Sopenharmony_ci		regulator-min-microvolt = <5000000>;
318c2ecf20Sopenharmony_ci		regulator-max-microvolt = <5000000>;
328c2ecf20Sopenharmony_ci		gpio = <&gpio5 1 GPIO_ACTIVE_HIGH>;
338c2ecf20Sopenharmony_ci		enable-active-high;
348c2ecf20Sopenharmony_ci	};
358c2ecf20Sopenharmony_ci
368c2ecf20Sopenharmony_ci	gpio-keys {
378c2ecf20Sopenharmony_ci		compatible = "gpio-keys";
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_ci		back {
408c2ecf20Sopenharmony_ci			label = "Back";
418c2ecf20Sopenharmony_ci			gpios = <&pca9534 1 GPIO_ACTIVE_LOW>;
428c2ecf20Sopenharmony_ci			linux,code = <KEY_BACK>;
438c2ecf20Sopenharmony_ci		};
448c2ecf20Sopenharmony_ci
458c2ecf20Sopenharmony_ci		home {
468c2ecf20Sopenharmony_ci			label = "Home";
478c2ecf20Sopenharmony_ci			gpios = <&pca9534 2 GPIO_ACTIVE_LOW>;
488c2ecf20Sopenharmony_ci			linux,code = <KEY_HOME>;
498c2ecf20Sopenharmony_ci		};
508c2ecf20Sopenharmony_ci
518c2ecf20Sopenharmony_ci		menu {
528c2ecf20Sopenharmony_ci			label = "Menu";
538c2ecf20Sopenharmony_ci			gpios = <&pca9534 3 GPIO_ACTIVE_LOW>;
548c2ecf20Sopenharmony_ci			linux,code = <KEY_MENU>;
558c2ecf20Sopenharmony_ci		};
568c2ecf20Sopenharmony_ci	};
578c2ecf20Sopenharmony_ci
588c2ecf20Sopenharmony_ci	leds {
598c2ecf20Sopenharmony_ci		compatible = "gpio-leds";
608c2ecf20Sopenharmony_ci
618c2ecf20Sopenharmony_ci		led {
628c2ecf20Sopenharmony_ci			label = "Heartbeat";
638c2ecf20Sopenharmony_ci			gpios = <&pca9534 0 GPIO_ACTIVE_LOW>;
648c2ecf20Sopenharmony_ci			linux,default-trigger = "heartbeat";
658c2ecf20Sopenharmony_ci		};
668c2ecf20Sopenharmony_ci	};
678c2ecf20Sopenharmony_ci};
688c2ecf20Sopenharmony_ci
698c2ecf20Sopenharmony_ci&ethphy {
708c2ecf20Sopenharmony_ci	reset-gpios = <&pca9534 5 GPIO_ACTIVE_HIGH>;
718c2ecf20Sopenharmony_ci};
728c2ecf20Sopenharmony_ci
738c2ecf20Sopenharmony_ci&i2c2 {
748c2ecf20Sopenharmony_ci	clock-frequency = <400000>;
758c2ecf20Sopenharmony_ci	pinctrl-names = "default";
768c2ecf20Sopenharmony_ci	pinctrl-0 = <&pinctrl_i2c2>;
778c2ecf20Sopenharmony_ci	status = "okay";
788c2ecf20Sopenharmony_ci
798c2ecf20Sopenharmony_ci	pca9534: gpio@20 {
808c2ecf20Sopenharmony_ci		compatible = "nxp,pca9534";
818c2ecf20Sopenharmony_ci		reg = <0x20>;
828c2ecf20Sopenharmony_ci		gpio-controller;
838c2ecf20Sopenharmony_ci		pinctrl-names = "default";
848c2ecf20Sopenharmony_ci		pinctrl-0 = <&pinctrl_pca9534>;
858c2ecf20Sopenharmony_ci		interrupt-parent = <&gpio1>;
868c2ecf20Sopenharmony_ci		interrupts = <7 IRQ_TYPE_EDGE_FALLING>;
878c2ecf20Sopenharmony_ci		#gpio-cells = <2>;
888c2ecf20Sopenharmony_ci		wakeup-source;
898c2ecf20Sopenharmony_ci
908c2ecf20Sopenharmony_ci		/* USB 3.0 OTG (usbotg1) / SATA port switch, set to USB 3.0 */
918c2ecf20Sopenharmony_ci		usb3-sata-sel-hog {
928c2ecf20Sopenharmony_ci			gpio-hog;
938c2ecf20Sopenharmony_ci			gpios = <4 GPIO_ACTIVE_HIGH>;
948c2ecf20Sopenharmony_ci			output-low;
958c2ecf20Sopenharmony_ci			line-name = "usb3_sata_sel";
968c2ecf20Sopenharmony_ci		};
978c2ecf20Sopenharmony_ci
988c2ecf20Sopenharmony_ci		som-vselect-hog {
998c2ecf20Sopenharmony_ci			gpio-hog;
1008c2ecf20Sopenharmony_ci			gpios = <6 GPIO_ACTIVE_HIGH>;
1018c2ecf20Sopenharmony_ci			output-low;
1028c2ecf20Sopenharmony_ci			line-name = "som_vselect";
1038c2ecf20Sopenharmony_ci		};
1048c2ecf20Sopenharmony_ci
1058c2ecf20Sopenharmony_ci		enet-sel-hog {
1068c2ecf20Sopenharmony_ci			gpio-hog;
1078c2ecf20Sopenharmony_ci			gpios = <7 GPIO_ACTIVE_HIGH>;
1088c2ecf20Sopenharmony_ci			output-low;
1098c2ecf20Sopenharmony_ci			line-name = "enet_sel";
1108c2ecf20Sopenharmony_ci		};
1118c2ecf20Sopenharmony_ci	};
1128c2ecf20Sopenharmony_ci
1138c2ecf20Sopenharmony_ci	extcon_usbotg1: typec@3d {
1148c2ecf20Sopenharmony_ci		compatible = "nxp,ptn5150";
1158c2ecf20Sopenharmony_ci		reg = <0x3d>;
1168c2ecf20Sopenharmony_ci		interrupt-parent = <&gpio1>;
1178c2ecf20Sopenharmony_ci		interrupts = <11 IRQ_TYPE_LEVEL_LOW>;
1188c2ecf20Sopenharmony_ci		pinctrl-names = "default";
1198c2ecf20Sopenharmony_ci		pinctrl-0 = <&pinctrl_ptn5150>;
1208c2ecf20Sopenharmony_ci		status = "okay";
1218c2ecf20Sopenharmony_ci	};
1228c2ecf20Sopenharmony_ci};
1238c2ecf20Sopenharmony_ci
1248c2ecf20Sopenharmony_ci&i2c3 {
1258c2ecf20Sopenharmony_ci	/* Capacitive touch controller */
1268c2ecf20Sopenharmony_ci	ft5x06_ts: touchscreen@38 {
1278c2ecf20Sopenharmony_ci		compatible = "edt,edt-ft5406";
1288c2ecf20Sopenharmony_ci		reg = <0x38>;
1298c2ecf20Sopenharmony_ci		pinctrl-names = "default";
1308c2ecf20Sopenharmony_ci		pinctrl-0 = <&pinctrl_captouch>;
1318c2ecf20Sopenharmony_ci		interrupt-parent = <&gpio5>;
1328c2ecf20Sopenharmony_ci		interrupts = <4 IRQ_TYPE_LEVEL_HIGH>;
1338c2ecf20Sopenharmony_ci
1348c2ecf20Sopenharmony_ci		touchscreen-size-x = <800>;
1358c2ecf20Sopenharmony_ci		touchscreen-size-y = <480>;
1368c2ecf20Sopenharmony_ci		touchscreen-inverted-x;
1378c2ecf20Sopenharmony_ci		touchscreen-inverted-y;
1388c2ecf20Sopenharmony_ci	};
1398c2ecf20Sopenharmony_ci
1408c2ecf20Sopenharmony_ci	rtc@68 {
1418c2ecf20Sopenharmony_ci		compatible = "dallas,ds1337";
1428c2ecf20Sopenharmony_ci		reg = <0x68>;
1438c2ecf20Sopenharmony_ci	};
1448c2ecf20Sopenharmony_ci};
1458c2ecf20Sopenharmony_ci
1468c2ecf20Sopenharmony_ci/* Header */
1478c2ecf20Sopenharmony_ci&uart1 {
1488c2ecf20Sopenharmony_ci	pinctrl-names = "default";
1498c2ecf20Sopenharmony_ci	pinctrl-0 = <&pinctrl_uart1>;
1508c2ecf20Sopenharmony_ci	status = "okay";
1518c2ecf20Sopenharmony_ci};
1528c2ecf20Sopenharmony_ci
1538c2ecf20Sopenharmony_ci/* Header */
1548c2ecf20Sopenharmony_ci&uart3 {
1558c2ecf20Sopenharmony_ci	pinctrl-names = "default";
1568c2ecf20Sopenharmony_ci	pinctrl-0 = <&pinctrl_uart3>;
1578c2ecf20Sopenharmony_ci	status = "okay";
1588c2ecf20Sopenharmony_ci};
1598c2ecf20Sopenharmony_ci
1608c2ecf20Sopenharmony_ci&usbotg1 {
1618c2ecf20Sopenharmony_ci	disable-over-current;
1628c2ecf20Sopenharmony_ci	extcon = <&extcon_usbotg1>, <&extcon_usbotg1>;
1638c2ecf20Sopenharmony_ci};
1648c2ecf20Sopenharmony_ci
1658c2ecf20Sopenharmony_ci&usbotg2 {
1668c2ecf20Sopenharmony_ci	dr_mode = "host";
1678c2ecf20Sopenharmony_ci	vbus-supply = <&reg_usb_otg2_vbus>;
1688c2ecf20Sopenharmony_ci	srp-disable;
1698c2ecf20Sopenharmony_ci	hnp-disable;
1708c2ecf20Sopenharmony_ci	adp-disable;
1718c2ecf20Sopenharmony_ci	disable-over-current;
1728c2ecf20Sopenharmony_ci	/delete-property/ usb-role-switch;
1738c2ecf20Sopenharmony_ci	/*
1748c2ecf20Sopenharmony_ci	 * FIXME: having USB2 enabled hangs the boot just after:
1758c2ecf20Sopenharmony_ci	 * [    1.943365] ci_hdrc ci_hdrc.1: EHCI Host Controller
1768c2ecf20Sopenharmony_ci	 * [    1.948287] ci_hdrc ci_hdrc.1: new USB bus registered, assigned bus number 1
1778c2ecf20Sopenharmony_ci	 * [    1.971006] ci_hdrc ci_hdrc.1: USB 2.0 started, EHCI 1.00
1788c2ecf20Sopenharmony_ci	 * [    1.977203] hub 1-0:1.0: USB hub found
1798c2ecf20Sopenharmony_ci	 * [    1.980987] hub 1-0:1.0: 1 port detected
1808c2ecf20Sopenharmony_ci	 */
1818c2ecf20Sopenharmony_ci	status = "disabled";
1828c2ecf20Sopenharmony_ci};
1838c2ecf20Sopenharmony_ci
1848c2ecf20Sopenharmony_ci&pinctrl_fec1 {
1858c2ecf20Sopenharmony_ci	fsl,pins = <
1868c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_MDC_ENET1_MDC			0x3
1878c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_MDIO_ENET1_MDIO		0x3
1888c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TD3_ENET1_RGMII_TD3		0x1f
1898c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TD2_ENET1_RGMII_TD2		0x1f
1908c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TD1_ENET1_RGMII_TD1		0x1f
1918c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TD0_ENET1_RGMII_TD0		0x1f
1928c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RD3_ENET1_RGMII_RD3		0x91
1938c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RD2_ENET1_RGMII_RD2		0x91
1948c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RD1_ENET1_RGMII_RD1		0x91
1958c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RD0_ENET1_RGMII_RD0		0x91
1968c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TXC_ENET1_RGMII_TXC		0x1f
1978c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RXC_ENET1_RGMII_RXC		0x91
1988c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_RX_CTL_ENET1_RGMII_RX_CTL	0x91
1998c2ecf20Sopenharmony_ci		MX8MM_IOMUXC_ENET_TX_CTL_ENET1_RGMII_TX_CTL	0x1f
2008c2ecf20Sopenharmony_ci		/* Remove the MX8MM_IOMUXC_GPIO1_IO09_GPIO1_IO9 as not used */
2018c2ecf20Sopenharmony_ci	>;
2028c2ecf20Sopenharmony_ci};
2038c2ecf20Sopenharmony_ci
2048c2ecf20Sopenharmony_ci&iomuxc {
2058c2ecf20Sopenharmony_ci	pinctrl_captouch: captouchgrp {
2068c2ecf20Sopenharmony_ci		fsl,pins = <
2078c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_SPDIF_RX_GPIO5_IO4		0x16
2088c2ecf20Sopenharmony_ci		>;
2098c2ecf20Sopenharmony_ci	};
2108c2ecf20Sopenharmony_ci
2118c2ecf20Sopenharmony_ci	pinctrl_i2c2: i2c2grp {
2128c2ecf20Sopenharmony_ci		fsl,pins = <
2138c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_I2C2_SCL_I2C2_SCL		0x400001c3
2148c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_I2C2_SDA_I2C2_SDA		0x400001c3
2158c2ecf20Sopenharmony_ci		>;
2168c2ecf20Sopenharmony_ci	};
2178c2ecf20Sopenharmony_ci
2188c2ecf20Sopenharmony_ci	pinctrl_pca9534: pca9534grp {
2198c2ecf20Sopenharmony_ci		fsl,pins = <
2208c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_GPIO1_IO07_GPIO1_IO7	0x16
2218c2ecf20Sopenharmony_ci		>;
2228c2ecf20Sopenharmony_ci	};
2238c2ecf20Sopenharmony_ci
2248c2ecf20Sopenharmony_ci	pinctrl_ptn5150: ptn5150grp {
2258c2ecf20Sopenharmony_ci		fsl,pins = <
2268c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_GPIO1_IO11_GPIO1_IO11	0x16
2278c2ecf20Sopenharmony_ci		>;
2288c2ecf20Sopenharmony_ci	};
2298c2ecf20Sopenharmony_ci
2308c2ecf20Sopenharmony_ci	pinctrl_reg_usb_otg2_vbus: regusbotg2vbusgrp {
2318c2ecf20Sopenharmony_ci		fsl,pins = <
2328c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_SAI3_TXD_GPIO5_IO1		0x16
2338c2ecf20Sopenharmony_ci		>;
2348c2ecf20Sopenharmony_ci	};
2358c2ecf20Sopenharmony_ci
2368c2ecf20Sopenharmony_ci	pinctrl_reg_usdhc2_vmmc: regusdhc2vmmcgrp {
2378c2ecf20Sopenharmony_ci		fsl,pins = <
2388c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_SD2_RESET_B_GPIO2_IO19	0x41
2398c2ecf20Sopenharmony_ci		>;
2408c2ecf20Sopenharmony_ci	};
2418c2ecf20Sopenharmony_ci
2428c2ecf20Sopenharmony_ci	pinctrl_uart1: uart1grp {
2438c2ecf20Sopenharmony_ci		fsl,pins = <
2448c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_UART1_RXD_UART1_DCE_RX	0x140
2458c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_UART1_TXD_UART1_DCE_TX	0x140
2468c2ecf20Sopenharmony_ci		>;
2478c2ecf20Sopenharmony_ci	};
2488c2ecf20Sopenharmony_ci
2498c2ecf20Sopenharmony_ci	pinctrl_uart3: uart3grp {
2508c2ecf20Sopenharmony_ci		fsl,pins = <
2518c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_UART3_RXD_UART3_DCE_RX	0x140
2528c2ecf20Sopenharmony_ci			MX8MM_IOMUXC_UART3_TXD_UART3_DCE_TX	0x140
2538c2ecf20Sopenharmony_ci		>;
2548c2ecf20Sopenharmony_ci	};
2558c2ecf20Sopenharmony_ci};
256