16097Ssherman// SPDX-License-Identifier: GPL-2.0-or-later OR MIT 214575Sbpb/* 36097Ssherman * Copyright (c) 2014 Protonic Holland 46097Ssherman * Copyright (c) 2020 Oleksij Rempel <kernel@pengutronix.de>, Pengutronix 56097Ssherman */ 66097Ssherman 76097Ssherman/dts-v1/; 86097Ssherman#include <dt-bindings/gpio/gpio.h> 96097Ssherman#include <dt-bindings/leds/common.h> 106097Ssherman#include "imx6dl.dtsi" 116097Ssherman 126097Ssherman/ { 136097Ssherman model = "Plymovent BAS board"; 146097Ssherman compatible = "ply,plybas", "fsl,imx6dl"; 156097Ssherman 166097Ssherman chosen { 176097Ssherman stdout-path = &uart4; 186097Ssherman }; 196097Ssherman 206097Ssherman gpio_keys { 216097Ssherman compatible = "gpio-keys"; 226097Ssherman autorepeat; 236097Ssherman 246097Ssherman button-start { 256097Ssherman label = "START"; 266097Ssherman linux,code = <31>; 276097Ssherman gpios = <&gpio5 8 GPIO_ACTIVE_LOW>; 286097Ssherman }; 296097Ssherman 306097Ssherman button-clean { 316097Ssherman label = "CLEAN"; 326097Ssherman linux,code = <46>; 336097Ssherman gpios = <&gpio5 9 GPIO_ACTIVE_LOW>; 346097Ssherman }; 356097Ssherman }; 366097Ssherman 376097Ssherman leds { 386097Ssherman compatible = "gpio-leds"; 396097Ssherman pinctrl-names = "default"; 406097Ssherman pinctrl-0 = <&pinctrl_leds>; 416097Ssherman 426097Ssherman led-0 { 436097Ssherman label = "debug0"; 446097Ssherman gpios = <&gpio1 8 GPIO_ACTIVE_HIGH>; 456097Ssherman }; 466097Ssherman 476097Ssherman led-1 { 486097Ssherman label = "debug1"; 496097Ssherman gpios = <&gpio1 9 GPIO_ACTIVE_HIGH>; 506097Ssherman }; 516097Ssherman 526097Ssherman led-2 { 536097Ssherman label = "light_tower1"; 546097Ssherman gpios = <&gpio4 22 GPIO_ACTIVE_HIGH>; 556097Ssherman linux,default-trigger = "heartbeat"; 566097Ssherman }; 576097Ssherman 586097Ssherman led-3 { 596097Ssherman label = "light_tower2"; 606097Ssherman gpios = <&gpio4 23 GPIO_ACTIVE_HIGH>; 616097Ssherman }; 626097Ssherman 636097Ssherman led-4 { 646097Ssherman label = "light_tower3"; 656097Ssherman gpios = <&gpio4 24 GPIO_ACTIVE_HIGH>; 666097Ssherman }; 676097Ssherman 686210Skmo led-5 { 696097Ssherman label = "light_tower4"; 706097Ssherman gpios = <&gpio4 25 GPIO_ACTIVE_HIGH>; 716097Ssherman }; 726097Ssherman }; 736097Ssherman 746097Ssherman clk50m_phy: phy-clock { 756097Ssherman compatible = "fixed-clock"; 766097Ssherman #clock-cells = <0>; 776097Ssherman clock-frequency = <50000000>; 786097Ssherman clock-output-names = "enet_ref_pad"; 796097Ssherman }; 806097Ssherman 816097Ssherman reg_5v0: regulator-5v0 { 826097Ssherman compatible = "regulator-fixed"; 836097Ssherman regulator-name = "5v0"; 846097Ssherman regulator-min-microvolt = <5000000>; 856097Ssherman regulator-max-microvolt = <5000000>; 866097Ssherman }; 876097Ssherman}; 886097Ssherman 896097Ssherman&can1 { 906097Ssherman pinctrl-names = "default"; 916097Ssherman pinctrl-0 = <&pinctrl_can1>; 926097Ssherman xceiver-supply = <®_5v0>; 936097Ssherman status = "okay"; 946097Ssherman}; 956097Ssherman 966097Ssherman&can2 { 976097Ssherman pinctrl-names = "default"; 986097Ssherman pinctrl-0 = <&pinctrl_can2>; 996097Ssherman xceiver-supply = <®_5v0>; 1006097Ssherman status = "okay"; 1016097Ssherman}; 1026097Ssherman 1036097Ssherman&clks { 1046097Ssherman clocks = <&clk50m_phy>; 1056097Ssherman clock-names = "enet_ref_pad"; 1066097Ssherman assigned-clocks = <&clks IMX6QDL_CLK_ENET_REF_SEL>; 1076097Ssherman assigned-clock-parents = <&clk50m_phy>; 1086097Ssherman}; 1096097Ssherman 1106097Ssherman&ecspi1 { 1116097Ssherman cs-gpios = <&gpio3 19 GPIO_ACTIVE_LOW>; 1126097Ssherman pinctrl-names = "default"; 1136097Ssherman pinctrl-0 = <&pinctrl_ecspi1>; 1146097Ssherman status = "okay"; 1156097Ssherman 1166097Ssherman flash@0 { 1176097Ssherman compatible = "jedec,spi-nor"; 1186097Ssherman reg = <0>; 1196097Ssherman spi-max-frequency = <20000000>; 1206097Ssherman }; 1216097Ssherman}; 1226097Ssherman 1236097Ssherman&fec { 1246097Ssherman pinctrl-names = "default"; 1256097Ssherman pinctrl-0 = <&pinctrl_enet>; 1266097Ssherman phy-mode = "rmii"; 1276097Ssherman phy-handle = <&rgmii_phy>; 1286097Ssherman status = "okay"; 1296097Ssherman 1306097Ssherman mdio { 1316097Ssherman #address-cells = <1>; 1326097Ssherman #size-cells = <0>; 1336097Ssherman 1346097Ssherman /* Microchip KSZ8081RNA PHY */ 1356097Ssherman rgmii_phy: ethernet-phy@0 { 1366097Ssherman reg = <0>; 1376097Ssherman interrupts-extended = <&gpio4 30 IRQ_TYPE_LEVEL_LOW>; 1386097Ssherman reset-gpios = <&gpio4 26 GPIO_ACTIVE_LOW>; 1396097Ssherman reset-assert-us = <10000>; 1407117Srriggs reset-deassert-us = <300>; 1417117Srriggs }; 1426097Ssherman }; 1436097Ssherman}; 1446097Ssherman 1456097Ssherman&gpio1 { 1466097Ssherman gpio-line-names = 1476097Ssherman "", "SD1_CD", "", "", "", "", "", "", 1486097Ssherman "DEBUG_0", "DEBUG_1", "", "", "", "", "", "", 1496097Ssherman "", "", "", "", "", "", "", "", 1506097Ssherman "", "", "", "", "", "", "", ""; 1516097Ssherman}; 1526097Ssherman 1536097Ssherman&gpio3 { 1546097Ssherman gpio-line-names = 1556210Skmo "", "", "", "", "", "", "", "", 1566097Ssherman "", "", "", "", "", "", "", "", 1576097Ssherman "", "", "", "ECSPI1_SS1", "", "USB_EXT_PWR", "", "", 1586097Ssherman "", "", "", "", "", "", "", ""; 1596097Ssherman}; 1606097Ssherman 1616097Ssherman&gpio4 { 1626097Ssherman gpio-line-names = 1636097Ssherman "", "", "", "", "", "", "", "", 1646097Ssherman "", "", "", "", "CAN1_SR", "CAN2_SR", "", "", 1656097Ssherman "LED_DI0_DEBUG_0", "LED_DI0_DEBUG_1", "IMX6_IN12", "IMX6_HMI", 1666097Ssherman "IMX6_IN11", "IMX6_BUZZER", "IMX6_LED1", "IMX6_LED2", 1676097Ssherman "IMX6_LED3", "IMX6_LED4", "ETH_RESET", "IMX6_ANA_OUT_SD", 1686097Ssherman "IMX6_ANA_OUT_ERR", "IMX6_ANA_OUT", "ETH_INTRP", ""; 1696097Ssherman}; 1706097Ssherman 1716097Ssherman&gpio5 { 1726097Ssherman gpio-line-names = 1736097Ssherman "", "", "", "", "", "IMX6_RELAY1", "IMX6_RELAY2", "", 1746097Ssherman "IMX6_IN1", "IMX6_IN2", "IMX6_IN3", "IMX6_IN4", "IMX6_IN5", 1756097Ssherman "IMX6_IN6", "IMX6_IN7", "IMX6_IN8", 1766097Ssherman "IMX6_IN9", "IMX6_IN10", "", "", "", "", "", "", 1776097Ssherman "", "", "", "", "", "", "", ""; 1786097Ssherman}; 1796097Ssherman 1806097Ssherman&i2c1 { 1816097Ssherman clock-frequency = <100000>; 1826097Ssherman pinctrl-names = "default"; 1836097Ssherman pinctrl-0 = <&pinctrl_i2c1>; 1846097Ssherman status = "okay"; 1856097Ssherman 1866097Ssherman /* additional i2c devices are added automatically by the boot loader */ 18714575Sbpb}; 1886097Ssherman 1896097Ssherman&i2c3 { 1906097Ssherman clock-frequency = <100000>; 1916097Ssherman pinctrl-names = "default"; 1926097Ssherman pinctrl-0 = <&pinctrl_i2c3>; 1936097Ssherman status = "okay"; 1946097Ssherman 1956097Ssherman temperature-sensor@70 { 1966097Ssherman compatible = "ti,tmp103"; 1976097Ssherman reg = <0x70>; 1986097Ssherman }; 1996097Ssherman 2006097Ssherman rtc@51 { 2016097Ssherman compatible = "nxp,pcf8563"; 2026097Ssherman reg = <0x51>; 2036097Ssherman }; 2046097Ssherman}; 2056097Ssherman 2066097Ssherman&pwm1 { 2076097Ssherman pinctrl-names = "default"; 2086097Ssherman pinctrl-0 = <&pinctrl_pwm1>; 2096097Ssherman status = "okay"; 2106097Ssherman}; 2116097Ssherman 2126097Ssherman&uart1 { 2136097Ssherman pinctrl-names = "default"; 2146097Ssherman pinctrl-0 = <&pinctrl_uart1>; 2156097Ssherman status = "okay"; 2166097Ssherman}; 2176097Ssherman 2186097Ssherman&uart2 { 2196097Ssherman pinctrl-names = "default"; 2206097Ssherman pinctrl-0 = <&pinctrl_uart2>; 2216097Ssherman uart-has-rtscts; 2226097Ssherman linux,rs485-enabled-at-boot-time; 2236097Ssherman rs485-rts-delay = <0 20>; 2246097Ssherman status = "okay"; 2256097Ssherman}; 2266097Ssherman 2276097Ssherman&uart4 { 2286097Ssherman pinctrl-names = "default"; 2296097Ssherman pinctrl-0 = <&pinctrl_uart4>; 2306097Ssherman status = "okay"; 2316097Ssherman}; 2326097Ssherman 2336097Ssherman&usbotg { 2346097Ssherman pinctrl-names = "default"; 2356097Ssherman pinctrl-0 = <&pinctrl_usbotg>; 2366097Ssherman phy_type = "utmi"; 2376097Ssherman dr_mode = "host"; 2386097Ssherman over-current-active-low; 2396097Ssherman status = "okay"; 2406097Ssherman}; 2416097Ssherman 2426097Ssherman&usbphynop1 { 2436097Ssherman status = "disabled"; 2447117Srriggs}; 2457117Srriggs 2466097Ssherman&usbphynop2 { 2476097Ssherman status = "disabled"; 2486097Ssherman}; 2496097Ssherman 2506097Ssherman&iomuxc { 2516097Ssherman pinctrl_can1: can1grp { 2526097Ssherman fsl,pins = < 2536097Ssherman MX6QDL_PAD_KEY_ROW2__FLEXCAN1_RX 0x1b000 2546097Ssherman MX6QDL_PAD_KEY_COL2__FLEXCAN1_TX 0x3008 2556097Ssherman /* CAN1_SR */ 25614575Sbpb MX6QDL_PAD_KEY_COL3__GPIO4_IO12 0x13008 25714575Sbpb >; 25814575Sbpb }; 25914575Sbpb 26014575Sbpb pinctrl_can2: can2grp { 26114575Sbpb fsl,pins = < 26214575Sbpb MX6QDL_PAD_KEY_ROW4__FLEXCAN2_RX 0x1b000 26314575Sbpb MX6QDL_PAD_KEY_COL4__FLEXCAN2_TX 0x3008 26414575Sbpb /* CAN2_SR */ 26514575Sbpb MX6QDL_PAD_KEY_ROW3__GPIO4_IO13 0x13008 26614575Sbpb >; 26714575Sbpb }; 26814575Sbpb 26914575Sbpb pinctrl_ecspi1: ecspi1grp { 27014575Sbpb fsl,pins = < 27114575Sbpb MX6QDL_PAD_EIM_D17__ECSPI1_MISO 0x1b000 27214575Sbpb MX6QDL_PAD_EIM_D18__ECSPI1_MOSI 0x3008 27314575Sbpb MX6QDL_PAD_EIM_D16__ECSPI1_SCLK 0x3008 27414575Sbpb /* CS */ 27514575Sbpb MX6QDL_PAD_EIM_D19__GPIO3_IO19 0x3008 27614575Sbpb >; 27714575Sbpb }; 27814575Sbpb 27914575Sbpb pinctrl_enet: enetgrp { 28014575Sbpb fsl,pins = < 28114575Sbpb /* MX6QDL_ENET_PINGRP4 */ 28214575Sbpb MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0 28314575Sbpb MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0 28414575Sbpb MX6QDL_PAD_ENET_RXD0__ENET_RX_DATA0 0x1b0b0 28514575Sbpb MX6QDL_PAD_ENET_RXD1__ENET_RX_DATA1 0x1b0b0 28614575Sbpb MX6QDL_PAD_ENET_RX_ER__ENET_RX_ER 0x1b0b0 28714575Sbpb MX6QDL_PAD_ENET_TX_EN__ENET_TX_EN 0x1b0b0 28814575Sbpb MX6QDL_PAD_ENET_TXD0__ENET_TX_DATA0 0x1b0b0 28914575Sbpb MX6QDL_PAD_ENET_TXD1__ENET_TX_DATA1 0x1b0b0 29014575Sbpb MX6QDL_PAD_ENET_CRS_DV__ENET_RX_EN 0x1b0b0 29114575Sbpb 29214575Sbpb MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x1b0b0 29314575Sbpb /* Phy reset */ 29414575Sbpb MX6QDL_PAD_DISP0_DAT5__GPIO4_IO26 0x1b0b0 29514575Sbpb /* nINTRP */ 29614575Sbpb MX6QDL_PAD_DISP0_DAT9__GPIO4_IO30 0x1b0b0 29714575Sbpb >; 29814575Sbpb }; 29914575Sbpb 30014575Sbpb pinctrl_i2c1: i2c1grp { 30114575Sbpb fsl,pins = < 30214575Sbpb MX6QDL_PAD_CSI0_DAT8__I2C1_SDA 0x4001f8b1 30314575Sbpb MX6QDL_PAD_CSI0_DAT9__I2C1_SCL 0x4001f8b1 30414575Sbpb >; 30514575Sbpb }; 30614575Sbpb 30714575Sbpb pinctrl_i2c3: i2c3grp { 30814575Sbpb fsl,pins = < 30914575Sbpb MX6QDL_PAD_GPIO_5__I2C3_SCL 0x4001b8b1 31014575Sbpb MX6QDL_PAD_GPIO_6__I2C3_SDA 0x4001b8b1 31114575Sbpb >; 31214575Sbpb }; 31314575Sbpb 31414575Sbpb pinctrl_leds: ledsgrp { 31514575Sbpb fsl,pins = < 31614575Sbpb /* DEBUG_0 */ 31714575Sbpb MX6QDL_PAD_GPIO_8__GPIO1_IO08 0x1b0b0 31814575Sbpb /* DEBUG_1 */ 31914575Sbpb MX6QDL_PAD_GPIO_9__GPIO1_IO09 0x1b0b0 32014575Sbpb 32114575Sbpb /* LED1 (lighttower) */ 32214575Sbpb MX6QDL_PAD_DISP0_DAT1__GPIO4_IO22 0x13070 32314575Sbpb /* LED2 (lighttower) */ 32414575Sbpb MX6QDL_PAD_DISP0_DAT2__GPIO4_IO23 0x13070 32514575Sbpb /* LED3 (lighttower) */ 32614575Sbpb MX6QDL_PAD_DISP0_DAT3__GPIO4_IO24 0x13070 32714575Sbpb /* LED4 (lighttower) */ 32814575Sbpb MX6QDL_PAD_DISP0_DAT4__GPIO4_IO25 0x13070 32914575Sbpb >; 33014575Sbpb }; 33114575Sbpb 33214575Sbpb pinctrl_pwm1: pwm1grp { 33314575Sbpb fsl,pins = < 33414575Sbpb MX6QDL_PAD_DISP0_DAT8__PWM1_OUT 0x1b0b0 33514575Sbpb >; 33614575Sbpb }; 33714575Sbpb 33814575Sbpb /* YaCO AUX Uart */ 33914575Sbpb pinctrl_uart1: uart1grp { 34014575Sbpb fsl,pins = < 34114575Sbpb MX6QDL_PAD_CSI0_DAT10__UART1_TX_DATA 0x1b0b1 34214575Sbpb MX6QDL_PAD_CSI0_DAT11__UART1_RX_DATA 0x1b0b1 34314575Sbpb >; 34414575Sbpb }; 34514575Sbpb 34614575Sbpb pinctrl_uart2: uart2grp { 34714575Sbpb fsl,pins = < 34814575Sbpb MX6QDL_PAD_EIM_D26__UART2_TX_DATA 0x1b0b1 34914575Sbpb MX6QDL_PAD_EIM_D27__UART2_RX_DATA 0x1b0b1 35014575Sbpb MX6QDL_PAD_EIM_D28__UART2_DTE_CTS_B 0x130b1 35114575Sbpb >; 35214575Sbpb }; 35314575Sbpb 35414575Sbpb pinctrl_uart4: uart4grp { 35514575Sbpb fsl,pins = < 35614575Sbpb MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1 35714575Sbpb MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1 35814575Sbpb >; 35914575Sbpb }; 3606097Ssherman 3616097Ssherman pinctrl_usbotg: usbotggrp { 3626097Ssherman fsl,pins = < 3636097Ssherman MX6QDL_PAD_EIM_D21__USB_OTG_OC 0x1b0b0 3646097Ssherman /* power enable, high active */ 3656097Ssherman MX6QDL_PAD_EIM_D22__GPIO3_IO22 0x1b0b0 3666097Ssherman >; 3676097Ssherman }; 3686097Ssherman 3696097Ssherman pinctrl_usdhc1: usdhc1grp { 3706097Ssherman fsl,pins = < 3716097Ssherman MX6QDL_PAD_SD1_CMD__SD1_CMD 0x170f9 3726097Ssherman MX6QDL_PAD_SD1_CLK__SD1_CLK 0x100f9 3736097Ssherman MX6QDL_PAD_SD1_DAT0__SD1_DATA0 0x170f9 3746097Ssherman MX6QDL_PAD_SD1_DAT1__SD1_DATA1 0x170f9 3756097Ssherman MX6QDL_PAD_SD1_DAT2__SD1_DATA2 0x170f9 3766097Ssherman MX6QDL_PAD_SD1_DAT3__SD1_DATA3 0x170f9 3776097Ssherman MX6QDL_PAD_GPIO_1__GPIO1_IO01 0x1b0b0 3786097Ssherman >; 37914575Sbpb }; 38014575Sbpb 38114575Sbpb pinctrl_usdhc3: usdhc3grp { 38214575Sbpb fsl,pins = < 38314575Sbpb MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17099 38414575Sbpb MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10099 38514575Sbpb MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17099 38614575Sbpb MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17099 38714575Sbpb MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17099 38814575Sbpb MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17099 38914575Sbpb MX6QDL_PAD_SD3_DAT4__SD3_DATA4 0x17099 39014575Sbpb MX6QDL_PAD_SD3_DAT5__SD3_DATA5 0x17099 39114575Sbpb MX6QDL_PAD_SD3_DAT6__SD3_DATA6 0x17099 39214575Sbpb MX6QDL_PAD_SD3_DAT7__SD3_DATA7 0x17099 3936097Ssherman MX6QDL_PAD_SD3_RST__SD3_RESET 0x1b0b1 3946097Ssherman >; 3956097Ssherman }; 3966097Ssherman}; 3976097Ssherman