[PATCH 3/3] arm64: dts: allwinner: Add Jide Remix Mini PC support
Jernej Škrabec
jernej.skrabec at gmail.com
Mon Feb 5 10:20:24 PST 2024
Dne ponedeljek, 05. februar 2024 ob 19:12:45 CET je Jernej Škrabec napisal(a):
> Hi Andre!
>
> Dne nedelja, 04. februar 2024 ob 10:44:04 CET je Andre Przywara napisal(a):
> > The Remix Mini PC is a "mini computer" using the Allwinner H64 SoC,
> > which appears to be just a relabelled A64. It was launched in 2015 by
> > the now defunct company Jide, and shipped with a desktop optimised
> > version of Android. It features
> > - Allwinner H64 Soc (4 * Arm Cortex-A53 cores)
> > - 1 or 2 GB DRAM
> > - 8 or 16 GB eMMC flash
> > - 100 MBit Ethernet port (using an X-Powers AC200 PHY)
> > - RTL8723BS WiFi & Bluetooth chip
> > - HDMI port
> > - two USB 2.0 ports
> > - 3.5mm AV port
> > - microSD card slot
> >
> > The devicetree covers most peripherals, though there is no agreed
> > binding for the PHY chip yet, so this is left out.
> >
> > Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> > ---
> > arch/arm64/boot/dts/allwinner/Makefile | 1 +
> > .../allwinner/sun50i-h64-remix-mini-pc.dts | 357 ++++++++++++++++++
> > 2 files changed, 358 insertions(+)
> > create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h64-remix-mini-pc.dts
> >
> > diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
> > index 91d505b385de..2db3b15ad09f 100644
> > --- a/arch/arm64/boot/dts/allwinner/Makefile
> > +++ b/arch/arm64/boot/dts/allwinner/Makefile
> > @@ -16,6 +16,7 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinetab.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinetab-early-adopter.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-sopine-baseboard.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-teres-i.dtb
> > +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h64-remix-mini-pc.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a100-allwinner-perf1.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h5-bananapi-m2-plus.dtb
> > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h5-bananapi-m2-plus-v1.2.dtb
> > diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h64-remix-mini-pc.dts b/arch/arm64/boot/dts/allwinner/sun50i-h64-remix-mini-pc.dts
> > new file mode 100644
> > index 000000000000..537923a541a8
> > --- /dev/null
> > +++ b/arch/arm64/boot/dts/allwinner/sun50i-h64-remix-mini-pc.dts
> > @@ -0,0 +1,357 @@
> > +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> > +// Copyright (c) 2018 ARM Ltd.
>
> Shouldn't be 2024?
>
> > +
> > +/dts-v1/;
> > +
> > +#include "sun50i-a64.dtsi"
> > +#include "sun50i-a64-cpu-opp.dtsi"
> > +
> > +#include <dt-bindings/gpio/gpio.h>
> > +
> > +/ {
> > + model = "Remix Mini PC";
> > + compatible = "jide,remix-mini-pc", "allwinner,sun50i-h64",
> > + "allwinner,sun50i-a64";
> > +
> > + aliases {
> > + ethernet1 = &rtl8723bs;
> > + serial0 = &uart0;
> > + };
> > +
> > + chosen {
> > + stdout-path = "serial0:115200n8";
> > + };
> > +
> > + hdmi-connector {
> > + compatible = "hdmi-connector";
> > + type = "a";
> > +
> > + port {
> > + hdmi_con_in: endpoint {
> > + remote-endpoint = <&hdmi_out_con>;
> > + };
> > + };
> > + };
> > +
> > + reg_vcc5v: regulator-5v {
> > + /* board wide 5V supply directly from the DC input */
> > + compatible = "regulator-fixed";
> > + regulator-name = "vcc-5v";
> > + regulator-min-microvolt = <5000000>;
> > + regulator-max-microvolt = <5000000>;
> > + regulator-always-on;
> > + };
> > +
> > + wifi_pwrseq: wifi_pwrseq {
> > + compatible = "mmc-pwrseq-simple";
> > + pinctrl-names = "default";
> > + reset-gpios = <&r_pio 0 2 GPIO_ACTIVE_LOW>; /* PL2 */
> > + post-power-on-delay-ms = <200>;
> > + };
> > +};
> > +
> > +&codec {
> > + status = "okay";
> > +};
> > +
> > +&codec_analog {
> > + cpvdd-supply = <®_eldo1>;
> > + status = "okay";
> > +};
> > +
> > +&cpu0 {
> > + cpu-supply = <®_dcdc2>;
> > +};
> > +
> > +&cpu1 {
> > + cpu-supply = <®_dcdc2>;
> > +};
> > +
> > +&cpu2 {
> > + cpu-supply = <®_dcdc2>;
> > +};
> > +
> > +&cpu3 {
> > + cpu-supply = <®_dcdc2>;
> > +};
> > +
> > +&dai {
> > + status = "okay";
> > +};
> > +
> > +&de {
> > + status = "okay";
> > +};
> > +
> > +&ehci0 {
> > + status = "okay";
> > +};
> > +
> > +&ehci1 {
> > + status = "okay";
> > +};
> > +
> > +&hdmi {
> > + hvcc-supply = <®_dldo1>;
> > + status = "okay";
> > +};
> > +
> > +&hdmi_out {
> > + hdmi_out_con: endpoint {
> > + remote-endpoint = <&hdmi_con_in>;
> > + };
> > +};
> > +
> > +/* Connects to the AC200 chip */
> > +&i2c0 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&i2c0_pins>;
> > + status = "okay";
> > +};
> > +
> > +&i2c0_pins {
> > + bias-pull-up;
> > +};
> > +
> > +&mmc0 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&mmc0_pins>;
> > + vmmc-supply = <®_dcdc1>;
> > + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>;
> > + disable-wp;
> > + bus-width = <4>;
> > + status = "okay";
> > +};
> > +
> > +&mmc1 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&mmc1_pins>;
> > + vmmc-supply = <®_aldo1>;
> > + vqmmc-supply = <®_dldo4>;
> > + mmc-pwrseq = <&wifi_pwrseq>;
> > + bus-width = <4>;
> > + non-removable;
> > + status = "okay";
> > +
> > + rtl8723bs: wifi at 1 {
> > + reg = <1>;
> > + interrupt-parent = <&r_pio>;
> > + interrupts = <0 3 IRQ_TYPE_LEVEL_LOW>; /* PL3 */
> > + interrupt-names = "host-wake";
> > + };
>
> Node without compatible doesn't help. Please remove it.
>
> > +};
> > +
> > +&mmc2 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&mmc2_pins>, <&mmc2_ds_pin>;
> > + vmmc-supply = <®_dcdc1>;
> > + vqmmc-supply = <®_eldo1>;
> > + bus-width = <8>;
> > + non-removable;
> > + mmc-ddr-1_8v;
> > + mmc-hs200-1_8v;
>
> Aren't these speed modes enabled by default?
Sorry, mmc-hs200-1_8v is ok, but mmc-ddr-1_8v should be
removed.
Best regards,
Jernej
> > + cap-mmc-hw-reset;
> > + status = "okay";
> > +};
> > +
> > +&ohci0 {
> > + status = "okay";
> > +};
> > +
> > +&ohci1 {
> > + status = "okay";
> > +};
> > +
> > +&pio {
> > + vcc-pb-supply = <®_dcdc1>;
> > + vcc-pc-supply = <®_dcdc1>;
> > + vcc-pd-supply = <®_dcdc1>;
> > + vcc-pe-supply = <®_dcdc1>;
> > + vcc-pf-supply = <®_dcdc1>;
> > + vcc-pg-supply = <®_dldo4>;
> > + vcc-ph-supply = <®_dcdc1>;
> > +};
> > +
> > +&r_ir {
> > + status = "okay";
> > +};
> > +
> > +&r_pio {
> > + /*
> > + * We cannot add that supply for now since it would create a circular
> > + * dependency between pinctrl, the regulator and the RSB Bus.
> > + *
> > + * vcc-pl-supply = <®_aldo2>;
> > + */
> > +};
> > +
> > +&r_rsb {
> > + status = "okay";
> > +
> > + axp803: pmic at 3a3 {
> > + compatible = "x-powers,axp803";
> > + reg = <0x3a3>;
> > + interrupt-parent = <&r_intc>;
> > + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_LOW>;
> > + x-powers,drive-vbus-en;
> > +
> > + vin1-supply = <®_vcc5v>;
> > + vin2-supply = <®_vcc5v>;
> > + vin3-supply = <®_vcc5v>;
> > + vin5-supply = <®_vcc5v>;
> > + vin6-supply = <®_vcc5v>;
> > + aldoin-supply = <®_vcc5v>;
> > + dldoin-supply = <®_vcc5v>;
> > + eldoin-supply = <®_vcc5v>;
> > + fldoin-supply = <®_vcc5v>;
> > + drivevbus-supply = <®_vcc5v>;
> > + ips-supply = <®_vcc5v>;
> > +
> > + status = "okay";
> > + };
> > +};
> > +
> > +#include "axp803.dtsi"
> > +
> > +&ac_power_supply {
> > + status = "okay";
> > +};
> > +
> > +®_dcdc1 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <3300000>;
> > + regulator-max-microvolt = <3300000>;
> > + regulator-name = "vcc-3v3";
> > +};
> > +
> > +®_dcdc2 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <1040000>;
> > + regulator-max-microvolt = <1300000>;
> > + regulator-name = "vdd-cpux";
> > +};
> > +
> > +/* DCDC3 is polyphased with DCDC2 */
> > +
> > +®_dcdc5 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <1500000>;
> > + regulator-max-microvolt = <1500000>;
> > + regulator-name = "vcc-dram";
> > +};
> > +
> > +/* Deviates from the reset default of 1.1V. */
> > +®_dcdc6 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <1200000>;
> > + regulator-max-microvolt = <1200000>;
> > + regulator-name = "vdd-sys";
> > +};
> > +
> > +®_aldo1 {
> > + regulator-min-microvolt = <3300000>;
> > + regulator-max-microvolt = <3300000>;
> > + regulator-name = "vcc-wifi";
> > +};
> > +
> > +®_aldo2 {
> > + /* Specifying R_PIO consumer would create circular dependency. */
> > + regulator-always-on;
> > + regulator-min-microvolt = <3300000>;
> > + regulator-max-microvolt = <3300000>;
> > + regulator-name = "vcc-pl";
> > +};
> > +
> > +®_aldo3 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <3000000>;
> > + regulator-max-microvolt = <3000000>;
> > + regulator-name = "vcc-pll-avcc";
> > +};
> > +
> > +/* AC200 power supply */
> > +®_dldo1 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <3300000>;
> > + regulator-max-microvolt = <3300000>;
> > + regulator-name = "vcc-ave-33";
> > +};
> > +
> > +®_dldo4 {
> > + regulator-min-microvolt = <3300000>;
> > + regulator-max-microvolt = <3300000>;
> > + regulator-name = "vcc-wifi-io";
> > +};
> > +
> > +®_drivevbus {
> > + regulator-name = "usb0-vbus";
> > + status = "okay";
> > +};
> > +
> > +®_eldo1 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <1800000>;
> > + regulator-max-microvolt = <1800000>;
> > + regulator-name = "vcc-cpvdd-dram-emmc";
> > +};
> > +
> > +/* Supplies the arisc management core, needed by TF-A to power off cores. */
> > +®_fldo2 {
> > + regulator-always-on;
> > + regulator-min-microvolt = <1100000>;
> > + regulator-max-microvolt = <1100000>;
> > + regulator-name = "vdd-cpus";
> > +};
> > +
> > +®_rtc_ldo {
> > + regulator-name = "vcc-rtc";
> > +};
> > +
> > +&simplefb_hdmi {
> > + vcc-hdmi-supply = <®_dcdc1>;
> > +};
> > +
> > +&sound {
> > + simple-audio-card,aux-devs = <&codec_analog>;
> > + simple-audio-card,widgets = "Microphone", "Microphone Jack",
> > + "Headphone", "Headphone Jack";
> > + simple-audio-card,routing =
> > + "Left DAC", "DACL",
> > + "Right DAC", "DACR",
> > + "Headphone Jack", "HP",
> > + "ADCL", "Left ADC",
> > + "ADCR", "Right ADC",
> > + "MIC2", "Microphone Jack";
> > + status = "okay";
> > +};
> > +
> > +/* On the (unpopulated) UART pads. */
> > +&uart0 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&uart0_pb_pins>;
> > + status = "okay";
> > +};
> > +
> > +&uart1 {
> > + pinctrl-names = "default";
> > + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
> > + uart-has-rtscts;
> > + status = "okay";
> > +
> > + bluetooth {
> > + compatible = "realtek,rtl8723bs-bt";
> > + enable-gpios = <&r_pio 0 4 GPIO_ACTIVE_HIGH>; /* PL4 */
> > + max-speed = <1500000>;
> > + };
> > +};
> > +
> > +&usb_otg {
> > + dr_mode = "host";
> > + status = "okay";
> > +};
> > +
> > +&usbphy {
> > + usb0_vbus-supply = <®_drivevbus>;
> > + usb1_vbus-supply = <®_drivevbus>;
> > + status = "okay";
> > +};
> >
>
>
>
>
>
More information about the linux-arm-kernel
mailing list