From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 882C6C0015E for ; Wed, 19 Jul 2023 08:16:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=MAnTxdXkxqkisC7YnxBrNdIkxKH2Zd3i36434bE2fYA=; b=B1CdOZovtRRkHh EmU9rQmWtoBgHgoLpoj64DCx7E3fd87V8ePuya/REvOdC4qMvDVHwZg8rTtdv5t0WWthsIUn6l024 ewu4tTGuefyMg42CdvDwWTkoDgcKEysVLMTFbwn4lkq8057iD9X9wwkkWEOPut3rj5AUqMeJwzzCL 7cIeXuiETsFqCic/zNzfwND18fituyhB0dWDmwWwTBeSw9aerTSV8gwU3hwRzPSmKtR8iRFYFpgOd Kk689C8T0xqZtVi5KnbS8G4dO/yMn5NPzhliY1gG1xV//0YNdnZcSMZh/mRX4LSOv2j8OclhzKt6w hIVM0OhWOhwJF/AyNrjA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1qM2MM-006HA5-0K; Wed, 19 Jul 2023 08:16:34 +0000 Received: from dfw.source.kernel.org ([139.178.84.217]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1qM2MH-006H7X-1q for linux-arm-kernel@lists.infradead.org; Wed, 19 Jul 2023 08:16:32 +0000 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 00A3F61305; Wed, 19 Jul 2023 08:16:29 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 40460C433C8; Wed, 19 Jul 2023 08:16:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1689754588; bh=YMBp0HO8nzFeSqBF/8icuiJ2um/D06p4FbGhg4kkZL8=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=pULz3vI326BkVc0SnHqKuWI0VOAxbTkEyNWJwJBvi4ehjp79jjwpQilkwGn/9ylyi viTctSx2Wwdxa9cU0A6S4oQOVuZYB6BePUDY1/qeS9x2Iu9JCo13Anll9yImQxAX5X EgosNaDPz4Ikgl8J707kxarzYLDbnUtTbzMQTh08Dn5M5Vzde88Qbl6BfSTvjvPzQ1 QEaRoUX25CUw1gWCjsg2kCgCKwIycavBvzoBDoNG2gDfBWfo3PlGPnIpkdkdi81unL hiunAaKBr5M4h7CikizFPX1ai0Tiutl49zy4qQvb2gqwPxqs+7zfmKhe2GqpOAKJrA MNUchggerhM/w== Date: Wed, 19 Jul 2023 16:16:15 +0800 From: Shawn Guo To: Marco Felsch Cc: robh+dt@kernel.org, krzysztof.kozlowski+dt@linaro.org, conor+dt@kernel.org, kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, laurent.pinchart@ideasonboard.com, dan.scally@ideasonboard.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: Re: [PATCH v2 4/4] arm64: dts: freescale: Add DEBIX SOM A and SOM A I/O Board support Message-ID: <20230719081615.GQ151430@dragon> References: <20230717165127.2882535-1-m.felsch@pengutronix.de> <20230717165127.2882535-4-m.felsch@pengutronix.de> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20230717165127.2882535-4-m.felsch@pengutronix.de> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20230719_011629_699144_769C8D4F X-CRM114-Status: GOOD ( 23.74 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org On Mon, Jul 17, 2023 at 06:51:27PM +0200, Marco Felsch wrote: > Add support for the Debix SOM A + SOM A I/O board. The commit enables > only the basic features like: > - 2x UART > - 2x Network > - eMMC/=B5SD > - CAN > - QSPI > - USB Host / Device > = > Signed-off-by: Marco Felsch > --- > Required patchsets: > = > - usb: https://lore.kernel.org/all/20230623142228.4069084-1-m.felsch@peng= utronix.de/ > - net: https://lore.kernel.org/all/20230717164307.2868264-1-m.felsch@peng= utronix.de/ > = > Changelog: > = > v2: > - drop to generic polyhex,imx8mp-debix binding > - net/phy: replace deprecated snps,reset-* and phy-reset-* bindings with > new phy-node based ones > - net/phy: fix phy properties and reset timings > - net/phy: add fec phy-supply handling > - net/phy: add eqos phy-supply handling > - net/phy: fix baseboard-vdd3v3 timings to fulfill net-phy-timings > - Fix spelling > - Drop superfluous blank lines > - pmic: make use of IRQ_TYPE_LEVEL_LOW > - pmic: add whitespace between buck node name and '{' > = > arch/arm64/boot/dts/freescale/Makefile | 1 + > .../freescale/imx8mp-debix-som-a-bmb-08.dts | 470 ++++++++++++++++++ > .../dts/freescale/imx8mp-debix-som-a.dtsi | 266 ++++++++++ > 3 files changed, 737 insertions(+) > create mode 100644 arch/arm64/boot/dts/freescale/imx8mp-debix-som-a-bmb-= 08.dts > create mode 100644 arch/arm64/boot/dts/freescale/imx8mp-debix-som-a.dtsi > = > diff --git a/arch/arm64/boot/dts/freescale/Makefile b/arch/arm64/boot/dts= /freescale/Makefile > index ef7d17aef58f0..ca7c9595e6ffa 100644 > --- a/arch/arm64/boot/dts/freescale/Makefile > +++ b/arch/arm64/boot/dts/freescale/Makefile > @@ -91,6 +91,7 @@ dtb-$(CONFIG_ARCH_MXC) +=3D imx8mn-venice-gw7902.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-beacon-kit.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-data-modul-edm-sbc.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-debix-model-a.dtb > +dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-debix-som-a-bmb-08.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-dhcom-pdk2.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-dhcom-pdk3.dtb > dtb-$(CONFIG_ARCH_MXC) +=3D imx8mp-evk.dtb > diff --git a/arch/arm64/boot/dts/freescale/imx8mp-debix-som-a-bmb-08.dts = b/arch/arm64/boot/dts/freescale/imx8mp-debix-som-a-bmb-08.dts > new file mode 100644 > index 0000000000000..17028ab169717 > --- /dev/null > +++ b/arch/arm64/boot/dts/freescale/imx8mp-debix-som-a-bmb-08.dts > @@ -0,0 +1,470 @@ > +// SPDX-License-Identifier: (GPL-2.0+ OR MIT) > +/* > + * Copyright 2019 NXP > + * Copyright (C) 2023 Pengutronix, Marco Felsch > + */ > + > +/dts-v1/; > + > +#include "imx8mp-debix-som-a.dtsi" > + > +/ { > + model =3D "Polyhex i.MX8MPlus Debix SOM A on BMB-08"; > + compatible =3D "polyhex,imx8mp-debix-som-a-bmb-08", "polyhex,imx8mp-deb= ix-som-a", > + "fsl,imx8mp"; > + > + chosen { > + stdout-path =3D &uart2; > + }; > + > + reg_baseboard_vdd3v3: regulator-baseboard-vdd3v3 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <3300000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-name =3D "BB_VDD3V3"; > + gpio =3D <&expander0 10 GPIO_ACTIVE_HIGH>; > + /* Required timings for ethernet phy's */ > + startup-delay-us =3D <50000>; > + off-on-delay-us =3D <110000>; > + enable-active-high; Can we place this right after the line below? gpio =3D <&expander0 10 GPIO_ACTIVE_HIGH>; > + regulator-always-on; > + }; > + > + reg_baseboard_vdd5v0: regulator-baseboard-vdd5v0 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <5000000>; > + regulator-max-microvolt =3D <5000000>; > + regulator-name =3D "BB_VDD5V"; > + gpio =3D <&expander0 9 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + }; > + > + regulator-som-vdd1v8 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <1800000>; > + regulator-max-microvolt =3D <1800000>; > + regulator-name =3D "SOM_VDD1V8_SW"; > + gpio =3D <&expander0 12 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + regulator-always-on; > + }; > + > + regulator-som-vdd3v3 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <3300000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-name =3D "SOM_VDD3V3_SW"; > + gpio =3D <&expander0 11 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + regulator-always-on; > + }; > + > + reg_usdhc2_vmmc: regulator-usdhc2 { > + compatible =3D "regulator-fixed"; > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_reg_usdhc2_vmmc>; > + regulator-name =3D "VSD_3V3"; > + regulator-min-microvolt =3D <3300000>; > + regulator-max-microvolt =3D <3300000>; > + gpio =3D <&gpio2 19 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + }; > + > + regulator-vbus-usb20 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <5000000>; > + regulator-max-microvolt =3D <5000000>; > + regulator-name =3D "USB20_5V"; > + gpio =3D <&expander1 14 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + regulator-always-on; > + vin-supply =3D <®_baseboard_vdd5v0>; > + }; > + > + regulator-vbus-usb30 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <5000000>; > + regulator-max-microvolt =3D <5000000>; > + regulator-name =3D "USB30_5V"; > + gpio =3D <&expander1 12 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + regulator-always-on; > + vin-supply =3D <®_baseboard_vdd5v0>; > + }; > + > + reg_vdd5v0: regulator-vdd5v0 { > + compatible =3D "regulator-fixed"; > + regulator-min-microvolt =3D <5000000>; > + regulator-max-microvolt =3D <5000000>; > + regulator-name =3D "VDD_5V"; > + gpio =3D <&expander0 8 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + }; > +}; > + > +&eqos { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_eqos>; > + phy-supply =3D <®_baseboard_vdd3v3>; > + phy-handle =3D <ðphy0>; > + phy-mode =3D "rgmii-id"; > + status =3D "okay"; > + > + mdio { > + compatible =3D "snps,dwmac-mdio"; > + #address-cells =3D <1>; > + #size-cells =3D <0>; > + > + ethphy0: ethernet-phy@0 { > + compatible =3D "ethernet-phy-ieee802.3-c22"; > + reg =3D <0>; > + reset-gpios =3D <&gpio4 18 GPIO_ACTIVE_LOW>; > + reset-assert-us =3D <20000>; > + reset-deassert-us =3D <150000>; > + eee-broken-1000t; > + realtek,clkout-disable; > + }; > + }; > +}; > + > +&fec { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_fec>; > + phy-supply =3D <®_baseboard_vdd3v3>; > + phy-handle =3D <ðphy1>; > + phy-mode =3D "rgmii-id"; > + fsl,magic-packet; > + status =3D "okay"; > + > + mdio { > + #address-cells =3D <1>; > + #size-cells =3D <0>; > + > + ethphy1: ethernet-phy@0 { > + compatible =3D "ethernet-phy-ieee802.3-c22"; > + reg =3D <0>; > + reset-gpios =3D <&gpio4 19 GPIO_ACTIVE_LOW>; > + reset-assert-us =3D <20000>; > + reset-deassert-us =3D <150000>; > + eee-broken-1000t; > + realtek,clkout-disable; > + }; > + }; > +}; > + > +&flexcan1 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_flexcan1>; > + xceiver-supply =3D <®_vdd5v0>; > + status =3D "okay"; > +}; > + > +&flexcan2 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_flexcan2>; > + xceiver-supply =3D <®_vdd5v0>; > + status =3D "okay"; > +}; > + > +&flexspi { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_flexspi0>; > + status =3D "okay"; > + > + flash: flash@0 { > + compatible =3D "jedec,spi-nor"; > + reg =3D <0>; > + spi-max-frequency =3D <80000000>; > + spi-tx-bus-width =3D <1>; > + spi-rx-bus-width =3D <4>; > + #address-cells =3D <1>; > + #size-cells =3D <1>; > + }; > +}; > + > +&i2c4 { > + expander0: gpio@20 { > + compatible =3D "nxp,pca9535"; > + reg =3D <0x20>; > + gpio-controller; > + #gpio-cells =3D <0x02>; > + }; > + > + expander1: gpio@23 { > + compatible =3D "nxp,pca9535"; > + reg =3D <0x23>; > + gpio-controller; > + #gpio-cells =3D <0x02>; > + > + /* > + * Since USB1 is bound to peripheral mode we need to ensure > + * that VBUS is turned off. > + */ > + usb30-otg-hog { > + gpio-hog; > + gpios =3D <13 GPIO_ACTIVE_HIGH>; > + output-low; > + line-name =3D "USB30_OTG_EN"; > + }; > + }; > + > + eeprom@52 { > + compatible =3D "atmel,24c02"; > + reg =3D <0x52>; > + pagesize =3D <16>; > + }; > + > + rtc@51 { Sort them in order of unit-address. > + compatible =3D "haoyu,hym8563"; > + reg =3D <0x51>; > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_rtc>; > + interrupt-parent =3D <&gpio4>; > + interrupts =3D <3 IRQ_TYPE_EDGE_FALLING>; > + #clock-cells =3D <0>; > + }; > +}; > + > +&snvs_pwrkey { > + status =3D "okay"; > +}; > + > +/* Debug */ > +&uart2 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_uart2>; > + status =3D "okay"; > +}; > + > +&uart3 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_uart3>; > + status =3D "okay"; > +}; > + > +&uart4 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_uart4>; > + status =3D "okay"; > +}; > + > +&usb3_0 { > + status =3D "okay"; > +}; > + > +&usb3_1 { > + status =3D "okay"; > +}; > + > +&usb_dwc3_0 { > + dr_mode =3D "peripheral"; > + status =3D "okay"; > +}; > + > +&usb_dwc3_1 { > + dr_mode =3D "host"; > + #address-cells =3D <1>; > + #size-cells =3D <0>; > + status =3D "okay"; > + > + /* 2.x hub on port 1 */ > + usb_hub_2_x: hub@1 { > + compatible =3D "usb5e3,610"; > + reg =3D <1>; > + reset-gpios =3D <&expander1 9 GPIO_ACTIVE_LOW>; > + vdd-supply =3D <®_vdd5v0>; > + peer-hub =3D <&usb_hub_3_x>; > + }; > + > + /* 3.x hub on port 2 */ > + usb_hub_3_x: hub@2 { > + compatible =3D "usb5e3,620"; > + reg =3D <2>; > + reset-gpios =3D <&expander1 9 GPIO_ACTIVE_LOW>; > + vdd-supply =3D <®_vdd5v0>; > + peer-hub =3D <&usb_hub_2_x>; > + }; > +}; > + > +&usb3_phy0 { > + status =3D "okay"; > +}; > + > +&usb3_phy1 { > + status =3D "okay"; > +}; > + > +/* =B5SD Card */ > +&usdhc2 { > + pinctrl-names =3D "default", "state_100mhz", "state_200mhz"; > + pinctrl-0 =3D <&pinctrl_usdhc2>; > + pinctrl-1 =3D <&pinctrl_usdhc2_100mhz>; > + pinctrl-2 =3D <&pinctrl_usdhc2_200mhz>; > + assigned-clocks =3D <&clk IMX8MP_CLK_USDHC2>; > + assigned-clock-rates =3D <400000000>; > + vmmc-supply =3D <®_usdhc2_vmmc>; > + bus-width =3D <4>; > + disable-wp; > + no-sdio; > + no-mmc; > + status =3D "okay"; > +}; > + > +&iomuxc { > + pinctrl_eqos: eqosgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_ENET_MDC__ENET_QOS_MDC 0x3 > + MX8MP_IOMUXC_ENET_MDIO__ENET_QOS_MDIO 0x3 > + MX8MP_IOMUXC_ENET_RD0__ENET_QOS_RGMII_RD0 0x91 > + MX8MP_IOMUXC_ENET_RD1__ENET_QOS_RGMII_RD1 0x91 > + MX8MP_IOMUXC_ENET_RD2__ENET_QOS_RGMII_RD2 0x91 > + MX8MP_IOMUXC_ENET_RD3__ENET_QOS_RGMII_RD3 0x91 > + MX8MP_IOMUXC_ENET_RXC__CCM_ENET_QOS_CLOCK_GENERATE_RX_CLK 0x91 > + MX8MP_IOMUXC_ENET_RX_CTL__ENET_QOS_RGMII_RX_CTL 0x91 > + MX8MP_IOMUXC_ENET_TD0__ENET_QOS_RGMII_TD0 0x1f > + MX8MP_IOMUXC_ENET_TD1__ENET_QOS_RGMII_TD1 0x1f > + MX8MP_IOMUXC_ENET_TD2__ENET_QOS_RGMII_TD2 0x1f > + MX8MP_IOMUXC_ENET_TD3__ENET_QOS_RGMII_TD3 0x1f > + MX8MP_IOMUXC_ENET_TX_CTL__ENET_QOS_RGMII_TX_CTL 0x1f > + MX8MP_IOMUXC_ENET_TXC__CCM_ENET_QOS_CLOCK_GENERATE_TX_CLK 0x1f > + > + MX8MP_IOMUXC_SAI1_RXFS__ENET1_1588_EVENT0_IN 0x1f > + MX8MP_IOMUXC_SAI1_TXD6__GPIO4_IO18 0x19 > + >; > + }; > + > + pinctrl_fec: fecgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SAI1_RXD2__ENET1_MDC 0x3 > + MX8MP_IOMUXC_SAI1_RXD3__ENET1_MDIO 0x3 > + MX8MP_IOMUXC_SAI1_RXD4__ENET1_RGMII_RD0 0x91 > + MX8MP_IOMUXC_SAI1_RXD5__ENET1_RGMII_RD1 0x91 > + MX8MP_IOMUXC_SAI1_RXD6__ENET1_RGMII_RD2 0x91 > + MX8MP_IOMUXC_SAI1_RXD7__ENET1_RGMII_RD3 0x91 > + MX8MP_IOMUXC_SAI1_TXC__ENET1_RGMII_RXC 0x91 > + MX8MP_IOMUXC_SAI1_TXFS__ENET1_RGMII_RX_CTL 0x91 > + MX8MP_IOMUXC_SAI1_TXD0__ENET1_RGMII_TD0 0x1f > + MX8MP_IOMUXC_SAI1_TXD1__ENET1_RGMII_TD1 0x1f > + MX8MP_IOMUXC_SAI1_TXD2__ENET1_RGMII_TD2 0x1f > + MX8MP_IOMUXC_SAI1_TXD3__ENET1_RGMII_TD3 0x1f > + MX8MP_IOMUXC_SAI1_TXD4__ENET1_RGMII_TX_CTL 0x1f > + MX8MP_IOMUXC_SAI1_TXD5__ENET1_RGMII_TXC 0x1f > + MX8MP_IOMUXC_SAI1_RXD0__ENET1_1588_EVENT1_IN 0x1f > + MX8MP_IOMUXC_SAI1_TXD7__GPIO4_IO19 0x19 > + >; > + }; > + > + pinctrl_flexcan1: flexcan1grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SAI5_RXD2__CAN1_RX 0x154 > + MX8MP_IOMUXC_SAI5_RXD1__CAN1_TX 0x154 > + >; > + }; > + > + pinctrl_flexcan2: flexcan2grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SAI5_MCLK__CAN2_RX 0x154 > + MX8MP_IOMUXC_SAI5_RXD3__CAN2_TX 0x154 > + >; > + }; > + > + pinctrl_flexspi0: flexspi0grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_NAND_ALE__FLEXSPI_A_SCLK 0x1c2 > + MX8MP_IOMUXC_NAND_CE0_B__FLEXSPI_A_SS0_B 0x82 > + MX8MP_IOMUXC_NAND_DATA00__FLEXSPI_A_DATA00 0x82 > + MX8MP_IOMUXC_NAND_DATA01__FLEXSPI_A_DATA01 0x82 > + MX8MP_IOMUXC_NAND_DATA02__FLEXSPI_A_DATA02 0x82 > + MX8MP_IOMUXC_NAND_DATA03__FLEXSPI_A_DATA03 0x82 > + >; > + }; > + > + pinctrl_i2c1: i2c1grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_I2C1_SCL__I2C1_SCL 0x400001c2 > + MX8MP_IOMUXC_I2C1_SDA__I2C1_SDA 0x400001c2 > + >; > + }; > + > + pinctrl_i2c4: i2c4grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_I2C4_SCL__I2C4_SCL 0x400001c3 > + MX8MP_IOMUXC_I2C4_SDA__I2C4_SDA 0x400001c3 > + >; > + }; > + > + pinctrl_rtc: rtcgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SAI1_RXD1__GPIO4_IO03 0x140 > + >; > + }; > + > + pinctrl_pmic: pmicgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_GPIO1_IO03__GPIO1_IO03 0x41 > + >; > + }; > + > + pinctrl_reg_usdhc2_vmmc: regusdhc2vmmcgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SD2_RESET_B__GPIO2_IO19 0x41 > + >; > + }; > + > + pinctrl_uart2: uart2grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_UART2_RXD__UART2_DCE_RX 0x14f > + MX8MP_IOMUXC_UART2_TXD__UART2_DCE_TX 0x14f > + >; > + }; > + > + pinctrl_uart3: uart3grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_UART3_RXD__UART3_DCE_RX 0x49 > + MX8MP_IOMUXC_UART3_TXD__UART3_DCE_TX 0x49 > + >; > + }; > + > + pinctrl_uart4: uart4grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_UART4_RXD__UART4_DCE_RX 0x49 > + MX8MP_IOMUXC_UART4_TXD__UART4_DCE_TX 0x49 > + >; > + }; > + > + pinctrl_usdhc2: usdhc2grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SD2_CLK__USDHC2_CLK 0x190 > + MX8MP_IOMUXC_SD2_CMD__USDHC2_CMD 0x1d0 > + MX8MP_IOMUXC_SD2_DATA0__USDHC2_DATA0 0x1d0 > + MX8MP_IOMUXC_SD2_DATA1__USDHC2_DATA1 0x1d0 > + MX8MP_IOMUXC_SD2_DATA2__USDHC2_DATA2 0x1d0 > + MX8MP_IOMUXC_SD2_DATA3__USDHC2_DATA3 0x1d0 > + MX8MP_IOMUXC_GPIO1_IO04__USDHC2_VSELECT 0xc1 > + >; > + }; > + > + pinctrl_usdhc2_100mhz: usdhc2-100mhzgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SD2_CLK__USDHC2_CLK 0x194 > + MX8MP_IOMUXC_SD2_CMD__USDHC2_CMD 0x1d4 > + MX8MP_IOMUXC_SD2_DATA0__USDHC2_DATA0 0x1d4 > + MX8MP_IOMUXC_SD2_DATA1__USDHC2_DATA1 0x1d4 > + MX8MP_IOMUXC_SD2_DATA2__USDHC2_DATA2 0x1d4 > + MX8MP_IOMUXC_SD2_DATA3__USDHC2_DATA3 0x1d4 > + MX8MP_IOMUXC_GPIO1_IO04__USDHC2_VSELECT 0xc1 > + >; > + }; > + > + pinctrl_usdhc2_200mhz: usdhc2-200mhzgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_SD2_CLK__USDHC2_CLK 0x196 > + MX8MP_IOMUXC_SD2_CMD__USDHC2_CMD 0x1d6 > + MX8MP_IOMUXC_SD2_DATA0__USDHC2_DATA0 0x1d6 > + MX8MP_IOMUXC_SD2_DATA1__USDHC2_DATA1 0x1d6 > + MX8MP_IOMUXC_SD2_DATA2__USDHC2_DATA2 0x1d6 > + MX8MP_IOMUXC_SD2_DATA3__USDHC2_DATA3 0x1d6 > + MX8MP_IOMUXC_GPIO1_IO04__USDHC2_VSELECT 0xc1 > + >; > + }; > +}; > diff --git a/arch/arm64/boot/dts/freescale/imx8mp-debix-som-a.dtsi b/arch= /arm64/boot/dts/freescale/imx8mp-debix-som-a.dtsi > new file mode 100644 > index 0000000000000..a089cadacc105 > --- /dev/null > +++ b/arch/arm64/boot/dts/freescale/imx8mp-debix-som-a.dtsi > @@ -0,0 +1,266 @@ > +// SPDX-License-Identifier: (GPL-2.0+ OR MIT) > +/* > + * Copyright 2019 NXP > + * Copyright (C) 2023 Pengutronix, Marco Felsch > + */ > + > +#include "imx8mp.dtsi" > + > +/ { > + model =3D "Polyhex i.MX8MPlus Debix SOM A"; > + compatible =3D "polyhex,imx8mp-debix-som-a", "fsl,imx8mp"; > +}; > + > +&A53_0 { > + cpu-supply =3D <&buck2>; > +}; > + > +&A53_1 { > + cpu-supply =3D <&buck2>; > +}; > + > +&A53_2 { > + cpu-supply =3D <&buck2>; > +}; > + > +&A53_3 { > + cpu-supply =3D <&buck2>; > +}; > + > +&i2c1 { > + clock-frequency =3D <400000>; > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_i2c1>; > + status =3D "okay"; > + > + pmic@25 { > + compatible =3D "nxp,pca9450c"; > + reg =3D <0x25>; > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_pmic>; > + interrupt-parent =3D <&gpio1>; > + interrupts =3D <3 IRQ_TYPE_LEVEL_LOW>; > + > + regulators { > + buck1: BUCK1 { > + regulator-name =3D "BUCK1"; > + regulator-min-microvolt =3D <600000>; > + regulator-max-microvolt =3D <2187500>; > + regulator-boot-on; > + regulator-always-on; > + regulator-ramp-delay =3D <3125>; > + }; > + > + buck2: BUCK2 { > + regulator-name =3D "BUCK2"; > + regulator-min-microvolt =3D <600000>; > + regulator-max-microvolt =3D <2187500>; > + regulator-boot-on; > + regulator-always-on; > + regulator-ramp-delay =3D <3125>; > + nxp,dvs-run-voltage =3D <950000>; > + nxp,dvs-standby-voltage =3D <850000>; > + }; > + > + buck4: BUCK4 { > + regulator-name =3D "BUCK4"; > + regulator-min-microvolt =3D <600000>; > + regulator-max-microvolt =3D <3400000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + buck5: BUCK5 { > + regulator-name =3D "BUCK5"; > + regulator-min-microvolt =3D <600000>; > + regulator-max-microvolt =3D <3400000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + buck6: BUCK6 { > + regulator-name =3D "BUCK6"; > + regulator-min-microvolt =3D <600000>; > + regulator-max-microvolt =3D <3400000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + ldo1: LDO1 { > + regulator-name =3D "LDO1"; > + regulator-min-microvolt =3D <1600000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + ldo2: LDO2 { > + regulator-name =3D "LDO2"; > + regulator-min-microvolt =3D <800000>; > + regulator-max-microvolt =3D <1150000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + ldo3: LDO3 { > + regulator-name =3D "LDO3"; > + regulator-min-microvolt =3D <800000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + ldo4: LDO4 { > + regulator-name =3D "LDO4"; > + regulator-min-microvolt =3D <800000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + > + ldo5: LDO5 { > + regulator-name =3D "LDO5"; > + regulator-min-microvolt =3D <1800000>; > + regulator-max-microvolt =3D <3300000>; > + regulator-boot-on; > + regulator-always-on; > + }; > + }; > + }; > +}; > + > +&i2c4 { > + clock-frequency =3D <400000>; > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_i2c4>; > + status =3D "okay"; > + > + adc@48 { > + compatible =3D "ti,ads1115"; > + reg =3D <0x48>; > + Unnecessary newline. > + #address-cells =3D <1>; > + #size-cells =3D <0>; > + > + channel@4 { > + reg =3D <4>; > + ti,gain =3D <1>; > + ti,datarate =3D <7>; > + }; Have a newline between nodes. Shawn > + channel@5 { > + reg =3D <5>; > + ti,gain =3D <1>; > + ti,datarate =3D <7>; > + }; > + channel@6 { > + reg =3D <6>; > + ti,gain =3D <1>; > + ti,datarate =3D <7>; > + }; > + channel@7 { > + reg =3D <7>; > + ti,gain =3D <1>; > + ti,datarate =3D <7>; > + }; > + }; > +}; > + > +&snvs_pwrkey { > + status =3D "okay"; > +}; > + > +/* eMMC */ > +&usdhc3 { > + pinctrl-names =3D "default", "state_100mhz", "state_200mhz"; > + pinctrl-0 =3D <&pinctrl_usdhc3>; > + pinctrl-1 =3D <&pinctrl_usdhc3_100mhz>; > + pinctrl-2 =3D <&pinctrl_usdhc3_200mhz>; > + assigned-clocks =3D <&clk IMX8MP_CLK_USDHC3>; > + assigned-clock-rates =3D <400000000>; > + bus-width =3D <8>; > + non-removable; > + status =3D "okay"; > +}; > + > +&wdog1 { > + pinctrl-names =3D "default"; > + pinctrl-0 =3D <&pinctrl_wdog>; > + fsl,ext-reset-output; > + status =3D "okay"; > +}; > + > +&iomuxc { > + pinctrl_i2c1: i2c1grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_I2C1_SCL__I2C1_SCL 0x400001c2 > + MX8MP_IOMUXC_I2C1_SDA__I2C1_SDA 0x400001c2 > + >; > + }; > + > + pinctrl_i2c4: i2c4grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_I2C4_SCL__I2C4_SCL 0x400001c3 > + MX8MP_IOMUXC_I2C4_SDA__I2C4_SDA 0x400001c3 > + >; > + }; > + > + pinctrl_pmic: pmicgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_GPIO1_IO03__GPIO1_IO03 0x41 > + >; > + }; > + > + pinctrl_usdhc3: usdhc3grp { > + fsl,pins =3D < > + MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x190 > + MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d0 > + MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d0 > + MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d0 > + MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d0 > + MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d0 > + MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d0 > + MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d0 > + MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d0 > + MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d0 > + MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x190 > + >; > + }; > + > + pinctrl_usdhc3_100mhz: usdhc3-100mhzgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x194 > + MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d4 > + MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d4 > + MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d4 > + MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d4 > + MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d4 > + MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d4 > + MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d4 > + MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d4 > + MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d4 > + MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x194 > + >; > + }; > + > + pinctrl_usdhc3_200mhz: usdhc3-200mhzgrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x196 > + MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d6 > + MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d6 > + MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d6 > + MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d6 > + MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d6 > + MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d6 > + MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d6 > + MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d6 > + MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d6 > + MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x196 > + >; > + }; > + > + pinctrl_wdog: wdoggrp { > + fsl,pins =3D < > + MX8MP_IOMUXC_GPIO1_IO02__WDOG1_WDOG_B 0xc6 > + >; > + }; > +}; > -- = > 2.39.2 > = _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel