From nobody Wed Apr 1 09:44:30 2026 Received: from mail-qt1-f227.google.com (mail-qt1-f227.google.com [209.85.160.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 07FEF283CAF for ; Wed, 1 Apr 2026 01:07:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.160.227 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1775005638; cv=none; b=Aga8D9VYdEF19kbY62c4iyK42ZK+gOylVxt6ei+XXkrKLsSNrijwNiquFKT1I82YWgr/VTxcwVWOpsyHvo1WOmdWa5S2GMAExW0ugyL5gejnkHCcvCINTfKdSRhHv+AZmjCa574WM0xKnVjjbRe4hwlON3IGqRt6H5QkP9vFM84= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1775005638; c=relaxed/simple; bh=NaLhfWmk5/Giy6F9KH30mMjWnwN6bFDdEavJO0r/gME=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=rYUU/p1FyZRO2uZMsPtoKjCxozfRdIhdEnZ/zXw7nMfljvd5SuKCCsy8D7XnC6wMxpsx66juTt+HOcxeAeabhB/DRx2VuwbSjVl4rSIXV/gVDKsDcFHPn/lR+6I+Aw5LdVHC66HtMKH4BjtFLPb0cutZR8/HipAOuVBhMP+oODc= 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=EmFCmZdU; arc=none smtp.client-ip=209.85.160.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="EmFCmZdU" Received: by mail-qt1-f227.google.com with SMTP id d75a77b69052e-50b2b289925so57221041cf.2 for ; Tue, 31 Mar 2026 18:07:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ausil.us; s=google; t=1775005636; x=1775610436; 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=eWAUT5q20CbAtBOIDV7jUJ3UZPFYCYSQkrgrPRigtE0=; b=EmFCmZdUByF2fXFjacnEgGsy0X79Q0gBN/X4jHyTbh8ihRhirg7Y0gocRFDp1HoKra /wKnHpjnVBKNfW4dEfUXi88+yMDyFncGpPOHMRx2GXOYH9OQlKLYO7ikGvfCvMzYAoOl tKUzje0hIAlS/S2aY+w7KBmfekbXTw6YESfYGelXtLxXOKbG+HHEdDLsNCZ2Koa5bXwf 5mpBTHa4vEOgMxYH2+u7LlgFCxzz0XowzL+iAQC30CbT3jeBYBq2ri5FSq9eYp+vKg3n jrg9uYtQKc0mb2mJIE/SYf4M18TsiZi20NCiYDjggaysS6afWB8qA61N1cAsIJWX7+EH 3d7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1775005636; x=1775610436; 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=eWAUT5q20CbAtBOIDV7jUJ3UZPFYCYSQkrgrPRigtE0=; b=BtFfWLRbnPRE4etIZbpaztLBmJZYQYjOFa9zv+YXc4jx1OGMQVhG0lVwCGHVb388Hl jXFK5xjkVlpVQ+rCNtZkRy24Ee4DcgH3vYIENFgoIMpMCc+5uLHDgxptrkEn4V138a2r 8uQtADNinU6Rn1bc8brkp3UZbwXzFqWvfB46j0wWBN2jhu0jjeKzFjClSU1ZfyHCy2ur dEBIwsT1yYvRZzz3yT5p7v45PBUtg5wmnUyyi9BvZzjhdWFNMPlSo+oVmsZMItQdMnh+ h5utmFH5em2usl4vsrXlhUHSb9/UAUYYHGP5F1j9PXaWzgZCfhh3vlLnTeLRyWKTN0f3 B+yg== X-Forwarded-Encrypted: i=1; AJvYcCWDtNTgD+/lQQREcVA2ijtkM6sW2tz5ClY6hV6krmylQ92ltWM4Sc8u59Cr3xWWIgE3AP7AWgA80Eb6aIY=@vger.kernel.org X-Gm-Message-State: AOJu0YxsaYdqk11LWlsp0ebadu2gV2sgSWSaSy1KrSz0tMjxd9LBfjnH 76li2no0XdP1wToGZwv44ODtACvUzlhR/ltmX9wWC3RMfsHkbzQsRaUjkLciXLLHysdfz4q6HBW dRYCcpL/g9ZEIm8kkZnOt9/FyST0aIX2L6tb7 X-Gm-Gg: ATEYQzyKgidtYUD4IzWr7PLMd5KOlmH45fQOW8iYaUE0GO72FrA1YOOEmvsELfv7tHL 2wQMEUmJ7b7DawzZt8cofbHOq+aGRv/gVlW+oGWqXFMmex6xSLkrvnJ8gHuCOpUrliGfSr69v5l /Ufnc/k8yMmWnTFVSuESscf9oOrUowHtHgSyKtJbtE+zSiDcJEp8iKyQBM1Fl0S9iTEGt+cQsCd NSQBkmT/SD3pMWaElx9sv/tSd7A0EXc9A2nT+nqN8OKbNdF5sAXXDUI3aWQdMlSmAsEJWqzsC+Z kHgK5OBLrmoIC30PR6EO/53IDqpaXP5d7F7wPU6HlpZltDIxCEKMROg/gjsgqU87qYTBdDJmweE m3biJR+C1iTBhb+eIu8Lhd4SJNJuVIC53QMGzYyi/VOq7 X-Received: by 2002:a05:622a:1cc9:b0:501:1795:9d52 with SMTP id d75a77b69052e-50d3bccd161mr25815091cf.33.1775005636012; Tue, 31 Mar 2026 18:07:16 -0700 (PDT) Received: from ryac.ausil.us (207-179-239-100.mtco.net. [207.179.239.100]) by smtp-relay.gmail.com with ESMTPS id 6a1803df08f44-89ecd72ecd5sm14105766d6.15.2026.03.31.18.07.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 31 Mar 2026 18:07:16 -0700 (PDT) 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 , Chukun Pan , Alexey Charkov , Peter Robinson , Dennis Gilmore , Michael Riesch , Mykola Kvach , Jimmy Hon , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v5 3/3] arm64: dts: rockchip: Add Orange Pi 5 Pro board support Date: Tue, 31 Mar 2026 20:07:07 -0500 Message-ID: <20260401010707.2584962-4-dennis@ausil.us> X-Mailer: git-send-email 2.53.0 In-Reply-To: <20260401010707.2584962-1-dennis@ausil.us> References: <20260401010707.2584962-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 device tree for the Xunlong Orange Pi 5 Pro (RK3588S). - eMMC module, you can optionally solder a SPI NOR in place and turn off the eMMC - PCIe-attached NIC (pcie2x1l1) - PCIe NVMe slot (pcie2x1l2) - AP6256 WiFi (BCM43456) via SDIO with mmc-pwrseq - BCM4345C5 Bluetooth - es8388 audio - USB 2.0 and USB 3.0 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 | 320 ++++++++++++++++++ 2 files changed, 321 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..7ab68245d2c6 --- /dev/null +++ b/arch/arm64/boot/dts/rockchip/rk3588s-orangepi-5-pro.dts @@ -0,0 +1,320 @@ +// 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 { + mmc0 =3D &sdhci; + mmc1 =3D &sdmmc; + mmc2 =3D &sdio; + }; + + 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>; + }; + }; + + pwm-leds { + compatible =3D "pwm-leds"; + + led-0 { + color =3D ; + function =3D LED_FUNCTION_STATUS; + linux,default-trigger =3D "heartbeat"; + max-brightness =3D <255>; + pwms =3D <&pwm15 0 1000000 0>; + }; + + led-1 { + color =3D ; + function =3D LED_FUNCTION_ACTIVITY; + linux,default-trigger =3D "heartbeat"; + max-brightness =3D <255>; + pwms =3D <&pwm3 0 1000000 0>; + }; + }; + + 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>; + }; + + vcc3v3_phy1: regulator-vcc3v3-phy1 { + 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_phy1"; + startup-delay-us =3D <50000>; + vin-supply =3D <&vcc_3v3_s3>; + }; + + 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-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>; + }; + + typea_con: usb-a-connector { + compatible =3D "usb-a-connector"; + data-role =3D "host"; + label =3D "USB3 Type-A"; + power-role =3D "source"; + vbus-supply =3D <&vcc5v0_otg>; + + ports { + #address-cells =3D <1>; + #size-cells =3D <0>; + + port@0 { + reg =3D <0>; + typea_con_hs: endpoint { + }; + }; + + port@1 { + reg =3D <1>; + typea_con_ss: endpoint { + }; + }; + }; + }; +}; + +&i2c1 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2c1m4_xfer>; + status =3D "okay"; +}; + +&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>; + }; +}; + +&i2c4 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&i2c4m3_xfer>; + status =3D "okay"; +}; + +&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 <&vcc_3v3_s3>; + status =3D "okay"; +}; + +/* NIC */ +&pcie2x1l2 { + reset-gpios =3D <&gpio3 RK_PD1 GPIO_ACTIVE_HIGH>; + vpcie3v3-supply =3D <&vcc3v3_phy1>; + 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>; + }; + }; + + 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>; + }; + }; +}; + +&pwm15 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm15m2_pins>; + status =3D "okay"; +}; + +&pwm2 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm2m1_pins>; + status =3D "okay"; +}; + +&pwm3 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm3m2_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; + 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>; + }; +}; + +&usb_host0_xhci { + dr_mode =3D "host"; +}; + +&usbdp_phy0 { + rockchip,dp-lane-mux =3D <0 1>; +}; --=20 2.53.0