// SPDX-License-Identifier: (GPL-2.0+ OR MIT) /* * Copyright (C) 2023 Marek Vasut * * DHCOM iMX8MP variant: * DHCM-iMX8ML8-C160-R409-F1638-SPI16-GE-CAN2-SD-RTC-WBTA-ADC-T-RGB-CSI2-HS-I-01D2 * DHCOM PCB number: 660-100 or newer * PDK3 PCB number: 669-100 or newer */ /dts-v1/; #include #include #include "imx8mp-dhcom-som.dtsi" / { model = "DH electronics i.MX8M Plus DHCOM Premium Developer Kit (3)"; compatible = "dh,imx8mp-dhcom-pdk3", "dh,imx8mp-dhcom-som", "fsl,imx8mp"; chosen { stdout-path = &uart1; }; clk_ext_audio_codec: clock-codec { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <24000000>; }; clk_xtal25: clock-xtal25 { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <25000000>; }; gpio-keys { compatible = "gpio-keys"; button-0 { gpios = <&gpio1 9 GPIO_ACTIVE_LOW>; /* GPIO A */ label = "TA1-GPIO-A"; linux,code = ; pinctrl-0 = <&pinctrl_dhcom_a>; pinctrl-names = "default"; wakeup-source; }; button-1 { gpios = <&gpio1 8 GPIO_ACTIVE_LOW>; /* GPIO B */ label = "TA2-GPIO-B"; linux,code = ; pinctrl-0 = <&pinctrl_dhcom_b>; pinctrl-names = "default"; wakeup-source; }; button-2 { gpios = <&gpio5 2 GPIO_ACTIVE_LOW>; /* GPIO C */ label = "TA3-GPIO-C"; linux,code = ; pinctrl-0 = <&pinctrl_dhcom_c>; pinctrl-names = "default"; wakeup-source; }; button-3 { gpios = <&gpio5 22 GPIO_ACTIVE_LOW>; /* GPIO E */ label = "TA4-GPIO-E"; linux,code = ; pinctrl-0 = <&pinctrl_dhcom_e>; pinctrl-names = "default"; wakeup-source; }; }; hdmi-connector { compatible = "hdmi-connector"; label = "X28"; type = "a"; port { hdmi_connector_in: endpoint { remote-endpoint = <&hdmi_tx_out>; }; }; }; led { compatible = "gpio-leds"; led-0 { color = ; default-state = "off"; function = LED_FUNCTION_INDICATOR; function-enumerator = <0>; gpios = <&gpio4 27 GPIO_ACTIVE_HIGH>; /* GPIO D */ pinctrl-0 = <&pinctrl_dhcom_d>; pinctrl-names = "default"; }; led-1 { color = ; default-state = "off"; function = LED_FUNCTION_INDICATOR; function-enumerator = <1>; gpios = <&gpio5 23 GPIO_ACTIVE_HIGH>; /* GPIO F */ pinctrl-0 = <&pinctrl_dhcom_f>; pinctrl-names = "default"; }; led-2 { color = ; default-state = "off"; function = LED_FUNCTION_INDICATOR; function-enumerator = <2>; gpios = <&gpio1 0 GPIO_ACTIVE_HIGH>; /* GPIO G */ pinctrl-0 = <&pinctrl_dhcom_g>; pinctrl-names = "default"; }; led-3 { color = ; default-state = "off"; function = LED_FUNCTION_INDICATOR; function-enumerator = <3>; gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>; /* GPIO I */ pinctrl-0 = <&pinctrl_dhcom_i>; pinctrl-names = "default"; }; }; reg_3p3vdd: regulator-3p3vdd { /* 3.3VDD */ compatible = "regulator-fixed"; regulator-always-on; regulator-min-microvolt = <3300000>; regulator-max-microvolt = <3300000>; regulator-name = "3P3VDD"; }; sound { compatible = "simple-audio-card"; simple-audio-card,name = "SGTL5000-Card"; simple-audio-card,format = "i2s"; simple-audio-card,bitclock-master = <&codec_dai>; simple-audio-card,frame-master = <&codec_dai>; simple-audio-card,widgets = "Headphone", "Headphone Jack"; simple-audio-card,routing = "Headphone Jack", "HP_OUT"; cpu_dai: simple-audio-card,cpu { sound-dai = <&sai3>; }; codec_dai: simple-audio-card,codec { sound-dai = <&sgtl5000>; }; }; }; &i2c5 { i2c-mux@70 { compatible = "nxp,pca9540"; reg = <0x70>; #address-cells = <1>; #size-cells = <0>; i2cmuxed0: i2c@0 { #address-cells = <1>; #size-cells = <0>; reg = <0>; sgtl5000: codec@a { compatible = "fsl,sgtl5000"; reg = <0x0a>; #sound-dai-cells = <0>; clocks = <&clk_ext_audio_codec>; VDDA-supply = <®_3p3vdd>; VDDIO-supply = <®_vdd_3p3v_awo>; }; csi2exp: gpio@24 { compatible = "nxp,pca9570"; reg = <0x24>; gpio-controller; #gpio-cells = <2>; gpio-line-names = "CSI2_#RESET", "CSI2_#PWDN", "CSI_#PWDN", "CSI_#RESET"; }; typec@3d { compatible = "nxp,ptn5150"; reg = <0x3d>; interrupt-parent = <&gpio4>; interrupts = <25 IRQ_TYPE_EDGE_FALLING>; pinctrl-names = "default"; pinctrl-0 = <&pinctrl_ptn5150>; port { ptn5150_out_ep: endpoint { remote-endpoint = <&dwc3_0_ep>; }; }; }; power-sensor@40 { compatible = "ti,ina238"; reg = <0x40>; shunt-resistor = <20000>; /* 0.02 R */ ti,shunt-gain = <1>; /* Drop cca. 40mV */ }; eeprom_board: eeprom@54 { compatible = "atmel,24c04"; pagesize = <16>; reg = <0x54>; }; pcieclk: clock@6b { compatible = "skyworks,si52144"; reg = <0x6b>; clocks = <&clk_xtal25>; #clock-cells = <1>; }; }; i2cmuxed1: i2c@1 { /* HDMI DDC I2C */ #address-cells = <1>; #size-cells = <0>; reg = <1>; }; }; }; &fec { /* Second ethernet */ pinctrl-0 = <&pinctrl_fec_rgmii>; phy-handle = <ðphypdk>; phy-mode = "rgmii-id"; mdio { ethphypdk: ethernet-phy@7 { /* Micrel KSZ9131RNXI */ compatible = "ethernet-phy-id0022.1642", "ethernet-phy-ieee802.3-c22"; interrupt-parent = <&gpio4>; interrupts = <3 IRQ_TYPE_LEVEL_LOW>; pinctrl-0 = <&pinctrl_ethphy1>; pinctrl-names = "default"; reg = <7>; reset-assert-us = <1000>; /* RESET_N signal rise time ~100ms */ reset-deassert-us = <120000>; reset-gpios = <&gpio4 2 GPIO_ACTIVE_LOW>; }; }; }; &flexcan1 { status = "okay"; }; &hdmi_pvi { status = "okay"; }; &hdmi_tx { ddc-i2c-bus = <&i2cmuxed1>; pinctrl-names = "default"; pinctrl-0 = <&pinctrl_hdmi>; status = "okay"; ports { port@1 { hdmi_tx_out: endpoint { remote-endpoint = <&hdmi_connector_in>; }; }; }; }; &hdmi_tx_phy { status = "okay"; }; &lcdif3 { status = "okay"; }; &pcie_phy { clocks = <&pcieclk 1>; clock-names = "ref"; fsl,refclk-pad-mode = ; status = "okay"; }; &pcie { fsl,max-link-speed = <3>; reset-gpio = <&gpio1 6 GPIO_ACTIVE_LOW>; status = "okay"; }; &sai3 { pinctrl-names = "default"; pinctrl-0 = <&pinctrl_sai3>; assigned-clocks = <&clk IMX8MP_CLK_SAI3>; assigned-clock-parents = <&clk IMX8MP_AUDIO_PLL1_OUT>; assigned-clock-rates = <12288000>; fsl,sai-mclk-direction-output; status = "okay"; }; &usb_dwc3_0 { usb-role-switch; port { dwc3_0_ep: endpoint { remote-endpoint = <&ptn5150_out_ep>; }; }; }; &usb3_1 { fsl,disable-port-power-control; fsl,permanently-attached; }; &usb_dwc3_1 { /* This port has USB5734 Hub connected to it, PWR/OC pins are unused */ /delete-property/ pinctrl-names; /delete-property/ pinctrl-0; }; &iomuxc { /* * GPIO_A,B,C,E are connected to buttons. * GPIO_D,F,G,I are connected to LEDs. * GPIO_H is connected to USB Hub RESET_N. * GPIO_M is connected to CLKOUT2. */ pinctrl-0 = <&pinctrl_hog_base &pinctrl_dhcom_h &pinctrl_dhcom_j &pinctrl_dhcom_k &pinctrl_dhcom_l &pinctrl_dhcom_int>; pinctrl_ptn5150: ptn5150grp { fsl,pins = < MX8MP_IOMUXC_SAI2_TXC__GPIO4_IO25 0x40000000 >; }; };