From 1cc2b6ad05806464b30405eab71a9eaf15d9eb08 Mon Sep 17 00:00:00 2001 From: Hal Feng Date: Thu, 14 Mar 2024 14:07:09 +0800 Subject: riscv: dts: starfive: visionfive2: Rename jh7110-visionfive-v2-*.dts to jh7110-starfive-visionfive-2-*.dts Rename the dts file, for sync with Linux mainline. Signed-off-by: Hal Feng --- arch/riscv/boot/dts/starfive/Makefile | 12 +- .../starfive/jh7110-starfive-visionfive-2-A10.dts | 196 ++++ .../starfive/jh7110-starfive-visionfive-2-A11.dts | 205 ++++ .../jh7110-starfive-visionfive-2-ac108.dts | 23 + .../starfive/jh7110-starfive-visionfive-2-tdm.dts | 22 + .../jh7110-starfive-visionfive-2-v1.3b.dts | 257 +++++ .../jh7110-starfive-visionfive-2-wm8960.dts | 26 + .../dts/starfive/jh7110-starfive-visionfive-2.dtsi | 1049 ++++++++++++++++++++ .../boot/dts/starfive/jh7110-visionfive-v2-A10.dts | 196 ---- .../boot/dts/starfive/jh7110-visionfive-v2-A11.dts | 205 ---- .../dts/starfive/jh7110-visionfive-v2-ac108.dts | 23 - .../boot/dts/starfive/jh7110-visionfive-v2-tdm.dts | 22 - .../dts/starfive/jh7110-visionfive-v2-wm8960.dts | 26 - .../boot/dts/starfive/jh7110-visionfive-v2.dts | 257 ----- .../boot/dts/starfive/jh7110-visionfive-v2.dtsi | 1049 -------------------- 15 files changed, 1784 insertions(+), 1784 deletions(-) create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A10.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A11.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-ac108.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-tdm.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-v1.3b.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-wm8960.dts create mode 100644 arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A10.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A11.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-ac108.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-tdm.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-wm8960.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dts delete mode 100644 arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dtsi diff --git a/arch/riscv/boot/dts/starfive/Makefile b/arch/riscv/boot/dts/starfive/Makefile index e180439adab3..cadd70841932 100644 --- a/arch/riscv/boot/dts/starfive/Makefile +++ b/arch/riscv/boot/dts/starfive/Makefile @@ -1,6 +1,6 @@ # SPDX-License-Identifier: GPL-2.0 subdir-y += evb-overlay vf2-overlay -dtb-$(CONFIG_SOC_STARFIVE_JH7110) += jh7110-visionfive-v2.dtb \ +dtb-$(CONFIG_SOC_STARFIVE_JH7110) += jh7110-starfive-visionfive-2-v1.3b.dtb \ jh7110-evb.dtb \ jh7110-evb-can-pdm-pwmdac.dtb \ jh7110-evb-dvp-rgb2hdmi.dtb \ @@ -11,8 +11,8 @@ dtb-$(CONFIG_SOC_STARFIVE_JH7110) += jh7110-visionfive-v2.dtb \ jh7110-evb-uart4-emmc-spdif.dtb \ jh7110-evb-uart5-pwm-i2c-tdm.dtb \ jh7110-evb-usbdevice.dtb \ - jh7110-visionfive-v2-A10.dtb \ - jh7110-visionfive-v2-A11.dtb \ - jh7110-visionfive-v2-wm8960.dtb \ - jh7110-visionfive-v2-ac108.dtb \ - jh7110-visionfive-v2-tdm.dtb + jh7110-starfive-visionfive-2-A10.dtb \ + jh7110-starfive-visionfive-2-A11.dtb \ + jh7110-starfive-visionfive-2-wm8960.dtb \ + jh7110-starfive-visionfive-2-ac108.dtb \ + jh7110-starfive-visionfive-2-tdm.dtb diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A10.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A10.dts new file mode 100644 index 000000000000..61169c769de2 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A10.dts @@ -0,0 +1,196 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + * For VisionFive2 version A1.0 + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2.dtsi" + +/ { + model = "StarFive VisionFive V2"; + compatible = "starfive,visionfive-v2", "starfive,jh7110"; +}; + +&gpio { + uart0_pins: uart0-pins { + uart0-pins-tx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + uart0-pins-rx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2c2_pins: i2c2-pins { + i2c2-pins-scl { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c2-pins-sda { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + mmc0_pins: mmc0-pins { + mmc0-pins-rest { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + sdcard1_pins: sdcard1-pins { + sdcard1-pins0 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + sdcard1-pins1 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins2 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins3 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins4 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins5 { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + inno_hdmi_pins: inno_hdmi-pins { + inno_hdmi-scl { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-sda { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-cec-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-hpd-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + pcie0_vbus_default: pcie0_vbus_default { + drive-vbus-pin { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; +}; + +&uart0 { + pinctrl-names = "default"; + pinctrl-0 = <&uart0_pins>; + status = "okay"; +}; + +&i2c2 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c2_pins>; + status = "okay"; +}; + +&mmc0 { + pinctrl-names = "default"; + pinctrl-0 = <&mmc0_pins>; + status = "okay"; +}; + +&mmc1 { + pinctrl-names = "default"; + pinctrl-0 = <&sdcard1_pins>; + status = "okay"; +}; + +&hdmi { + status = "okay"; + pinctrl-names = "default"; + pinctrl-0 = <&inno_hdmi_pins>; +}; + +&pcie0 { + pinctrl-names = "default", "perst-default", "perst-active"; + pinctrl-0 = <&pcie0_wake_default>, + <&pcie0_clkreq_default>, + <&pcie0_vbus_default>; + pinctrl-1 = <&pcie0_perst_default>; + pinctrl-2 = <&pcie0_perst_active>; + status = "okay"; +}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A11.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A11.dts new file mode 100644 index 000000000000..021cc31cd9b2 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-A11.dts @@ -0,0 +1,205 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + * For VisionFive2 version A1.1 + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2.dtsi" + +/ { + model = "StarFive VisionFive V2"; + compatible = "starfive,visionfive-v2", "starfive,jh7110"; + + gpio-restart { + compatible = "gpio-restart"; + gpios = <&gpio 35 GPIO_ACTIVE_HIGH>; + priority = <224>; + }; +}; + +&gpio { + uart0_pins: uart0-pins { + uart0-pins-tx { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + uart0-pins-rx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2c2_pins: i2c2-pins { + i2c2-pins-scl { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c2-pins-sda { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + mmc0_pins: mmc0-pins { + mmc0-pins-rest { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + sdcard1_pins: sdcard1-pins { + sdcard1-pins0 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + sdcard1-pins1 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins2 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins3 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins4 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins5 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + inno_hdmi_pins: inno_hdmi-pins { + inno_hdmi-scl { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-sda { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-cec-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-hpd-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + pcie0_vbus_default: pcie0_vbus_default { + drive-vbus-pin { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; +}; + +&uart0 { + pinctrl-names = "default"; + pinctrl-0 = <&uart0_pins>; + status = "okay"; +}; + +&i2c2 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c2_pins>; + status = "okay"; +}; + +&mmc0 { + pinctrl-names = "default"; + pinctrl-0 = <&mmc0_pins>; + status = "okay"; +}; + +&mmc1 { + pinctrl-names = "default"; + pinctrl-0 = <&sdcard1_pins>; + status = "okay"; +}; + +&hdmi { + status = "okay"; + pinctrl-names = "default"; + pinctrl-0 = <&inno_hdmi_pins>; +}; + +&pcie0 { + pinctrl-names = "default", "perst-default", "perst-active"; + pinctrl-0 = <&pcie0_wake_default>, + <&pcie0_clkreq_default>, + <&pcie0_vbus_default>; + pinctrl-1 = <&pcie0_perst_default>; + pinctrl-2 = <&pcie0_perst_active>; + status = "okay"; +}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-ac108.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-ac108.dts new file mode 100644 index 000000000000..9189b7ab2fa4 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-ac108.dts @@ -0,0 +1,23 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2-v1.3b.dts" +#include "codecs/sf_ac108.dtsi" + +&i2c0 { + ac108: ac108@3b { + compatible = "x-power,ac108_0"; + reg = <0x3b>; + #sound-dai-cells = <0>; + data-protocol = <0>; + }; +}; + +&i2srx_3ch { + status = "okay"; +}; + diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-tdm.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-tdm.dts new file mode 100644 index 000000000000..2ad90bc76c54 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-tdm.dts @@ -0,0 +1,22 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2-v1.3b.dts" +#include "codecs/sf_tdm.dtsi" + +&i2c0 { + wm8960: codec@1a { + compatible = "wlf,wm8960"; + reg = <0x1a>; + wlf,shared-lrclk; + #sound-dai-cells = <0>; + }; +}; + +&tdm { + status = "okay"; +}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-v1.3b.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-v1.3b.dts new file mode 100644 index 000000000000..13d683ac84de --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-v1.3b.dts @@ -0,0 +1,257 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2.dtsi" +#include "codecs/sf_hdmi.dtsi" + +/ { + model = "StarFive VisionFive V2"; + compatible = "starfive,visionfive-v2", "starfive,jh7110"; + + gpio-restart { + compatible = "gpio-restart"; + gpios = <&gpio 35 GPIO_ACTIVE_HIGH>; + priority = <160>; + }; +}; + +&gpio { + uart0_pins: uart0-pins { + uart0-pins-tx { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + uart0-pins-rx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2c2_pins: i2c2-pins { + i2c2-pins-scl { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c2-pins-sda { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + mmc0_pins: mmc0-pins { + mmc0-pins-rest { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + mmc0-pins-cLK { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-cmd { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data0 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data1 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data2 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data3 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data4 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data5 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data6 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + + mmc0-pins-data7 { + starfive,pins = ; + starfive,pin-ioconfig = ; + }; + }; + + sdcard1_pins: sdcard1-pins { + sdcard1-pins0 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + sdcard1-pins1 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins2 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins3 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins4 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + sdcard1-pins5 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + inno_hdmi_pins: inno_hdmi-pins { + inno_hdmi-scl { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-sda { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-cec-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-din = ; + }; + + inno_hdmi-hpd-pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + mclk_ext_pins: mclk_ext_pins { + mclk_ext_pins { + starfive,pins = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-din = ; + starfive,pin-gpio-doen = ; + }; + }; +}; + +&uart0 { + pinctrl-names = "default"; + pinctrl-0 = <&uart0_pins>; + status = "okay"; +}; + +&i2c2 { + pinctrl-names = "default"; + pinctrl-0 = <&i2c2_pins>; + status = "okay"; +}; + +&mmc0 { + pinctrl-names = "default"; + pinctrl-0 = <&mmc0_pins>; + status = "okay"; +}; + +&mmc1 { + pinctrl-names = "default"; + pinctrl-0 = <&sdcard1_pins>; + status = "okay"; +}; + +&hdmi { + pinctrl-names = "default"; + pinctrl-0 = <&inno_hdmi_pins>; + hpd-gpio = <&gpio 15 GPIO_ACTIVE_HIGH>; + status = "okay"; +}; + +&i2stx_4ch0 { + pinctrl-names = "default"; + pinctrl-0 = <&mclk_ext_pins>; + status = "okay"; +}; + +&cpu1 { + cpu-supply = <&cpu_vdd>; + clocks = <&clkgen JH7110_CPU_CORE>; + clock-names = "cpu"; +}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-wm8960.dts b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-wm8960.dts new file mode 100644 index 000000000000..fd2b9d6dec60 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-wm8960.dts @@ -0,0 +1,26 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + */ + +/dts-v1/; +#include "jh7110-starfive-visionfive-2-v1.3b.dts" +#include "codecs/sf_wm8960.dtsi" + +&i2c0 { + wm8960: codec@1a { + compatible = "wlf,wm8960"; + reg = <0x1a>; + wlf,shared-lrclk; + #sound-dai-cells = <0>; + }; +}; + +&i2srx_3ch { + status = "okay"; +}; + +&i2stx_4ch1 { + status = "okay"; +}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi new file mode 100644 index 000000000000..1014f0aa72c0 --- /dev/null +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi @@ -0,0 +1,1049 @@ +// SPDX-License-Identifier: GPL-2.0 OR MIT +/* + * Copyright (C) 2022 StarFive Technology Co., Ltd. + * Copyright (C) 2022 Hal Feng + */ + +/dts-v1/; +#include +#include +#include +#include "jh7110.dtsi" +#include "codecs/sf_pwmdac.dtsi" + +/ { + model = "StarFive VisionFive V2"; + compatible = "starfive,visionfive-v2", "starfive,jh7110"; + + aliases { + spi0 = &qspi; + gpio0 = &gpio; + ethernet0 = &gmac0; + ethernet1 = &gmac1; + mmc0 = &mmc0; + mmc1 = &mmc1; + serial0 = &uart0; + serial3 = &uart3; + i2c0 = &i2c0; + i2c1 = &i2c1; + i2c2 = &i2c2; + i2c3 = &i2c3; + i2c4 = &i2c4; + i2c5 = &i2c5; + i2c6 = &i2c6; + }; + + chosen { + linux,initrd-start = <0x0 0x46100000>; + linux,initrd-end = <0x0 0x4c000000>; + stdout-path = "serial0:115200"; + #bootargs = "debug console=ttyS0 rootwait"; + }; + + cpus { + timebase-frequency = <4000000>; + }; + + memory@40000000 { + device_type = "memory"; + reg = <0x0 0x40000000 0x1 0x0>; + }; + + reserved-memory { + #address-cells = <2>; + #size-cells = <2>; + ranges; + + linux,cma { + compatible = "shared-dma-pool"; + reusable; + size = <0x0 0x20000000>; + alignment = <0x0 0x1000>; + alloc-ranges = <0x0 0x70000000 0x0 0x20000000>; + linux,cma-default; + }; + + e24_mem: e24@c0000000 { + reg = <0x0 0x6ce00000 0x0 0x1600000>; + }; + + xrp_reserved: xrpbuffer@f0000000 { + reg = <0x0 0x69c00000 0x0 0x01ffffff + 0x0 0x6bc00000 0x0 0x00001000 + 0x0 0x6bc01000 0x0 0x00fff000 + 0x0 0x6cc00000 0x0 0x00001000>; + }; + }; + + leds { + compatible = "gpio-leds"; + + led-ack { + gpios = <&gpioa 3 GPIO_ACTIVE_HIGH>; + color = ; + function = LED_FUNCTION_HEARTBEAT; + linux,default-trigger = "heartbeat"; + label = "ack"; + }; + }; + + thermal-zones { + cpu-thermal { + polling-delay-passive = <250>; + polling-delay = <15000>; + + thermal-sensors = <&sfctemp>; + + trips { + cpu_alert0: cpu_alert0 { + /* milliCelsius */ + temperature = <85000>; + hysteresis = <2000>; + type = "passive"; + }; + + cpu_crit: cpu_crit { + /* milliCelsius */ + temperature = <100000>; + hysteresis = <0>; + type = "critical"; + }; + }; + + cooling-maps { + map0 { + trip = <&cpu_alert0>; + cooling-device = + <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, + <&cpu1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, + <&cpu2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, + <&cpu3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; + }; + }; + }; + }; +}; + +&gpio { + i2c0_pins: i2c0-pins { + i2c0-pins-scl { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c0-pins-sda { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2c5_pins: i2c5-pins { + i2c5-pins-scl { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c5-pins-sda { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2c6_pins: i2c6-pins { + i2c6-pins-scl { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + i2c6-pins-sda { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + pwmdac0_pins: pwmdac0-pins { + pwmdac0-pins-left { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + pwmdac0-pins-right { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pwm_pins: pwm-pins { + pwm_ch0-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + pwm_ch1-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + ssp0_pins: ssp0-pins { + ssp0-pins_tx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + ssp0-pins_rx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + ssp0-pins_clk { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + ssp0-pins_cs { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie0_perst_default: pcie0_perst_default { + perst-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie0_perst_active: pcie0_perst_active { + perst-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie0_wake_default: pcie0_wake_default { + wake-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie0_clkreq_default: pcie0_clkreq_default { + clkreq-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie1_perst_default: pcie1_perst_default { + perst-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie1_perst_active: pcie1_perst_active { + perst-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie1_wake_default: pcie1_wake_default { + wake-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + }; + }; + + pcie1_clkreq_default: pcie1_clkreq_default { + clkreq-pins { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + }; + }; + + usb_pins: usb-pins { + drive-vbus-pin { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + i2srx_pins: i2srx-pins { + i2srx-pins0 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; + + i2s_clk_pins: i2s-clk0 { + i2s-clk0_bclk { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-din = ; + starfive,pin-gpio-doen = ; + }; + + i2s-clk0_lrclk { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-din = ; + starfive,pin-gpio-doen = ; + }; + }; + + i2stx_pins: i2stx-pins { + i2stx-pins0 { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + }; + + tdm0_pins: tdm0-pins { + tdm0-pins-tx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-dout = ; + starfive,pin-gpio-doen = ; + }; + + tdm0-pins-rx { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + tdm0-pins-sync { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + + tdm0-pins-pcmclk { + starfive,pins = ; + starfive,pinmux = ; + starfive,pin-ioconfig = ; + starfive,pin-gpio-doen = ; + starfive,pin-gpio-din = ; + }; + }; +}; + +&uart0 { + status = "okay"; +}; + +&dma { + status = "okay"; +}; + +&trng { + status = "okay"; +}; + +&crypto { + status = "okay"; +}; + +&sec_dma { + status = "okay"; +}; + +&i2c0 { + clock-frequency = <100000>; + i2c-sda-hold-time-ns = <300>; + i2c-sda-falling-time-ns = <510>; + i2c-scl-falling-time-ns = <510>; + auto_calc_scl_lhcnt; + pinctrl-names = "default"; + pinctrl-0 = <&i2c0_pins>; + status = "okay"; +}; + +&i2c2 { + clock-frequency = <100000>; + i2c-sda-hold-time-ns = <300>; + i2c-sda-falling-time-ns = <510>; + i2c-scl-falling-time-ns = <510>; + auto_calc_scl_lhcnt; + status = "okay"; + + seeed_plane_i2c@45 { + compatible = "seeed_panel"; + reg = <0x45>; + + port { + panel_out0: endpoint { + remote-endpoint = <&dsi0_output>; + }; + }; + }; + + tinker_ft5406: tinker_ft5406@38 { + compatible = "tinker_ft5406"; + reg = <0x38>; + }; + + touchscreen@14 { + compatible = "goodix,gt911"; + reg = <0x14>; + irq-gpios = <&gpio 30 GPIO_ACTIVE_HIGH>; + reset-gpios = <&gpio 31 GPIO_ACTIVE_HIGH>; + }; + + panel_radxa@19 { + compatible ="starfive_jadard"; + reg = <0x19>; + reset-gpio = <&gpio 23 0>; + enable-gpio = <&gpio 22 0>; + + port { + panel_out1: endpoint { + remote-endpoint = <&dsi1_output>; + }; + }; + }; + +}; + +&i2c5 { + clock-frequency = <100000>; + i2c-sda-hold-time-ns = <300>; + i2c-sda-falling-time-ns = <510>; + i2c-scl-falling-time-ns = <510>; + auto_calc_scl_lhcnt; + pinctrl-names = "default"; + pinctrl-0 = <&i2c5_pins>; + status = "okay"; + + eeprom@50 { + compatible = "atmel,24c04"; + reg = <0x50>; + pagesize = <16>; + }; + + pmic: axp15060_reg@36 { + compatible = "x-powers,axp15060"; + reg = <0x36>; + + regulators { + mipi_0p9: ALDO1 { + regulator-boot-on; + regulator-compatible = "aldo1"; + regulator-name = "mipi_0p9"; + regulator-min-microvolt = <900000>; + regulator-max-microvolt = <900000>; + }; + + hdmi_0p9: ALDO5 { + regulator-boot-on; + regulator-compatible = "aldo5"; + regulator-name = "hdmi_0p9"; + regulator-min-microvolt = <900000>; + regulator-max-microvolt = <900000>; + }; + + hdmi_1p8: ALDO3 { + regulator-boot-on; + regulator-compatible = "aldo3"; + regulator-name = "hdmi_1p8"; + regulator-min-microvolt = <1800000>; + regulator-max-microvolt = <1800000>; + }; + + sdio_vdd: ALDO4 { + regulator-boot-on; + regulator-always-on; + regulator-compatible = "aldo4"; + regulator-name = "sdio_vdd"; + regulator-min-microvolt = <1800000>; + regulator-max-microvolt = <1800000>; + }; + + vcc_3v3: DCDC1 { + regulator-boot-on; + regulator-always-on; + regulator-compatible = "dcdc1"; + regulator-name = "vcc_3v3"; + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + }; + + cpu_vdd: DCDC2 { + regulator-boot-on; + regulator-always-on; + regulator-compatible = "dcdc2"; + regulator-name = "cpu_vdd"; + regulator-min-microvolt = <500000>; + regulator-max-microvolt = <1540000>; + }; + }; + }; +}; + +&i2c6 { + clock-frequency = <100000>; + i2c-sda-hold-time-ns = <300>; + i2c-sda-falling-time-ns = <510>; + i2c-scl-falling-time-ns = <510>; + auto_calc_scl_lhcnt; + pinctrl-names = "default"; + pinctrl-0 = <&i2c6_pins>; + status = "okay"; + + imx219: imx219@10 { + compatible = "sony,imx219"; + reg = <0x10>; + clocks = <&clk_ext_camera>; + clock-names = "xclk"; + reset-gpio = <&gpio 18 0>; + rotation = <0>; + orientation = <1>; //CAMERA_ORIENTATION_BACK + + port { + /* CSI2 bus endpoint */ + imx219_to_csi2rx0: endpoint { + remote-endpoint = <&csi2rx0_from_imx219>; + bus-type = <4>; /* MIPI CSI-2 D-PHY */ + clock-lanes = <4>; + data-lanes = <0 1>; + lane-polarities = <0 0 0>; + link-frequencies = /bits/ 64 <456000000>; + }; + }; + }; + + imx708: imx708@1a { + compatible = "sony,imx708"; + reg = <0x1a>; + clocks = <&clk_ext_camera>; + reset-gpio = <&gpio 18 0>; + + port { + imx708_to_csi2rx0: endpoint { + remote-endpoint = <&csi2rx0_from_imx708>; + data-lanes = <1 2>; + clock-noncontinuous; + link-frequencies = /bits/ 64 <450000000>; + }; + }; + }; + + ov4689: ov4689@36 { + compatible = "ovti,ov4689"; + reg = <0x36>; + clocks = <&clk_ext_camera>; + clock-names = "xclk"; + rotation = <180>; + + port { + /* Parallel bus endpoint */ + ov4689_to_csi2rx0: endpoint { + remote-endpoint = <&csi2rx0_from_ov4689>; + bus-type = <4>; /* MIPI CSI-2 D-PHY */ + clock-lanes = <0>; + data-lanes = <1 2>; + }; + }; + }; +}; + +&mmc0 { + max-frequency = <100000000>; + assigned-clocks = <&clkgen JH7110_SDIO0_CLK_SDCARD>; + assigned-clock-rates = <50000000>; + card-detect-delay = <300>; + bus-width = <8>; + cap-mmc-highspeed; + mmc-hs200-1_8v; + non-removable; + cap-mmc-hw-reset; + post-power-on-delay-ms = <200>; + vmmc-supply = <&vcc_3v3>; + vqmmc-supply = <&sdio_vdd>; + status = "okay"; +}; + +&mmc1 { + max-frequency = <100000000>; + assigned-clocks = <&clkgen JH7110_SDIO1_CLK_SDCARD>; + assigned-clock-rates = <50000000>; + card-detect-delay = <300>; + bus-width = <4>; + no-sdio; + no-mmc; + broken-cd; + cap-sd-highspeed; + post-power-on-delay-ms = <200>; + status = "okay"; +}; + +&vin_sysctl { + /* when use dvp open this pinctrl*/ + status = "okay"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@1 { + reg = <1>; + #address-cells = <1>; + #size-cells = <0>; + + /* CSI2 bus endpoint */ + csi2rx0_from_imx219: endpoint@0 { + reg = <0>; + remote-endpoint = <&imx219_to_csi2rx0>; + bus-type = <4>; /* MIPI CSI-2 D-PHY */ + clock-lanes = <4>; + data-lanes = <0 1>; + lane-polarities = <0 0 0>; + status = "okay"; + }; + + csi2rx0_from_imx708: endpoint@1 { + reg = <1>; + remote-endpoint = <&imx708_to_csi2rx0>; + bus-type = <4>; /* MIPI CSI-2 D-PHY */ + clock-lanes = <4>; + data-lanes = <0 1>; + lane-polarities = <0 0 0>; + status = "okay"; + }; + + csi2rx0_from_ov4689: endpoint@2 { + reg = <2>; + remote-endpoint = <&ov4689_to_csi2rx0>; + bus-type = <4>; /* MIPI CSI-2 D-PHY */ + clock-lanes = <4>; + data-lanes = <0 1>; + status = "okay"; + }; + }; + }; +}; + +&sfctemp { + status = "okay"; +}; + +&jpu { + status = "okay"; +}; + +&vpu_dec { + status = "okay"; +}; + +&vpu_enc { + status = "okay"; +}; + +&gmac0 { + status = "okay"; + #address-cells = <1>; + #size-cells = <0>; + clock-names = "gtx", + "tx", + "ptp_ref", + "stmmaceth", + "pclk", + "gtxc", + "rmii_rtx"; + clocks = <&clkgen JH7110_GMAC0_GTXCLK>, + <&clkgen JH7110_U0_GMAC5_CLK_TX>, + <&clkgen JH7110_GMAC0_PTP>, + <&clkgen JH7110_U0_GMAC5_CLK_AHB>, + <&clkgen JH7110_U0_GMAC5_CLK_AXI>, + <&clkgen JH7110_GMAC0_GTXC>, + <&clkgen JH7110_GMAC0_RMII_RTX>; + + phy0: ethernet-phy@0 { + rgmii_sw_dr_2 = <0x0>; + rgmii_sw_dr = <0x3>; + rgmii_sw_dr_rxc = <0x6>; + rxc_dly_en = <0>; + rx_delay_sel = <0xa>; + tx_delay_sel_fe = <5>; + tx_delay_sel = <0xa>; + tx_inverted_10 = <0x1>; + tx_inverted_100 = <0x1>; + tx_inverted_1000 = <0x1>; + }; +}; + +&gmac1 { + #address-cells = <1>; + #size-cells = <0>; + status = "okay"; + clock-names = "gtx", + "tx", + "ptp_ref", + "stmmaceth", + "pclk", + "gtxc", + "rmii_rtx"; + clocks = <&clkgen JH7110_GMAC1_GTXCLK>, + <&clkgen JH7110_GMAC5_CLK_TX>, + <&clkgen JH7110_GMAC5_CLK_PTP>, + <&clkgen JH7110_GMAC5_CLK_AHB>, + <&clkgen JH7110_GMAC5_CLK_AXI>, + <&clkgen JH7110_GMAC1_GTXC>, + <&clkgen JH7110_GMAC1_RMII_RTX>; + + phy1: ethernet-phy@1 { + rgmii_sw_dr_2 = <0x0>; + rgmii_sw_dr = <0x3>; + rgmii_sw_dr_rxc = <0x6>; + tx_delay_sel_fe = <5>; + tx_delay_sel = <0>; + rxc_dly_en = <0>; + rx_delay_sel = <0x2>; + tx_inverted_10 = <0x1>; + tx_inverted_100 = <0x1>; + tx_inverted_1000 = <0x0>; + }; +}; + +&gpu { + status = "okay"; +}; + +&pwmdac { + pinctrl-names = "default"; + pinctrl-0 = <&pwmdac0_pins>; + status = "okay"; +}; + +&i2srx_3ch { + pinctrl-names = "default"; + pinctrl-0 = <&i2s_clk_pins &i2srx_pins>; + status = "disabled"; +}; + +&i2stx_4ch1 { + pinctrl-names = "default"; + pinctrl-0 = <&i2stx_pins>; + status = "disabled"; +}; + +&tdm { + pinctrl-names = "default"; + pinctrl-0 = <&tdm0_pins>; + status = "disabled"; +}; + +&pwmdac_codec { + status = "okay"; +}; + +&spi0 { + pinctrl-names = "default"; + pinctrl-0 = <&ssp0_pins>; + status = "okay"; + + spi_dev0: spi@0 { + compatible = "rohm,dh2228fv"; + pl022,com-mode = <1>; + spi-max-frequency = <10000000>; + reg = <0>; + status = "okay"; + }; +}; + +&pcie0 { + pinctrl-names = "default"; + pinctrl-0 = <&pcie0_wake_default>, + <&pcie0_clkreq_default>; + reset-gpios = <&gpio 26 GPIO_ACTIVE_LOW>; + status = "okay"; +}; + +&pcie1 { + pinctrl-names = "default"; + pinctrl-0 = <&pcie1_wake_default>, + <&pcie1_clkreq_default>; + reset-gpios = <&gpio 28 GPIO_ACTIVE_LOW>; + status = "okay"; +}; + +&mailbox_contrl0 { + status = "okay"; +}; + +&mailbox_client0 { + status = "okay"; +}; + +&display { + status = "okay"; +}; + +&hdmi { + status = "okay"; + + hdmi_in: port { + #address-cells = <1>; + #size-cells = <0>; + hdmi_in_lcdc: endpoint@0 { + reg = <0>; + remote-endpoint = <&dc_out_dpi1>; + }; + }; +}; + +&dc8200 { + status = "okay"; + + dc_out: port { + #address-cells = <1>; + #size-cells = <0>; + dc_out_dpi0: endpoint@0 { + reg = <0>; + remote-endpoint = <&hdmi_input0>; + }; + dc_out_dpi1: endpoint@1 { + reg = <1>; + remote-endpoint = <&hdmi_in_lcdc>; + }; + + dc_out_dpi2: endpoint@2 { + reg = <2>; + remote-endpoint = <&mipi_in>; + }; + }; +}; + +&rgb_output { + status = "disabled"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + port@0 { + #address-cells = <1>; + #size-cells = <0>; + reg = <0>; + hdmi_input0:endpoint@0 { + reg = <0>; + remote-endpoint = <&dc_out_dpi0>; + }; + }; + }; +}; + +&dsi_output { + status = "okay"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + mipi_in: endpoint { + remote-endpoint = <&dc_out_dpi2>; + }; + }; + + port@1 { + reg = <1>; + sf_dpi_output: endpoint { + remote-endpoint = <&dsi_in_port>; + }; + }; + }; +}; + +&mipi_dsi { + status = "okay"; + + ports { + #address-cells = <1>; + #size-cells = <0>; + + port@0 { + reg = <0>; + #address-cells = <1>; + #size-cells = <0>; + + dsi0_output: endpoint@0 { + reg = <0>; + remote-endpoint = <&panel_out0>; + }; + + dsi1_output: endpoint@1 { + reg = <1>; + remote-endpoint = <&panel_out1>; + }; + + }; + + port@1{ + reg = <1>; + dsi_in_port: endpoint { + remote-endpoint = <&sf_dpi_output>; + }; + }; + + }; +}; + +&mipi_dphy { + status = "okay"; +}; + +&co_process { + memory-region = <&e24_mem>; + status = "okay"; +}; + +&usbdrd30 { + clocks = <&clkgen JH7110_USB_125M>, + <&clkgen JH7110_USB0_CLK_APP_125>, + <&clkgen JH7110_USB0_CLK_LPM>, + <&clkgen JH7110_USB0_CLK_STB>, + <&clkgen JH7110_USB0_CLK_USB_APB>, + <&clkgen JH7110_USB0_CLK_AXI>, + <&clkgen JH7110_USB0_CLK_UTMI_APB>; + clock-names = "125m","app","lpm","stb","apb","axi","utmi"; + resets = <&rstgen RSTN_U0_CDN_USB_PWRUP>, + <&rstgen RSTN_U0_CDN_USB_APB>, + <&rstgen RSTN_U0_CDN_USB_AXI>, + <&rstgen RSTN_U0_CDN_USB_UTMI_APB>; + reset-names = "pwrup","apb","axi","utmi"; + starfive,usb2-only; + dr_mode = "peripheral"; /*host or peripheral*/ + status = "okay"; +}; + +&xrp { + memory-region = <&xrp_reserved>; + status = "okay"; +}; + +&ptc { + pinctrl-names = "default"; + pinctrl-0 = <&pwm_pins>; + status = "okay"; +}; + +&qspi { + nor_flash: nor-flash@0 { + compatible = "jedec,spi-nor"; + reg=<0>; + cdns,read-delay = <5>; + spi-max-frequency = <100000000>; + cdns,tshsl-ns = <1>; + cdns,tsd2d-ns = <1>; + cdns,tchsh-ns = <1>; + cdns,tslch-ns = <1>; + status = "okay"; + + partitions { + compatible = "fixed-partitions"; + #address-cells = <1>; + #size-cells = <1>; + + spl@0 { + reg = <0x0 0x40000>; + }; + uboot-env@100000 { + reg = <0xf0000 0x10000>; + }; + uboot@100000 { + reg = <0x100000 0x300000>; + }; + data@f00000 { + reg = <0xf00000 0x100000>; + }; + }; + }; +}; + diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A10.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A10.dts deleted file mode 100644 index fc99123baa3c..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A10.dts +++ /dev/null @@ -1,196 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - * For VisionFive2 version A1.0 - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dtsi" - -/ { - model = "StarFive VisionFive V2"; - compatible = "starfive,visionfive-v2", "starfive,jh7110"; -}; - -&gpio { - uart0_pins: uart0-pins { - uart0-pins-tx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - uart0-pins-rx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2c2_pins: i2c2-pins { - i2c2-pins-scl { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c2-pins-sda { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - mmc0_pins: mmc0-pins { - mmc0-pins-rest { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - sdcard1_pins: sdcard1-pins { - sdcard1-pins0 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - sdcard1-pins1 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins2 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins3 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins4 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins5 { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - inno_hdmi_pins: inno_hdmi-pins { - inno_hdmi-scl { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-sda { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-cec-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-hpd-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - pcie0_vbus_default: pcie0_vbus_default { - drive-vbus-pin { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; -}; - -&uart0 { - pinctrl-names = "default"; - pinctrl-0 = <&uart0_pins>; - status = "okay"; -}; - -&i2c2 { - pinctrl-names = "default"; - pinctrl-0 = <&i2c2_pins>; - status = "okay"; -}; - -&mmc0 { - pinctrl-names = "default"; - pinctrl-0 = <&mmc0_pins>; - status = "okay"; -}; - -&mmc1 { - pinctrl-names = "default"; - pinctrl-0 = <&sdcard1_pins>; - status = "okay"; -}; - -&hdmi { - status = "okay"; - pinctrl-names = "default"; - pinctrl-0 = <&inno_hdmi_pins>; -}; - -&pcie0 { - pinctrl-names = "default", "perst-default", "perst-active"; - pinctrl-0 = <&pcie0_wake_default>, - <&pcie0_clkreq_default>, - <&pcie0_vbus_default>; - pinctrl-1 = <&pcie0_perst_default>; - pinctrl-2 = <&pcie0_perst_active>; - status = "okay"; -}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A11.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A11.dts deleted file mode 100644 index 228807aebe67..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-A11.dts +++ /dev/null @@ -1,205 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - * For VisionFive2 version A1.1 - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dtsi" - -/ { - model = "StarFive VisionFive V2"; - compatible = "starfive,visionfive-v2", "starfive,jh7110"; - - gpio-restart { - compatible = "gpio-restart"; - gpios = <&gpio 35 GPIO_ACTIVE_HIGH>; - priority = <224>; - }; -}; - -&gpio { - uart0_pins: uart0-pins { - uart0-pins-tx { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - uart0-pins-rx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2c2_pins: i2c2-pins { - i2c2-pins-scl { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c2-pins-sda { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - mmc0_pins: mmc0-pins { - mmc0-pins-rest { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - sdcard1_pins: sdcard1-pins { - sdcard1-pins0 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - sdcard1-pins1 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins2 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins3 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins4 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins5 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - inno_hdmi_pins: inno_hdmi-pins { - inno_hdmi-scl { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-sda { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-cec-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-hpd-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - pcie0_vbus_default: pcie0_vbus_default { - drive-vbus-pin { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; -}; - -&uart0 { - pinctrl-names = "default"; - pinctrl-0 = <&uart0_pins>; - status = "okay"; -}; - -&i2c2 { - pinctrl-names = "default"; - pinctrl-0 = <&i2c2_pins>; - status = "okay"; -}; - -&mmc0 { - pinctrl-names = "default"; - pinctrl-0 = <&mmc0_pins>; - status = "okay"; -}; - -&mmc1 { - pinctrl-names = "default"; - pinctrl-0 = <&sdcard1_pins>; - status = "okay"; -}; - -&hdmi { - status = "okay"; - pinctrl-names = "default"; - pinctrl-0 = <&inno_hdmi_pins>; -}; - -&pcie0 { - pinctrl-names = "default", "perst-default", "perst-active"; - pinctrl-0 = <&pcie0_wake_default>, - <&pcie0_clkreq_default>, - <&pcie0_vbus_default>; - pinctrl-1 = <&pcie0_perst_default>; - pinctrl-2 = <&pcie0_perst_active>; - status = "okay"; -}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-ac108.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-ac108.dts deleted file mode 100644 index d590513531da..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-ac108.dts +++ /dev/null @@ -1,23 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dts" -#include "codecs/sf_ac108.dtsi" - -&i2c0 { - ac108: ac108@3b { - compatible = "x-power,ac108_0"; - reg = <0x3b>; - #sound-dai-cells = <0>; - data-protocol = <0>; - }; -}; - -&i2srx_3ch { - status = "okay"; -}; - diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-tdm.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-tdm.dts deleted file mode 100644 index 1d8543a23c0e..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-tdm.dts +++ /dev/null @@ -1,22 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dts" -#include "codecs/sf_tdm.dtsi" - -&i2c0 { - wm8960: codec@1a { - compatible = "wlf,wm8960"; - reg = <0x1a>; - wlf,shared-lrclk; - #sound-dai-cells = <0>; - }; -}; - -&tdm { - status = "okay"; -}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-wm8960.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-wm8960.dts deleted file mode 100644 index dd6abc5177eb..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2-wm8960.dts +++ /dev/null @@ -1,26 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dts" -#include "codecs/sf_wm8960.dtsi" - -&i2c0 { - wm8960: codec@1a { - compatible = "wlf,wm8960"; - reg = <0x1a>; - wlf,shared-lrclk; - #sound-dai-cells = <0>; - }; -}; - -&i2srx_3ch { - status = "okay"; -}; - -&i2stx_4ch1 { - status = "okay"; -}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dts b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dts deleted file mode 100644 index 3bab214ad73b..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dts +++ /dev/null @@ -1,257 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - */ - -/dts-v1/; -#include "jh7110-visionfive-v2.dtsi" -#include "codecs/sf_hdmi.dtsi" - -/ { - model = "StarFive VisionFive V2"; - compatible = "starfive,visionfive-v2", "starfive,jh7110"; - - gpio-restart { - compatible = "gpio-restart"; - gpios = <&gpio 35 GPIO_ACTIVE_HIGH>; - priority = <160>; - }; -}; - -&gpio { - uart0_pins: uart0-pins { - uart0-pins-tx { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - uart0-pins-rx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2c2_pins: i2c2-pins { - i2c2-pins-scl { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c2-pins-sda { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - mmc0_pins: mmc0-pins { - mmc0-pins-rest { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - mmc0-pins-cLK { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-cmd { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data0 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data1 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data2 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data3 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data4 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data5 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data6 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - - mmc0-pins-data7 { - starfive,pins = ; - starfive,pin-ioconfig = ; - }; - }; - - sdcard1_pins: sdcard1-pins { - sdcard1-pins0 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - sdcard1-pins1 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins2 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins3 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins4 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - sdcard1-pins5 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - inno_hdmi_pins: inno_hdmi-pins { - inno_hdmi-scl { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-sda { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-cec-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-din = ; - }; - - inno_hdmi-hpd-pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - mclk_ext_pins: mclk_ext_pins { - mclk_ext_pins { - starfive,pins = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-din = ; - starfive,pin-gpio-doen = ; - }; - }; -}; - -&uart0 { - pinctrl-names = "default"; - pinctrl-0 = <&uart0_pins>; - status = "okay"; -}; - -&i2c2 { - pinctrl-names = "default"; - pinctrl-0 = <&i2c2_pins>; - status = "okay"; -}; - -&mmc0 { - pinctrl-names = "default"; - pinctrl-0 = <&mmc0_pins>; - status = "okay"; -}; - -&mmc1 { - pinctrl-names = "default"; - pinctrl-0 = <&sdcard1_pins>; - status = "okay"; -}; - -&hdmi { - pinctrl-names = "default"; - pinctrl-0 = <&inno_hdmi_pins>; - hpd-gpio = <&gpio 15 GPIO_ACTIVE_HIGH>; - status = "okay"; -}; - -&i2stx_4ch0 { - pinctrl-names = "default"; - pinctrl-0 = <&mclk_ext_pins>; - status = "okay"; -}; - -&cpu1 { - cpu-supply = <&cpu_vdd>; - clocks = <&clkgen JH7110_CPU_CORE>; - clock-names = "cpu"; -}; diff --git a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dtsi b/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dtsi deleted file mode 100644 index 1014f0aa72c0..000000000000 --- a/arch/riscv/boot/dts/starfive/jh7110-visionfive-v2.dtsi +++ /dev/null @@ -1,1049 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 OR MIT -/* - * Copyright (C) 2022 StarFive Technology Co., Ltd. - * Copyright (C) 2022 Hal Feng - */ - -/dts-v1/; -#include -#include -#include -#include "jh7110.dtsi" -#include "codecs/sf_pwmdac.dtsi" - -/ { - model = "StarFive VisionFive V2"; - compatible = "starfive,visionfive-v2", "starfive,jh7110"; - - aliases { - spi0 = &qspi; - gpio0 = &gpio; - ethernet0 = &gmac0; - ethernet1 = &gmac1; - mmc0 = &mmc0; - mmc1 = &mmc1; - serial0 = &uart0; - serial3 = &uart3; - i2c0 = &i2c0; - i2c1 = &i2c1; - i2c2 = &i2c2; - i2c3 = &i2c3; - i2c4 = &i2c4; - i2c5 = &i2c5; - i2c6 = &i2c6; - }; - - chosen { - linux,initrd-start = <0x0 0x46100000>; - linux,initrd-end = <0x0 0x4c000000>; - stdout-path = "serial0:115200"; - #bootargs = "debug console=ttyS0 rootwait"; - }; - - cpus { - timebase-frequency = <4000000>; - }; - - memory@40000000 { - device_type = "memory"; - reg = <0x0 0x40000000 0x1 0x0>; - }; - - reserved-memory { - #address-cells = <2>; - #size-cells = <2>; - ranges; - - linux,cma { - compatible = "shared-dma-pool"; - reusable; - size = <0x0 0x20000000>; - alignment = <0x0 0x1000>; - alloc-ranges = <0x0 0x70000000 0x0 0x20000000>; - linux,cma-default; - }; - - e24_mem: e24@c0000000 { - reg = <0x0 0x6ce00000 0x0 0x1600000>; - }; - - xrp_reserved: xrpbuffer@f0000000 { - reg = <0x0 0x69c00000 0x0 0x01ffffff - 0x0 0x6bc00000 0x0 0x00001000 - 0x0 0x6bc01000 0x0 0x00fff000 - 0x0 0x6cc00000 0x0 0x00001000>; - }; - }; - - leds { - compatible = "gpio-leds"; - - led-ack { - gpios = <&gpioa 3 GPIO_ACTIVE_HIGH>; - color = ; - function = LED_FUNCTION_HEARTBEAT; - linux,default-trigger = "heartbeat"; - label = "ack"; - }; - }; - - thermal-zones { - cpu-thermal { - polling-delay-passive = <250>; - polling-delay = <15000>; - - thermal-sensors = <&sfctemp>; - - trips { - cpu_alert0: cpu_alert0 { - /* milliCelsius */ - temperature = <85000>; - hysteresis = <2000>; - type = "passive"; - }; - - cpu_crit: cpu_crit { - /* milliCelsius */ - temperature = <100000>; - hysteresis = <0>; - type = "critical"; - }; - }; - - cooling-maps { - map0 { - trip = <&cpu_alert0>; - cooling-device = - <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, - <&cpu1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, - <&cpu2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, - <&cpu3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; - }; - }; - }; - }; -}; - -&gpio { - i2c0_pins: i2c0-pins { - i2c0-pins-scl { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c0-pins-sda { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2c5_pins: i2c5-pins { - i2c5-pins-scl { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c5-pins-sda { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2c6_pins: i2c6-pins { - i2c6-pins-scl { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - i2c6-pins-sda { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - pwmdac0_pins: pwmdac0-pins { - pwmdac0-pins-left { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - pwmdac0-pins-right { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pwm_pins: pwm-pins { - pwm_ch0-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - pwm_ch1-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - ssp0_pins: ssp0-pins { - ssp0-pins_tx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - ssp0-pins_rx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - ssp0-pins_clk { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - ssp0-pins_cs { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie0_perst_default: pcie0_perst_default { - perst-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie0_perst_active: pcie0_perst_active { - perst-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie0_wake_default: pcie0_wake_default { - wake-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie0_clkreq_default: pcie0_clkreq_default { - clkreq-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie1_perst_default: pcie1_perst_default { - perst-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie1_perst_active: pcie1_perst_active { - perst-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie1_wake_default: pcie1_wake_default { - wake-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - }; - }; - - pcie1_clkreq_default: pcie1_clkreq_default { - clkreq-pins { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - }; - }; - - usb_pins: usb-pins { - drive-vbus-pin { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - i2srx_pins: i2srx-pins { - i2srx-pins0 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; - - i2s_clk_pins: i2s-clk0 { - i2s-clk0_bclk { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-din = ; - starfive,pin-gpio-doen = ; - }; - - i2s-clk0_lrclk { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-din = ; - starfive,pin-gpio-doen = ; - }; - }; - - i2stx_pins: i2stx-pins { - i2stx-pins0 { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - }; - - tdm0_pins: tdm0-pins { - tdm0-pins-tx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-dout = ; - starfive,pin-gpio-doen = ; - }; - - tdm0-pins-rx { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - tdm0-pins-sync { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - - tdm0-pins-pcmclk { - starfive,pins = ; - starfive,pinmux = ; - starfive,pin-ioconfig = ; - starfive,pin-gpio-doen = ; - starfive,pin-gpio-din = ; - }; - }; -}; - -&uart0 { - status = "okay"; -}; - -&dma { - status = "okay"; -}; - -&trng { - status = "okay"; -}; - -&crypto { - status = "okay"; -}; - -&sec_dma { - status = "okay"; -}; - -&i2c0 { - clock-frequency = <100000>; - i2c-sda-hold-time-ns = <300>; - i2c-sda-falling-time-ns = <510>; - i2c-scl-falling-time-ns = <510>; - auto_calc_scl_lhcnt; - pinctrl-names = "default"; - pinctrl-0 = <&i2c0_pins>; - status = "okay"; -}; - -&i2c2 { - clock-frequency = <100000>; - i2c-sda-hold-time-ns = <300>; - i2c-sda-falling-time-ns = <510>; - i2c-scl-falling-time-ns = <510>; - auto_calc_scl_lhcnt; - status = "okay"; - - seeed_plane_i2c@45 { - compatible = "seeed_panel"; - reg = <0x45>; - - port { - panel_out0: endpoint { - remote-endpoint = <&dsi0_output>; - }; - }; - }; - - tinker_ft5406: tinker_ft5406@38 { - compatible = "tinker_ft5406"; - reg = <0x38>; - }; - - touchscreen@14 { - compatible = "goodix,gt911"; - reg = <0x14>; - irq-gpios = <&gpio 30 GPIO_ACTIVE_HIGH>; - reset-gpios = <&gpio 31 GPIO_ACTIVE_HIGH>; - }; - - panel_radxa@19 { - compatible ="starfive_jadard"; - reg = <0x19>; - reset-gpio = <&gpio 23 0>; - enable-gpio = <&gpio 22 0>; - - port { - panel_out1: endpoint { - remote-endpoint = <&dsi1_output>; - }; - }; - }; - -}; - -&i2c5 { - clock-frequency = <100000>; - i2c-sda-hold-time-ns = <300>; - i2c-sda-falling-time-ns = <510>; - i2c-scl-falling-time-ns = <510>; - auto_calc_scl_lhcnt; - pinctrl-names = "default"; - pinctrl-0 = <&i2c5_pins>; - status = "okay"; - - eeprom@50 { - compatible = "atmel,24c04"; - reg = <0x50>; - pagesize = <16>; - }; - - pmic: axp15060_reg@36 { - compatible = "x-powers,axp15060"; - reg = <0x36>; - - regulators { - mipi_0p9: ALDO1 { - regulator-boot-on; - regulator-compatible = "aldo1"; - regulator-name = "mipi_0p9"; - regulator-min-microvolt = <900000>; - regulator-max-microvolt = <900000>; - }; - - hdmi_0p9: ALDO5 { - regulator-boot-on; - regulator-compatible = "aldo5"; - regulator-name = "hdmi_0p9"; - regulator-min-microvolt = <900000>; - regulator-max-microvolt = <900000>; - }; - - hdmi_1p8: ALDO3 { - regulator-boot-on; - regulator-compatible = "aldo3"; - regulator-name = "hdmi_1p8"; - regulator-min-microvolt = <1800000>; - regulator-max-microvolt = <1800000>; - }; - - sdio_vdd: ALDO4 { - regulator-boot-on; - regulator-always-on; - regulator-compatible = "aldo4"; - regulator-name = "sdio_vdd"; - regulator-min-microvolt = <1800000>; - regulator-max-microvolt = <1800000>; - }; - - vcc_3v3: DCDC1 { - regulator-boot-on; - regulator-always-on; - regulator-compatible = "dcdc1"; - regulator-name = "vcc_3v3"; - regulator-min-microvolt = <3300000>; - regulator-max-microvolt = <3300000>; - }; - - cpu_vdd: DCDC2 { - regulator-boot-on; - regulator-always-on; - regulator-compatible = "dcdc2"; - regulator-name = "cpu_vdd"; - regulator-min-microvolt = <500000>; - regulator-max-microvolt = <1540000>; - }; - }; - }; -}; - -&i2c6 { - clock-frequency = <100000>; - i2c-sda-hold-time-ns = <300>; - i2c-sda-falling-time-ns = <510>; - i2c-scl-falling-time-ns = <510>; - auto_calc_scl_lhcnt; - pinctrl-names = "default"; - pinctrl-0 = <&i2c6_pins>; - status = "okay"; - - imx219: imx219@10 { - compatible = "sony,imx219"; - reg = <0x10>; - clocks = <&clk_ext_camera>; - clock-names = "xclk"; - reset-gpio = <&gpio 18 0>; - rotation = <0>; - orientation = <1>; //CAMERA_ORIENTATION_BACK - - port { - /* CSI2 bus endpoint */ - imx219_to_csi2rx0: endpoint { - remote-endpoint = <&csi2rx0_from_imx219>; - bus-type = <4>; /* MIPI CSI-2 D-PHY */ - clock-lanes = <4>; - data-lanes = <0 1>; - lane-polarities = <0 0 0>; - link-frequencies = /bits/ 64 <456000000>; - }; - }; - }; - - imx708: imx708@1a { - compatible = "sony,imx708"; - reg = <0x1a>; - clocks = <&clk_ext_camera>; - reset-gpio = <&gpio 18 0>; - - port { - imx708_to_csi2rx0: endpoint { - remote-endpoint = <&csi2rx0_from_imx708>; - data-lanes = <1 2>; - clock-noncontinuous; - link-frequencies = /bits/ 64 <450000000>; - }; - }; - }; - - ov4689: ov4689@36 { - compatible = "ovti,ov4689"; - reg = <0x36>; - clocks = <&clk_ext_camera>; - clock-names = "xclk"; - rotation = <180>; - - port { - /* Parallel bus endpoint */ - ov4689_to_csi2rx0: endpoint { - remote-endpoint = <&csi2rx0_from_ov4689>; - bus-type = <4>; /* MIPI CSI-2 D-PHY */ - clock-lanes = <0>; - data-lanes = <1 2>; - }; - }; - }; -}; - -&mmc0 { - max-frequency = <100000000>; - assigned-clocks = <&clkgen JH7110_SDIO0_CLK_SDCARD>; - assigned-clock-rates = <50000000>; - card-detect-delay = <300>; - bus-width = <8>; - cap-mmc-highspeed; - mmc-hs200-1_8v; - non-removable; - cap-mmc-hw-reset; - post-power-on-delay-ms = <200>; - vmmc-supply = <&vcc_3v3>; - vqmmc-supply = <&sdio_vdd>; - status = "okay"; -}; - -&mmc1 { - max-frequency = <100000000>; - assigned-clocks = <&clkgen JH7110_SDIO1_CLK_SDCARD>; - assigned-clock-rates = <50000000>; - card-detect-delay = <300>; - bus-width = <4>; - no-sdio; - no-mmc; - broken-cd; - cap-sd-highspeed; - post-power-on-delay-ms = <200>; - status = "okay"; -}; - -&vin_sysctl { - /* when use dvp open this pinctrl*/ - status = "okay"; - - ports { - #address-cells = <1>; - #size-cells = <0>; - - port@1 { - reg = <1>; - #address-cells = <1>; - #size-cells = <0>; - - /* CSI2 bus endpoint */ - csi2rx0_from_imx219: endpoint@0 { - reg = <0>; - remote-endpoint = <&imx219_to_csi2rx0>; - bus-type = <4>; /* MIPI CSI-2 D-PHY */ - clock-lanes = <4>; - data-lanes = <0 1>; - lane-polarities = <0 0 0>; - status = "okay"; - }; - - csi2rx0_from_imx708: endpoint@1 { - reg = <1>; - remote-endpoint = <&imx708_to_csi2rx0>; - bus-type = <4>; /* MIPI CSI-2 D-PHY */ - clock-lanes = <4>; - data-lanes = <0 1>; - lane-polarities = <0 0 0>; - status = "okay"; - }; - - csi2rx0_from_ov4689: endpoint@2 { - reg = <2>; - remote-endpoint = <&ov4689_to_csi2rx0>; - bus-type = <4>; /* MIPI CSI-2 D-PHY */ - clock-lanes = <4>; - data-lanes = <0 1>; - status = "okay"; - }; - }; - }; -}; - -&sfctemp { - status = "okay"; -}; - -&jpu { - status = "okay"; -}; - -&vpu_dec { - status = "okay"; -}; - -&vpu_enc { - status = "okay"; -}; - -&gmac0 { - status = "okay"; - #address-cells = <1>; - #size-cells = <0>; - clock-names = "gtx", - "tx", - "ptp_ref", - "stmmaceth", - "pclk", - "gtxc", - "rmii_rtx"; - clocks = <&clkgen JH7110_GMAC0_GTXCLK>, - <&clkgen JH7110_U0_GMAC5_CLK_TX>, - <&clkgen JH7110_GMAC0_PTP>, - <&clkgen JH7110_U0_GMAC5_CLK_AHB>, - <&clkgen JH7110_U0_GMAC5_CLK_AXI>, - <&clkgen JH7110_GMAC0_GTXC>, - <&clkgen JH7110_GMAC0_RMII_RTX>; - - phy0: ethernet-phy@0 { - rgmii_sw_dr_2 = <0x0>; - rgmii_sw_dr = <0x3>; - rgmii_sw_dr_rxc = <0x6>; - rxc_dly_en = <0>; - rx_delay_sel = <0xa>; - tx_delay_sel_fe = <5>; - tx_delay_sel = <0xa>; - tx_inverted_10 = <0x1>; - tx_inverted_100 = <0x1>; - tx_inverted_1000 = <0x1>; - }; -}; - -&gmac1 { - #address-cells = <1>; - #size-cells = <0>; - status = "okay"; - clock-names = "gtx", - "tx", - "ptp_ref", - "stmmaceth", - "pclk", - "gtxc", - "rmii_rtx"; - clocks = <&clkgen JH7110_GMAC1_GTXCLK>, - <&clkgen JH7110_GMAC5_CLK_TX>, - <&clkgen JH7110_GMAC5_CLK_PTP>, - <&clkgen JH7110_GMAC5_CLK_AHB>, - <&clkgen JH7110_GMAC5_CLK_AXI>, - <&clkgen JH7110_GMAC1_GTXC>, - <&clkgen JH7110_GMAC1_RMII_RTX>; - - phy1: ethernet-phy@1 { - rgmii_sw_dr_2 = <0x0>; - rgmii_sw_dr = <0x3>; - rgmii_sw_dr_rxc = <0x6>; - tx_delay_sel_fe = <5>; - tx_delay_sel = <0>; - rxc_dly_en = <0>; - rx_delay_sel = <0x2>; - tx_inverted_10 = <0x1>; - tx_inverted_100 = <0x1>; - tx_inverted_1000 = <0x0>; - }; -}; - -&gpu { - status = "okay"; -}; - -&pwmdac { - pinctrl-names = "default"; - pinctrl-0 = <&pwmdac0_pins>; - status = "okay"; -}; - -&i2srx_3ch { - pinctrl-names = "default"; - pinctrl-0 = <&i2s_clk_pins &i2srx_pins>; - status = "disabled"; -}; - -&i2stx_4ch1 { - pinctrl-names = "default"; - pinctrl-0 = <&i2stx_pins>; - status = "disabled"; -}; - -&tdm { - pinctrl-names = "default"; - pinctrl-0 = <&tdm0_pins>; - status = "disabled"; -}; - -&pwmdac_codec { - status = "okay"; -}; - -&spi0 { - pinctrl-names = "default"; - pinctrl-0 = <&ssp0_pins>; - status = "okay"; - - spi_dev0: spi@0 { - compatible = "rohm,dh2228fv"; - pl022,com-mode = <1>; - spi-max-frequency = <10000000>; - reg = <0>; - status = "okay"; - }; -}; - -&pcie0 { - pinctrl-names = "default"; - pinctrl-0 = <&pcie0_wake_default>, - <&pcie0_clkreq_default>; - reset-gpios = <&gpio 26 GPIO_ACTIVE_LOW>; - status = "okay"; -}; - -&pcie1 { - pinctrl-names = "default"; - pinctrl-0 = <&pcie1_wake_default>, - <&pcie1_clkreq_default>; - reset-gpios = <&gpio 28 GPIO_ACTIVE_LOW>; - status = "okay"; -}; - -&mailbox_contrl0 { - status = "okay"; -}; - -&mailbox_client0 { - status = "okay"; -}; - -&display { - status = "okay"; -}; - -&hdmi { - status = "okay"; - - hdmi_in: port { - #address-cells = <1>; - #size-cells = <0>; - hdmi_in_lcdc: endpoint@0 { - reg = <0>; - remote-endpoint = <&dc_out_dpi1>; - }; - }; -}; - -&dc8200 { - status = "okay"; - - dc_out: port { - #address-cells = <1>; - #size-cells = <0>; - dc_out_dpi0: endpoint@0 { - reg = <0>; - remote-endpoint = <&hdmi_input0>; - }; - dc_out_dpi1: endpoint@1 { - reg = <1>; - remote-endpoint = <&hdmi_in_lcdc>; - }; - - dc_out_dpi2: endpoint@2 { - reg = <2>; - remote-endpoint = <&mipi_in>; - }; - }; -}; - -&rgb_output { - status = "disabled"; - - ports { - #address-cells = <1>; - #size-cells = <0>; - port@0 { - #address-cells = <1>; - #size-cells = <0>; - reg = <0>; - hdmi_input0:endpoint@0 { - reg = <0>; - remote-endpoint = <&dc_out_dpi0>; - }; - }; - }; -}; - -&dsi_output { - status = "okay"; - - ports { - #address-cells = <1>; - #size-cells = <0>; - - port@0 { - reg = <0>; - mipi_in: endpoint { - remote-endpoint = <&dc_out_dpi2>; - }; - }; - - port@1 { - reg = <1>; - sf_dpi_output: endpoint { - remote-endpoint = <&dsi_in_port>; - }; - }; - }; -}; - -&mipi_dsi { - status = "okay"; - - ports { - #address-cells = <1>; - #size-cells = <0>; - - port@0 { - reg = <0>; - #address-cells = <1>; - #size-cells = <0>; - - dsi0_output: endpoint@0 { - reg = <0>; - remote-endpoint = <&panel_out0>; - }; - - dsi1_output: endpoint@1 { - reg = <1>; - remote-endpoint = <&panel_out1>; - }; - - }; - - port@1{ - reg = <1>; - dsi_in_port: endpoint { - remote-endpoint = <&sf_dpi_output>; - }; - }; - - }; -}; - -&mipi_dphy { - status = "okay"; -}; - -&co_process { - memory-region = <&e24_mem>; - status = "okay"; -}; - -&usbdrd30 { - clocks = <&clkgen JH7110_USB_125M>, - <&clkgen JH7110_USB0_CLK_APP_125>, - <&clkgen JH7110_USB0_CLK_LPM>, - <&clkgen JH7110_USB0_CLK_STB>, - <&clkgen JH7110_USB0_CLK_USB_APB>, - <&clkgen JH7110_USB0_CLK_AXI>, - <&clkgen JH7110_USB0_CLK_UTMI_APB>; - clock-names = "125m","app","lpm","stb","apb","axi","utmi"; - resets = <&rstgen RSTN_U0_CDN_USB_PWRUP>, - <&rstgen RSTN_U0_CDN_USB_APB>, - <&rstgen RSTN_U0_CDN_USB_AXI>, - <&rstgen RSTN_U0_CDN_USB_UTMI_APB>; - reset-names = "pwrup","apb","axi","utmi"; - starfive,usb2-only; - dr_mode = "peripheral"; /*host or peripheral*/ - status = "okay"; -}; - -&xrp { - memory-region = <&xrp_reserved>; - status = "okay"; -}; - -&ptc { - pinctrl-names = "default"; - pinctrl-0 = <&pwm_pins>; - status = "okay"; -}; - -&qspi { - nor_flash: nor-flash@0 { - compatible = "jedec,spi-nor"; - reg=<0>; - cdns,read-delay = <5>; - spi-max-frequency = <100000000>; - cdns,tshsl-ns = <1>; - cdns,tsd2d-ns = <1>; - cdns,tchsh-ns = <1>; - cdns,tslch-ns = <1>; - status = "okay"; - - partitions { - compatible = "fixed-partitions"; - #address-cells = <1>; - #size-cells = <1>; - - spl@0 { - reg = <0x0 0x40000>; - }; - uboot-env@100000 { - reg = <0xf0000 0x10000>; - }; - uboot@100000 { - reg = <0x100000 0x300000>; - }; - data@f00000 { - reg = <0xf00000 0x100000>; - }; - }; - }; -}; - -- cgit v1.2.3