From nobody Wed Apr 15 16:30:09 2026 Received: from mail-pf1-f227.google.com (mail-pf1-f227.google.com [209.85.210.227]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6B623353EDA for ; Wed, 4 Mar 2026 02:55:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.227 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592930; cv=none; b=Rr8XkDt7qQg0lOJxMG/gAjWZ5XgbQvdWkuXgw67MkqylxD7SNjIh4s7rbDR4N9ivS0LF5dCdeKPC9zbVddXSZftFfIjbZM7WhsKDzUIZq5nkcNOgzElQcMs5DJKzrsp39b5YZsDyAJqh/Q5wE5LxlF/23nfVqdWKwogWvIZjIk8= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592930; c=relaxed/simple; bh=YOfFbIpwiNDmQQ6SnW9JqzlFwsdx7DsINX0gVz2lQkI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=TvE8/8L/voKSc5vrCj/JzvvIEFJEBFJua79znzG7Lls8vuYV7FwzwkhOF1jMVVCqDNrw+l3IzPejH2uCnP6qhkm/iWFnOi6mES+AOTqqTcSllzgRUVjthS3yi5qMMLUYQr2+lXjme0djeII3XHZFZvU0Z8ovkTGEV7qaj3o9KVQ= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ausil.us; spf=pass smtp.mailfrom=ausil.us; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b=ifFU71gG; arc=none smtp.client-ip=209.85.210.227 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ausil.us Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ausil.us Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b="ifFU71gG" Received: by mail-pf1-f227.google.com with SMTP id d2e1a72fcca58-824a829f9bbso2959420b3a.0 for ; Tue, 03 Mar 2026 18:55:29 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ausil.us; s=google; t=1772592929; x=1773197729; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=C8HDblj7fRKJtovg4Bo+ljGQF5b9QTgQki2w/2Xqdco=; b=ifFU71gG2pZfWlCzQwVHjkg/glKTnLEOD81TvptsCzcE1rUgKgcOmSUUpi720t3Wfs jp8KPWzFYTSkdwALY2n+2W3AlTWVpcpxh/RDDM4qM9J3mpBIfeccoLrLB1rkhdFc08ZW et4UwFQDQDAfNoZe9SkWcNJTfclqhEdrZqfoY3rh6YrkuUZO2bH/E3TLStuh/UTHK7h9 DiVc6/Bs17nOpdtWaFmXf6Ie1RvyrXt4fL8DMgXXqT7CoJzWKySgwt45abdFks+19Wk+ fpP+G2iG0c04N5Ks0fnB0E8Oxjt67Q9GYUekGZGJbNdrqm4iifcCKlnBPlPvnbfspO1I sqvw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772592929; x=1773197729; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=C8HDblj7fRKJtovg4Bo+ljGQF5b9QTgQki2w/2Xqdco=; b=xR8ByF4VEKbbntbdmOcF0wmyGi0W8FR12hzjyqIqKFNevwIh2qQzmm8g7b0naHqZc7 ivwCv6oYzzEWwBedmnMI/vhxsuJqPpwIWmifnBAT+4FwQcW8yfUMddPaIAaraBwIr4cM l1Xn9LAyHrilbtqRAHW4X0P/nXu5UvZeTqO68606ZVsC/gPjIV/elwuxe8Zs34HBZUPj o0DRJ8vse7aE2fYRYZ0ovg7ut7VBhwo4dEqq2eZqynKNAIrYdcQfh+oE17B3XmgM0iLW 4ZAOA10eSuAaOsNjdBt7+s02KQlKgqUy56s5weSmRa7NN5xzxsyJ0M4J0Bbx0mIhO67O lVOA== X-Forwarded-Encrypted: i=1; AJvYcCW/BUEWGCzY5YnGy7k582rUpSbaSoM3QlsHG3gYVliYIaAPdQqiGYogdVrpVLtvpNfbjyj33GWgw8kfJjg=@vger.kernel.org X-Gm-Message-State: AOJu0YydGfKdzBOHGEJoSlKJS0ZPuyjpujUu1orlXmIIO+0OxuNc2Ss8 ihFw27ooo9W5GxTQtJMhv7o6hUsOjEngza2kLWt6e56/o0XMSfZeHIS5omvv+HCLCFCAIEb2LWF s96ZAzPncswJN12Bg/ZPV3H7xX2HMuTRZ43AP X-Gm-Gg: ATEYQzzsDmRzP5ncmr+AcnRxsKbYtBRUC/+LSRTcbKGv1t1L1rKM8qT2LhyX6LBlAJ3 T2/DGD0G5SKyJrIK2DDHoLykAOvt74xIyKonMUErzpdEl+gez03y7TqX9j79u3/Zddh90XdYlO8 94EA5NGqBFXJeXT3o9HV17Ewu1INkYm8wgZ0PPz/ATG/+vrVw0gzsZLZGLqvjKUQ1i2Pn1mfIUu BoWOWRsSOyw0SgQ6962ixupDY3IKs7tV0KvaNRl5pJxM0tfsOyMkDEyO7rGQp6xvbbbbLC+GOK6 ITR2eKVSx95qzhfdbux3ErBAsuuAchGBzXhj+R0JG7nIyLCa6S/ELKtxqLYVygS8BNri7NuKzNt ip5qkzQdElY5Z0hm1xSxyT7IpzzIqLTekzGXdkDGZGFJ9 X-Received: by 2002:a05:6300:2109:b0:366:14ac:e20a with SMTP id adf61e73a8af0-3982e215fe1mr450654637.72.1772592928735; Tue, 03 Mar 2026 18:55:28 -0800 (PST) Received: from ryac.ausil.us (207-179-239-100.mtco.net. [207.179.239.100]) by smtp-relay.gmail.com with ESMTPS id 41be03b00d2f7-c70fa7d59b3sm1374096a12.7.2026.03.03.18.55.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 18:55:28 -0800 (PST) X-Relaying-Domain: ausil.us From: dennis@ausil.us To: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Heiko Stuebner Cc: FUKAUMI Naoki , Hsun Lai , Jonas Karlman , Chaoyi Chen , John Clark , Michael Opdenacker , Quentin Schulz , Andrew Lunn , Alexey Charkov , Peter Robinson , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, Dennis Gilmore , Krzysztof Kozlowski Subject: [PATCH V2 1/3] dt-bindings: arm: rockchip: Add Orange Pi 5 Pro Date: Tue, 3 Mar 2026 20:55:18 -0600 Message-ID: <20260304025521.210377-2-dennis@ausil.us> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260304025521.210377-1-dennis@ausil.us> References: <20260304025521.210377-1-dennis@ausil.us> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" From: Dennis Gilmore Add compatible string for the Orange Pi 5 Pro. Acked-by: Krzysztof Kozlowski Signed-off-by: Dennis Gilmore --- Documentation/devicetree/bindings/arm/rockchip.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/Documentation/devicetree/bindings/arm/rockchip.yaml b/Document= ation/devicetree/bindings/arm/rockchip.yaml index ae77ded9fe47..3c6b83a84463 100644 --- a/Documentation/devicetree/bindings/arm/rockchip.yaml +++ b/Documentation/devicetree/bindings/arm/rockchip.yaml @@ -1320,6 +1320,7 @@ properties: items: - enum: - xunlong,orangepi-5 + - xunlong,orangepi-5-pro - xunlong,orangepi-5b - const: rockchip,rk3588s =20 --=20 2.53.0 From nobody Wed Apr 15 16:30:09 2026 Received: from mail-pf1-f226.google.com (mail-pf1-f226.google.com [209.85.210.226]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 652D8353EF7 for ; Wed, 4 Mar 2026 02:55:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.226 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592933; cv=none; b=fTw4rvZyFxfheqjKZHRnIgK5A+Bnq8U2pLlA2eundzNuQumtIu9z3NCWeTcJTZN6J8Q6gBKh86s8BifZEAQoMBNpwN+PeCUEtuLQ71K1HPEB0NwynDytcEZvMUQEdJsa4RkQt39lq657ktgz9YfeCjoMcPh998zqT8VsEOUk9Io= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592933; c=relaxed/simple; bh=F59+Jc7sBT/sB7Bf2aTGXlMhSv4GG5B4BafcXYNcTzo=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=lDDEZMYgXKkp+/jDViMN4+t5lwT17LrvmCjXPCVg0yiQMHEB3RIt+mVv782K95tX3OscomLOWULO/7lJFfb451f2gKq7Uiq2lOu0CpymoLm7B/foBo6VbEfTYn5dHj1yBUt0q5F1Tor3FdudC/hzYTTnNmVYNGSM2g4ae8w8DFo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ausil.us; spf=pass smtp.mailfrom=ausil.us; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b=MCrd1N7W; arc=none smtp.client-ip=209.85.210.226 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=ausil.us Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ausil.us Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b="MCrd1N7W" Received: by mail-pf1-f226.google.com with SMTP id d2e1a72fcca58-8274936d2c0so6218240b3a.3 for ; Tue, 03 Mar 2026 18:55:31 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ausil.us; s=google; t=1772592931; x=1773197731; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=pGL01KQz8fGNmgMjeX5GBD+LWCxCWAmCr/D+fX/lnJI=; b=MCrd1N7WVZQ561MtTgrjId2NaSz1k3AtwbJQFRprN6jVeY1nSs8cK/9zvyNFdV3bMU KJkKH5hQZEq+sYps97abMfJlWYQicFqsR5c8fbeDvhVPaSFnR/Mkx60xiHmfO3wGaTWd kE3/PPm11V+e58U/LPIbyXLScA/mx8sDmxvxb/6kE3cmMLrM7kz+iSPWCqyq8a9YCcus HOyoof8+wgr8QWQOBjcmofWsiv7SWC1Ap3V3oIfOsCqY6eW4jNKlI7QrHMYxXdxqdtIl RAjhZRQHmxsMpJzhwBUoaEdDtcypEeeBx64oixPigHK3+3h+yuAGhoc7/gw2UDz6w+t4 nwkQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772592931; x=1773197731; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=pGL01KQz8fGNmgMjeX5GBD+LWCxCWAmCr/D+fX/lnJI=; b=dJQSSiS8nch60alGjqjN/XteVaeRsbbZ/s03ueVeokiHz51sb8durK95q1DC+Ygn09 FnnKt3xyhH/hvMHo8IbKpIpmraVVEZXOxdGxdt2OpDbM8LuPE5HpllRN+9mPR32RKYXa M9JKfmVeP0aOkZuzuZnxJ2wKZljDMOEk+WoGMSF2I7qETXsYUNle/r5oGqs8N+aGLxlt mEWrZJezRRp/yxQir+EUF1ZyV1d9YguKUaGcNT4m2xYiMzqW22XetDaUavEO5YKTapHm ONfO2aYYoAYWmCdwl3JixPja4oEK1a38tNelXvQb4lNCdf1pBnLk8YSFuJs5EfFv1emk 7L6w== X-Forwarded-Encrypted: i=1; AJvYcCWNGUPCzmivhsHyZcckl06aKnhyDS3VJlKbFPtELmOK0tVzDJ2OGn1p8HNX13rM7z2WPnjcaEdSxoxGS6E=@vger.kernel.org X-Gm-Message-State: AOJu0YzbVlrwNrLfV43I+PSX5cYcfEolLTP1D2aILDmkJov1ruVv01En FN2PYqkrHP3X1naS2HAN3Ys8H0xaWGXwqCN8RjTWnq/RHQWmEUaLBqSZUeT53R/WWkbbqJ3i5sI At7XTYqGC3KspFlBZ+2JhT8IhHqHQ36gNkzkl X-Gm-Gg: ATEYQzx1S6BvWtaBf3WvU3GDh22KqDU39W7180olxO92/xNxhe0stF1bbQ3DSf9ySVj peI92LqKazQJSB6VXD1h54R1wAntSkbefJDKVFgnnWV8/P3AoBM5chFxABjmJ1ddSf8h5r4OCWt B4XI+lOoXQ4IMiIhWTcbdlpQidkMJKST7DdQWNdNvidiGpdCngTd2EqEhThiQWz0T8AyKKmaog+ BeHFYtZZ8XyPOmL3gXncOcVLbNekZgqcXxXpBRGYBFGWXd6/IcJf7q7d1Wz3b2d/uvuNnXKVpuJ DZsSVlm2LD7MDkbqpeu1wEu4JGrOFLOR7wqhLnnYcilsAorlJjXE35EpdlXC5sFk24g7/NCgQGo Rq7/qGscORJrFa0rij/m4KUywxEG+snDWWUmYe3bGCChN X-Received: by 2002:a05:6300:6710:b0:394:427b:eab with SMTP id adf61e73a8af0-3982dd5fb4bmr439560637.11.1772592930680; Tue, 03 Mar 2026 18:55:30 -0800 (PST) Received: from ryac.ausil.us (207-179-239-100.mtco.net. [207.179.239.100]) by smtp-relay.gmail.com with ESMTPS id 41be03b00d2f7-c70fa7d59b3sm1374096a12.7.2026.03.03.18.55.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 18:55:30 -0800 (PST) X-Relaying-Domain: ausil.us From: dennis@ausil.us To: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Heiko Stuebner Cc: FUKAUMI Naoki , Hsun Lai , Jonas Karlman , Chaoyi Chen , John Clark , Michael Opdenacker , Quentin Schulz , Andrew Lunn , Alexey Charkov , Peter Robinson , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, Dennis Gilmore Subject: [PATCH V2 2/3] arm64: dts: rockchip: refactor items from Orange Pi 5/b to prep for Pro Date: Tue, 3 Mar 2026 20:55:19 -0600 Message-ID: <20260304025521.210377-3-dennis@ausil.us> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260304025521.210377-1-dennis@ausil.us> References: <20260304025521.210377-1-dennis@ausil.us> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" From: Dennis Gilmore The Orange Pi 5 Pro uses the same SoC and base as the Orange Pi 5 and Orange Pi 5B but has had sound, USB, and leds wired up differently. The boards also use gmac for ethernet where thre Pro has a PCIe attached NIC Signed-off-by: Dennis Gilmore --- .../boot/dts/rockchip/rk3588s-orangepi-5.dts | 184 ++++++++++++++++ .../boot/dts/rockchip/rk3588s-orangepi-5.dtsi | 202 ++---------------- .../boot/dts/rockchip/rk3588s-orangepi-5b.dts | 181 ++++++++++++++++ 3 files changed, 378 insertions(+), 189 deletions(-) diff --git a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts b/arch/arm= 64/boot/dts/rockchip/rk3588s-orangepi-5.dts index 83b9b6645a1e..a102458d7f6f 100644 --- a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dts @@ -2,12 +2,62 @@ =20 /dts-v1/; =20 +#include #include "rk3588s-orangepi-5.dtsi" =20 / { model =3D "Xunlong Orange Pi 5"; compatible =3D "xunlong,orangepi-5", "rockchip,rk3588s"; =20 + aliases { + ethernet0 =3D &gmac1; + mmc0 =3D &sdmmc; + }; + + analog-sound { + compatible =3D "simple-audio-card"; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&hp_detect>; + simple-audio-card,name =3D "rockchip,es8388"; + simple-audio-card,bitclock-master =3D <&masterdai>; + simple-audio-card,format =3D "i2s"; + simple-audio-card,frame-master =3D <&masterdai>; + simple-audio-card,hp-det-gpios =3D <&gpio1 RK_PD5 GPIO_ACTIVE_HIGH>; + simple-audio-card,mclk-fs =3D <256>; + simple-audio-card,routing =3D + "Headphones", "LOUT1", + "Headphones", "ROUT1", + "LINPUT1", "Microphone Jack", + "RINPUT1", "Microphone Jack", + "LINPUT2", "Onboard Microphone", + "RINPUT2", "Onboard Microphone"; + simple-audio-card,widgets =3D + "Microphone", "Microphone Jack", + "Microphone", "Onboard Microphone", + "Headphone", "Headphones"; + + simple-audio-card,cpu { + sound-dai =3D <&i2s1_8ch>; + }; + + masterdai: simple-audio-card,codec { + sound-dai =3D <&es8388>; + system-clock-frequency =3D <12288000>; + }; + }; + + pwm-leds { + compatible =3D "pwm-leds"; + + led { + color =3D ; + function =3D LED_FUNCTION_STATUS; + linux,default-trigger =3D "heartbeat"; + max-brightness =3D <255>; + pwms =3D <&pwm0 0 25000 0>; + }; + }; + vcc3v3_pcie20: regulator-vcc3v3-pcie20 { compatible =3D "regulator-fixed"; enable-active-high; @@ -21,12 +71,146 @@ vcc3v3_pcie20: regulator-vcc3v3-pcie20 { }; }; =20 +&gmac1 { + clock_in_out =3D "output"; + phy-handle =3D <&rgmii_phy1>; + phy-mode =3D "rgmii-rxid"; + pinctrl-0 =3D <&gmac1_miim + &gmac1_tx_bus2 + &gmac1_rx_bus2 + &gmac1_rgmii_clk + &gmac1_rgmii_bus>; + pinctrl-names =3D "default"; + tx_delay =3D <0x42>; + status =3D "okay"; +}; + +&i2c6 { + es8388: audio-codec@10 { + compatible =3D "everest,es8388", "everest,es8328"; + reg =3D <0x10>; + clocks =3D <&cru I2S1_8CH_MCLKOUT>; + AVDD-supply =3D <&vcc_3v3_s0>; + DVDD-supply =3D <&vcc_1v8_s0>; + HPVDD-supply =3D <&vcc_3v3_s0>; + PVDD-supply =3D <&vcc_3v3_s0>; + assigned-clocks =3D <&cru I2S1_8CH_MCLKOUT>; + assigned-clock-rates =3D <12288000>; + #sound-dai-cells =3D <0>; + }; + + usbc0: usb-typec@22 { + compatible =3D "fcs,fusb302"; + reg =3D <0x22>; + interrupt-parent =3D <&gpio0>; + interrupts =3D ; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&usbc0_int>; + vbus-supply =3D <&vbus_typec>; + status =3D "okay"; + + usb_con: connector { + compatible =3D "usb-c-connector"; + label =3D "USB-C"; + data-role =3D "dual"; + op-sink-microwatt =3D <1000000>; + power-role =3D "dual"; + sink-pdos =3D + ; + source-pdos =3D + ; + try-power-role =3D "source"; + + ports { + #address-cells =3D <1>; + #size-cells =3D <0>; + + port@0 { + reg =3D <0>; + usbc0_hs: endpoint { + remote-endpoint =3D <&usb_host0_xhci_drd_sw>; + }; + }; + + port@1 { + reg =3D <1>; + usbc0_ss: endpoint { + remote-endpoint =3D <&usbdp_phy0_typec_ss>; + }; + }; + + port@2 { + reg =3D <2>; + usbc0_sbu: endpoint { + remote-endpoint =3D <&usbdp_phy0_typec_sbu>; + }; + }; + }; + }; + }; +}; + +&i2s1_8ch { + rockchip,i2s-tx-route =3D <3 2 1 0>; + rockchip,i2s-rx-route =3D <1 3 2 0>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2s1m0_sclk + &i2s1m0_mclk + &i2s1m0_lrck + &i2s1m0_sdi1 + &i2s1m0_sdo3>; + status =3D "okay"; +}; + &pcie2x1l2 { reset-gpios =3D <&gpio3 RK_PD1 GPIO_ACTIVE_HIGH>; vpcie3v3-supply =3D <&vcc3v3_pcie20>; status =3D "okay"; }; =20 +&pwm0 { + pinctrl-0 =3D <&pwm0m2_pins>; + pinctrl-names =3D "default"; + status =3D "okay"; +}; + &sfc { status =3D "okay"; }; + +&usb_host0_xhci { + dr_mode =3D "otg"; + usb-role-switch; + + port { + usb_host0_xhci_drd_sw: endpoint { + remote-endpoint =3D <&usbc0_hs>; + }; + }; +}; + +&usb_host2_xhci { + status =3D "okay"; +}; + +&usbdp_phy0 { + mode-switch; + orientation-switch; + sbu1-dc-gpios =3D <&gpio4 RK_PA5 GPIO_ACTIVE_HIGH>; + sbu2-dc-gpios =3D <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>; + + port { + #address-cells =3D <1>; + #size-cells =3D <0>; + + usbdp_phy0_typec_ss: endpoint@0 { + reg =3D <0>; + remote-endpoint =3D <&usbc0_ss>; + }; + + usbdp_phy0_typec_sbu: endpoint@1 { + reg =3D <1>; + remote-endpoint =3D <&usbc0_sbu>; + }; + }; +}; diff --git a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dtsi b/arch/ar= m64/boot/dts/rockchip/rk3588s-orangepi-5.dtsi index dafad29f9854..7c7276968d95 100644 --- a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dtsi +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5.dtsi @@ -3,19 +3,13 @@ /dts-v1/; =20 #include -#include #include +#include #include #include -#include #include "rk3588s.dtsi" =20 / { - aliases { - ethernet0 =3D &gmac1; - mmc0 =3D &sdmmc; - }; - chosen { stdout-path =3D "serial2:1500000n8"; }; @@ -34,38 +28,6 @@ button-recovery { }; }; =20 - analog-sound { - compatible =3D "simple-audio-card"; - pinctrl-names =3D "default"; - pinctrl-0 =3D <&hp_detect>; - simple-audio-card,name =3D "rockchip,es8388"; - simple-audio-card,bitclock-master =3D <&masterdai>; - simple-audio-card,format =3D "i2s"; - simple-audio-card,frame-master =3D <&masterdai>; - simple-audio-card,hp-det-gpios =3D <&gpio1 RK_PD5 GPIO_ACTIVE_HIGH>; - simple-audio-card,mclk-fs =3D <256>; - simple-audio-card,routing =3D - "Headphones", "LOUT1", - "Headphones", "ROUT1", - "LINPUT1", "Microphone Jack", - "RINPUT1", "Microphone Jack", - "LINPUT2", "Onboard Microphone", - "RINPUT2", "Onboard Microphone"; - simple-audio-card,widgets =3D - "Microphone", "Microphone Jack", - "Microphone", "Onboard Microphone", - "Headphone", "Headphones"; - - simple-audio-card,cpu { - sound-dai =3D <&i2s1_8ch>; - }; - - masterdai: simple-audio-card,codec { - sound-dai =3D <&es8388>; - system-clock-frequency =3D <12288000>; - }; - }; - hdmi0-con { compatible =3D "hdmi-connector"; type =3D "a"; @@ -77,18 +39,6 @@ hdmi0_con_in: endpoint { }; }; =20 - pwm-leds { - compatible =3D "pwm-leds"; - - led { - color =3D ; - function =3D LED_FUNCTION_STATUS; - linux,default-trigger =3D "heartbeat"; - max-brightness =3D <255>; - pwms =3D <&pwm0 0 25000 0>; - }; - }; - vbus_typec: regulator-vbus-typec { compatible =3D "regulator-fixed"; enable-active-high; @@ -101,15 +51,6 @@ vbus_typec: regulator-vbus-typec { vin-supply =3D <&vcc5v0_sys>; }; =20 - vcc5v0_sys: regulator-vcc5v0-sys { - compatible =3D "regulator-fixed"; - regulator-name =3D "vcc5v0_sys"; - regulator-always-on; - regulator-boot-on; - regulator-min-microvolt =3D <5000000>; - regulator-max-microvolt =3D <5000000>; - }; - vcc_3v3_sd_s0: regulator-vcc-3v3-sd-s0 { compatible =3D "regulator-fixed"; gpios =3D <&gpio4 RK_PB5 GPIO_ACTIVE_LOW>; @@ -119,6 +60,15 @@ vcc_3v3_sd_s0: regulator-vcc-3v3-sd-s0 { regulator-max-microvolt =3D <3300000>; vin-supply =3D <&vcc_3v3_s3>; }; + + vcc5v0_sys: regulator-vcc5v0-sys { + compatible =3D "regulator-fixed"; + regulator-name =3D "vcc5v0_sys"; + regulator-always-on; + regulator-boot-on; + regulator-min-microvolt =3D <5000000>; + regulator-max-microvolt =3D <5000000>; + }; }; =20 &combphy0_ps { @@ -161,20 +111,6 @@ &cpu_l3 { cpu-supply =3D <&vdd_cpu_lit_s0>; }; =20 -&gmac1 { - clock_in_out =3D "output"; - phy-handle =3D <&rgmii_phy1>; - phy-mode =3D "rgmii-rxid"; - pinctrl-0 =3D <&gmac1_miim - &gmac1_tx_bus2 - &gmac1_rx_bus2 - &gmac1_rgmii_clk - &gmac1_rgmii_bus>; - pinctrl-names =3D "default"; - tx_delay =3D <0x42>; - status =3D "okay"; -}; - &gpu { mali-supply =3D <&vdd_gpu_s0>; status =3D "okay"; @@ -270,69 +206,6 @@ &i2c6 { pinctrl-0 =3D <&i2c6m3_xfer>; status =3D "okay"; =20 - es8388: audio-codec@10 { - compatible =3D "everest,es8388", "everest,es8328"; - reg =3D <0x10>; - clocks =3D <&cru I2S1_8CH_MCLKOUT>; - AVDD-supply =3D <&vcc_3v3_s0>; - DVDD-supply =3D <&vcc_1v8_s0>; - HPVDD-supply =3D <&vcc_3v3_s0>; - PVDD-supply =3D <&vcc_3v3_s0>; - assigned-clocks =3D <&cru I2S1_8CH_MCLKOUT>; - assigned-clock-rates =3D <12288000>; - #sound-dai-cells =3D <0>; - }; - - usbc0: usb-typec@22 { - compatible =3D "fcs,fusb302"; - reg =3D <0x22>; - interrupt-parent =3D <&gpio0>; - interrupts =3D ; - pinctrl-names =3D "default"; - pinctrl-0 =3D <&usbc0_int>; - vbus-supply =3D <&vbus_typec>; - status =3D "okay"; - - usb_con: connector { - compatible =3D "usb-c-connector"; - label =3D "USB-C"; - data-role =3D "dual"; - op-sink-microwatt =3D <1000000>; - power-role =3D "dual"; - sink-pdos =3D - ; - source-pdos =3D - ; - try-power-role =3D "source"; - - ports { - #address-cells =3D <1>; - #size-cells =3D <0>; - - port@0 { - reg =3D <0>; - usbc0_hs: endpoint { - remote-endpoint =3D <&usb_host0_xhci_drd_sw>; - }; - }; - - port@1 { - reg =3D <1>; - usbc0_ss: endpoint { - remote-endpoint =3D <&usbdp_phy0_typec_ss>; - }; - }; - - port@2 { - reg =3D <2>; - usbc0_sbu: endpoint { - remote-endpoint =3D <&usbdp_phy0_typec_sbu>; - }; - }; - }; - }; - }; - hym8563: rtc@51 { compatible =3D "haoyu,hym8563"; reg =3D <0x51>; @@ -346,18 +219,6 @@ hym8563: rtc@51 { }; }; =20 -&i2s1_8ch { - rockchip,i2s-tx-route =3D <3 2 1 0>; - rockchip,i2s-rx-route =3D <1 3 2 0>; - pinctrl-names =3D "default"; - pinctrl-0 =3D <&i2s1m0_sclk - &i2s1m0_mclk - &i2s1m0_lrck - &i2s1m0_sdi1 - &i2s1m0_sdo3>; - status =3D "okay"; -}; - &i2s5_8ch { status =3D "okay"; }; @@ -404,12 +265,6 @@ typec5v_pwren: typec5v-pwren { }; }; =20 -&pwm0 { - pinctrl-0 =3D <&pwm0m2_pins>; - pinctrl-names =3D "default"; - status =3D "okay"; -}; - &rknn_core_0 { npu-supply =3D <&vdd_npu_s0>; sram-supply =3D <&vdd_npu_s0>; @@ -840,29 +695,6 @@ &uart2 { status =3D "okay"; }; =20 -&usbdp_phy0 { - mode-switch; - orientation-switch; - sbu1-dc-gpios =3D <&gpio4 RK_PA5 GPIO_ACTIVE_HIGH>; - sbu2-dc-gpios =3D <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>; - status =3D "okay"; - - port { - #address-cells =3D <1>; - #size-cells =3D <0>; - - usbdp_phy0_typec_ss: endpoint@0 { - reg =3D <0>; - remote-endpoint =3D <&usbc0_ss>; - }; - - usbdp_phy0_typec_sbu: endpoint@1 { - reg =3D <1>; - remote-endpoint =3D <&usbc0_sbu>; - }; - }; -}; - &usb_host0_ehci { status =3D "okay"; }; @@ -872,15 +704,7 @@ &usb_host0_ohci { }; =20 &usb_host0_xhci { - dr_mode =3D "otg"; - usb-role-switch; status =3D "okay"; - - port { - usb_host0_xhci_drd_sw: endpoint { - remote-endpoint =3D <&usbc0_hs>; - }; - }; }; =20 &usb_host1_ehci { @@ -891,15 +715,15 @@ &usb_host1_ohci { status =3D "okay"; }; =20 -&usb_host2_xhci { +&usbdp_phy0 { status =3D "okay"; }; =20 -&vop_mmu { +&vop { status =3D "okay"; }; =20 -&vop { +&vop_mmu { status =3D "okay"; }; =20 diff --git a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5b.dts b/arch/ar= m64/boot/dts/rockchip/rk3588s-orangepi-5b.dts index d21ec320d295..5acd96969ddf 100644 --- a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5b.dts +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5b.dts @@ -2,6 +2,7 @@ =20 /dts-v1/; =20 +#include #include "rk3588s-orangepi-5.dtsi" =20 / { @@ -9,11 +10,191 @@ / { compatible =3D "xunlong,orangepi-5b", "rockchip,rk3588s"; =20 aliases { + ethernet0 =3D &gmac1; mmc0 =3D &sdhci; mmc1 =3D &sdmmc; }; + + analog-sound { + compatible =3D "simple-audio-card"; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&hp_detect>; + simple-audio-card,name =3D "rockchip,es8388"; + simple-audio-card,bitclock-master =3D <&masterdai>; + simple-audio-card,format =3D "i2s"; + simple-audio-card,frame-master =3D <&masterdai>; + simple-audio-card,hp-det-gpios =3D <&gpio1 RK_PD5 GPIO_ACTIVE_HIGH>; + simple-audio-card,mclk-fs =3D <256>; + simple-audio-card,routing =3D + "Headphones", "LOUT1", + "Headphones", "ROUT1", + "LINPUT1", "Microphone Jack", + "RINPUT1", "Microphone Jack", + "LINPUT2", "Onboard Microphone", + "RINPUT2", "Onboard Microphone"; + simple-audio-card,widgets =3D + "Microphone", "Microphone Jack", + "Microphone", "Onboard Microphone", + "Headphone", "Headphones"; + + simple-audio-card,cpu { + sound-dai =3D <&i2s1_8ch>; + }; + + masterdai: simple-audio-card,codec { + sound-dai =3D <&es8388>; + system-clock-frequency =3D <12288000>; + }; + }; + + pwm-leds { + compatible =3D "pwm-leds"; + + led { + color =3D ; + function =3D LED_FUNCTION_STATUS; + linux,default-trigger =3D "heartbeat"; + max-brightness =3D <255>; + pwms =3D <&pwm0 0 25000 0>; + }; + }; + +}; + +&gmac1 { + clock_in_out =3D "output"; + phy-handle =3D <&rgmii_phy1>; + phy-mode =3D "rgmii-rxid"; + pinctrl-0 =3D <&gmac1_miim + &gmac1_tx_bus2 + &gmac1_rx_bus2 + &gmac1_rgmii_clk + &gmac1_rgmii_bus>; + pinctrl-names =3D "default"; + tx_delay =3D <0x42>; + status =3D "okay"; +}; + +&i2c6 { + es8388: audio-codec@10 { + compatible =3D "everest,es8388", "everest,es8328"; + reg =3D <0x10>; + clocks =3D <&cru I2S1_8CH_MCLKOUT>; + AVDD-supply =3D <&vcc_3v3_s0>; + DVDD-supply =3D <&vcc_1v8_s0>; + HPVDD-supply =3D <&vcc_3v3_s0>; + PVDD-supply =3D <&vcc_3v3_s0>; + assigned-clocks =3D <&cru I2S1_8CH_MCLKOUT>; + assigned-clock-rates =3D <12288000>; + #sound-dai-cells =3D <0>; + }; + + usbc0: usb-typec@22 { + compatible =3D "fcs,fusb302"; + reg =3D <0x22>; + interrupt-parent =3D <&gpio0>; + interrupts =3D ; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&usbc0_int>; + vbus-supply =3D <&vbus_typec>; + status =3D "okay"; + + usb_con: connector { + compatible =3D "usb-c-connector"; + label =3D "USB-C"; + data-role =3D "dual"; + op-sink-microwatt =3D <1000000>; + power-role =3D "dual"; + sink-pdos =3D + ; + source-pdos =3D + ; + try-power-role =3D "source"; + + ports { + #address-cells =3D <1>; + #size-cells =3D <0>; + + port@0 { + reg =3D <0>; + usbc0_hs: endpoint { + remote-endpoint =3D <&usb_host0_xhci_drd_sw>; + }; + }; + + port@1 { + reg =3D <1>; + usbc0_ss: endpoint { + remote-endpoint =3D <&usbdp_phy0_typec_ss>; + }; + }; + + port@2 { + reg =3D <2>; + usbc0_sbu: endpoint { + remote-endpoint =3D <&usbdp_phy0_typec_sbu>; + }; + }; + }; + }; + }; +}; + +&i2s1_8ch { + rockchip,i2s-tx-route =3D <3 2 1 0>; + rockchip,i2s-rx-route =3D <1 3 2 0>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2s1m0_sclk + &i2s1m0_mclk + &i2s1m0_lrck + &i2s1m0_sdi1 + &i2s1m0_sdo3>; + status =3D "okay"; +}; + +&pwm0 { + pinctrl-0 =3D <&pwm0m2_pins>; + pinctrl-names =3D "default"; + status =3D "okay"; }; =20 &sdhci { status =3D "okay"; }; + +&usb_host0_xhci { + dr_mode =3D "otg"; + usb-role-switch; + + port { + usb_host0_xhci_drd_sw: endpoint { + remote-endpoint =3D <&usbc0_hs>; + }; + }; +}; + +&usb_host2_xhci { + status =3D "okay"; +}; + +&usbdp_phy0 { + mode-switch; + orientation-switch; + sbu1-dc-gpios =3D <&gpio4 RK_PA5 GPIO_ACTIVE_HIGH>; + sbu2-dc-gpios =3D <&gpio4 RK_PA7 GPIO_ACTIVE_HIGH>; + + port { + #address-cells =3D <1>; + #size-cells =3D <0>; + + usbdp_phy0_typec_ss: endpoint@0 { + reg =3D <0>; + remote-endpoint =3D <&usbc0_ss>; + }; + + usbdp_phy0_typec_sbu: endpoint@1 { + reg =3D <1>; + remote-endpoint =3D <&usbc0_sbu>; + }; + }; +}; --=20 2.53.0 From nobody Wed Apr 15 16:30:09 2026 Received: from mail-pf1-f225.google.com (mail-pf1-f225.google.com [209.85.210.225]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 498803542E1 for ; Wed, 4 Mar 2026 02:55:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.225 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592934; cv=none; b=SODgP9t8rWVl/pEdJhnqXJ1nBqmPZh+TSixruQSR5lf7uxzOMwvH8ChU+6oyUjllRzXe/c9Wv8gCCsR/qr1Q2ZZ3zVP46ujCMxU6i8LPqVow4t3RXm7GSAzwrtH849PIYm+Z+zN0KdRpv7Kk21lAdSVIdxMMSgnN3KvsUB+M57I= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1772592934; c=relaxed/simple; bh=l2F65hctVvbLUgSBsy2T20gFUKOLqF0a3g4h/by3QQA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=R9UeWjFqQihR1pxDkImFAH2/KhENrrbaosB4aaZmT37WscxO4DXx9z7jx8Og5kGowEOsnRUpFZSkQ1XGQBda1A0ixH9Lrot1Jg5eJeg8Ec8BzeyHgef1ydXlqgiolZCys2r1S26NmxVtZIoaAkDXZZ16abbC0PvOWwBU1nSZPQA= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=ausil.us; spf=pass smtp.mailfrom=ausil.us; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b=ROjTUp5q; arc=none smtp.client-ip=209.85.210.225 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=ausil.us Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ausil.us Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ausil.us header.i=@ausil.us header.b="ROjTUp5q" Received: by mail-pf1-f225.google.com with SMTP id d2e1a72fcca58-824af5e5c81so6579861b3a.0 for ; Tue, 03 Mar 2026 18:55:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ausil.us; s=google; t=1772592933; x=1773197733; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=vc/mKMQHWBKWISLIX5zCISp9R0i/eqeNN9jxcO1amd4=; b=ROjTUp5qsEofZaBG0Fxlr5P3BXbR6GTFufLQMDjNdziZG88KRUJbBx3SOsCt16scqS o+2Fu8VcTOAu4R3wfZhvubTbvg2r4xtG1SkmQPV3oJMu7KFPaVpuez2WIuZeMSQ1QY36 U+7EU1Or9/BZuUB82Ij2RWSuN9F/ksu0N1822Oo+YAv3drakb81reSW/UFtmac0Kn4kM HEfvFSS3144Ac0PqN/kRLRNvZ/BC0iEsZGGsbYUiiKd7plI+u73sRjurMLQEkYArZlmw 1PxcnxT7UGMYGbaU4en4cxxPf73by0lMa1BVpiCU7NVPqsSUY6+dK/E7otiJo1Zszxpf zu7w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1772592933; x=1773197733; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from :to:cc:subject:date:message-id:reply-to; bh=vc/mKMQHWBKWISLIX5zCISp9R0i/eqeNN9jxcO1amd4=; b=S8rR3pIqYwblCUl99T99tJWUkUtWY6sgRznGDancJSxclG7DwDrg75101HxurQz3/z ehI0ce5zzclslHqzUydTYdsVAdhmfHMtAmIhemdQ9BWR3X8G17Ozza/utHhjKq5NaRho lx4cV3FdBEp3FOO9YMfFiv3Mty4Aow2ZpfSi/8j+agjvc7GgaQFIyhtPxCL2UL5XApT2 5z443RJeGfRVER2H75qhEFC7gwEJBRXPk2h1CeiqF0NtDDKUrWsx101zPhbTNwrhW5yA BzNTHyJIoJkC/yS3PyFnqi0lEwJTxto2CtijwTB/EOwaalJL7C+pGxtPYrNHyDCMw6wa hdBA== X-Forwarded-Encrypted: i=1; AJvYcCUSlg8zqKAT/Px65M1s8LnsgD7s7PFKuqDFptIC2W/yrmmxKPZVkcR2m8WGDxKgQxGIUs8eFSoybdPraHM=@vger.kernel.org X-Gm-Message-State: AOJu0YxxFXfPbVFRbSOeMVZN6e08DealLwJsGHM82S2GZnG2XYMR3ovD pYrdB8Dc42Q35SuJbiZCS0mgjTjU9IrlUD1QalLxiV2DKyvNypGFNtkJsJs818PDmptb8OoOdxB Ong/bFo3qeYr2jezcNA6u19LJEWYv1LC7RnDp X-Gm-Gg: ATEYQzzAvXmulwSfbnGzGtr+wcNjp3DBqPE0W0O7vK2147jZPr1V0jalkVY1lVFWWP9 33ruU+T7lYIfBD+5u8n69vYp9jEDfaG4+ebfq2Sj6LyaS4+5tni6DXagK+Xx+CNE9faAksV69cm W9fSC//ljI6fCugCISP6eR760xfP0kBMSsW3g7CTa7KoqQGOgXl8XyH7SaqP8Bj96ND94xHbrsJ PxnmF8M7W1yZLt+9MEiOc++bdbk0BYdhbkh06nxeKx9sTeE7cJRT0VmzDzahSz/ITq6TJpGCJFh ygKXpVn+rs+B3f7g/l5vu2riXXBx9cIJ2xUU4TEONuMUez5r17kvMsFImueJqIFDLzla0I4f2BP gAGM6K+02T1yeQby2IWkH8AEJPZOsq2lLtbMTnKAmZOJ2 X-Received: by 2002:a05:6a21:7d06:b0:395:101e:9b40 with SMTP id adf61e73a8af0-3982dda4262mr500384637.1.1772592932621; Tue, 03 Mar 2026 18:55:32 -0800 (PST) Received: from ryac.ausil.us (207-179-239-100.mtco.net. [207.179.239.100]) by smtp-relay.gmail.com with ESMTPS id 41be03b00d2f7-c70fa7d59b3sm1374096a12.7.2026.03.03.18.55.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Mar 2026 18:55:32 -0800 (PST) X-Relaying-Domain: ausil.us From: dennis@ausil.us To: Rob Herring , Krzysztof Kozlowski , Conor Dooley , Heiko Stuebner Cc: FUKAUMI Naoki , Hsun Lai , Jonas Karlman , Chaoyi Chen , John Clark , Michael Opdenacker , Quentin Schulz , Andrew Lunn , Alexey Charkov , Peter Robinson , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, Dennis Gilmore Subject: [PATCH V2 3/3] arm64: dts: rockchip: Add Orange Pi 5 Pro board support Date: Tue, 3 Mar 2026 20:55:20 -0600 Message-ID: <20260304025521.210377-4-dennis@ausil.us> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260304025521.210377-1-dennis@ausil.us> References: <20260304025521.210377-1-dennis@ausil.us> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable From: Dennis Gilmore Add device tree for the Xunlong Orange Pi 5 Pro (RK3588S). The Pro differs from the base Orange Pi 5 in the following ways: - No SPI NOR flash; eMMC module slot instead, you can optionally solder a SPI NOR fin place and turn off the eMMC - PCIe-attached NIC (pcie2x1l1) replaces the GMAC1 ethernet - PCIe NVMe slot (pcie2x1l2) - AP6256 WiFi (BCM43456) via SDIO with mmc-pwrseq - BCM4345C5 Bluetooth via uart9 with full RTS/CTS - Two-colour (blue/green) GPIO LED using modern color/function binding - audio is wired up differently Vendors description and links to schematics available: http://www.orangepi.org/html/hardWare/computerAndMicrocontrollers/details/O= range-Pi-5-Pro.html Signed-off-by: Dennis Gilmore --- arch/arm64/boot/dts/rockchip/Makefile | 1 + .../dts/rockchip/rk3588s-orangepi-5-pro.dts | 376 ++++++++++++++++++ 2 files changed, 377 insertions(+) create mode 100644 arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5-pro.dts diff --git a/arch/arm64/boot/dts/rockchip/Makefile b/arch/arm64/boot/dts/ro= ckchip/Makefile index 4d384f153c13..c99dca2ae9e7 100644 --- a/arch/arm64/boot/dts/rockchip/Makefile +++ b/arch/arm64/boot/dts/rockchip/Makefile @@ -214,6 +214,7 @@ dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-nanopi-r6c.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-odroid-m2.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-orangepi-5.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-orangepi-5b.dtb +dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-orangepi-5-pro.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-orangepi-cm5-base.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-radxa-cm5-io.dtb dtb-$(CONFIG_ARCH_ROCKCHIP) +=3D rk3588s-roc-pc.dtb diff --git a/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5-pro.dts b/arch= /arm64/boot/dts/rockchip/rk3588s-orangepi-5-pro.dts new file mode 100644 index 000000000000..d656328c906d --- /dev/null +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5-pro.dts @@ -0,0 +1,376 @@ +// SPDX-License-Identifier: (GPL-2.0+ OR MIT) + +/dts-v1/; + +#include "rk3588s-orangepi-5.dtsi" + +/ { + model =3D "Xunlong Orange Pi 5 Pro"; + compatible =3D "xunlong,orangepi-5-pro", "rockchip,rk3588s"; + + aliases { + /delete-property/ ethernet0; + mmc0 =3D &sdhci; + mmc1 =3D &sdmmc; + mmc2 =3D &sdio; + }; + + /* Pro uses gpio-leds instead; pwm0 LED is not wired up */ + /delete-node/ pwm-leds; + + /* + * Pro uses i2s2 (i2s2m1 mux) for audio, not i2s1. Recreate the sound + * card node pointing at i2s2_2ch instead. + */ + /delete-node/ analog-sound; + + analog-sound { + compatible =3D "simple-audio-card"; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&hp_detect>; + simple-audio-card,bitclock-master =3D <&masterdai>; + simple-audio-card,format =3D "i2s"; + simple-audio-card,frame-master =3D <&masterdai>; + simple-audio-card,hp-det-gpios =3D <&gpio1 RK_PD5 GPIO_ACTIVE_HIGH>; + simple-audio-card,mclk-fs =3D <256>; + simple-audio-card,name =3D "rockchip,es8388"; + simple-audio-card,routing =3D + "Headphones", "LOUT1", + "Headphones", "ROUT1", + "LINPUT1", "Microphone Jack", + "RINPUT1", "Microphone Jack", + "LINPUT2", "Onboard Microphone", + "RINPUT2", "Onboard Microphone"; + simple-audio-card,widgets =3D + "Microphone", "Microphone Jack", + "Microphone", "Onboard Microphone", + "Headphone", "Headphones"; + + simple-audio-card,cpu { + sound-dai =3D <&i2s2_2ch>; + }; + + masterdai: simple-audio-card,codec { + sound-dai =3D <&es8388>; + system-clock-frequency =3D <12288000>; + }; + }; + + fan: pwm-fan { + compatible =3D "pwm-fan"; + #cooling-cells =3D <2>; + cooling-levels =3D <0 50 100 150 200 255>; + fan-supply =3D <&vcc5v0_sys>; + pwms =3D <&pwm2 0 20000000 0>; + }; + + gpio-leds { + compatible =3D "gpio-leds"; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&leds_rgb>; + + blue-led { + color =3D ; + function =3D LED_FUNCTION_STATUS; + gpios =3D <&gpio1 RK_PC6 GPIO_ACTIVE_HIGH>; + linux,default-trigger =3D "heartbeat"; + }; + + green-led { + color =3D ; + function =3D LED_FUNCTION_ACTIVITY; + gpios =3D <&gpio1 RK_PC2 GPIO_ACTIVE_HIGH>; + linux,default-trigger =3D "mmc0"; + }; + }; + + vcc5v0_otg: regulator-vcc5v0-otg { + compatible =3D "regulator-fixed"; + enable-active-high; + gpios =3D <&gpio0 RK_PC4 GPIO_ACTIVE_HIGH>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&vcc5v0_otg_en>; + regulator-always-on; + regulator-boot-on; + regulator-max-microvolt =3D <5000000>; + regulator-min-microvolt =3D <5000000>; + regulator-name =3D "vcc5v0_otg"; + vin-supply =3D <&vcc5v0_sys>; + }; + + sdio_pwrseq: sdio-pwrseq { + compatible =3D "mmc-pwrseq-simple"; + clocks =3D <&hym8563>; + clock-names =3D "ext_clock"; + post-power-on-delay-ms =3D <200>; + reset-gpios =3D <&gpio0 RK_PD0 GPIO_ACTIVE_LOW>; + }; + + vcc3v3_pcie20: regulator-vcc3v3-pcie20 { + compatible =3D "regulator-fixed"; + enable-active-high; + gpios =3D <&gpio3 RK_PB7 GPIO_ACTIVE_HIGH>; + regulator-boot-on; + regulator-max-microvolt =3D <3300000>; + regulator-min-microvolt =3D <3300000>; + regulator-name =3D "vcc3v3_pcie20"; + startup-delay-us =3D <50000>; + vin-supply =3D <&vcc5v0_sys>; + }; + + vcc3v3_pcie_eth: regulator-vcc3v3-pcie-eth { + compatible =3D "regulator-fixed"; + regulator-always-on; + regulator-boot-on; + regulator-max-microvolt =3D <3300000>; + regulator-min-microvolt =3D <3300000>; + regulator-name =3D "vcc3v3_pcie_eth"; + vin-supply =3D <&vcc5v0_sys>; + }; +}; + +/* disable gmac1 as the pro has a PCIe attached NIC */ +&gmac1 { + status =3D "disabled"; +}; + +/* 40-pin header pins 3/5 */ +&i2c1 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2c1m4_xfer>; + status =3D "okay"; +}; + +/* + * Pro routes audio codec via i2c3 (not i2c6) and i2s2m1 (not i2s1m0). + * Delete the inherited es8388 node from i2c6 and redeclare it here. + */ +/delete-node/ &es8388; + +&i2c3 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2c3m0_xfer>; + status =3D "okay"; + + es8388: audio-codec@11 { + compatible =3D "everest,es8388", "everest,es8328"; + reg =3D <0x11>; + #sound-dai-cells =3D <0>; + AVDD-supply =3D <&vcc_3v3_s0>; + DVDD-supply =3D <&vcc_1v8_s0>; + HPVDD-supply =3D <&vcc_3v3_s0>; + PVDD-supply =3D <&vcc_3v3_s0>; + assigned-clock-rates =3D <12288000>; + assigned-clocks =3D <&cru I2S2_2CH_MCLKOUT>; + clocks =3D <&cru I2S2_2CH_MCLKOUT>; + }; +}; + +/* 40-pin header pins 27/28 */ +&i2c4 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2c4m3_xfer>; + status =3D "okay"; +}; + +/* + * i2s1_8ch uses i2s1m0 which occupies GPIO4_PA0 (CLKREQ#) and GPIO4_PA1 + * (WAKE#) needed for the NVMe M.2 slot. Disable it; audio is on i2s2_2ch. + */ +&i2s1_8ch { + status =3D "disabled"; +}; + +/* Audio codec on i2s2, m1 mux; add mclk pin to the base pinctrl */ +&i2s2_2ch { + pinctrl-0 =3D <&i2s2m1_lrck &i2s2m1_mclk &i2s2m1_sclk + &i2s2m1_sdi &i2s2m1_sdo>; + status =3D "okay"; +}; + +&package_thermal { + polling-delay =3D <1000>; + + cooling-maps { + map0 { + trip =3D <&package_fan0>; + cooling-device =3D <&fan THERMAL_NO_LIMIT 1>; + }; + + map1 { + trip =3D <&package_fan1>; + cooling-device =3D <&fan 2 THERMAL_NO_LIMIT>; + }; + }; + + trips { + package_fan0: package-fan0 { + hysteresis =3D <2000>; + temperature =3D <55000>; + type =3D "active"; + }; + + package_fan1: package-fan1 { + hysteresis =3D <2000>; + temperature =3D <65000>; + type =3D "active"; + }; + }; +}; + +/* NVMe */ +&pcie2x1l1 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pcie30x1m1_1_clkreqn &pcie30x1m1_1_waken>; + reset-gpios =3D <&gpio4 RK_PA2 GPIO_ACTIVE_HIGH>; + supports-clkreq; + vpcie3v3-supply =3D <&vcc3v3_pcie_eth>; + status =3D "okay"; +}; + +/* NIC */ +&pcie2x1l2 { + reset-gpios =3D <&gpio3 RK_PD1 GPIO_ACTIVE_HIGH>; + vpcie3v3-supply =3D <&vcc3v3_pcie20>; + status =3D "okay"; +}; + +&pinctrl { + bluetooth { + bt_wake_gpio: bt-wake-pin { + rockchip,pins =3D <0 RK_PC6 RK_FUNC_GPIO &pcfg_pull_none>; + }; + + bt_wake_host_irq: bt-wake-host-irq { + rockchip,pins =3D <0 RK_PC5 RK_FUNC_GPIO &pcfg_pull_down>; + }; + }; + + gpio-leds { + leds_rgb: leds-rgb { + rockchip,pins =3D <1 RK_PC6 RK_FUNC_GPIO &pcfg_pull_none>, + <1 RK_PC2 RK_FUNC_GPIO &pcfg_pull_none>; + }; + }; + + usb { + vcc5v0_otg_en: vcc5v0-otg-en { + rockchip,pins =3D <0 RK_PC4 RK_FUNC_GPIO &pcfg_pull_none>; + }; + }; + + wlan { + wifi_host_wake_irq: wifi-host-wake-irq { + rockchip,pins =3D <0 RK_PA0 RK_FUNC_GPIO &pcfg_pull_down>; + }; + }; +}; + +/* pwm0 pin conflicts with i2c4 pin 27 Pro */ +&pwm0 { + status =3D "disabled"; +}; + +&pwm2 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm2m1_pins>; + status =3D "okay"; +}; + +&sdhci { + status =3D "okay"; +}; + +&sdio { + #address-cells =3D <1>; + #size-cells =3D <0>; + bus-width =3D <4>; + cap-sd-highspeed; + cap-sdio-irq; + disable-wp; + keep-power-in-suspend; + max-frequency =3D <150000000>; + mmc-pwrseq =3D <&sdio_pwrseq>; + no-mmc; + no-sd; + non-removable; + sd-uhs-sdr104; + status =3D "okay"; + + ap6256: wifi@1 { + compatible =3D "brcm,bcm43456-fmac", "brcm,bcm4329-fmac"; + reg =3D <1>; + interrupt-names =3D "host-wake"; + interrupt-parent =3D <&gpio0>; + interrupts =3D ; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&wifi_host_wake_irq>; + }; +}; + +&uart9 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&uart9m2_xfer &uart9m2_ctsn &uart9m2_rtsn>; + uart-has-rtscts; + status =3D "okay"; + + bluetooth { + compatible =3D "brcm,bcm4345c5"; + clocks =3D <&hym8563>; + clock-names =3D "lpo"; + device-wakeup-gpios =3D <&gpio0 RK_PC6 GPIO_ACTIVE_HIGH>; + interrupt-names =3D "host-wakeup"; + interrupt-parent =3D <&gpio0>; + interrupts =3D ; + max-speed =3D <1500000>; + pinctrl-names =3D "default"; + pinctrl-0 =3D <&bt_wake_host_irq &bt_wake_gpio>; + shutdown-gpios =3D <&gpio0 RK_PD5 GPIO_ACTIVE_HIGH>; + vbat-supply =3D <&vcc_3v3_s3>; + vddio-supply =3D <&vcc_1v8_s3>; + }; +}; + +/* USB2 OTG PHY for usb_host0_xhci; phy-supply enables VBUS to USB3 Type-A= port */ +&u2phy0_otg { + phy-supply =3D <&vcc5v0_otg>; +}; + +/* Pro has no FUSB302; the USB-C port is power delivery only */ +/delete-node/ &usbc0; + +/* + * The Pro's USB-C port is power delivery only: no FUSB302, no data lines, + * no alt-mode switching. The parent DTSI enables usbdp_phy0 (status =3D "= okay") + * and adds FUSB302 alt-mode/orientation properties; delete those here. + * + * dp-lane-mux =3D <0 1>: PHY lanes 0/1 are DP (physically routed to the + * LT8711UXD DP=E2=86=92HDMI2 bridge), lanes 2/3 are USB3 SuperSpeed (phys= ically + * routed to the USB3 Type-A port P3). Without this property the driver + * defaults to USB-only mode and places USB3 on lanes 0/1, which do not + * reach the Type-A connector and makes the USB3 port non-functional. + */ +&usbdp_phy0 { + rockchip,dp-lane-mux =3D <0 1>; + /delete-property/ mode-switch; + /delete-property/ orientation-switch; + /delete-property/ sbu1-dc-gpios; + /delete-property/ sbu2-dc-gpios; + /delete-node/ port; +}; + +/* USB3 Type-A port*/ +&usb_host0_xhci { + dr_mode =3D "host"; + /delete-property/ usb-role-switch; + status =3D "okay"; + /delete-node/ port; +}; + +/* + * combphy2_psu is shared between usb_host2_xhci (USB3) and pcie2x1l1 (PCI= e). + * Disable USB3 so the PHY can be used for the NVMe M.2 slot. + */ +&usb_host2_xhci { + status =3D "disabled"; +}; --=20 2.53.0