* [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
@ 2025-05-06 12:28 kurachenko-urup
2025-05-07 19:39 ` Vitaly Chikunov
2025-05-08 1:22 ` Vitaly Chikunov
0 siblings, 2 replies; 7+ messages in thread
From: kurachenko-urup @ 2025-05-06 12:28 UTC (permalink / raw)
To: devel-kernel
From: Anton Kurachenko <srebrov@altlinux.org>
Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
a dtb file.
Patch designed specifically for ALT and never used anywhere.
The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
Represents the result of merging these files with applying some modifications.
Files that were used during the creation process:
sun50i-h6-repka-pi4-optimal.dts
Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
sun50i-h6.dtsi
Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
sun50i-h6-cpu-opp.dtsi
Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
---
arch/arm64/boot/dts/allwinner/Makefile | 1 +
.../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
2 files changed, 1919 insertions(+)
create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
index 00bed412ee31..2df5189e0d44 100644
--- a/arch/arm64/boot/dts/allwinner/Makefile
+++ b/arch/arm64/boot/dts/allwinner/Makefile
@@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
+dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
new file mode 100644
index 000000000000..9d95297a30b8
--- /dev/null
+++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
@@ -0,0 +1,1918 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+// based on the dts, which is:
+// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
+// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
+// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
+// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
+
+/dts-v1/;
+
+#include <dt-bindings/interrupt-controller/arm-gic.h>
+#include <dt-bindings/clock/sun50i-h6-ccu.h>
+#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
+#include <dt-bindings/clock/sun6i-rtc.h>
+#include <dt-bindings/clock/sun8i-de2.h>
+#include <dt-bindings/clock/sun8i-tcon-top.h>
+#include <dt-bindings/reset/sun50i-h6-ccu.h>
+#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
+#include <dt-bindings/reset/sun8i-de2.h>
+#include <dt-bindings/thermal/thermal.h>
+#include <dt-bindings/gpio/gpio.h>
+
+/ {
+ interrupt-parent = <&gic>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ model = "Repka-Pi4-Optimal";
+ repka-freq = "1.968 GHz";
+ repka-pinout = "repka-pi4-base";
+ compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
+
+ aliases {
+ mmc0 = &mmc0;
+ mmc1 = &mmc1;
+ mmc2 = &mmc2;
+ ethernet0 = &emac;
+ serial0 = &uart0;
+ serial1 = &uart1;
+ serial2 = &r_uart;
+
+ spi0 = &spi1;
+ i2c1 = &i2c0;
+ i2c2 = &i2c2;
+ i2c3 = &i2c1;
+ i2c4 = &i2c3;
+
+ };
+
+ reserved-memory {
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges;
+
+ custom_region: region@40010000 {
+ reg = <0x40010000 0x00070000>;
+ no-map;
+ };
+ };
+
+ analog: analog-codec {
+ compatible = "simple-audio-card";
+ simple-audio-card,format = "i2s";
+ simple-audio-card,name = "ac200-audio";
+ simple-audio-card,mclk-fs = <512>;
+ status = "okay";
+
+ simple-audio-card,cpu {
+ sound-dai = <&i2s3>;
+ };
+
+ simple-audio-card,codec {
+ sound-dai = <&ac200_codec>;
+ };
+ };
+
+ ac200_pwm_clk: ac200_clk {
+ compatible = "pwm-clock";
+ #clock-cells = <0>;
+ clock-frequency = <24000000>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&pwm1_pin>;
+ pwms = <&pwm 1 42 0>;
+ status = "okay";
+ };
+
+ cpus {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ cpu0: cpu@0 {
+ compatible = "arm,cortex-a53";
+ device_type = "cpu";
+ reg = <0>;
+ enable-method = "psci";
+ clocks = <&ccu CLK_CPUX>;
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ #cooling-cells = <2>;
+ operating-points-v2 = <&cpu_opp_table>;
+ cpu-supply = <®_dcdca>;
+ };
+
+ cpu1: cpu@1 {
+ compatible = "arm,cortex-a53";
+ device_type = "cpu";
+ reg = <1>;
+ enable-method = "psci";
+ clocks = <&ccu CLK_CPUX>;
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ #cooling-cells = <2>;
+ operating-points-v2 = <&cpu_opp_table>;
+ };
+
+ cpu2: cpu@2 {
+ compatible = "arm,cortex-a53";
+ device_type = "cpu";
+ reg = <2>;
+ enable-method = "psci";
+ clocks = <&ccu CLK_CPUX>;
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ #cooling-cells = <2>;
+ operating-points-v2 = <&cpu_opp_table>;
+ };
+
+ cpu3: cpu@3 {
+ compatible = "arm,cortex-a53";
+ device_type = "cpu";
+ reg = <3>;
+ enable-method = "psci";
+ clocks = <&ccu CLK_CPUX>;
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ #cooling-cells = <2>;
+ operating-points-v2 = <&cpu_opp_table>;
+ };
+ };
+
+ de: display-engine {
+ compatible = "allwinner,sun50i-h6-display-engine";
+ allwinner,pipelines = <&mixer0>;
+ status = "okay";
+ };
+
+ osc24M: osc24M_clk {
+ #clock-cells = <0>;
+ compatible = "fixed-clock";
+ clock-frequency = <24000000>;
+ clock-output-names = "osc24M";
+ };
+
+ pmu {
+ compatible = "arm,cortex-a53-pmu";
+ interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
+ };
+
+ psci {
+ compatible = "arm,psci-0.2";
+ method = "smc";
+ };
+
+ scpi_protocol: scpi {
+ compatible = "arm,scpi";
+ mboxes = <&msgbox 2>, <&msgbox 3>;
+ mbox-names = "tx", "rx";
+ shmem = <&scpi_sram>;
+ };
+
+ sound_hdmi: sound_hdmi {
+ compatible = "allwinner,sun9i-a80-hdmi-audio",
+ "allwinner,sun50i-h6-hdmi-audio";
+ status = "okay";
+ codec {
+ sound-dai = <&hdmi>;
+ };
+
+ cpu {
+ sound-dai = <&i2s1>;
+ };
+ };
+
+ timer {
+ compatible = "arm,armv8-timer";
+ arm,no-tick-in-suspend;
+ interrupts = <GIC_PPI 13
+ (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
+ <GIC_PPI 14
+ (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
+ <GIC_PPI 11
+ (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
+ <GIC_PPI 10
+ (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
+ };
+
+
+ soc {
+ compatible = "simple-bus";
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges;
+
+ bus@1000000 {
+ compatible = "allwinner,sun50i-h6-de3",
+ "allwinner,sun50i-a64-de2";
+ reg = <0x1000000 0x400000>;
+ allwinner,sram = <&de2_sram 1>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges = <0 0x1000000 0x400000>;
+
+ display_clocks: clock@0 {
+ compatible = "allwinner,sun50i-h6-de3-clk";
+ reg = <0x0 0x10000>;
+ clocks = <&ccu CLK_BUS_DE>,
+ <&ccu CLK_DE>;
+ clock-names = "bus",
+ "mod";
+ resets = <&ccu RST_BUS_DE>;
+ #clock-cells = <1>;
+ #reset-cells = <1>;
+ };
+
+ mixer0: mixer@100000 {
+ compatible = "allwinner,sun50i-h6-de3-mixer-0";
+ reg = <0x100000 0x100000>;
+ clocks = <&display_clocks CLK_BUS_MIXER0>,
+ <&display_clocks CLK_MIXER0>;
+ clock-names = "bus",
+ "mod";
+ resets = <&display_clocks RST_MIXER0>;
+ iommus = <&iommu 0>;
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ mixer0_out: port@1 {
+ reg = <1>;
+
+ mixer0_out_tcon_top_mixer0: endpoint {
+ remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
+ };
+ };
+ };
+ };
+ };
+
+
+ video-codec-g2@1c00000 {
+ compatible = "allwinner,sun50i-h6-vpu-g2";
+ reg = <0x01c00000 0x1000>;
+ interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
+ clock-names = "bus", "mod";
+ resets = <&ccu RST_BUS_VP9>;
+ iommus = <&iommu 5>;
+ };
+
+ deinterlace: deinterlace@1420000 {
+ compatible = "allwinner,sun50i-h6-deinterlace";
+ reg = <0x01420000 0x2000>;
+ clocks = <&ccu CLK_BUS_DEINTERLACE>,
+ <&ccu CLK_DEINTERLACE>,
+ <&ccu CLK_MBUS_DEINTERLACE>;
+ clock-names = "bus", "mod", "ram";
+ resets = <&ccu RST_BUS_DEINTERLACE>;
+ interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
+ iommus = <&iommu 2>;
+ };
+
+ video-codec@1c0e000 {
+ compatible = "allwinner,sun50i-h6-video-engine";
+ reg = <0x01c0e000 0x2000>;
+ clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
+ <&ccu CLK_MBUS_VE>;
+ clock-names = "ahb", "mod", "ram";
+ resets = <&ccu RST_BUS_VE>;
+ interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
+ allwinner,sram = <&ve_sram 1>;
+ iommus = <&iommu 1>, <&iommu 3>;
+ };
+
+ gpu: gpu@1800000 {
+ compatible = "allwinner,sun50i-h6-mali",
+ "arm,mali-t720";
+ reg = <0x01800000 0x4000>;
+ interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-names = "job", "mmu", "gpu";
+ clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
+ clock-names = "core", "bus";
+ resets = <&ccu RST_BUS_GPU>;
+ #cooling-cells = <2>;
+ status = "okay";
+ operating-points-v2 = <&gpu_opp_table>;
+ mali-supply = <®_dcdcc>;
+ };
+
+ crypto: crypto@1904000 {
+ compatible = "allwinner,sun50i-h6-crypto";
+ reg = <0x01904000 0x1000>;
+ interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
+ clock-names = "bus", "mod", "ram";
+ resets = <&ccu RST_BUS_CE>;
+ };
+
+ syscon: syscon@3000000 {
+ compatible = "allwinner,sun50i-h6-system-control",
+ "allwinner,sun50i-a64-system-control";
+ reg = <0x03000000 0x1000>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges;
+
+ sram_a2: sram@100000 {
+ compatible = "mmio-sram";
+ reg = <0x00100000 0x18000>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges = <0 0x00100000 0x18000>;
+
+ scpi_sram: scp-shmem@17c00 {
+ compatible = "arm,scp-shmem";
+ reg = <0x17c00 0x200>;
+ };
+ };
+
+ sram_c: sram@28000 {
+ compatible = "mmio-sram";
+ reg = <0x00028000 0x1e000>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges = <0 0x00028000 0x1e000>;
+
+ de2_sram: sram-section@0 {
+ compatible = "allwinner,sun50i-h6-sram-c",
+ "allwinner,sun50i-a64-sram-c";
+ reg = <0x0000 0x1e000>;
+ };
+ };
+
+ sram_c1: sram@1a00000 {
+ compatible = "mmio-sram";
+ reg = <0x01a00000 0x200000>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges = <0 0x01a00000 0x200000>;
+
+ ve_sram: sram-section@0 {
+ compatible = "allwinner,sun50i-h6-sram-c1",
+ "allwinner,sun4i-a10-sram-c1";
+ reg = <0x000000 0x200000>;
+ };
+ };
+ };
+
+ ccu: clock@3001000 {
+ compatible = "allwinner,sun50i-h6-ccu";
+ reg = <0x03001000 0x1000>;
+ clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
+ clock-names = "hosc", "losc", "iosc";
+ protected-clocks = <CLK_BUS_MSGBOX>;
+ #clock-cells = <1>;
+ #reset-cells = <1>;
+ };
+
+ dma: dma-controller@3002000 {
+ compatible = "allwinner,sun50i-h6-dma";
+ reg = <0x03002000 0x1000>;
+ interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
+ clock-names = "bus", "mbus";
+ dma-channels = <16>;
+ dma-requests = <46>;
+ resets = <&ccu RST_BUS_DMA>;
+ #dma-cells = <1>;
+ };
+
+ msgbox: mailbox@3003000 {
+ compatible = "allwinner,sun50i-h6-msgbox",
+ "allwinner,sun6i-a31-msgbox";
+ reg = <0x03003000 0x1000>;
+ clocks = <&ccu CLK_BUS_MSGBOX>;
+ resets = <&ccu RST_BUS_MSGBOX>;
+ interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
+ #mbox-cells = <1>;
+ };
+
+ gic: interrupt-controller@3021000 {
+ compatible = "arm,gic-400";
+ reg = <0x03021000 0x1000>,
+ <0x03022000 0x2000>,
+ <0x03024000 0x2000>,
+ <0x03026000 0x2000>;
+ interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
+ interrupt-controller;
+ #interrupt-cells = <3>;
+ };
+
+ sid: efuse@3006000 {
+ compatible = "allwinner,sun50i-h6-sid";
+ reg = <0x03006000 0x400>;
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ ths_calibration: thermal-sensor-calibration@14 {
+ reg = <0x14 0x8>;
+ };
+
+ cpu_speed_grade: cpu-speed-grade@1c {
+ reg = <0x1c 0x4>;
+ };
+
+ ephy_calib: ephy_calib@2c {
+ reg = <0x2c 0x2>;
+ };
+
+ ac200_bg: ac200_bg@30 {
+ reg = <0x30 0x2>;
+ };
+ };
+
+ timer@3009000 {
+ compatible = "allwinner,sun50i-h6-timer",
+ "allwinner,sun8i-a23-timer";
+ reg = <0x03009000 0xa0>;
+ interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&osc24M>;
+ };
+
+ watchdog: watchdog@30090a0 {
+ compatible = "allwinner,sun50i-h6-wdt",
+ "allwinner,sun6i-a31-wdt";
+ reg = <0x030090a0 0x20>;
+ interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&osc24M>;
+ /* Broken on some H6 boards */
+ status = "disabled";
+ };
+
+ pwm: pwm@300a000 {
+ compatible = "allwinner,sun50i-h6-pwm";
+ reg = <0x0300a000 0x400>;
+ clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
+ clock-names = "mod", "bus";
+ resets = <&ccu RST_BUS_PWM>;
+ #pwm-cells = <3>;
+ status = "okay";
+ };
+
+ pio: pinctrl@300b000 {
+ compatible = "allwinner,sun50i-h6-pinctrl";
+ reg = <0x0300b000 0x400>;
+ interrupt-parent = <&r_intc>;
+ interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
+ clock-names = "apb", "hosc", "losc";
+ gpio-controller;
+ #gpio-cells = <3>;
+ interrupt-controller;
+ #interrupt-cells = <3>;
+ vcc-pc-supply = <®_bldo2>;
+ vcc-pd-supply = <®_cldo1>;
+ vcc-pg-supply = <®_vcc_wifi_io>;
+
+ /omit-if-no-ref/
+ ext_rgmii_pins: rgmii-pins {
+ pins = "PD0", "PD1", "PD2", "PD3", "PD4",
+ "PD5", "PD7", "PD8", "PD9", "PD10",
+ "PD11", "PD12", "PD13", "PD19", "PD20";
+ function = "emac";
+ drive-strength = <40>;
+ };
+
+ ext_rmii_pins: rmii_pins {
+ pins = "PA0", "PA1", "PA2", "PA3", "PA4",
+ "PA5", "PA6", "PA7", "PA8", "PA9";
+ function = "emac";
+ drive-strength = <40>;
+ };
+
+ hdmi_pins: hdmi-pins {
+ pins = "PH8", "PH9", "PH10";
+ function = "hdmi";
+ };
+
+ i2c0_pins: i2c0-pins {
+ pins = "PD25", "PD26";
+ function = "i2c0";
+ };
+
+ i2c1_pins: i2c1-pins {
+ pins = "PH5", "PH6";
+ function = "i2c1";
+ };
+
+ i2c2_pins: i2c2-pins {
+ pins = "PD23", "PD24";
+ function = "i2c2";
+ };
+
+ i2c3_pins: i2c3-pins {
+ pins = "PB17", "PB18";
+ function = "i2c3";
+ bias-pull-up;
+ };
+
+ i2s3_pins: i2s3-pins {
+ pins = "PB12", "PB13", "PB14", "PB15", "PB16";
+ function = "i2s3";
+ };
+
+ mmc0_pins: mmc0-pins {
+ pins = "PF0", "PF1", "PF2", "PF3",
+ "PF4", "PF5";
+ function = "mmc0";
+ drive-strength = <30>;
+ bias-pull-up;
+ };
+
+ /omit-if-no-ref/
+ mmc1_pins: mmc1-pins {
+ pins = "PG0", "PG1", "PG2", "PG3",
+ "PG4", "PG5";
+ function = "mmc1";
+ drive-strength = <30>;
+ bias-pull-up;
+ };
+
+ /omit-if-no-ref/
+ mmc2_pins: mmc2-pins {
+ pins = "PC1", "PC4", "PC5", "PC6",
+ "PC7", "PC8", "PC9", "PC10",
+ "PC11", "PC12", "PC13", "PC14";
+ function = "mmc2";
+ drive-strength = <30>;
+ bias-pull-up;
+ };
+
+ pwm1_pin: pwm1-pin {
+ pins = "PB19";
+ function = "pwm1";
+ };
+
+ pwm_pin: pwm-pin {
+ pins = "PD22";
+ function = "pwm";
+ };
+
+ /omit-if-no-ref/
+ spi0_pins: spi0-pins {
+ pins = "PC0", "PC2", "PC3";
+ function = "spi0";
+ };
+
+ /* pin shared with MMC2-CMD (eMMC) */
+ /omit-if-no-ref/
+ spi0_cs_pin: spi0-cs-pin {
+ pins = "PC5";
+ function = "spi0";
+ };
+
+ /omit-if-no-ref/
+ spi1_pins: spi1-pins {
+ pins = "PH4", "PH5", "PH6";
+ function = "spi1";
+ };
+
+ /omit-if-no-ref/
+ spi1_cs_pin: spi1-cs-pin {
+ pins = "PH3";
+ function = "spi1";
+ };
+
+ /omit-if-no-ref/
+ spdif_tx_pin: spdif-tx-pin {
+ pins = "PH7";
+ function = "spdif";
+ };
+
+ uart0_ph_pins: uart0-ph-pins {
+ pins = "PH0", "PH1";
+ function = "uart0";
+ };
+
+ uart1_pins: uart1-pins {
+ pins = "PG6", "PG7";
+ function = "uart1";
+ };
+
+ uart1_rts_cts_pins: uart1-rts-cts-pins {
+ pins = "PG8", "PG9";
+ function = "uart1";
+ };
+
+ uart2_pins: uart2-pins {
+ pins = "PD19", "PD20";
+ function = "uart2";
+ };
+
+ uart2_rts_cts_pins: uart2-rts-cts-pins {
+ pins = "PD21", "PD22";
+ function = "uart2";
+ };
+
+ uart3_pins: uart3-pins {
+ pins = "PD23", "PD24";
+ function = "uart3";
+ };
+
+ uart3_rts_cts_pins: uart3-rts-cts-pins {
+ pins = "PD25", "PD26";
+ function = "uart3";
+ };
+
+ i2s2_pins: i2s2-pins {
+ pins = "PG10", "PG11", "PG12", "PG13";
+ function = "i2s2";
+ };
+ };
+
+ iommu: iommu@30f0000 {
+ compatible = "allwinner,sun50i-h6-iommu";
+ reg = <0x030f0000 0x10000>;
+ interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_IOMMU>;
+ resets = <&ccu RST_BUS_IOMMU>;
+ #iommu-cells = <1>;
+ };
+
+ mmc0: mmc@4020000 {
+ compatible = "allwinner,sun50i-h6-mmc",
+ "allwinner,sun50i-a64-mmc";
+ reg = <0x04020000 0x1000>;
+ clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
+ clock-names = "ahb", "mmc";
+ resets = <&ccu RST_BUS_MMC0>;
+ reset-names = "ahb";
+ interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&mmc0_pins>;
+ max-frequency = <150000000>;
+ status = "okay";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ vmmc-supply = <®_cldo1>;
+ cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
+ bus-width = <4>;
+ };
+
+ mmc1: mmc@4021000 {
+ compatible = "allwinner,sun50i-h6-mmc",
+ "allwinner,sun50i-a64-mmc";
+ reg = <0x04021000 0x1000>;
+ clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
+ clock-names = "ahb", "mmc";
+ resets = <&ccu RST_BUS_MMC1>;
+ reset-names = "ahb";
+ interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&mmc1_pins>;
+ max-frequency = <150000000>;
+ status = "okay";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ vmmc-supply = <®_vcc33_wifi>;
+ vqmmc-supply = <®_vcc_wifi_io>;
+ mmc-pwrseq = <&wifi_pwrseq>;
+ bus-width = <4>;
+ non-removable;
+
+ brcm: sdio-wifi@1 {
+ reg = <1>;
+ compatible = "brcm,bcm4329-fmac";
+ interrupt-parent = <&r_pio>;
+ interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
+ interrupt-names = "host-wake";
+ };
+ };
+
+ mmc2: mmc@4022000 {
+ compatible = "allwinner,sun50i-h6-emmc";
+ reg = <0x04022000 0x1000>;
+ clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
+ clock-names = "ahb", "mmc";
+ resets = <&ccu RST_BUS_MMC2>;
+ reset-names = "ahb";
+ interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&mmc2_pins>;
+ max-frequency = <150000000>;
+ status = "okay";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ vmmc-supply = <®_cldo1>;
+ vqmmc-supply = <®_bldo2>;
+ cap-mmc-hw-reset;
+ non-removable;
+ bus-width = <8>;
+ };
+
+ uart0: serial@5000000 {
+ compatible = "snps,dw-apb-uart";
+ reg = <0x05000000 0x400>;
+ interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
+ reg-shift = <2>;
+ reg-io-width = <4>;
+ clocks = <&ccu CLK_BUS_UART0>;
+ resets = <&ccu RST_BUS_UART0>;
+ status = "okay";
+ pinctrl-names = "default";
+ pinctrl-0 = <&uart0_ph_pins>;
+ };
+
+ uart1: serial@5000400 {
+ compatible = "snps,dw-apb-uart";
+ reg = <0x05000400 0x400>;
+ interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
+ reg-shift = <2>;
+ reg-io-width = <4>;
+ clocks = <&ccu CLK_BUS_UART1>;
+ resets = <&ccu RST_BUS_UART1>;
+ status = "okay";
+ pinctrl-names = "default";
+ pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
+ uart-has-rtscts;
+
+ bluetooth {
+ compatible = "brcm,bcm4345c5";
+ clocks = <&rtc 1>;
+ clock-names = "lpo";
+ device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
+ host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
+ shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
+ max-speed = <1500000>;
+ };
+ };
+
+ uart2: serial@5000800 {
+ compatible = "snps,dw-apb-uart";
+ reg = <0x05000800 0x400>;
+ interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
+ reg-shift = <2>;
+ reg-io-width = <4>;
+ clocks = <&ccu CLK_BUS_UART2>;
+ resets = <&ccu RST_BUS_UART2>;
+ status = "disabled";
+ };
+
+ uart3: serial@5000c00 {
+ compatible = "snps,dw-apb-uart";
+ reg = <0x05000c00 0x400>;
+ interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
+ reg-shift = <2>;
+ reg-io-width = <4>;
+ clocks = <&ccu CLK_BUS_UART3>;
+ resets = <&ccu RST_BUS_UART3>;
+ status = "disabled";
+ };
+
+ i2c0: i2c@5002000 {
+ compatible = "allwinner,sun50i-h6-i2c",
+ "allwinner,sun6i-a31-i2c";
+ reg = <0x05002000 0x400>;
+ interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2C0>;
+ resets = <&ccu RST_BUS_I2C0>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2c0_pins>;
+ status = "disabled";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ };
+
+ i2c1: i2c@5002400 {
+ compatible = "allwinner,sun50i-h6-i2c",
+ "allwinner,sun6i-a31-i2c";
+ reg = <0x05002400 0x400>;
+ interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2C1>;
+ resets = <&ccu RST_BUS_I2C1>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2c1_pins>;
+ status = "disabled";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ };
+
+ i2c2: i2c@5002800 {
+ compatible = "allwinner,sun50i-h6-i2c",
+ "allwinner,sun6i-a31-i2c";
+ reg = <0x05002800 0x400>;
+ interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2C2>;
+ resets = <&ccu RST_BUS_I2C2>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2c2_pins>;
+ status = "disabled";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ };
+
+ i2c3: i2c@5002c00 {
+ compatible = "allwinner,sun50i-h6-i2c",
+ "allwinner,sun6i-a31-i2c";
+ reg = <0x05002c00 0x400>;
+ interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2C3>;
+ resets = <&ccu RST_BUS_I2C3>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2c3_pins>;
+ clock-frequency = <100000>;
+ status = "okay"; /* нужно для ac200 */
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ ac200: mfd@10 {
+ compatible = "x-powers,ac200";
+ reg = <0x10>;
+ clocks = <&ac200_pwm_clk>;
+ interrupt-parent = <&pio>;
+ interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
+ interrupt-controller;
+ #interrupt-cells = <1>;
+ nvmem-cells = <&ac200_bg>;
+ nvmem-cell-names = "bandgap";
+
+ ac200_ephy_ctl: syscon {
+ compatible = "x-powers,ac200-ephy-ctl";
+ nvmem-cells = <&ephy_calib>;
+ nvmem-cell-names = "calibration";
+ #clock-cells = <0>;
+ #reset-cells = <0>;
+ phy-mode = "rmii";
+ status = "okay";
+ x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
+ phy-address = <1>;
+ };
+
+ ac200_codec: codec {
+ #sound-dai-cells = <0>;
+ compatible = "x-powers,ac200-codec";
+ status = "okay";
+ avcc-supply = <®_aldo2>;
+ };
+ };
+ };
+
+ spi1: spi@5011000 {
+ compatible = "allwinner,sun50i-h6-spi",
+ "allwinner,sun8i-h3-spi";
+ reg = <0x05011000 0x1000>;
+ interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
+ clock-names = "ahb", "mod";
+ dmas = <&dma 23>, <&dma 23>;
+ dma-names = "rx", "tx";
+ pinctrl-names = "default";
+ pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
+ resets = <&ccu RST_BUS_SPI1>;
+ status = "disabled";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ };
+
+ emac: ethernet@5020000 {
+ compatible = "allwinner,sun50i-h6-emac",
+ "allwinner,sun50i-a64-emac";
+ syscon = <&syscon>;
+ reg = <0x05020000 0x10000>;
+ interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-names = "macirq";
+ resets = <&ccu RST_BUS_EMAC>;
+ reset-names = "stmmaceth";
+ clocks = <&ccu CLK_BUS_EMAC>;
+ clock-names = "stmmaceth";
+ status = "okay";
+ pinctrl-names = "default";
+ pinctrl-0 = <&ext_rmii_pins>;
+ phy-mode = "rmii";
+ phy-handle = <&ext_rmii_phy>;
+
+ mdio: mdio {
+ compatible = "snps,dwmac-mdio";
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ ext_rmii_phy: ethernet-phy@1 {
+ compatible = "ethernet-phy-id0044.1400",
+ "ethernet-phy-ieee802.3-c22";
+ reg = <1>;
+ resets = <&ac200_ephy_ctl>;
+ reset-names = "phy";
+ clocks = <&ac200_ephy_ctl>;
+ };
+ };
+ };
+
+ i2s3: i2s@508f000 {
+ #sound-dai-cells = <0>;
+ compatible = "allwinner,sun50i-h6-i2s";
+ reg = <0x0508f000 0x1000>;
+ interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
+ clock-names = "apb", "mod";
+ dmas = <&dma 6>, <&dma 6>;
+ resets = <&ccu RST_BUS_I2S3>;
+ dma-names = "rx", "tx";
+ pinctrl-names = "default";
+ pinctrl-0 = <&i2s3_pins>;
+ status = "okay";
+ };
+
+ i2s2: i2s@5092000 {
+ #sound-dai-cells = <0>;
+ compatible = "allwinner,sun50i-h6-i2s";
+ reg = <0x05092000 0x1000>;
+ interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
+ clock-names = "apb", "mod";
+ dmas = <&dma 5>, <&dma 5>;
+ resets = <&ccu RST_BUS_I2S2>;
+ dma-names = "rx", "tx";
+ status = "disabled";
+ };
+
+ i2s1: i2s@5091000 {
+ #sound-dai-cells = <0>;
+ compatible = "allwinner,sun50i-h6-i2s";
+ reg = <0x05091000 0x1000>;
+ interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
+ clock-names = "apb", "mod";
+ dmas = <&dma 4>, <&dma 4>;
+ resets = <&ccu RST_BUS_I2S1>;
+ dma-names = "rx", "tx";
+ status = "okay";
+ };
+
+ spdif: spdif@5093000 {
+ #sound-dai-cells = <0>;
+ compatible = "allwinner,sun50i-h6-spdif";
+ reg = <0x05093000 0x400>;
+ interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
+ clock-names = "apb", "spdif";
+ resets = <&ccu RST_BUS_SPDIF>;
+ dmas = <&dma 2>, <&dma 2>;
+ dma-names = "rx", "tx";
+ status = "disabled";
+ };
+
+ usb2otg: usb@5100000 {
+ compatible = "allwinner,sun50i-h6-musb",
+ "allwinner,sun8i-a33-musb";
+ reg = <0x05100000 0x0400>;
+ clocks = <&ccu CLK_BUS_OTG>;
+ resets = <&ccu RST_BUS_OTG>;
+ interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-names = "mc";
+ phys = <&usb2phy 0>;
+ phy-names = "usb";
+ extcon = <&usb2phy 0>;
+ status = "okay";
+ dr_mode = "host";
+ };
+
+ usb2phy: phy@5100400 {
+ compatible = "allwinner,sun50i-h6-usb-phy";
+ reg = <0x05100400 0x24>,
+ <0x05101800 0x4>,
+ <0x05311800 0x4>;
+ reg-names = "phy_ctrl",
+ "pmu0",
+ "pmu3";
+ clocks = <&ccu CLK_USB_PHY0>,
+ <&ccu CLK_USB_PHY3>;
+ clock-names = "usb0_phy",
+ "usb3_phy";
+ resets = <&ccu RST_USB_PHY0>,
+ <&ccu RST_USB_PHY3>;
+ reset-names = "usb0_reset",
+ "usb3_reset";
+ status = "okay";
+ #phy-cells = <1>;
+ };
+
+ ehci0: usb@5101000 {
+ compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
+ reg = <0x05101000 0x100>;
+ interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_OHCI0>,
+ <&ccu CLK_BUS_EHCI0>,
+ <&ccu CLK_USB_OHCI0>;
+ resets = <&ccu RST_BUS_OHCI0>,
+ <&ccu RST_BUS_EHCI0>;
+ phys = <&usb2phy 0>;
+ phy-names = "usb";
+ status = "okay";
+ };
+
+ ohci0: usb@5101400 {
+ compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
+ reg = <0x05101400 0x100>;
+ interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_OHCI0>,
+ <&ccu CLK_USB_OHCI0>;
+ resets = <&ccu RST_BUS_OHCI0>;
+ phys = <&usb2phy 0>;
+ phy-names = "usb";
+ status = "okay";
+ };
+
+ dwc3: usb@5200000 {
+ compatible = "snps,dwc3";
+ reg = <0x05200000 0x10000>;
+ interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_XHCI>,
+ <&ccu CLK_BUS_XHCI>,
+ <&rtc CLK_OSC32K>;
+ clock-names = "ref", "bus_early", "suspend";
+ resets = <&ccu RST_BUS_XHCI>;
+ /*
+ * The datasheet of the chip doesn't declare the
+ * peripheral function, and there's no boards known
+ * to have a USB Type-B port routed to the port.
+ * In addition, no one has tested the peripheral
+ * function yet.
+ * So set the dr_mode to "host" in the DTSI file.
+ */
+ dr_mode = "host";
+ phys = <&usb3phy>;
+ phy-names = "usb3-phy";
+ status = "okay";
+ };
+
+ usb3phy: phy@5210000 {
+ compatible = "allwinner,sun50i-h6-usb3-phy";
+ reg = <0x5210000 0x10000>;
+ clocks = <&ccu CLK_USB_PHY1>;
+ resets = <&ccu RST_USB_PHY1>;
+ #phy-cells = <0>;
+ status = "okay";
+ };
+
+ ehci3: usb@5311000 {
+ compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
+ reg = <0x05311000 0x100>;
+ interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_OHCI3>,
+ <&ccu CLK_BUS_EHCI3>,
+ <&ccu CLK_USB_OHCI3>;
+ resets = <&ccu RST_BUS_OHCI3>,
+ <&ccu RST_BUS_EHCI3>;
+ phys = <&usb2phy 3>;
+ phy-names = "usb";
+ status = "okay";
+ };
+
+ ohci3: usb@5311400 {
+ compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
+ reg = <0x05311400 0x100>;
+ interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_OHCI3>,
+ <&ccu CLK_USB_OHCI3>;
+ resets = <&ccu RST_BUS_OHCI3>;
+ phys = <&usb2phy 3>;
+ phy-names = "usb";
+ status = "okay";
+ };
+
+ pcie: pcie@5400000 {
+ #address-cells = <3>;
+ #size-cells = <2>;
+ compatible = "pine64,allwinner-h6-pcie-wrapped";
+ reg = <0x05400000 0x4000>,
+ <0x05410000 0x10000>;
+ reg-names = "dbi", "config";
+ device_type = "pci";
+ bus-range = <0x00 0xff>;
+ ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
+ 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
+ num-lanes = <1>;
+ max-link-speed = <2>;
+ interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
+ interrupt-names = "msi", "linkup";
+ clocks = <&ccu CLK_PCIE_REF_OUT>,
+ <&ccu CLK_PCIE_MAXI>,
+ <&ccu CLK_PCIE_AUX>,
+ <&ccu CLK_BUS_PCIE>;
+ clock-names = "ref", "axi", "aux", "bus";
+ resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
+ reset-names = "power", "bus";
+ #interrupt-cells = <1>;
+ interrupt-map-mask = <0 0 0 0>;
+ interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
+ status = "okay";
+ vcc-supply = <®_bldo2>;
+ vdd-supply = <®_dcdcd>;
+ slot-supply = <®_vcc33_wifi>;
+ perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
+ /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
+ /* wake-gpio = <&r_pio 0 4 0>; */
+ };
+
+
+ hdmi: hdmi@6000000 {
+ #sound-dai-cells = <0>;
+ compatible = "allwinner,sun50i-h6-dw-hdmi";
+ reg = <0x06000000 0x10000>;
+ reg-io-width = <1>;
+ interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
+ <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
+ <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
+ clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
+ "hdcp-bus";
+ resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
+ reset-names = "ctrl", "hdcp";
+ phys = <&hdmi_phy>;
+ phy-names = "phy";
+ pinctrl-names = "default";
+ pinctrl-0 = <&hdmi_pins>;
+ status = "okay";
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ hdmi_in: port@0 {
+ reg = <0>;
+
+ hdmi_in_tcon_top: endpoint {
+ remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
+ };
+ };
+
+ hdmi_out: port@1 {
+ reg = <1>;
+
+ hdmi_out_con: endpoint {
+ remote-endpoint = <&hdmi_con_in>;
+ };
+ };
+ };
+ };
+
+ hdmi_phy: hdmi-phy@6010000 {
+ compatible = "allwinner,sun50i-h6-hdmi-phy";
+ reg = <0x06010000 0x10000>;
+ clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
+ clock-names = "bus", "mod";
+ resets = <&ccu RST_BUS_HDMI>;
+ reset-names = "phy";
+ #phy-cells = <0>;
+ };
+
+ tcon_top: tcon-top@6510000 {
+ compatible = "allwinner,sun50i-h6-tcon-top";
+ reg = <0x06510000 0x1000>;
+ clocks = <&ccu CLK_BUS_TCON_TOP>,
+ <&ccu CLK_TCON_TV0>;
+ clock-names = "bus",
+ "tcon-tv0";
+ clock-output-names = "tcon-top-tv0";
+ resets = <&ccu RST_BUS_TCON_TOP>;
+ #clock-cells = <1>;
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ tcon_top_mixer0_in: port@0 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0>;
+
+ tcon_top_mixer0_in_mixer0: endpoint@0 {
+ reg = <0>;
+ remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
+ };
+ };
+
+ tcon_top_mixer0_out: port@1 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <1>;
+
+ tcon_top_mixer0_out_tcon_tv: endpoint@2 {
+ reg = <2>;
+ remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
+ };
+ };
+
+ tcon_top_hdmi_in: port@4 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <4>;
+
+ tcon_top_hdmi_in_tcon_tv: endpoint@0 {
+ reg = <0>;
+ remote-endpoint = <&tcon_tv_out_tcon_top>;
+ };
+ };
+
+ tcon_top_hdmi_out: port@5 {
+ reg = <5>;
+
+ tcon_top_hdmi_out_hdmi: endpoint {
+ remote-endpoint = <&hdmi_in_tcon_top>;
+ };
+ };
+ };
+ };
+
+ tcon_tv: lcd-controller@6515000 {
+ compatible = "allwinner,sun50i-h6-tcon-tv",
+ "allwinner,sun8i-r40-tcon-tv";
+ reg = <0x06515000 0x1000>;
+ interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_TCON_TV0>,
+ <&tcon_top CLK_TCON_TOP_TV0>;
+ clock-names = "ahb",
+ "tcon-ch1";
+ resets = <&ccu RST_BUS_TCON_TV0>;
+ reset-names = "lcd";
+
+ ports {
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ tcon_tv_in: port@0 {
+ reg = <0>;
+
+ tcon_tv_in_tcon_top_mixer0: endpoint {
+ remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
+ };
+ };
+
+ tcon_tv_out: port@1 {
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <1>;
+
+ tcon_tv_out_tcon_top: endpoint@1 {
+ reg = <1>;
+ remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
+ };
+ };
+ };
+ };
+
+ r_uart: serial@7080000 {
+ compatible = "snps,dw-apb-uart";
+ reg = <0x07080000 0x400>;
+ interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
+ reg-shift = <2>;
+ reg-io-width = <4>;
+ clocks = <&r_ccu CLK_R_APB2_UART>;
+ resets = <&r_ccu RST_R_APB2_UART>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&r_uart_pins>;
+ status = "disabled";
+ };
+
+ rtc: rtc@7000000 {
+ compatible = "allwinner,sun50i-h6-rtc";
+ reg = <0x07000000 0x400>;
+ interrupt-parent = <&r_intc>;
+ interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
+ clock-output-names = "osc32k", "osc32k-out", "iosc";
+ #clock-cells = <1>;
+ clocks = <&ext_osc32k>;
+ };
+
+ r_ccu: clock@7010000 {
+ compatible = "allwinner,sun50i-h6-r-ccu";
+ reg = <0x07010000 0x400>;
+ clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
+ <&ccu CLK_PLL_PERIPH0>;
+ clock-names = "hosc", "losc", "iosc", "pll-periph";
+ protected-clocks = <CLK_R_APB1_TWD>;
+ #clock-cells = <1>;
+ #reset-cells = <1>;
+ };
+
+ r_watchdog: watchdog@7020400 {
+ compatible = "allwinner,sun50i-h6-wdt",
+ "allwinner,sun6i-a31-wdt";
+ reg = <0x07020400 0x20>;
+ interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&osc24M>;
+ };
+
+ r_intc: interrupt-controller@7021000 {
+ compatible = "allwinner,sun50i-h6-r-intc";
+ interrupt-controller;
+ #interrupt-cells = <3>;
+ reg = <0x07021000 0x400>;
+ interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
+ };
+
+ r_pwm: pwm@7020C00 {
+ compatible = "allwinner,sun50i-h6-pwm";
+ reg = <0x07020C00 0x400>;
+ clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
+ clock-names = "mod", "bus";
+ resets = <&ccu RST_R_APB1_PWM>;
+ #pwm-cells = <3>;
+ status = "disabled";
+ };
+
+ r_pio: pinctrl@7022000 {
+ compatible = "allwinner,sun50i-h6-r-pinctrl";
+ reg = <0x07022000 0x400>;
+ interrupt-parent = <&r_intc>;
+ interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
+ <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
+ <&rtc CLK_OSC32K>;
+ clock-names = "apb", "hosc", "losc";
+ gpio-controller;
+ #gpio-cells = <3>;
+ interrupt-controller;
+ #interrupt-cells = <3>;
+
+ r_i2c_pins: r-i2c-pins {
+ pins = "PL0", "PL1";
+ function = "s_i2c";
+ };
+
+ r_ir_rx_pin: r-ir-rx-pin {
+ pins = "PL9";
+ function = "s_cir_rx";
+ };
+
+ r_rsb_pins: r-rsb-pins {
+ pins = "PL0", "PL1";
+ function = "s_rsb";
+ };
+
+ r_uart_pins: r-uart-pins {
+ pins = "PL2", "PL3";
+ function = "s_uart";
+ };
+
+ r_pwm_pin: r-pwm-pin {
+ pins = "PL8";
+ function = "s_pwm";
+ };
+
+ };
+
+ r_ir: ir@7040000 {
+ compatible = "allwinner,sun50i-h6-ir",
+ "allwinner,sun6i-a31-ir";
+ reg = <0x07040000 0x400>;
+ interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&r_ccu CLK_R_APB1_IR>,
+ <&r_ccu CLK_IR>;
+ clock-names = "apb", "ir";
+ resets = <&r_ccu RST_R_APB1_IR>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&r_ir_rx_pin>;
+ status = "disabled";
+ };
+
+ r_i2c: i2c@7081400 {
+ compatible = "allwinner,sun50i-h6-i2c",
+ "allwinner,sun6i-a31-i2c";
+ reg = <0x07081400 0x400>;
+ interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&r_ccu CLK_R_APB2_I2C>;
+ resets = <&r_ccu RST_R_APB2_I2C>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&r_i2c_pins>;
+ status = "okay";
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ axp805: pmic@36 {
+ compatible = "x-powers,axp805", "x-powers,axp806";
+ reg = <0x36>;
+ interrupt-parent = <&r_intc>;
+ interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
+ interrupt-controller;
+ #interrupt-cells = <1>;
+ x-powers,self-working-mode;
+ vina-supply = <®_vcc5v>;
+ vinb-supply = <®_vcc5v>;
+ vinc-supply = <®_vcc5v>;
+ vind-supply = <®_vcc5v>;
+ vine-supply = <®_vcc5v>;
+ aldoin-supply = <®_vcc5v>;
+ bldoin-supply = <®_vcc5v>;
+ cldoin-supply = <®_vcc5v>;
+
+ regulators {
+ reg_aldo1: aldo1 {
+ regulator-always-on;
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc-pl-led-ir";
+ };
+
+ reg_aldo2: aldo2 {
+ regulator-always-on;
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc33-audio-tv-ephy-mac";
+ regulator-enable-ramp-delay = <100000>;
+ };
+
+ reg_aldo3: aldo3 {
+ regulator-always-on;
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
+ };
+
+ reg_bldo1: bldo1 {
+ regulator-always-on;
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-name = "vcc18-dram-bias-pll";
+ };
+
+ reg_bldo2: bldo2 {
+ regulator-always-on;
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-name = "vcc-efuse-pcie-hdmi-pc";
+ };
+
+ reg_bldo3: bldo3 {
+ regulator-always-on;
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-name = "vcc-dcxoio";
+ };
+
+ reg_bldo4: bldo4 {
+ regulator-always-on;
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-name = "vcc-dcxoio";
+ };
+
+ reg_cldo1: cldo1 {
+ regulator-always-on;
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
+ };
+
+ reg_cldo2: cldo2 {
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc-wifi-1";
+ };
+
+ reg_cldo3: cldo3 {
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-name = "vcc-wifi-2";
+ };
+
+ reg_dcdca: dcdca {
+ regulator-always-on;
+ regulator-min-microvolt = <810000>;
+ regulator-max-microvolt = <1200000>;
+ regulator-ramp-delay = <2500>;
+ regulator-name = "vdd-cpu";
+ };
+
+ reg_dcdcc: dcdcc {
+ regulator-enable-ramp-delay = <32000>;
+ regulator-min-microvolt = <810000>;
+ regulator-max-microvolt = <1080000>;
+ regulator-ramp-delay = <2500>;
+ regulator-name = "vdd-gpu";
+ };
+
+ reg_dcdcd: dcdcd {
+ regulator-always-on;
+ regulator-min-microvolt = <1000000>;
+ regulator-max-microvolt = <1000000>;
+ regulator-name = "vdd-sys";
+ };
+
+ sw {
+ /* unused */
+ };
+ };
+ };
+ };
+
+ r_rsb: rsb@7083000 {
+ compatible = "allwinner,sun8i-a23-rsb";
+ reg = <0x07083000 0x400>;
+ interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&r_ccu CLK_R_APB2_RSB>;
+ clock-frequency = <3000000>;
+ resets = <&r_ccu RST_R_APB2_RSB>;
+ pinctrl-names = "default";
+ pinctrl-0 = <&r_rsb_pins>;
+ status = "disabled";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ };
+
+ ths: thermal-sensor@5070400 {
+ compatible = "allwinner,sun50i-h6-ths";
+ reg = <0x05070400 0x100>;
+ interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
+ clocks = <&ccu CLK_BUS_THS>;
+ clock-names = "bus";
+ resets = <&ccu RST_BUS_THS>;
+ nvmem-cells = <&ths_calibration>;
+ nvmem-cell-names = "calibration";
+ #thermal-sensor-cells = <1>;
+ };
+
+ sunxi-info {
+ compatible = "allwinner,sun50i-h6-sys-info";
+ status = "okay";
+ };
+
+ addr_mgt: addr-mgt {
+ compatible = "allwinner,sunxi-addr_mgt";
+ type_addr_wifi = <0x2>;
+ type_addr_bt = <0x2>;
+ type_addr_eth = <0x2>;
+ status = "okay";
+ };
+
+ dump_reg: dump_reg@20000 {
+ compatible = "allwinner,sunxi-dump-reg";
+ reg = <0x0 0x03001000 0x0 0x0f20>;
+ status = "okay";
+ };
+ };
+
+ thermal-zones {
+ cpu-thermal {
+ polling-delay-passive = <250>;
+ polling-delay = <1000>;
+ thermal-sensors = <&ths 0>;
+
+ trips {
+ cpu_warm: cpu_warm {
+ temperature = <70000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_hot0: cpu_hot0 {
+ temperature = <74000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_hot1: cpu_hot1 {
+ temperature = <76000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot0: cpu_very_hot0 {
+ temperature = <78000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot1: cpu_very_hot1 {
+ temperature = <80000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot2: cpu_very_hot2 {
+ temperature = <82000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot3: cpu_very_hot3 {
+ temperature = <84000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot4: cpu_very_hot4 {
+ temperature = <86000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot5: cpu_very_hot5 {
+ temperature = <88000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_very_hot6: cpu_very_hot6 {
+ temperature = <90000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ cpu_crit: cpu_crit {
+ temperature = <97000>;
+ hysteresis = <2000>;
+ type = "critical";
+ };
+ };
+
+ cooling-maps {
+ cpu_warm_limit_cpu {
+ trip = <&cpu_warm>;
+ cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
+ };
+ };
+ };
+
+ gpu-thermal {
+ polling-delay-passive = <1000>;
+ polling-delay = <2000>;
+ thermal-sensors = <&ths 1>;
+
+ trips {
+ gpu_alert0: gpu-alert-0 {
+ temperature = <95000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ gpu_alert1: gpu-alert-1 {
+ temperature = <100000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ gpu_alert2: gpu-alert-2 {
+ temperature = <105000>;
+ hysteresis = <2000>;
+ type = "passive";
+ };
+
+ gpu-crit {
+ temperature = <115000>;
+ hysteresis = <0>;
+ type = "critical";
+ };
+ };
+
+ cooling-maps {
+ // Forbid the GPU to go over 756MHz
+ map0 {
+ trip = <&gpu_alert0>;
+ cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
+ };
+
+ // Forbid the GPU to go over 624MHz
+ map1 {
+ trip = <&gpu_alert1>;
+ cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
+ };
+
+ // Forbid the GPU to go over 576MHz
+ map2 {
+ trip = <&gpu_alert2>;
+ cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
+ };
+ };
+ };
+ };
+
+ cpu_opp_table: cpu-opp-table {
+ compatible = "allwinner,sun50i-h6-operating-points";
+ nvmem-cells = <&cpu_speed_grade>;
+ opp-shared;
+
+ opp-480000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <480000000>;
+
+ opp-microvolt-speed0 = <880000>;
+ };
+
+ opp-720000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <720000000>;
+
+ opp-microvolt-speed0 = <880000>;
+ };
+
+ opp-888000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <888000000>;
+
+ opp-microvolt-speed0 = <880000>;
+ };
+
+ opp-1080000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1080000000>;
+
+ opp-microvolt-speed0 = <940000>;
+ };
+
+ opp-1320000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1320000000>;
+
+ opp-microvolt-speed0 = <1000000>;
+ };
+
+ opp-1488000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1488000000>;
+
+ opp-microvolt-speed0 = <1060000>;
+ };
+
+ opp-1608000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1608000000>;
+
+ opp-microvolt-speed0 = <1090000>;
+ };
+
+ opp-1704000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1704000000>;
+
+ opp-microvolt-speed0 = <1120000>;
+ };
+
+ opp-1800000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1800000000>;
+
+ opp-microvolt-speed0 = <1160000>;
+ };
+
+ opp@1896000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1896000000>;
+
+ opp-microvolt-speed0 = <1180000>;
+ };
+
+ opp@1968000000 {
+ clock-latency-ns = <244144>; /* 8 32k periods */
+ opp-hz = /bits/ 64 <1968000000>;
+
+ opp-microvolt-speed0 = <1200000>;
+ };
+
+ };
+
+ gpu_opp_table: opp-table-gpu {
+ compatible = "operating-points-v2";
+
+ opp-216000000 {
+ opp-hz = /bits/ 64 <216000000>;
+ opp-microvolt = <810000 810000 1200000>;
+ };
+
+ opp-264000000 {
+ opp-hz = /bits/ 64 <264000000>;
+ opp-microvolt = <810000 810000 1200000>;
+ };
+
+ opp-312000000 {
+ opp-hz = /bits/ 64 <312000000>;
+ opp-microvolt = <810000 810000 1200000>;
+ };
+
+ opp-336000000 {
+ opp-hz = /bits/ 64 <336000000>;
+ opp-microvolt = <810000 810000 1200000>;
+ };
+
+ opp-360000000 {
+ opp-hz = /bits/ 64 <360000000>;
+ opp-microvolt = <820000 820000 1200000>;
+ };
+
+ opp-384000000 {
+ opp-hz = /bits/ 64 <384000000>;
+ opp-microvolt = <830000 830000 1200000>;
+ };
+
+ opp-408000000 {
+ opp-hz = /bits/ 64 <408000000>;
+ opp-microvolt = <840000 840000 1200000>;
+ };
+
+ opp-420000000 {
+ opp-hz = /bits/ 64 <420000000>;
+ opp-microvolt = <850000 850000 1200000>;
+ };
+
+ opp-432000000 {
+ opp-hz = /bits/ 64 <432000000>;
+ opp-microvolt = <860000 860000 1200000>;
+ };
+
+ opp-456000000 {
+ opp-hz = /bits/ 64 <456000000>;
+ opp-microvolt = <870000 870000 1200000>;
+ };
+
+ opp-504000000 {
+ opp-hz = /bits/ 64 <504000000>;
+ opp-microvolt = <890000 890000 1200000>;
+ };
+
+ opp-540000000 {
+ opp-hz = /bits/ 64 <540000000>;
+ opp-microvolt = <910000 910000 1200000>;
+ };
+
+ opp-576000000 {
+ opp-hz = /bits/ 64 <576000000>;
+ opp-microvolt = <930000 930000 1200000>;
+ };
+
+ opp-624000000 {
+ opp-hz = /bits/ 64 <624000000>;
+ opp-microvolt = <950000 950000 1200000>;
+ };
+
+ opp-756000000 {
+ opp-hz = /bits/ 64 <756000000>;
+ opp-microvolt = <1040000 1040000 1200000>;
+ };
+ };
+
+ chosen {
+ stdout-path = "serial0:115200n8";
+ };
+
+ connector {
+ compatible = "hdmi-connector";
+ type = "a";
+
+ port {
+ hdmi_con_in: endpoint {
+ remote-endpoint = <&hdmi_out_con>;
+ };
+ };
+ };
+
+ ext_osc32k: ext_osc32k_clk {
+ #clock-cells = <0>;
+ compatible = "fixed-clock";
+ clock-frequency = <32768>;
+ clock-output-names = "ext_osc32k";
+ };
+
+ leds {
+ compatible = "gpio-leds";
+
+ led-0 {
+ label = "repka:red:power";
+ gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
+ linux,default-trigger = "heartbeat";
+ };
+ };
+
+ reg_vcc5v: vcc5v {
+ /* board wide 5V supply directly from the DC jack */
+ compatible = "regulator-fixed";
+ regulator-name = "vcc-5v";
+ regulator-min-microvolt = <5000000>;
+ regulator-max-microvolt = <5000000>;
+ regulator-always-on;
+ };
+
+ reg_vcc33_wifi: vcc33-wifi {
+ /* Always on 3.3V regulator for WiFi and BT */
+ compatible = "regulator-fixed";
+ regulator-name = "vcc33-wifi";
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-always-on;
+ vin-supply = <®_vcc5v>;
+ };
+
+ reg_vcc_wifi_io: vcc-wifi-io {
+ /* Always on 1.8V/300mA regulator for WiFi and BT IO */
+ compatible = "regulator-fixed";
+ regulator-name = "vcc-wifi-io";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ regulator-always-on;
+ vin-supply = <®_vcc33_wifi>;
+ };
+
+ wifi_pwrseq: wifi-pwrseq {
+ compatible = "mmc-pwrseq-simple";
+ clocks = <&rtc 1>;
+ clock-names = "ext_clock";
+ reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
+ post-power-on-delay-ms = <200>;
+ };
+};
--
2.42.2
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-06 12:28 [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal kurachenko-urup
@ 2025-05-07 19:39 ` Vitaly Chikunov
2025-05-07 20:50 ` Kurachenko Anton
2025-05-08 1:22 ` Vitaly Chikunov
1 sibling, 1 reply; 7+ messages in thread
From: Vitaly Chikunov @ 2025-05-07 19:39 UTC (permalink / raw)
To: ALT Linux kernel packages development
Anton,
On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
> From: Anton Kurachenko <srebrov@altlinux.org>
>
> Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
> u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
> a dtb file.
>
> Patch designed specifically for ALT and never used anywhere.
1. Это изменение протестировано?
2. Зачем нужен этот патч, если есть флейворы repka/repka4?
Thanks,
>
> The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
> file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
> from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
> Represents the result of merging these files with applying some modifications.
>
> Files that were used during the creation process:
>
> sun50i-h6-repka-pi4-optimal.dts
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
>
> sun50i-h6.dtsi
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
>
> sun50i-h6-cpu-opp.dtsi
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
>
> Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
> ---
> arch/arm64/boot/dts/allwinner/Makefile | 1 +
> .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
> 2 files changed, 1919 insertions(+)
> create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>
> diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
> index 00bed412ee31..2df5189e0d44 100644
> --- a/arch/arm64/boot/dts/allwinner/Makefile
> +++ b/arch/arm64/boot/dts/allwinner/Makefile
> @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
> +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
> diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> new file mode 100644
> index 000000000000..9d95297a30b8
> --- /dev/null
> +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> @@ -0,0 +1,1918 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +// based on the dts, which is:
> +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
> +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
> +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
> +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
> +
> +/dts-v1/;
> +
> +#include <dt-bindings/interrupt-controller/arm-gic.h>
> +#include <dt-bindings/clock/sun50i-h6-ccu.h>
> +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
> +#include <dt-bindings/clock/sun6i-rtc.h>
> +#include <dt-bindings/clock/sun8i-de2.h>
> +#include <dt-bindings/clock/sun8i-tcon-top.h>
> +#include <dt-bindings/reset/sun50i-h6-ccu.h>
> +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
> +#include <dt-bindings/reset/sun8i-de2.h>
> +#include <dt-bindings/thermal/thermal.h>
> +#include <dt-bindings/gpio/gpio.h>
> +
> +/ {
> + interrupt-parent = <&gic>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + model = "Repka-Pi4-Optimal";
> + repka-freq = "1.968 GHz";
> + repka-pinout = "repka-pi4-base";
> + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
> +
> + aliases {
> + mmc0 = &mmc0;
> + mmc1 = &mmc1;
> + mmc2 = &mmc2;
> + ethernet0 = &emac;
> + serial0 = &uart0;
> + serial1 = &uart1;
> + serial2 = &r_uart;
> +
> + spi0 = &spi1;
> + i2c1 = &i2c0;
> + i2c2 = &i2c2;
> + i2c3 = &i2c1;
> + i2c4 = &i2c3;
> +
> + };
> +
> + reserved-memory {
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + custom_region: region@40010000 {
> + reg = <0x40010000 0x00070000>;
> + no-map;
> + };
> + };
> +
> + analog: analog-codec {
> + compatible = "simple-audio-card";
> + simple-audio-card,format = "i2s";
> + simple-audio-card,name = "ac200-audio";
> + simple-audio-card,mclk-fs = <512>;
> + status = "okay";
> +
> + simple-audio-card,cpu {
> + sound-dai = <&i2s3>;
> + };
> +
> + simple-audio-card,codec {
> + sound-dai = <&ac200_codec>;
> + };
> + };
> +
> + ac200_pwm_clk: ac200_clk {
> + compatible = "pwm-clock";
> + #clock-cells = <0>;
> + clock-frequency = <24000000>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&pwm1_pin>;
> + pwms = <&pwm 1 42 0>;
> + status = "okay";
> + };
> +
> + cpus {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + cpu0: cpu@0 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <0>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + cpu-supply = <®_dcdca>;
> + };
> +
> + cpu1: cpu@1 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <1>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> +
> + cpu2: cpu@2 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <2>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> +
> + cpu3: cpu@3 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <3>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> + };
> +
> + de: display-engine {
> + compatible = "allwinner,sun50i-h6-display-engine";
> + allwinner,pipelines = <&mixer0>;
> + status = "okay";
> + };
> +
> + osc24M: osc24M_clk {
> + #clock-cells = <0>;
> + compatible = "fixed-clock";
> + clock-frequency = <24000000>;
> + clock-output-names = "osc24M";
> + };
> +
> + pmu {
> + compatible = "arm,cortex-a53-pmu";
> + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
> + };
> +
> + psci {
> + compatible = "arm,psci-0.2";
> + method = "smc";
> + };
> +
> + scpi_protocol: scpi {
> + compatible = "arm,scpi";
> + mboxes = <&msgbox 2>, <&msgbox 3>;
> + mbox-names = "tx", "rx";
> + shmem = <&scpi_sram>;
> + };
> +
> + sound_hdmi: sound_hdmi {
> + compatible = "allwinner,sun9i-a80-hdmi-audio",
> + "allwinner,sun50i-h6-hdmi-audio";
> + status = "okay";
> + codec {
> + sound-dai = <&hdmi>;
> + };
> +
> + cpu {
> + sound-dai = <&i2s1>;
> + };
> + };
> +
> + timer {
> + compatible = "arm,armv8-timer";
> + arm,no-tick-in-suspend;
> + interrupts = <GIC_PPI 13
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 14
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 11
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 10
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> + };
> +
> +
> + soc {
> + compatible = "simple-bus";
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + bus@1000000 {
> + compatible = "allwinner,sun50i-h6-de3",
> + "allwinner,sun50i-a64-de2";
> + reg = <0x1000000 0x400000>;
> + allwinner,sram = <&de2_sram 1>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x1000000 0x400000>;
> +
> + display_clocks: clock@0 {
> + compatible = "allwinner,sun50i-h6-de3-clk";
> + reg = <0x0 0x10000>;
> + clocks = <&ccu CLK_BUS_DE>,
> + <&ccu CLK_DE>;
> + clock-names = "bus",
> + "mod";
> + resets = <&ccu RST_BUS_DE>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + mixer0: mixer@100000 {
> + compatible = "allwinner,sun50i-h6-de3-mixer-0";
> + reg = <0x100000 0x100000>;
> + clocks = <&display_clocks CLK_BUS_MIXER0>,
> + <&display_clocks CLK_MIXER0>;
> + clock-names = "bus",
> + "mod";
> + resets = <&display_clocks RST_MIXER0>;
> + iommus = <&iommu 0>;
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + mixer0_out: port@1 {
> + reg = <1>;
> +
> + mixer0_out_tcon_top_mixer0: endpoint {
> + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
> + };
> + };
> + };
> + };
> + };
> +
> +
> + video-codec-g2@1c00000 {
> + compatible = "allwinner,sun50i-h6-vpu-g2";
> + reg = <0x01c00000 0x1000>;
> + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
> + clock-names = "bus", "mod";
> + resets = <&ccu RST_BUS_VP9>;
> + iommus = <&iommu 5>;
> + };
> +
> + deinterlace: deinterlace@1420000 {
> + compatible = "allwinner,sun50i-h6-deinterlace";
> + reg = <0x01420000 0x2000>;
> + clocks = <&ccu CLK_BUS_DEINTERLACE>,
> + <&ccu CLK_DEINTERLACE>,
> + <&ccu CLK_MBUS_DEINTERLACE>;
> + clock-names = "bus", "mod", "ram";
> + resets = <&ccu RST_BUS_DEINTERLACE>;
> + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
> + iommus = <&iommu 2>;
> + };
> +
> + video-codec@1c0e000 {
> + compatible = "allwinner,sun50i-h6-video-engine";
> + reg = <0x01c0e000 0x2000>;
> + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
> + <&ccu CLK_MBUS_VE>;
> + clock-names = "ahb", "mod", "ram";
> + resets = <&ccu RST_BUS_VE>;
> + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
> + allwinner,sram = <&ve_sram 1>;
> + iommus = <&iommu 1>, <&iommu 3>;
> + };
> +
> + gpu: gpu@1800000 {
> + compatible = "allwinner,sun50i-h6-mali",
> + "arm,mali-t720";
> + reg = <0x01800000 0x4000>;
> + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "job", "mmu", "gpu";
> + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
> + clock-names = "core", "bus";
> + resets = <&ccu RST_BUS_GPU>;
> + #cooling-cells = <2>;
> + status = "okay";
> + operating-points-v2 = <&gpu_opp_table>;
> + mali-supply = <®_dcdcc>;
> + };
> +
> + crypto: crypto@1904000 {
> + compatible = "allwinner,sun50i-h6-crypto";
> + reg = <0x01904000 0x1000>;
> + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
> + clock-names = "bus", "mod", "ram";
> + resets = <&ccu RST_BUS_CE>;
> + };
> +
> + syscon: syscon@3000000 {
> + compatible = "allwinner,sun50i-h6-system-control",
> + "allwinner,sun50i-a64-system-control";
> + reg = <0x03000000 0x1000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + sram_a2: sram@100000 {
> + compatible = "mmio-sram";
> + reg = <0x00100000 0x18000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x00100000 0x18000>;
> +
> + scpi_sram: scp-shmem@17c00 {
> + compatible = "arm,scp-shmem";
> + reg = <0x17c00 0x200>;
> + };
> + };
> +
> + sram_c: sram@28000 {
> + compatible = "mmio-sram";
> + reg = <0x00028000 0x1e000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x00028000 0x1e000>;
> +
> + de2_sram: sram-section@0 {
> + compatible = "allwinner,sun50i-h6-sram-c",
> + "allwinner,sun50i-a64-sram-c";
> + reg = <0x0000 0x1e000>;
> + };
> + };
> +
> + sram_c1: sram@1a00000 {
> + compatible = "mmio-sram";
> + reg = <0x01a00000 0x200000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x01a00000 0x200000>;
> +
> + ve_sram: sram-section@0 {
> + compatible = "allwinner,sun50i-h6-sram-c1",
> + "allwinner,sun4i-a10-sram-c1";
> + reg = <0x000000 0x200000>;
> + };
> + };
> + };
> +
> + ccu: clock@3001000 {
> + compatible = "allwinner,sun50i-h6-ccu";
> + reg = <0x03001000 0x1000>;
> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
> + clock-names = "hosc", "losc", "iosc";
> + protected-clocks = <CLK_BUS_MSGBOX>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + dma: dma-controller@3002000 {
> + compatible = "allwinner,sun50i-h6-dma";
> + reg = <0x03002000 0x1000>;
> + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
> + clock-names = "bus", "mbus";
> + dma-channels = <16>;
> + dma-requests = <46>;
> + resets = <&ccu RST_BUS_DMA>;
> + #dma-cells = <1>;
> + };
> +
> + msgbox: mailbox@3003000 {
> + compatible = "allwinner,sun50i-h6-msgbox",
> + "allwinner,sun6i-a31-msgbox";
> + reg = <0x03003000 0x1000>;
> + clocks = <&ccu CLK_BUS_MSGBOX>;
> + resets = <&ccu RST_BUS_MSGBOX>;
> + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> + #mbox-cells = <1>;
> + };
> +
> + gic: interrupt-controller@3021000 {
> + compatible = "arm,gic-400";
> + reg = <0x03021000 0x1000>,
> + <0x03022000 0x2000>,
> + <0x03024000 0x2000>,
> + <0x03026000 0x2000>;
> + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + };
> +
> + sid: efuse@3006000 {
> + compatible = "allwinner,sun50i-h6-sid";
> + reg = <0x03006000 0x400>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> +
> + ths_calibration: thermal-sensor-calibration@14 {
> + reg = <0x14 0x8>;
> + };
> +
> + cpu_speed_grade: cpu-speed-grade@1c {
> + reg = <0x1c 0x4>;
> + };
> +
> + ephy_calib: ephy_calib@2c {
> + reg = <0x2c 0x2>;
> + };
> +
> + ac200_bg: ac200_bg@30 {
> + reg = <0x30 0x2>;
> + };
> + };
> +
> + timer@3009000 {
> + compatible = "allwinner,sun50i-h6-timer",
> + "allwinner,sun8i-a23-timer";
> + reg = <0x03009000 0xa0>;
> + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + };
> +
> + watchdog: watchdog@30090a0 {
> + compatible = "allwinner,sun50i-h6-wdt",
> + "allwinner,sun6i-a31-wdt";
> + reg = <0x030090a0 0x20>;
> + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + /* Broken on some H6 boards */
> + status = "disabled";
> + };
> +
> + pwm: pwm@300a000 {
> + compatible = "allwinner,sun50i-h6-pwm";
> + reg = <0x0300a000 0x400>;
> + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
> + clock-names = "mod", "bus";
> + resets = <&ccu RST_BUS_PWM>;
> + #pwm-cells = <3>;
> + status = "okay";
> + };
> +
> + pio: pinctrl@300b000 {
> + compatible = "allwinner,sun50i-h6-pinctrl";
> + reg = <0x0300b000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
> + clock-names = "apb", "hosc", "losc";
> + gpio-controller;
> + #gpio-cells = <3>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + vcc-pc-supply = <®_bldo2>;
> + vcc-pd-supply = <®_cldo1>;
> + vcc-pg-supply = <®_vcc_wifi_io>;
> +
> + /omit-if-no-ref/
> + ext_rgmii_pins: rgmii-pins {
> + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
> + "PD5", "PD7", "PD8", "PD9", "PD10",
> + "PD11", "PD12", "PD13", "PD19", "PD20";
> + function = "emac";
> + drive-strength = <40>;
> + };
> +
> + ext_rmii_pins: rmii_pins {
> + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
> + "PA5", "PA6", "PA7", "PA8", "PA9";
> + function = "emac";
> + drive-strength = <40>;
> + };
> +
> + hdmi_pins: hdmi-pins {
> + pins = "PH8", "PH9", "PH10";
> + function = "hdmi";
> + };
> +
> + i2c0_pins: i2c0-pins {
> + pins = "PD25", "PD26";
> + function = "i2c0";
> + };
> +
> + i2c1_pins: i2c1-pins {
> + pins = "PH5", "PH6";
> + function = "i2c1";
> + };
> +
> + i2c2_pins: i2c2-pins {
> + pins = "PD23", "PD24";
> + function = "i2c2";
> + };
> +
> + i2c3_pins: i2c3-pins {
> + pins = "PB17", "PB18";
> + function = "i2c3";
> + bias-pull-up;
> + };
> +
> + i2s3_pins: i2s3-pins {
> + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
> + function = "i2s3";
> + };
> +
> + mmc0_pins: mmc0-pins {
> + pins = "PF0", "PF1", "PF2", "PF3",
> + "PF4", "PF5";
> + function = "mmc0";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + /omit-if-no-ref/
> + mmc1_pins: mmc1-pins {
> + pins = "PG0", "PG1", "PG2", "PG3",
> + "PG4", "PG5";
> + function = "mmc1";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + /omit-if-no-ref/
> + mmc2_pins: mmc2-pins {
> + pins = "PC1", "PC4", "PC5", "PC6",
> + "PC7", "PC8", "PC9", "PC10",
> + "PC11", "PC12", "PC13", "PC14";
> + function = "mmc2";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + pwm1_pin: pwm1-pin {
> + pins = "PB19";
> + function = "pwm1";
> + };
> +
> + pwm_pin: pwm-pin {
> + pins = "PD22";
> + function = "pwm";
> + };
> +
> + /omit-if-no-ref/
> + spi0_pins: spi0-pins {
> + pins = "PC0", "PC2", "PC3";
> + function = "spi0";
> + };
> +
> + /* pin shared with MMC2-CMD (eMMC) */
> + /omit-if-no-ref/
> + spi0_cs_pin: spi0-cs-pin {
> + pins = "PC5";
> + function = "spi0";
> + };
> +
> + /omit-if-no-ref/
> + spi1_pins: spi1-pins {
> + pins = "PH4", "PH5", "PH6";
> + function = "spi1";
> + };
> +
> + /omit-if-no-ref/
> + spi1_cs_pin: spi1-cs-pin {
> + pins = "PH3";
> + function = "spi1";
> + };
> +
> + /omit-if-no-ref/
> + spdif_tx_pin: spdif-tx-pin {
> + pins = "PH7";
> + function = "spdif";
> + };
> +
> + uart0_ph_pins: uart0-ph-pins {
> + pins = "PH0", "PH1";
> + function = "uart0";
> + };
> +
> + uart1_pins: uart1-pins {
> + pins = "PG6", "PG7";
> + function = "uart1";
> + };
> +
> + uart1_rts_cts_pins: uart1-rts-cts-pins {
> + pins = "PG8", "PG9";
> + function = "uart1";
> + };
> +
> + uart2_pins: uart2-pins {
> + pins = "PD19", "PD20";
> + function = "uart2";
> + };
> +
> + uart2_rts_cts_pins: uart2-rts-cts-pins {
> + pins = "PD21", "PD22";
> + function = "uart2";
> + };
> +
> + uart3_pins: uart3-pins {
> + pins = "PD23", "PD24";
> + function = "uart3";
> + };
> +
> + uart3_rts_cts_pins: uart3-rts-cts-pins {
> + pins = "PD25", "PD26";
> + function = "uart3";
> + };
> +
> + i2s2_pins: i2s2-pins {
> + pins = "PG10", "PG11", "PG12", "PG13";
> + function = "i2s2";
> + };
> + };
> +
> + iommu: iommu@30f0000 {
> + compatible = "allwinner,sun50i-h6-iommu";
> + reg = <0x030f0000 0x10000>;
> + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_IOMMU>;
> + resets = <&ccu RST_BUS_IOMMU>;
> + #iommu-cells = <1>;
> + };
> +
> + mmc0: mmc@4020000 {
> + compatible = "allwinner,sun50i-h6-mmc",
> + "allwinner,sun50i-a64-mmc";
> + reg = <0x04020000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC0>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc0_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_cldo1>;
> + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
> + bus-width = <4>;
> + };
> +
> + mmc1: mmc@4021000 {
> + compatible = "allwinner,sun50i-h6-mmc",
> + "allwinner,sun50i-a64-mmc";
> + reg = <0x04021000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC1>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc1_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_vcc33_wifi>;
> + vqmmc-supply = <®_vcc_wifi_io>;
> + mmc-pwrseq = <&wifi_pwrseq>;
> + bus-width = <4>;
> + non-removable;
> +
> + brcm: sdio-wifi@1 {
> + reg = <1>;
> + compatible = "brcm,bcm4329-fmac";
> + interrupt-parent = <&r_pio>;
> + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
> + interrupt-names = "host-wake";
> + };
> + };
> +
> + mmc2: mmc@4022000 {
> + compatible = "allwinner,sun50i-h6-emmc";
> + reg = <0x04022000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC2>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc2_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_cldo1>;
> + vqmmc-supply = <®_bldo2>;
> + cap-mmc-hw-reset;
> + non-removable;
> + bus-width = <8>;
> + };
> +
> + uart0: serial@5000000 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000000 0x400>;
> + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART0>;
> + resets = <&ccu RST_BUS_UART0>;
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&uart0_ph_pins>;
> + };
> +
> + uart1: serial@5000400 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000400 0x400>;
> + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART1>;
> + resets = <&ccu RST_BUS_UART1>;
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
> + uart-has-rtscts;
> +
> + bluetooth {
> + compatible = "brcm,bcm4345c5";
> + clocks = <&rtc 1>;
> + clock-names = "lpo";
> + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
> + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
> + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
> + max-speed = <1500000>;
> + };
> + };
> +
> + uart2: serial@5000800 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000800 0x400>;
> + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART2>;
> + resets = <&ccu RST_BUS_UART2>;
> + status = "disabled";
> + };
> +
> + uart3: serial@5000c00 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000c00 0x400>;
> + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART3>;
> + resets = <&ccu RST_BUS_UART3>;
> + status = "disabled";
> + };
> +
> + i2c0: i2c@5002000 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002000 0x400>;
> + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C0>;
> + resets = <&ccu RST_BUS_I2C0>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c0_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c1: i2c@5002400 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002400 0x400>;
> + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C1>;
> + resets = <&ccu RST_BUS_I2C1>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c1_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c2: i2c@5002800 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002800 0x400>;
> + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C2>;
> + resets = <&ccu RST_BUS_I2C2>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c2_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c3: i2c@5002c00 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002c00 0x400>;
> + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C3>;
> + resets = <&ccu RST_BUS_I2C3>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c3_pins>;
> + clock-frequency = <100000>;
> + status = "okay"; /* нужно для ac200 */
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + ac200: mfd@10 {
> + compatible = "x-powers,ac200";
> + reg = <0x10>;
> + clocks = <&ac200_pwm_clk>;
> + interrupt-parent = <&pio>;
> + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
> + interrupt-controller;
> + #interrupt-cells = <1>;
> + nvmem-cells = <&ac200_bg>;
> + nvmem-cell-names = "bandgap";
> +
> + ac200_ephy_ctl: syscon {
> + compatible = "x-powers,ac200-ephy-ctl";
> + nvmem-cells = <&ephy_calib>;
> + nvmem-cell-names = "calibration";
> + #clock-cells = <0>;
> + #reset-cells = <0>;
> + phy-mode = "rmii";
> + status = "okay";
> + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
> + phy-address = <1>;
> + };
> +
> + ac200_codec: codec {
> + #sound-dai-cells = <0>;
> + compatible = "x-powers,ac200-codec";
> + status = "okay";
> + avcc-supply = <®_aldo2>;
> + };
> + };
> + };
> +
> + spi1: spi@5011000 {
> + compatible = "allwinner,sun50i-h6-spi",
> + "allwinner,sun8i-h3-spi";
> + reg = <0x05011000 0x1000>;
> + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
> + clock-names = "ahb", "mod";
> + dmas = <&dma 23>, <&dma 23>;
> + dma-names = "rx", "tx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
> + resets = <&ccu RST_BUS_SPI1>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + emac: ethernet@5020000 {
> + compatible = "allwinner,sun50i-h6-emac",
> + "allwinner,sun50i-a64-emac";
> + syscon = <&syscon>;
> + reg = <0x05020000 0x10000>;
> + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "macirq";
> + resets = <&ccu RST_BUS_EMAC>;
> + reset-names = "stmmaceth";
> + clocks = <&ccu CLK_BUS_EMAC>;
> + clock-names = "stmmaceth";
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&ext_rmii_pins>;
> + phy-mode = "rmii";
> + phy-handle = <&ext_rmii_phy>;
> +
> + mdio: mdio {
> + compatible = "snps,dwmac-mdio";
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + ext_rmii_phy: ethernet-phy@1 {
> + compatible = "ethernet-phy-id0044.1400",
> + "ethernet-phy-ieee802.3-c22";
> + reg = <1>;
> + resets = <&ac200_ephy_ctl>;
> + reset-names = "phy";
> + clocks = <&ac200_ephy_ctl>;
> + };
> + };
> + };
> +
> + i2s3: i2s@508f000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x0508f000 0x1000>;
> + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 6>, <&dma 6>;
> + resets = <&ccu RST_BUS_I2S3>;
> + dma-names = "rx", "tx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2s3_pins>;
> + status = "okay";
> + };
> +
> + i2s2: i2s@5092000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x05092000 0x1000>;
> + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 5>, <&dma 5>;
> + resets = <&ccu RST_BUS_I2S2>;
> + dma-names = "rx", "tx";
> + status = "disabled";
> + };
> +
> + i2s1: i2s@5091000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x05091000 0x1000>;
> + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 4>, <&dma 4>;
> + resets = <&ccu RST_BUS_I2S1>;
> + dma-names = "rx", "tx";
> + status = "okay";
> + };
> +
> + spdif: spdif@5093000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-spdif";
> + reg = <0x05093000 0x400>;
> + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
> + clock-names = "apb", "spdif";
> + resets = <&ccu RST_BUS_SPDIF>;
> + dmas = <&dma 2>, <&dma 2>;
> + dma-names = "rx", "tx";
> + status = "disabled";
> + };
> +
> + usb2otg: usb@5100000 {
> + compatible = "allwinner,sun50i-h6-musb",
> + "allwinner,sun8i-a33-musb";
> + reg = <0x05100000 0x0400>;
> + clocks = <&ccu CLK_BUS_OTG>;
> + resets = <&ccu RST_BUS_OTG>;
> + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "mc";
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + extcon = <&usb2phy 0>;
> + status = "okay";
> + dr_mode = "host";
> + };
> +
> + usb2phy: phy@5100400 {
> + compatible = "allwinner,sun50i-h6-usb-phy";
> + reg = <0x05100400 0x24>,
> + <0x05101800 0x4>,
> + <0x05311800 0x4>;
> + reg-names = "phy_ctrl",
> + "pmu0",
> + "pmu3";
> + clocks = <&ccu CLK_USB_PHY0>,
> + <&ccu CLK_USB_PHY3>;
> + clock-names = "usb0_phy",
> + "usb3_phy";
> + resets = <&ccu RST_USB_PHY0>,
> + <&ccu RST_USB_PHY3>;
> + reset-names = "usb0_reset",
> + "usb3_reset";
> + status = "okay";
> + #phy-cells = <1>;
> + };
> +
> + ehci0: usb@5101000 {
> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> + reg = <0x05101000 0x100>;
> + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI0>,
> + <&ccu CLK_BUS_EHCI0>,
> + <&ccu CLK_USB_OHCI0>;
> + resets = <&ccu RST_BUS_OHCI0>,
> + <&ccu RST_BUS_EHCI0>;
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + ohci0: usb@5101400 {
> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> + reg = <0x05101400 0x100>;
> + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI0>,
> + <&ccu CLK_USB_OHCI0>;
> + resets = <&ccu RST_BUS_OHCI0>;
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + dwc3: usb@5200000 {
> + compatible = "snps,dwc3";
> + reg = <0x05200000 0x10000>;
> + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_XHCI>,
> + <&ccu CLK_BUS_XHCI>,
> + <&rtc CLK_OSC32K>;
> + clock-names = "ref", "bus_early", "suspend";
> + resets = <&ccu RST_BUS_XHCI>;
> + /*
> + * The datasheet of the chip doesn't declare the
> + * peripheral function, and there's no boards known
> + * to have a USB Type-B port routed to the port.
> + * In addition, no one has tested the peripheral
> + * function yet.
> + * So set the dr_mode to "host" in the DTSI file.
> + */
> + dr_mode = "host";
> + phys = <&usb3phy>;
> + phy-names = "usb3-phy";
> + status = "okay";
> + };
> +
> + usb3phy: phy@5210000 {
> + compatible = "allwinner,sun50i-h6-usb3-phy";
> + reg = <0x5210000 0x10000>;
> + clocks = <&ccu CLK_USB_PHY1>;
> + resets = <&ccu RST_USB_PHY1>;
> + #phy-cells = <0>;
> + status = "okay";
> + };
> +
> + ehci3: usb@5311000 {
> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> + reg = <0x05311000 0x100>;
> + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI3>,
> + <&ccu CLK_BUS_EHCI3>,
> + <&ccu CLK_USB_OHCI3>;
> + resets = <&ccu RST_BUS_OHCI3>,
> + <&ccu RST_BUS_EHCI3>;
> + phys = <&usb2phy 3>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + ohci3: usb@5311400 {
> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> + reg = <0x05311400 0x100>;
> + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI3>,
> + <&ccu CLK_USB_OHCI3>;
> + resets = <&ccu RST_BUS_OHCI3>;
> + phys = <&usb2phy 3>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + pcie: pcie@5400000 {
> + #address-cells = <3>;
> + #size-cells = <2>;
> + compatible = "pine64,allwinner-h6-pcie-wrapped";
> + reg = <0x05400000 0x4000>,
> + <0x05410000 0x10000>;
> + reg-names = "dbi", "config";
> + device_type = "pci";
> + bus-range = <0x00 0xff>;
> + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
> + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
> + num-lanes = <1>;
> + max-link-speed = <2>;
> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "msi", "linkup";
> + clocks = <&ccu CLK_PCIE_REF_OUT>,
> + <&ccu CLK_PCIE_MAXI>,
> + <&ccu CLK_PCIE_AUX>,
> + <&ccu CLK_BUS_PCIE>;
> + clock-names = "ref", "axi", "aux", "bus";
> + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
> + reset-names = "power", "bus";
> + #interrupt-cells = <1>;
> + interrupt-map-mask = <0 0 0 0>;
> + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
> + status = "okay";
> + vcc-supply = <®_bldo2>;
> + vdd-supply = <®_dcdcd>;
> + slot-supply = <®_vcc33_wifi>;
> + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
> + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
> + /* wake-gpio = <&r_pio 0 4 0>; */
> + };
> +
> +
> + hdmi: hdmi@6000000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-dw-hdmi";
> + reg = <0x06000000 0x10000>;
> + reg-io-width = <1>;
> + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
> + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
> + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
> + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
> + "hdcp-bus";
> + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
> + reset-names = "ctrl", "hdcp";
> + phys = <&hdmi_phy>;
> + phy-names = "phy";
> + pinctrl-names = "default";
> + pinctrl-0 = <&hdmi_pins>;
> + status = "okay";
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + hdmi_in: port@0 {
> + reg = <0>;
> +
> + hdmi_in_tcon_top: endpoint {
> + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
> + };
> + };
> +
> + hdmi_out: port@1 {
> + reg = <1>;
> +
> + hdmi_out_con: endpoint {
> + remote-endpoint = <&hdmi_con_in>;
> + };
> + };
> + };
> + };
> +
> + hdmi_phy: hdmi-phy@6010000 {
> + compatible = "allwinner,sun50i-h6-hdmi-phy";
> + reg = <0x06010000 0x10000>;
> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
> + clock-names = "bus", "mod";
> + resets = <&ccu RST_BUS_HDMI>;
> + reset-names = "phy";
> + #phy-cells = <0>;
> + };
> +
> + tcon_top: tcon-top@6510000 {
> + compatible = "allwinner,sun50i-h6-tcon-top";
> + reg = <0x06510000 0x1000>;
> + clocks = <&ccu CLK_BUS_TCON_TOP>,
> + <&ccu CLK_TCON_TV0>;
> + clock-names = "bus",
> + "tcon-tv0";
> + clock-output-names = "tcon-top-tv0";
> + resets = <&ccu RST_BUS_TCON_TOP>;
> + #clock-cells = <1>;
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + tcon_top_mixer0_in: port@0 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0>;
> +
> + tcon_top_mixer0_in_mixer0: endpoint@0 {
> + reg = <0>;
> + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
> + };
> + };
> +
> + tcon_top_mixer0_out: port@1 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <1>;
> +
> + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
> + reg = <2>;
> + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
> + };
> + };
> +
> + tcon_top_hdmi_in: port@4 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <4>;
> +
> + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
> + reg = <0>;
> + remote-endpoint = <&tcon_tv_out_tcon_top>;
> + };
> + };
> +
> + tcon_top_hdmi_out: port@5 {
> + reg = <5>;
> +
> + tcon_top_hdmi_out_hdmi: endpoint {
> + remote-endpoint = <&hdmi_in_tcon_top>;
> + };
> + };
> + };
> + };
> +
> + tcon_tv: lcd-controller@6515000 {
> + compatible = "allwinner,sun50i-h6-tcon-tv",
> + "allwinner,sun8i-r40-tcon-tv";
> + reg = <0x06515000 0x1000>;
> + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_TCON_TV0>,
> + <&tcon_top CLK_TCON_TOP_TV0>;
> + clock-names = "ahb",
> + "tcon-ch1";
> + resets = <&ccu RST_BUS_TCON_TV0>;
> + reset-names = "lcd";
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + tcon_tv_in: port@0 {
> + reg = <0>;
> +
> + tcon_tv_in_tcon_top_mixer0: endpoint {
> + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
> + };
> + };
> +
> + tcon_tv_out: port@1 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <1>;
> +
> + tcon_tv_out_tcon_top: endpoint@1 {
> + reg = <1>;
> + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
> + };
> + };
> + };
> + };
> +
> + r_uart: serial@7080000 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x07080000 0x400>;
> + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&r_ccu CLK_R_APB2_UART>;
> + resets = <&r_ccu RST_R_APB2_UART>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_uart_pins>;
> + status = "disabled";
> + };
> +
> + rtc: rtc@7000000 {
> + compatible = "allwinner,sun50i-h6-rtc";
> + reg = <0x07000000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
> + clock-output-names = "osc32k", "osc32k-out", "iosc";
> + #clock-cells = <1>;
> + clocks = <&ext_osc32k>;
> + };
> +
> + r_ccu: clock@7010000 {
> + compatible = "allwinner,sun50i-h6-r-ccu";
> + reg = <0x07010000 0x400>;
> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
> + <&ccu CLK_PLL_PERIPH0>;
> + clock-names = "hosc", "losc", "iosc", "pll-periph";
> + protected-clocks = <CLK_R_APB1_TWD>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + r_watchdog: watchdog@7020400 {
> + compatible = "allwinner,sun50i-h6-wdt",
> + "allwinner,sun6i-a31-wdt";
> + reg = <0x07020400 0x20>;
> + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + };
> +
> + r_intc: interrupt-controller@7021000 {
> + compatible = "allwinner,sun50i-h6-r-intc";
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + reg = <0x07021000 0x400>;
> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
> + };
> +
> + r_pwm: pwm@7020C00 {
> + compatible = "allwinner,sun50i-h6-pwm";
> + reg = <0x07020C00 0x400>;
> + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
> + clock-names = "mod", "bus";
> + resets = <&ccu RST_R_APB1_PWM>;
> + #pwm-cells = <3>;
> + status = "disabled";
> + };
> +
> + r_pio: pinctrl@7022000 {
> + compatible = "allwinner,sun50i-h6-r-pinctrl";
> + reg = <0x07022000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
> + <&rtc CLK_OSC32K>;
> + clock-names = "apb", "hosc", "losc";
> + gpio-controller;
> + #gpio-cells = <3>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> +
> + r_i2c_pins: r-i2c-pins {
> + pins = "PL0", "PL1";
> + function = "s_i2c";
> + };
> +
> + r_ir_rx_pin: r-ir-rx-pin {
> + pins = "PL9";
> + function = "s_cir_rx";
> + };
> +
> + r_rsb_pins: r-rsb-pins {
> + pins = "PL0", "PL1";
> + function = "s_rsb";
> + };
> +
> + r_uart_pins: r-uart-pins {
> + pins = "PL2", "PL3";
> + function = "s_uart";
> + };
> +
> + r_pwm_pin: r-pwm-pin {
> + pins = "PL8";
> + function = "s_pwm";
> + };
> +
> + };
> +
> + r_ir: ir@7040000 {
> + compatible = "allwinner,sun50i-h6-ir",
> + "allwinner,sun6i-a31-ir";
> + reg = <0x07040000 0x400>;
> + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB1_IR>,
> + <&r_ccu CLK_IR>;
> + clock-names = "apb", "ir";
> + resets = <&r_ccu RST_R_APB1_IR>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_ir_rx_pin>;
> + status = "disabled";
> + };
> +
> + r_i2c: i2c@7081400 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x07081400 0x400>;
> + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB2_I2C>;
> + resets = <&r_ccu RST_R_APB2_I2C>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_i2c_pins>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + axp805: pmic@36 {
> + compatible = "x-powers,axp805", "x-powers,axp806";
> + reg = <0x36>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
> + interrupt-controller;
> + #interrupt-cells = <1>;
> + x-powers,self-working-mode;
> + vina-supply = <®_vcc5v>;
> + vinb-supply = <®_vcc5v>;
> + vinc-supply = <®_vcc5v>;
> + vind-supply = <®_vcc5v>;
> + vine-supply = <®_vcc5v>;
> + aldoin-supply = <®_vcc5v>;
> + bldoin-supply = <®_vcc5v>;
> + cldoin-supply = <®_vcc5v>;
> +
> + regulators {
> + reg_aldo1: aldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-pl-led-ir";
> + };
> +
> + reg_aldo2: aldo2 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-audio-tv-ephy-mac";
> + regulator-enable-ramp-delay = <100000>;
> + };
> +
> + reg_aldo3: aldo3 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
> + };
> +
> + reg_bldo1: bldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc18-dram-bias-pll";
> + };
> +
> + reg_bldo2: bldo2 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-efuse-pcie-hdmi-pc";
> + };
> +
> + reg_bldo3: bldo3 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-dcxoio";
> + };
> +
> + reg_bldo4: bldo4 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-dcxoio";
> + };
> +
> + reg_cldo1: cldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
> + };
> +
> + reg_cldo2: cldo2 {
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-wifi-1";
> + };
> +
> + reg_cldo3: cldo3 {
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-wifi-2";
> + };
> +
> + reg_dcdca: dcdca {
> + regulator-always-on;
> + regulator-min-microvolt = <810000>;
> + regulator-max-microvolt = <1200000>;
> + regulator-ramp-delay = <2500>;
> + regulator-name = "vdd-cpu";
> + };
> +
> + reg_dcdcc: dcdcc {
> + regulator-enable-ramp-delay = <32000>;
> + regulator-min-microvolt = <810000>;
> + regulator-max-microvolt = <1080000>;
> + regulator-ramp-delay = <2500>;
> + regulator-name = "vdd-gpu";
> + };
> +
> + reg_dcdcd: dcdcd {
> + regulator-always-on;
> + regulator-min-microvolt = <1000000>;
> + regulator-max-microvolt = <1000000>;
> + regulator-name = "vdd-sys";
> + };
> +
> + sw {
> + /* unused */
> + };
> + };
> + };
> + };
> +
> + r_rsb: rsb@7083000 {
> + compatible = "allwinner,sun8i-a23-rsb";
> + reg = <0x07083000 0x400>;
> + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB2_RSB>;
> + clock-frequency = <3000000>;
> + resets = <&r_ccu RST_R_APB2_RSB>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_rsb_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + ths: thermal-sensor@5070400 {
> + compatible = "allwinner,sun50i-h6-ths";
> + reg = <0x05070400 0x100>;
> + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_THS>;
> + clock-names = "bus";
> + resets = <&ccu RST_BUS_THS>;
> + nvmem-cells = <&ths_calibration>;
> + nvmem-cell-names = "calibration";
> + #thermal-sensor-cells = <1>;
> + };
> +
> + sunxi-info {
> + compatible = "allwinner,sun50i-h6-sys-info";
> + status = "okay";
> + };
> +
> + addr_mgt: addr-mgt {
> + compatible = "allwinner,sunxi-addr_mgt";
> + type_addr_wifi = <0x2>;
> + type_addr_bt = <0x2>;
> + type_addr_eth = <0x2>;
> + status = "okay";
> + };
> +
> + dump_reg: dump_reg@20000 {
> + compatible = "allwinner,sunxi-dump-reg";
> + reg = <0x0 0x03001000 0x0 0x0f20>;
> + status = "okay";
> + };
> + };
> +
> + thermal-zones {
> + cpu-thermal {
> + polling-delay-passive = <250>;
> + polling-delay = <1000>;
> + thermal-sensors = <&ths 0>;
> +
> + trips {
> + cpu_warm: cpu_warm {
> + temperature = <70000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_hot0: cpu_hot0 {
> + temperature = <74000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_hot1: cpu_hot1 {
> + temperature = <76000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot0: cpu_very_hot0 {
> + temperature = <78000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot1: cpu_very_hot1 {
> + temperature = <80000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot2: cpu_very_hot2 {
> + temperature = <82000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot3: cpu_very_hot3 {
> + temperature = <84000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot4: cpu_very_hot4 {
> + temperature = <86000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot5: cpu_very_hot5 {
> + temperature = <88000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot6: cpu_very_hot6 {
> + temperature = <90000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_crit: cpu_crit {
> + temperature = <97000>;
> + hysteresis = <2000>;
> + type = "critical";
> + };
> + };
> +
> + cooling-maps {
> + cpu_warm_limit_cpu {
> + trip = <&cpu_warm>;
> + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
> + };
> + };
> + };
> +
> + gpu-thermal {
> + polling-delay-passive = <1000>;
> + polling-delay = <2000>;
> + thermal-sensors = <&ths 1>;
> +
> + trips {
> + gpu_alert0: gpu-alert-0 {
> + temperature = <95000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu_alert1: gpu-alert-1 {
> + temperature = <100000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu_alert2: gpu-alert-2 {
> + temperature = <105000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu-crit {
> + temperature = <115000>;
> + hysteresis = <0>;
> + type = "critical";
> + };
> + };
> +
> + cooling-maps {
> + // Forbid the GPU to go over 756MHz
> + map0 {
> + trip = <&gpu_alert0>;
> + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
> + };
> +
> + // Forbid the GPU to go over 624MHz
> + map1 {
> + trip = <&gpu_alert1>;
> + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
> + };
> +
> + // Forbid the GPU to go over 576MHz
> + map2 {
> + trip = <&gpu_alert2>;
> + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
> + };
> + };
> + };
> + };
> +
> + cpu_opp_table: cpu-opp-table {
> + compatible = "allwinner,sun50i-h6-operating-points";
> + nvmem-cells = <&cpu_speed_grade>;
> + opp-shared;
> +
> + opp-480000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <480000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-720000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <720000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-888000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <888000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-1080000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1080000000>;
> +
> + opp-microvolt-speed0 = <940000>;
> + };
> +
> + opp-1320000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1320000000>;
> +
> + opp-microvolt-speed0 = <1000000>;
> + };
> +
> + opp-1488000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1488000000>;
> +
> + opp-microvolt-speed0 = <1060000>;
> + };
> +
> + opp-1608000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1608000000>;
> +
> + opp-microvolt-speed0 = <1090000>;
> + };
> +
> + opp-1704000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1704000000>;
> +
> + opp-microvolt-speed0 = <1120000>;
> + };
> +
> + opp-1800000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1800000000>;
> +
> + opp-microvolt-speed0 = <1160000>;
> + };
> +
> + opp@1896000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1896000000>;
> +
> + opp-microvolt-speed0 = <1180000>;
> + };
> +
> + opp@1968000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1968000000>;
> +
> + opp-microvolt-speed0 = <1200000>;
> + };
> +
> + };
> +
> + gpu_opp_table: opp-table-gpu {
> + compatible = "operating-points-v2";
> +
> + opp-216000000 {
> + opp-hz = /bits/ 64 <216000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-264000000 {
> + opp-hz = /bits/ 64 <264000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-312000000 {
> + opp-hz = /bits/ 64 <312000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-336000000 {
> + opp-hz = /bits/ 64 <336000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-360000000 {
> + opp-hz = /bits/ 64 <360000000>;
> + opp-microvolt = <820000 820000 1200000>;
> + };
> +
> + opp-384000000 {
> + opp-hz = /bits/ 64 <384000000>;
> + opp-microvolt = <830000 830000 1200000>;
> + };
> +
> + opp-408000000 {
> + opp-hz = /bits/ 64 <408000000>;
> + opp-microvolt = <840000 840000 1200000>;
> + };
> +
> + opp-420000000 {
> + opp-hz = /bits/ 64 <420000000>;
> + opp-microvolt = <850000 850000 1200000>;
> + };
> +
> + opp-432000000 {
> + opp-hz = /bits/ 64 <432000000>;
> + opp-microvolt = <860000 860000 1200000>;
> + };
> +
> + opp-456000000 {
> + opp-hz = /bits/ 64 <456000000>;
> + opp-microvolt = <870000 870000 1200000>;
> + };
> +
> + opp-504000000 {
> + opp-hz = /bits/ 64 <504000000>;
> + opp-microvolt = <890000 890000 1200000>;
> + };
> +
> + opp-540000000 {
> + opp-hz = /bits/ 64 <540000000>;
> + opp-microvolt = <910000 910000 1200000>;
> + };
> +
> + opp-576000000 {
> + opp-hz = /bits/ 64 <576000000>;
> + opp-microvolt = <930000 930000 1200000>;
> + };
> +
> + opp-624000000 {
> + opp-hz = /bits/ 64 <624000000>;
> + opp-microvolt = <950000 950000 1200000>;
> + };
> +
> + opp-756000000 {
> + opp-hz = /bits/ 64 <756000000>;
> + opp-microvolt = <1040000 1040000 1200000>;
> + };
> + };
> +
> + chosen {
> + stdout-path = "serial0:115200n8";
> + };
> +
> + connector {
> + compatible = "hdmi-connector";
> + type = "a";
> +
> + port {
> + hdmi_con_in: endpoint {
> + remote-endpoint = <&hdmi_out_con>;
> + };
> + };
> + };
> +
> + ext_osc32k: ext_osc32k_clk {
> + #clock-cells = <0>;
> + compatible = "fixed-clock";
> + clock-frequency = <32768>;
> + clock-output-names = "ext_osc32k";
> + };
> +
> + leds {
> + compatible = "gpio-leds";
> +
> + led-0 {
> + label = "repka:red:power";
> + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
> + linux,default-trigger = "heartbeat";
> + };
> + };
> +
> + reg_vcc5v: vcc5v {
> + /* board wide 5V supply directly from the DC jack */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc-5v";
> + regulator-min-microvolt = <5000000>;
> + regulator-max-microvolt = <5000000>;
> + regulator-always-on;
> + };
> +
> + reg_vcc33_wifi: vcc33-wifi {
> + /* Always on 3.3V regulator for WiFi and BT */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc33-wifi";
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-always-on;
> + vin-supply = <®_vcc5v>;
> + };
> +
> + reg_vcc_wifi_io: vcc-wifi-io {
> + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc-wifi-io";
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-always-on;
> + vin-supply = <®_vcc33_wifi>;
> + };
> +
> + wifi_pwrseq: wifi-pwrseq {
> + compatible = "mmc-pwrseq-simple";
> + clocks = <&rtc 1>;
> + clock-names = "ext_clock";
> + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
> + post-power-on-delay-ms = <200>;
> + };
> +};
> --
> 2.42.2
>
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-07 19:39 ` Vitaly Chikunov
@ 2025-05-07 20:50 ` Kurachenko Anton
2025-05-08 0:54 ` Vitaly Chikunov
0 siblings, 1 reply; 7+ messages in thread
From: Kurachenko Anton @ 2025-05-07 20:50 UTC (permalink / raw)
To: devel-kernel
1. Я проверял сборку и работоспособность полученного результата на ядре
6.12.25-alt1.
2. Дело в том, что загрузчик u-boot для Repka Pi 4 требует обязательного
наличия dtb для запуска. Сейчас нам приходится заниматься скачиванием и
распаковкой ядра repka4, затем извлекать нужный dtb и переносить его в
/boot/devicetree/$kernelversion/allwinner ядра 6.12, чтобы хотя бы
просто начать процесс установки. Патч призван решить эту проблему.
07.05.2025 22:39, Vitaly Chikunov пишет:
> Anton,
>
> On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
>> From: Anton Kurachenko <srebrov@altlinux.org>
>>
>> Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
>> u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
>> a dtb file.
>>
>> Patch designed specifically for ALT and never used anywhere.
>
> 1. Это изменение протестировано?
> 2. Зачем нужен этот патч, если есть флейворы repka/repka4?
>
> Thanks,
>
>>
>> The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
>> file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
>> from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
>> Represents the result of merging these files with applying some modifications.
>>
>> Files that were used during the creation process:
>>
>> sun50i-h6-repka-pi4-optimal.dts
>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
>>
>> sun50i-h6.dtsi
>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
>>
>> sun50i-h6-cpu-opp.dtsi
>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
>>
>> Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
>> ---
>> arch/arm64/boot/dts/allwinner/Makefile | 1 +
>> .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
>> 2 files changed, 1919 insertions(+)
>> create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>>
>> diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
>> index 00bed412ee31..2df5189e0d44 100644
>> --- a/arch/arm64/boot/dts/allwinner/Makefile
>> +++ b/arch/arm64/boot/dts/allwinner/Makefile
>> @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
>> +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
>> diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>> new file mode 100644
>> index 000000000000..9d95297a30b8
>> --- /dev/null
>> +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>> @@ -0,0 +1,1918 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +// based on the dts, which is:
>> +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
>> +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
>> +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
>> +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
>> +
>> +/dts-v1/;
>> +
>> +#include <dt-bindings/interrupt-controller/arm-gic.h>
>> +#include <dt-bindings/clock/sun50i-h6-ccu.h>
>> +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
>> +#include <dt-bindings/clock/sun6i-rtc.h>
>> +#include <dt-bindings/clock/sun8i-de2.h>
>> +#include <dt-bindings/clock/sun8i-tcon-top.h>
>> +#include <dt-bindings/reset/sun50i-h6-ccu.h>
>> +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
>> +#include <dt-bindings/reset/sun8i-de2.h>
>> +#include <dt-bindings/thermal/thermal.h>
>> +#include <dt-bindings/gpio/gpio.h>
>> +
>> +/ {
>> + interrupt-parent = <&gic>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + model = "Repka-Pi4-Optimal";
>> + repka-freq = "1.968 GHz";
>> + repka-pinout = "repka-pi4-base";
>> + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
>> +
>> + aliases {
>> + mmc0 = &mmc0;
>> + mmc1 = &mmc1;
>> + mmc2 = &mmc2;
>> + ethernet0 = &emac;
>> + serial0 = &uart0;
>> + serial1 = &uart1;
>> + serial2 = &r_uart;
>> +
>> + spi0 = &spi1;
>> + i2c1 = &i2c0;
>> + i2c2 = &i2c2;
>> + i2c3 = &i2c1;
>> + i2c4 = &i2c3;
>> +
>> + };
>> +
>> + reserved-memory {
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges;
>> +
>> + custom_region: region@40010000 {
>> + reg = <0x40010000 0x00070000>;
>> + no-map;
>> + };
>> + };
>> +
>> + analog: analog-codec {
>> + compatible = "simple-audio-card";
>> + simple-audio-card,format = "i2s";
>> + simple-audio-card,name = "ac200-audio";
>> + simple-audio-card,mclk-fs = <512>;
>> + status = "okay";
>> +
>> + simple-audio-card,cpu {
>> + sound-dai = <&i2s3>;
>> + };
>> +
>> + simple-audio-card,codec {
>> + sound-dai = <&ac200_codec>;
>> + };
>> + };
>> +
>> + ac200_pwm_clk: ac200_clk {
>> + compatible = "pwm-clock";
>> + #clock-cells = <0>;
>> + clock-frequency = <24000000>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&pwm1_pin>;
>> + pwms = <&pwm 1 42 0>;
>> + status = "okay";
>> + };
>> +
>> + cpus {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + cpu0: cpu@0 {
>> + compatible = "arm,cortex-a53";
>> + device_type = "cpu";
>> + reg = <0>;
>> + enable-method = "psci";
>> + clocks = <&ccu CLK_CPUX>;
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + #cooling-cells = <2>;
>> + operating-points-v2 = <&cpu_opp_table>;
>> + cpu-supply = <®_dcdca>;
>> + };
>> +
>> + cpu1: cpu@1 {
>> + compatible = "arm,cortex-a53";
>> + device_type = "cpu";
>> + reg = <1>;
>> + enable-method = "psci";
>> + clocks = <&ccu CLK_CPUX>;
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + #cooling-cells = <2>;
>> + operating-points-v2 = <&cpu_opp_table>;
>> + };
>> +
>> + cpu2: cpu@2 {
>> + compatible = "arm,cortex-a53";
>> + device_type = "cpu";
>> + reg = <2>;
>> + enable-method = "psci";
>> + clocks = <&ccu CLK_CPUX>;
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + #cooling-cells = <2>;
>> + operating-points-v2 = <&cpu_opp_table>;
>> + };
>> +
>> + cpu3: cpu@3 {
>> + compatible = "arm,cortex-a53";
>> + device_type = "cpu";
>> + reg = <3>;
>> + enable-method = "psci";
>> + clocks = <&ccu CLK_CPUX>;
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + #cooling-cells = <2>;
>> + operating-points-v2 = <&cpu_opp_table>;
>> + };
>> + };
>> +
>> + de: display-engine {
>> + compatible = "allwinner,sun50i-h6-display-engine";
>> + allwinner,pipelines = <&mixer0>;
>> + status = "okay";
>> + };
>> +
>> + osc24M: osc24M_clk {
>> + #clock-cells = <0>;
>> + compatible = "fixed-clock";
>> + clock-frequency = <24000000>;
>> + clock-output-names = "osc24M";
>> + };
>> +
>> + pmu {
>> + compatible = "arm,cortex-a53-pmu";
>> + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
>> + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
>> + };
>> +
>> + psci {
>> + compatible = "arm,psci-0.2";
>> + method = "smc";
>> + };
>> +
>> + scpi_protocol: scpi {
>> + compatible = "arm,scpi";
>> + mboxes = <&msgbox 2>, <&msgbox 3>;
>> + mbox-names = "tx", "rx";
>> + shmem = <&scpi_sram>;
>> + };
>> +
>> + sound_hdmi: sound_hdmi {
>> + compatible = "allwinner,sun9i-a80-hdmi-audio",
>> + "allwinner,sun50i-h6-hdmi-audio";
>> + status = "okay";
>> + codec {
>> + sound-dai = <&hdmi>;
>> + };
>> +
>> + cpu {
>> + sound-dai = <&i2s1>;
>> + };
>> + };
>> +
>> + timer {
>> + compatible = "arm,armv8-timer";
>> + arm,no-tick-in-suspend;
>> + interrupts = <GIC_PPI 13
>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>> + <GIC_PPI 14
>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>> + <GIC_PPI 11
>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>> + <GIC_PPI 10
>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
>> + };
>> +
>> +
>> + soc {
>> + compatible = "simple-bus";
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges;
>> +
>> + bus@1000000 {
>> + compatible = "allwinner,sun50i-h6-de3",
>> + "allwinner,sun50i-a64-de2";
>> + reg = <0x1000000 0x400000>;
>> + allwinner,sram = <&de2_sram 1>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges = <0 0x1000000 0x400000>;
>> +
>> + display_clocks: clock@0 {
>> + compatible = "allwinner,sun50i-h6-de3-clk";
>> + reg = <0x0 0x10000>;
>> + clocks = <&ccu CLK_BUS_DE>,
>> + <&ccu CLK_DE>;
>> + clock-names = "bus",
>> + "mod";
>> + resets = <&ccu RST_BUS_DE>;
>> + #clock-cells = <1>;
>> + #reset-cells = <1>;
>> + };
>> +
>> + mixer0: mixer@100000 {
>> + compatible = "allwinner,sun50i-h6-de3-mixer-0";
>> + reg = <0x100000 0x100000>;
>> + clocks = <&display_clocks CLK_BUS_MIXER0>,
>> + <&display_clocks CLK_MIXER0>;
>> + clock-names = "bus",
>> + "mod";
>> + resets = <&display_clocks RST_MIXER0>;
>> + iommus = <&iommu 0>;
>> +
>> + ports {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + mixer0_out: port@1 {
>> + reg = <1>;
>> +
>> + mixer0_out_tcon_top_mixer0: endpoint {
>> + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
>> + };
>> + };
>> + };
>> + };
>> + };
>> +
>> +
>> + video-codec-g2@1c00000 {
>> + compatible = "allwinner,sun50i-h6-vpu-g2";
>> + reg = <0x01c00000 0x1000>;
>> + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
>> + clock-names = "bus", "mod";
>> + resets = <&ccu RST_BUS_VP9>;
>> + iommus = <&iommu 5>;
>> + };
>> +
>> + deinterlace: deinterlace@1420000 {
>> + compatible = "allwinner,sun50i-h6-deinterlace";
>> + reg = <0x01420000 0x2000>;
>> + clocks = <&ccu CLK_BUS_DEINTERLACE>,
>> + <&ccu CLK_DEINTERLACE>,
>> + <&ccu CLK_MBUS_DEINTERLACE>;
>> + clock-names = "bus", "mod", "ram";
>> + resets = <&ccu RST_BUS_DEINTERLACE>;
>> + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
>> + iommus = <&iommu 2>;
>> + };
>> +
>> + video-codec@1c0e000 {
>> + compatible = "allwinner,sun50i-h6-video-engine";
>> + reg = <0x01c0e000 0x2000>;
>> + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
>> + <&ccu CLK_MBUS_VE>;
>> + clock-names = "ahb", "mod", "ram";
>> + resets = <&ccu RST_BUS_VE>;
>> + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
>> + allwinner,sram = <&ve_sram 1>;
>> + iommus = <&iommu 1>, <&iommu 3>;
>> + };
>> +
>> + gpu: gpu@1800000 {
>> + compatible = "allwinner,sun50i-h6-mali",
>> + "arm,mali-t720";
>> + reg = <0x01800000 0x4000>;
>> + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
>> + interrupt-names = "job", "mmu", "gpu";
>> + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
>> + clock-names = "core", "bus";
>> + resets = <&ccu RST_BUS_GPU>;
>> + #cooling-cells = <2>;
>> + status = "okay";
>> + operating-points-v2 = <&gpu_opp_table>;
>> + mali-supply = <®_dcdcc>;
>> + };
>> +
>> + crypto: crypto@1904000 {
>> + compatible = "allwinner,sun50i-h6-crypto";
>> + reg = <0x01904000 0x1000>;
>> + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
>> + clock-names = "bus", "mod", "ram";
>> + resets = <&ccu RST_BUS_CE>;
>> + };
>> +
>> + syscon: syscon@3000000 {
>> + compatible = "allwinner,sun50i-h6-system-control",
>> + "allwinner,sun50i-a64-system-control";
>> + reg = <0x03000000 0x1000>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges;
>> +
>> + sram_a2: sram@100000 {
>> + compatible = "mmio-sram";
>> + reg = <0x00100000 0x18000>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges = <0 0x00100000 0x18000>;
>> +
>> + scpi_sram: scp-shmem@17c00 {
>> + compatible = "arm,scp-shmem";
>> + reg = <0x17c00 0x200>;
>> + };
>> + };
>> +
>> + sram_c: sram@28000 {
>> + compatible = "mmio-sram";
>> + reg = <0x00028000 0x1e000>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges = <0 0x00028000 0x1e000>;
>> +
>> + de2_sram: sram-section@0 {
>> + compatible = "allwinner,sun50i-h6-sram-c",
>> + "allwinner,sun50i-a64-sram-c";
>> + reg = <0x0000 0x1e000>;
>> + };
>> + };
>> +
>> + sram_c1: sram@1a00000 {
>> + compatible = "mmio-sram";
>> + reg = <0x01a00000 0x200000>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> + ranges = <0 0x01a00000 0x200000>;
>> +
>> + ve_sram: sram-section@0 {
>> + compatible = "allwinner,sun50i-h6-sram-c1",
>> + "allwinner,sun4i-a10-sram-c1";
>> + reg = <0x000000 0x200000>;
>> + };
>> + };
>> + };
>> +
>> + ccu: clock@3001000 {
>> + compatible = "allwinner,sun50i-h6-ccu";
>> + reg = <0x03001000 0x1000>;
>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
>> + clock-names = "hosc", "losc", "iosc";
>> + protected-clocks = <CLK_BUS_MSGBOX>;
>> + #clock-cells = <1>;
>> + #reset-cells = <1>;
>> + };
>> +
>> + dma: dma-controller@3002000 {
>> + compatible = "allwinner,sun50i-h6-dma";
>> + reg = <0x03002000 0x1000>;
>> + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
>> + clock-names = "bus", "mbus";
>> + dma-channels = <16>;
>> + dma-requests = <46>;
>> + resets = <&ccu RST_BUS_DMA>;
>> + #dma-cells = <1>;
>> + };
>> +
>> + msgbox: mailbox@3003000 {
>> + compatible = "allwinner,sun50i-h6-msgbox",
>> + "allwinner,sun6i-a31-msgbox";
>> + reg = <0x03003000 0x1000>;
>> + clocks = <&ccu CLK_BUS_MSGBOX>;
>> + resets = <&ccu RST_BUS_MSGBOX>;
>> + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
>> + #mbox-cells = <1>;
>> + };
>> +
>> + gic: interrupt-controller@3021000 {
>> + compatible = "arm,gic-400";
>> + reg = <0x03021000 0x1000>,
>> + <0x03022000 0x2000>,
>> + <0x03024000 0x2000>,
>> + <0x03026000 0x2000>;
>> + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
>> + interrupt-controller;
>> + #interrupt-cells = <3>;
>> + };
>> +
>> + sid: efuse@3006000 {
>> + compatible = "allwinner,sun50i-h6-sid";
>> + reg = <0x03006000 0x400>;
>> + #address-cells = <1>;
>> + #size-cells = <1>;
>> +
>> + ths_calibration: thermal-sensor-calibration@14 {
>> + reg = <0x14 0x8>;
>> + };
>> +
>> + cpu_speed_grade: cpu-speed-grade@1c {
>> + reg = <0x1c 0x4>;
>> + };
>> +
>> + ephy_calib: ephy_calib@2c {
>> + reg = <0x2c 0x2>;
>> + };
>> +
>> + ac200_bg: ac200_bg@30 {
>> + reg = <0x30 0x2>;
>> + };
>> + };
>> +
>> + timer@3009000 {
>> + compatible = "allwinner,sun50i-h6-timer",
>> + "allwinner,sun8i-a23-timer";
>> + reg = <0x03009000 0xa0>;
>> + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&osc24M>;
>> + };
>> +
>> + watchdog: watchdog@30090a0 {
>> + compatible = "allwinner,sun50i-h6-wdt",
>> + "allwinner,sun6i-a31-wdt";
>> + reg = <0x030090a0 0x20>;
>> + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&osc24M>;
>> + /* Broken on some H6 boards */
>> + status = "disabled";
>> + };
>> +
>> + pwm: pwm@300a000 {
>> + compatible = "allwinner,sun50i-h6-pwm";
>> + reg = <0x0300a000 0x400>;
>> + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
>> + clock-names = "mod", "bus";
>> + resets = <&ccu RST_BUS_PWM>;
>> + #pwm-cells = <3>;
>> + status = "okay";
>> + };
>> +
>> + pio: pinctrl@300b000 {
>> + compatible = "allwinner,sun50i-h6-pinctrl";
>> + reg = <0x0300b000 0x400>;
>> + interrupt-parent = <&r_intc>;
>> + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
>> + clock-names = "apb", "hosc", "losc";
>> + gpio-controller;
>> + #gpio-cells = <3>;
>> + interrupt-controller;
>> + #interrupt-cells = <3>;
>> + vcc-pc-supply = <®_bldo2>;
>> + vcc-pd-supply = <®_cldo1>;
>> + vcc-pg-supply = <®_vcc_wifi_io>;
>> +
>> + /omit-if-no-ref/
>> + ext_rgmii_pins: rgmii-pins {
>> + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
>> + "PD5", "PD7", "PD8", "PD9", "PD10",
>> + "PD11", "PD12", "PD13", "PD19", "PD20";
>> + function = "emac";
>> + drive-strength = <40>;
>> + };
>> +
>> + ext_rmii_pins: rmii_pins {
>> + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
>> + "PA5", "PA6", "PA7", "PA8", "PA9";
>> + function = "emac";
>> + drive-strength = <40>;
>> + };
>> +
>> + hdmi_pins: hdmi-pins {
>> + pins = "PH8", "PH9", "PH10";
>> + function = "hdmi";
>> + };
>> +
>> + i2c0_pins: i2c0-pins {
>> + pins = "PD25", "PD26";
>> + function = "i2c0";
>> + };
>> +
>> + i2c1_pins: i2c1-pins {
>> + pins = "PH5", "PH6";
>> + function = "i2c1";
>> + };
>> +
>> + i2c2_pins: i2c2-pins {
>> + pins = "PD23", "PD24";
>> + function = "i2c2";
>> + };
>> +
>> + i2c3_pins: i2c3-pins {
>> + pins = "PB17", "PB18";
>> + function = "i2c3";
>> + bias-pull-up;
>> + };
>> +
>> + i2s3_pins: i2s3-pins {
>> + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
>> + function = "i2s3";
>> + };
>> +
>> + mmc0_pins: mmc0-pins {
>> + pins = "PF0", "PF1", "PF2", "PF3",
>> + "PF4", "PF5";
>> + function = "mmc0";
>> + drive-strength = <30>;
>> + bias-pull-up;
>> + };
>> +
>> + /omit-if-no-ref/
>> + mmc1_pins: mmc1-pins {
>> + pins = "PG0", "PG1", "PG2", "PG3",
>> + "PG4", "PG5";
>> + function = "mmc1";
>> + drive-strength = <30>;
>> + bias-pull-up;
>> + };
>> +
>> + /omit-if-no-ref/
>> + mmc2_pins: mmc2-pins {
>> + pins = "PC1", "PC4", "PC5", "PC6",
>> + "PC7", "PC8", "PC9", "PC10",
>> + "PC11", "PC12", "PC13", "PC14";
>> + function = "mmc2";
>> + drive-strength = <30>;
>> + bias-pull-up;
>> + };
>> +
>> + pwm1_pin: pwm1-pin {
>> + pins = "PB19";
>> + function = "pwm1";
>> + };
>> +
>> + pwm_pin: pwm-pin {
>> + pins = "PD22";
>> + function = "pwm";
>> + };
>> +
>> + /omit-if-no-ref/
>> + spi0_pins: spi0-pins {
>> + pins = "PC0", "PC2", "PC3";
>> + function = "spi0";
>> + };
>> +
>> + /* pin shared with MMC2-CMD (eMMC) */
>> + /omit-if-no-ref/
>> + spi0_cs_pin: spi0-cs-pin {
>> + pins = "PC5";
>> + function = "spi0";
>> + };
>> +
>> + /omit-if-no-ref/
>> + spi1_pins: spi1-pins {
>> + pins = "PH4", "PH5", "PH6";
>> + function = "spi1";
>> + };
>> +
>> + /omit-if-no-ref/
>> + spi1_cs_pin: spi1-cs-pin {
>> + pins = "PH3";
>> + function = "spi1";
>> + };
>> +
>> + /omit-if-no-ref/
>> + spdif_tx_pin: spdif-tx-pin {
>> + pins = "PH7";
>> + function = "spdif";
>> + };
>> +
>> + uart0_ph_pins: uart0-ph-pins {
>> + pins = "PH0", "PH1";
>> + function = "uart0";
>> + };
>> +
>> + uart1_pins: uart1-pins {
>> + pins = "PG6", "PG7";
>> + function = "uart1";
>> + };
>> +
>> + uart1_rts_cts_pins: uart1-rts-cts-pins {
>> + pins = "PG8", "PG9";
>> + function = "uart1";
>> + };
>> +
>> + uart2_pins: uart2-pins {
>> + pins = "PD19", "PD20";
>> + function = "uart2";
>> + };
>> +
>> + uart2_rts_cts_pins: uart2-rts-cts-pins {
>> + pins = "PD21", "PD22";
>> + function = "uart2";
>> + };
>> +
>> + uart3_pins: uart3-pins {
>> + pins = "PD23", "PD24";
>> + function = "uart3";
>> + };
>> +
>> + uart3_rts_cts_pins: uart3-rts-cts-pins {
>> + pins = "PD25", "PD26";
>> + function = "uart3";
>> + };
>> +
>> + i2s2_pins: i2s2-pins {
>> + pins = "PG10", "PG11", "PG12", "PG13";
>> + function = "i2s2";
>> + };
>> + };
>> +
>> + iommu: iommu@30f0000 {
>> + compatible = "allwinner,sun50i-h6-iommu";
>> + reg = <0x030f0000 0x10000>;
>> + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_IOMMU>;
>> + resets = <&ccu RST_BUS_IOMMU>;
>> + #iommu-cells = <1>;
>> + };
>> +
>> + mmc0: mmc@4020000 {
>> + compatible = "allwinner,sun50i-h6-mmc",
>> + "allwinner,sun50i-a64-mmc";
>> + reg = <0x04020000 0x1000>;
>> + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
>> + clock-names = "ahb", "mmc";
>> + resets = <&ccu RST_BUS_MMC0>;
>> + reset-names = "ahb";
>> + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&mmc0_pins>;
>> + max-frequency = <150000000>;
>> + status = "okay";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + vmmc-supply = <®_cldo1>;
>> + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
>> + bus-width = <4>;
>> + };
>> +
>> + mmc1: mmc@4021000 {
>> + compatible = "allwinner,sun50i-h6-mmc",
>> + "allwinner,sun50i-a64-mmc";
>> + reg = <0x04021000 0x1000>;
>> + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
>> + clock-names = "ahb", "mmc";
>> + resets = <&ccu RST_BUS_MMC1>;
>> + reset-names = "ahb";
>> + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&mmc1_pins>;
>> + max-frequency = <150000000>;
>> + status = "okay";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + vmmc-supply = <®_vcc33_wifi>;
>> + vqmmc-supply = <®_vcc_wifi_io>;
>> + mmc-pwrseq = <&wifi_pwrseq>;
>> + bus-width = <4>;
>> + non-removable;
>> +
>> + brcm: sdio-wifi@1 {
>> + reg = <1>;
>> + compatible = "brcm,bcm4329-fmac";
>> + interrupt-parent = <&r_pio>;
>> + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
>> + interrupt-names = "host-wake";
>> + };
>> + };
>> +
>> + mmc2: mmc@4022000 {
>> + compatible = "allwinner,sun50i-h6-emmc";
>> + reg = <0x04022000 0x1000>;
>> + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
>> + clock-names = "ahb", "mmc";
>> + resets = <&ccu RST_BUS_MMC2>;
>> + reset-names = "ahb";
>> + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&mmc2_pins>;
>> + max-frequency = <150000000>;
>> + status = "okay";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + vmmc-supply = <®_cldo1>;
>> + vqmmc-supply = <®_bldo2>;
>> + cap-mmc-hw-reset;
>> + non-removable;
>> + bus-width = <8>;
>> + };
>> +
>> + uart0: serial@5000000 {
>> + compatible = "snps,dw-apb-uart";
>> + reg = <0x05000000 0x400>;
>> + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
>> + reg-shift = <2>;
>> + reg-io-width = <4>;
>> + clocks = <&ccu CLK_BUS_UART0>;
>> + resets = <&ccu RST_BUS_UART0>;
>> + status = "okay";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&uart0_ph_pins>;
>> + };
>> +
>> + uart1: serial@5000400 {
>> + compatible = "snps,dw-apb-uart";
>> + reg = <0x05000400 0x400>;
>> + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>> + reg-shift = <2>;
>> + reg-io-width = <4>;
>> + clocks = <&ccu CLK_BUS_UART1>;
>> + resets = <&ccu RST_BUS_UART1>;
>> + status = "okay";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
>> + uart-has-rtscts;
>> +
>> + bluetooth {
>> + compatible = "brcm,bcm4345c5";
>> + clocks = <&rtc 1>;
>> + clock-names = "lpo";
>> + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
>> + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
>> + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
>> + max-speed = <1500000>;
>> + };
>> + };
>> +
>> + uart2: serial@5000800 {
>> + compatible = "snps,dw-apb-uart";
>> + reg = <0x05000800 0x400>;
>> + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
>> + reg-shift = <2>;
>> + reg-io-width = <4>;
>> + clocks = <&ccu CLK_BUS_UART2>;
>> + resets = <&ccu RST_BUS_UART2>;
>> + status = "disabled";
>> + };
>> +
>> + uart3: serial@5000c00 {
>> + compatible = "snps,dw-apb-uart";
>> + reg = <0x05000c00 0x400>;
>> + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
>> + reg-shift = <2>;
>> + reg-io-width = <4>;
>> + clocks = <&ccu CLK_BUS_UART3>;
>> + resets = <&ccu RST_BUS_UART3>;
>> + status = "disabled";
>> + };
>> +
>> + i2c0: i2c@5002000 {
>> + compatible = "allwinner,sun50i-h6-i2c",
>> + "allwinner,sun6i-a31-i2c";
>> + reg = <0x05002000 0x400>;
>> + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2C0>;
>> + resets = <&ccu RST_BUS_I2C0>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&i2c0_pins>;
>> + status = "disabled";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + };
>> +
>> + i2c1: i2c@5002400 {
>> + compatible = "allwinner,sun50i-h6-i2c",
>> + "allwinner,sun6i-a31-i2c";
>> + reg = <0x05002400 0x400>;
>> + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2C1>;
>> + resets = <&ccu RST_BUS_I2C1>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&i2c1_pins>;
>> + status = "disabled";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + };
>> +
>> + i2c2: i2c@5002800 {
>> + compatible = "allwinner,sun50i-h6-i2c",
>> + "allwinner,sun6i-a31-i2c";
>> + reg = <0x05002800 0x400>;
>> + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2C2>;
>> + resets = <&ccu RST_BUS_I2C2>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&i2c2_pins>;
>> + status = "disabled";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + };
>> +
>> + i2c3: i2c@5002c00 {
>> + compatible = "allwinner,sun50i-h6-i2c",
>> + "allwinner,sun6i-a31-i2c";
>> + reg = <0x05002c00 0x400>;
>> + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2C3>;
>> + resets = <&ccu RST_BUS_I2C3>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&i2c3_pins>;
>> + clock-frequency = <100000>;
>> + status = "okay"; /* нужно для ac200 */
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + ac200: mfd@10 {
>> + compatible = "x-powers,ac200";
>> + reg = <0x10>;
>> + clocks = <&ac200_pwm_clk>;
>> + interrupt-parent = <&pio>;
>> + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
>> + interrupt-controller;
>> + #interrupt-cells = <1>;
>> + nvmem-cells = <&ac200_bg>;
>> + nvmem-cell-names = "bandgap";
>> +
>> + ac200_ephy_ctl: syscon {
>> + compatible = "x-powers,ac200-ephy-ctl";
>> + nvmem-cells = <&ephy_calib>;
>> + nvmem-cell-names = "calibration";
>> + #clock-cells = <0>;
>> + #reset-cells = <0>;
>> + phy-mode = "rmii";
>> + status = "okay";
>> + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
>> + phy-address = <1>;
>> + };
>> +
>> + ac200_codec: codec {
>> + #sound-dai-cells = <0>;
>> + compatible = "x-powers,ac200-codec";
>> + status = "okay";
>> + avcc-supply = <®_aldo2>;
>> + };
>> + };
>> + };
>> +
>> + spi1: spi@5011000 {
>> + compatible = "allwinner,sun50i-h6-spi",
>> + "allwinner,sun8i-h3-spi";
>> + reg = <0x05011000 0x1000>;
>> + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
>> + clock-names = "ahb", "mod";
>> + dmas = <&dma 23>, <&dma 23>;
>> + dma-names = "rx", "tx";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
>> + resets = <&ccu RST_BUS_SPI1>;
>> + status = "disabled";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + };
>> +
>> + emac: ethernet@5020000 {
>> + compatible = "allwinner,sun50i-h6-emac",
>> + "allwinner,sun50i-a64-emac";
>> + syscon = <&syscon>;
>> + reg = <0x05020000 0x10000>;
>> + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
>> + interrupt-names = "macirq";
>> + resets = <&ccu RST_BUS_EMAC>;
>> + reset-names = "stmmaceth";
>> + clocks = <&ccu CLK_BUS_EMAC>;
>> + clock-names = "stmmaceth";
>> + status = "okay";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&ext_rmii_pins>;
>> + phy-mode = "rmii";
>> + phy-handle = <&ext_rmii_phy>;
>> +
>> + mdio: mdio {
>> + compatible = "snps,dwmac-mdio";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + ext_rmii_phy: ethernet-phy@1 {
>> + compatible = "ethernet-phy-id0044.1400",
>> + "ethernet-phy-ieee802.3-c22";
>> + reg = <1>;
>> + resets = <&ac200_ephy_ctl>;
>> + reset-names = "phy";
>> + clocks = <&ac200_ephy_ctl>;
>> + };
>> + };
>> + };
>> +
>> + i2s3: i2s@508f000 {
>> + #sound-dai-cells = <0>;
>> + compatible = "allwinner,sun50i-h6-i2s";
>> + reg = <0x0508f000 0x1000>;
>> + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
>> + clock-names = "apb", "mod";
>> + dmas = <&dma 6>, <&dma 6>;
>> + resets = <&ccu RST_BUS_I2S3>;
>> + dma-names = "rx", "tx";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&i2s3_pins>;
>> + status = "okay";
>> + };
>> +
>> + i2s2: i2s@5092000 {
>> + #sound-dai-cells = <0>;
>> + compatible = "allwinner,sun50i-h6-i2s";
>> + reg = <0x05092000 0x1000>;
>> + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
>> + clock-names = "apb", "mod";
>> + dmas = <&dma 5>, <&dma 5>;
>> + resets = <&ccu RST_BUS_I2S2>;
>> + dma-names = "rx", "tx";
>> + status = "disabled";
>> + };
>> +
>> + i2s1: i2s@5091000 {
>> + #sound-dai-cells = <0>;
>> + compatible = "allwinner,sun50i-h6-i2s";
>> + reg = <0x05091000 0x1000>;
>> + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
>> + clock-names = "apb", "mod";
>> + dmas = <&dma 4>, <&dma 4>;
>> + resets = <&ccu RST_BUS_I2S1>;
>> + dma-names = "rx", "tx";
>> + status = "okay";
>> + };
>> +
>> + spdif: spdif@5093000 {
>> + #sound-dai-cells = <0>;
>> + compatible = "allwinner,sun50i-h6-spdif";
>> + reg = <0x05093000 0x400>;
>> + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
>> + clock-names = "apb", "spdif";
>> + resets = <&ccu RST_BUS_SPDIF>;
>> + dmas = <&dma 2>, <&dma 2>;
>> + dma-names = "rx", "tx";
>> + status = "disabled";
>> + };
>> +
>> + usb2otg: usb@5100000 {
>> + compatible = "allwinner,sun50i-h6-musb",
>> + "allwinner,sun8i-a33-musb";
>> + reg = <0x05100000 0x0400>;
>> + clocks = <&ccu CLK_BUS_OTG>;
>> + resets = <&ccu RST_BUS_OTG>;
>> + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
>> + interrupt-names = "mc";
>> + phys = <&usb2phy 0>;
>> + phy-names = "usb";
>> + extcon = <&usb2phy 0>;
>> + status = "okay";
>> + dr_mode = "host";
>> + };
>> +
>> + usb2phy: phy@5100400 {
>> + compatible = "allwinner,sun50i-h6-usb-phy";
>> + reg = <0x05100400 0x24>,
>> + <0x05101800 0x4>,
>> + <0x05311800 0x4>;
>> + reg-names = "phy_ctrl",
>> + "pmu0",
>> + "pmu3";
>> + clocks = <&ccu CLK_USB_PHY0>,
>> + <&ccu CLK_USB_PHY3>;
>> + clock-names = "usb0_phy",
>> + "usb3_phy";
>> + resets = <&ccu RST_USB_PHY0>,
>> + <&ccu RST_USB_PHY3>;
>> + reset-names = "usb0_reset",
>> + "usb3_reset";
>> + status = "okay";
>> + #phy-cells = <1>;
>> + };
>> +
>> + ehci0: usb@5101000 {
>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
>> + reg = <0x05101000 0x100>;
>> + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_OHCI0>,
>> + <&ccu CLK_BUS_EHCI0>,
>> + <&ccu CLK_USB_OHCI0>;
>> + resets = <&ccu RST_BUS_OHCI0>,
>> + <&ccu RST_BUS_EHCI0>;
>> + phys = <&usb2phy 0>;
>> + phy-names = "usb";
>> + status = "okay";
>> + };
>> +
>> + ohci0: usb@5101400 {
>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
>> + reg = <0x05101400 0x100>;
>> + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_OHCI0>,
>> + <&ccu CLK_USB_OHCI0>;
>> + resets = <&ccu RST_BUS_OHCI0>;
>> + phys = <&usb2phy 0>;
>> + phy-names = "usb";
>> + status = "okay";
>> + };
>> +
>> + dwc3: usb@5200000 {
>> + compatible = "snps,dwc3";
>> + reg = <0x05200000 0x10000>;
>> + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_XHCI>,
>> + <&ccu CLK_BUS_XHCI>,
>> + <&rtc CLK_OSC32K>;
>> + clock-names = "ref", "bus_early", "suspend";
>> + resets = <&ccu RST_BUS_XHCI>;
>> + /*
>> + * The datasheet of the chip doesn't declare the
>> + * peripheral function, and there's no boards known
>> + * to have a USB Type-B port routed to the port.
>> + * In addition, no one has tested the peripheral
>> + * function yet.
>> + * So set the dr_mode to "host" in the DTSI file.
>> + */
>> + dr_mode = "host";
>> + phys = <&usb3phy>;
>> + phy-names = "usb3-phy";
>> + status = "okay";
>> + };
>> +
>> + usb3phy: phy@5210000 {
>> + compatible = "allwinner,sun50i-h6-usb3-phy";
>> + reg = <0x5210000 0x10000>;
>> + clocks = <&ccu CLK_USB_PHY1>;
>> + resets = <&ccu RST_USB_PHY1>;
>> + #phy-cells = <0>;
>> + status = "okay";
>> + };
>> +
>> + ehci3: usb@5311000 {
>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
>> + reg = <0x05311000 0x100>;
>> + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_OHCI3>,
>> + <&ccu CLK_BUS_EHCI3>,
>> + <&ccu CLK_USB_OHCI3>;
>> + resets = <&ccu RST_BUS_OHCI3>,
>> + <&ccu RST_BUS_EHCI3>;
>> + phys = <&usb2phy 3>;
>> + phy-names = "usb";
>> + status = "okay";
>> + };
>> +
>> + ohci3: usb@5311400 {
>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
>> + reg = <0x05311400 0x100>;
>> + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_OHCI3>,
>> + <&ccu CLK_USB_OHCI3>;
>> + resets = <&ccu RST_BUS_OHCI3>;
>> + phys = <&usb2phy 3>;
>> + phy-names = "usb";
>> + status = "okay";
>> + };
>> +
>> + pcie: pcie@5400000 {
>> + #address-cells = <3>;
>> + #size-cells = <2>;
>> + compatible = "pine64,allwinner-h6-pcie-wrapped";
>> + reg = <0x05400000 0x4000>,
>> + <0x05410000 0x10000>;
>> + reg-names = "dbi", "config";
>> + device_type = "pci";
>> + bus-range = <0x00 0xff>;
>> + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
>> + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
>> + num-lanes = <1>;
>> + max-link-speed = <2>;
>> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
>> + interrupt-names = "msi", "linkup";
>> + clocks = <&ccu CLK_PCIE_REF_OUT>,
>> + <&ccu CLK_PCIE_MAXI>,
>> + <&ccu CLK_PCIE_AUX>,
>> + <&ccu CLK_BUS_PCIE>;
>> + clock-names = "ref", "axi", "aux", "bus";
>> + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
>> + reset-names = "power", "bus";
>> + #interrupt-cells = <1>;
>> + interrupt-map-mask = <0 0 0 0>;
>> + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
>> + status = "okay";
>> + vcc-supply = <®_bldo2>;
>> + vdd-supply = <®_dcdcd>;
>> + slot-supply = <®_vcc33_wifi>;
>> + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
>> + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
>> + /* wake-gpio = <&r_pio 0 4 0>; */
>> + };
>> +
>> +
>> + hdmi: hdmi@6000000 {
>> + #sound-dai-cells = <0>;
>> + compatible = "allwinner,sun50i-h6-dw-hdmi";
>> + reg = <0x06000000 0x10000>;
>> + reg-io-width = <1>;
>> + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
>> + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
>> + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
>> + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
>> + "hdcp-bus";
>> + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
>> + reset-names = "ctrl", "hdcp";
>> + phys = <&hdmi_phy>;
>> + phy-names = "phy";
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&hdmi_pins>;
>> + status = "okay";
>> +
>> + ports {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + hdmi_in: port@0 {
>> + reg = <0>;
>> +
>> + hdmi_in_tcon_top: endpoint {
>> + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
>> + };
>> + };
>> +
>> + hdmi_out: port@1 {
>> + reg = <1>;
>> +
>> + hdmi_out_con: endpoint {
>> + remote-endpoint = <&hdmi_con_in>;
>> + };
>> + };
>> + };
>> + };
>> +
>> + hdmi_phy: hdmi-phy@6010000 {
>> + compatible = "allwinner,sun50i-h6-hdmi-phy";
>> + reg = <0x06010000 0x10000>;
>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
>> + clock-names = "bus", "mod";
>> + resets = <&ccu RST_BUS_HDMI>;
>> + reset-names = "phy";
>> + #phy-cells = <0>;
>> + };
>> +
>> + tcon_top: tcon-top@6510000 {
>> + compatible = "allwinner,sun50i-h6-tcon-top";
>> + reg = <0x06510000 0x1000>;
>> + clocks = <&ccu CLK_BUS_TCON_TOP>,
>> + <&ccu CLK_TCON_TV0>;
>> + clock-names = "bus",
>> + "tcon-tv0";
>> + clock-output-names = "tcon-top-tv0";
>> + resets = <&ccu RST_BUS_TCON_TOP>;
>> + #clock-cells = <1>;
>> +
>> + ports {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + tcon_top_mixer0_in: port@0 {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + reg = <0>;
>> +
>> + tcon_top_mixer0_in_mixer0: endpoint@0 {
>> + reg = <0>;
>> + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
>> + };
>> + };
>> +
>> + tcon_top_mixer0_out: port@1 {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + reg = <1>;
>> +
>> + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
>> + reg = <2>;
>> + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
>> + };
>> + };
>> +
>> + tcon_top_hdmi_in: port@4 {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + reg = <4>;
>> +
>> + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
>> + reg = <0>;
>> + remote-endpoint = <&tcon_tv_out_tcon_top>;
>> + };
>> + };
>> +
>> + tcon_top_hdmi_out: port@5 {
>> + reg = <5>;
>> +
>> + tcon_top_hdmi_out_hdmi: endpoint {
>> + remote-endpoint = <&hdmi_in_tcon_top>;
>> + };
>> + };
>> + };
>> + };
>> +
>> + tcon_tv: lcd-controller@6515000 {
>> + compatible = "allwinner,sun50i-h6-tcon-tv",
>> + "allwinner,sun8i-r40-tcon-tv";
>> + reg = <0x06515000 0x1000>;
>> + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_TCON_TV0>,
>> + <&tcon_top CLK_TCON_TOP_TV0>;
>> + clock-names = "ahb",
>> + "tcon-ch1";
>> + resets = <&ccu RST_BUS_TCON_TV0>;
>> + reset-names = "lcd";
>> +
>> + ports {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + tcon_tv_in: port@0 {
>> + reg = <0>;
>> +
>> + tcon_tv_in_tcon_top_mixer0: endpoint {
>> + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
>> + };
>> + };
>> +
>> + tcon_tv_out: port@1 {
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + reg = <1>;
>> +
>> + tcon_tv_out_tcon_top: endpoint@1 {
>> + reg = <1>;
>> + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
>> + };
>> + };
>> + };
>> + };
>> +
>> + r_uart: serial@7080000 {
>> + compatible = "snps,dw-apb-uart";
>> + reg = <0x07080000 0x400>;
>> + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
>> + reg-shift = <2>;
>> + reg-io-width = <4>;
>> + clocks = <&r_ccu CLK_R_APB2_UART>;
>> + resets = <&r_ccu RST_R_APB2_UART>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&r_uart_pins>;
>> + status = "disabled";
>> + };
>> +
>> + rtc: rtc@7000000 {
>> + compatible = "allwinner,sun50i-h6-rtc";
>> + reg = <0x07000000 0x400>;
>> + interrupt-parent = <&r_intc>;
>> + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
>> + clock-output-names = "osc32k", "osc32k-out", "iosc";
>> + #clock-cells = <1>;
>> + clocks = <&ext_osc32k>;
>> + };
>> +
>> + r_ccu: clock@7010000 {
>> + compatible = "allwinner,sun50i-h6-r-ccu";
>> + reg = <0x07010000 0x400>;
>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
>> + <&ccu CLK_PLL_PERIPH0>;
>> + clock-names = "hosc", "losc", "iosc", "pll-periph";
>> + protected-clocks = <CLK_R_APB1_TWD>;
>> + #clock-cells = <1>;
>> + #reset-cells = <1>;
>> + };
>> +
>> + r_watchdog: watchdog@7020400 {
>> + compatible = "allwinner,sun50i-h6-wdt",
>> + "allwinner,sun6i-a31-wdt";
>> + reg = <0x07020400 0x20>;
>> + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&osc24M>;
>> + };
>> +
>> + r_intc: interrupt-controller@7021000 {
>> + compatible = "allwinner,sun50i-h6-r-intc";
>> + interrupt-controller;
>> + #interrupt-cells = <3>;
>> + reg = <0x07021000 0x400>;
>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
>> + };
>> +
>> + r_pwm: pwm@7020C00 {
>> + compatible = "allwinner,sun50i-h6-pwm";
>> + reg = <0x07020C00 0x400>;
>> + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
>> + clock-names = "mod", "bus";
>> + resets = <&ccu RST_R_APB1_PWM>;
>> + #pwm-cells = <3>;
>> + status = "disabled";
>> + };
>> +
>> + r_pio: pinctrl@7022000 {
>> + compatible = "allwinner,sun50i-h6-r-pinctrl";
>> + reg = <0x07022000 0x400>;
>> + interrupt-parent = <&r_intc>;
>> + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
>> + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
>> + <&rtc CLK_OSC32K>;
>> + clock-names = "apb", "hosc", "losc";
>> + gpio-controller;
>> + #gpio-cells = <3>;
>> + interrupt-controller;
>> + #interrupt-cells = <3>;
>> +
>> + r_i2c_pins: r-i2c-pins {
>> + pins = "PL0", "PL1";
>> + function = "s_i2c";
>> + };
>> +
>> + r_ir_rx_pin: r-ir-rx-pin {
>> + pins = "PL9";
>> + function = "s_cir_rx";
>> + };
>> +
>> + r_rsb_pins: r-rsb-pins {
>> + pins = "PL0", "PL1";
>> + function = "s_rsb";
>> + };
>> +
>> + r_uart_pins: r-uart-pins {
>> + pins = "PL2", "PL3";
>> + function = "s_uart";
>> + };
>> +
>> + r_pwm_pin: r-pwm-pin {
>> + pins = "PL8";
>> + function = "s_pwm";
>> + };
>> +
>> + };
>> +
>> + r_ir: ir@7040000 {
>> + compatible = "allwinner,sun50i-h6-ir",
>> + "allwinner,sun6i-a31-ir";
>> + reg = <0x07040000 0x400>;
>> + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&r_ccu CLK_R_APB1_IR>,
>> + <&r_ccu CLK_IR>;
>> + clock-names = "apb", "ir";
>> + resets = <&r_ccu RST_R_APB1_IR>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&r_ir_rx_pin>;
>> + status = "disabled";
>> + };
>> +
>> + r_i2c: i2c@7081400 {
>> + compatible = "allwinner,sun50i-h6-i2c",
>> + "allwinner,sun6i-a31-i2c";
>> + reg = <0x07081400 0x400>;
>> + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&r_ccu CLK_R_APB2_I2C>;
>> + resets = <&r_ccu RST_R_APB2_I2C>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&r_i2c_pins>;
>> + status = "okay";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> +
>> + axp805: pmic@36 {
>> + compatible = "x-powers,axp805", "x-powers,axp806";
>> + reg = <0x36>;
>> + interrupt-parent = <&r_intc>;
>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
>> + interrupt-controller;
>> + #interrupt-cells = <1>;
>> + x-powers,self-working-mode;
>> + vina-supply = <®_vcc5v>;
>> + vinb-supply = <®_vcc5v>;
>> + vinc-supply = <®_vcc5v>;
>> + vind-supply = <®_vcc5v>;
>> + vine-supply = <®_vcc5v>;
>> + aldoin-supply = <®_vcc5v>;
>> + bldoin-supply = <®_vcc5v>;
>> + cldoin-supply = <®_vcc5v>;
>> +
>> + regulators {
>> + reg_aldo1: aldo1 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc-pl-led-ir";
>> + };
>> +
>> + reg_aldo2: aldo2 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc33-audio-tv-ephy-mac";
>> + regulator-enable-ramp-delay = <100000>;
>> + };
>> +
>> + reg_aldo3: aldo3 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
>> + };
>> +
>> + reg_bldo1: bldo1 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <1800000>;
>> + regulator-max-microvolt = <1800000>;
>> + regulator-name = "vcc18-dram-bias-pll";
>> + };
>> +
>> + reg_bldo2: bldo2 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <1800000>;
>> + regulator-max-microvolt = <1800000>;
>> + regulator-name = "vcc-efuse-pcie-hdmi-pc";
>> + };
>> +
>> + reg_bldo3: bldo3 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <1800000>;
>> + regulator-max-microvolt = <1800000>;
>> + regulator-name = "vcc-dcxoio";
>> + };
>> +
>> + reg_bldo4: bldo4 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <1800000>;
>> + regulator-max-microvolt = <1800000>;
>> + regulator-name = "vcc-dcxoio";
>> + };
>> +
>> + reg_cldo1: cldo1 {
>> + regulator-always-on;
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
>> + };
>> +
>> + reg_cldo2: cldo2 {
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc-wifi-1";
>> + };
>> +
>> + reg_cldo3: cldo3 {
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-name = "vcc-wifi-2";
>> + };
>> +
>> + reg_dcdca: dcdca {
>> + regulator-always-on;
>> + regulator-min-microvolt = <810000>;
>> + regulator-max-microvolt = <1200000>;
>> + regulator-ramp-delay = <2500>;
>> + regulator-name = "vdd-cpu";
>> + };
>> +
>> + reg_dcdcc: dcdcc {
>> + regulator-enable-ramp-delay = <32000>;
>> + regulator-min-microvolt = <810000>;
>> + regulator-max-microvolt = <1080000>;
>> + regulator-ramp-delay = <2500>;
>> + regulator-name = "vdd-gpu";
>> + };
>> +
>> + reg_dcdcd: dcdcd {
>> + regulator-always-on;
>> + regulator-min-microvolt = <1000000>;
>> + regulator-max-microvolt = <1000000>;
>> + regulator-name = "vdd-sys";
>> + };
>> +
>> + sw {
>> + /* unused */
>> + };
>> + };
>> + };
>> + };
>> +
>> + r_rsb: rsb@7083000 {
>> + compatible = "allwinner,sun8i-a23-rsb";
>> + reg = <0x07083000 0x400>;
>> + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&r_ccu CLK_R_APB2_RSB>;
>> + clock-frequency = <3000000>;
>> + resets = <&r_ccu RST_R_APB2_RSB>;
>> + pinctrl-names = "default";
>> + pinctrl-0 = <&r_rsb_pins>;
>> + status = "disabled";
>> + #address-cells = <1>;
>> + #size-cells = <0>;
>> + };
>> +
>> + ths: thermal-sensor@5070400 {
>> + compatible = "allwinner,sun50i-h6-ths";
>> + reg = <0x05070400 0x100>;
>> + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
>> + clocks = <&ccu CLK_BUS_THS>;
>> + clock-names = "bus";
>> + resets = <&ccu RST_BUS_THS>;
>> + nvmem-cells = <&ths_calibration>;
>> + nvmem-cell-names = "calibration";
>> + #thermal-sensor-cells = <1>;
>> + };
>> +
>> + sunxi-info {
>> + compatible = "allwinner,sun50i-h6-sys-info";
>> + status = "okay";
>> + };
>> +
>> + addr_mgt: addr-mgt {
>> + compatible = "allwinner,sunxi-addr_mgt";
>> + type_addr_wifi = <0x2>;
>> + type_addr_bt = <0x2>;
>> + type_addr_eth = <0x2>;
>> + status = "okay";
>> + };
>> +
>> + dump_reg: dump_reg@20000 {
>> + compatible = "allwinner,sunxi-dump-reg";
>> + reg = <0x0 0x03001000 0x0 0x0f20>;
>> + status = "okay";
>> + };
>> + };
>> +
>> + thermal-zones {
>> + cpu-thermal {
>> + polling-delay-passive = <250>;
>> + polling-delay = <1000>;
>> + thermal-sensors = <&ths 0>;
>> +
>> + trips {
>> + cpu_warm: cpu_warm {
>> + temperature = <70000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_hot0: cpu_hot0 {
>> + temperature = <74000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_hot1: cpu_hot1 {
>> + temperature = <76000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot0: cpu_very_hot0 {
>> + temperature = <78000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot1: cpu_very_hot1 {
>> + temperature = <80000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot2: cpu_very_hot2 {
>> + temperature = <82000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot3: cpu_very_hot3 {
>> + temperature = <84000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot4: cpu_very_hot4 {
>> + temperature = <86000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot5: cpu_very_hot5 {
>> + temperature = <88000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_very_hot6: cpu_very_hot6 {
>> + temperature = <90000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + cpu_crit: cpu_crit {
>> + temperature = <97000>;
>> + hysteresis = <2000>;
>> + type = "critical";
>> + };
>> + };
>> +
>> + cooling-maps {
>> + cpu_warm_limit_cpu {
>> + trip = <&cpu_warm>;
>> + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>> + };
>> + };
>> + };
>> +
>> + gpu-thermal {
>> + polling-delay-passive = <1000>;
>> + polling-delay = <2000>;
>> + thermal-sensors = <&ths 1>;
>> +
>> + trips {
>> + gpu_alert0: gpu-alert-0 {
>> + temperature = <95000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + gpu_alert1: gpu-alert-1 {
>> + temperature = <100000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + gpu_alert2: gpu-alert-2 {
>> + temperature = <105000>;
>> + hysteresis = <2000>;
>> + type = "passive";
>> + };
>> +
>> + gpu-crit {
>> + temperature = <115000>;
>> + hysteresis = <0>;
>> + type = "critical";
>> + };
>> + };
>> +
>> + cooling-maps {
>> + // Forbid the GPU to go over 756MHz
>> + map0 {
>> + trip = <&gpu_alert0>;
>> + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
>> + };
>> +
>> + // Forbid the GPU to go over 624MHz
>> + map1 {
>> + trip = <&gpu_alert1>;
>> + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
>> + };
>> +
>> + // Forbid the GPU to go over 576MHz
>> + map2 {
>> + trip = <&gpu_alert2>;
>> + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
>> + };
>> + };
>> + };
>> + };
>> +
>> + cpu_opp_table: cpu-opp-table {
>> + compatible = "allwinner,sun50i-h6-operating-points";
>> + nvmem-cells = <&cpu_speed_grade>;
>> + opp-shared;
>> +
>> + opp-480000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <480000000>;
>> +
>> + opp-microvolt-speed0 = <880000>;
>> + };
>> +
>> + opp-720000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <720000000>;
>> +
>> + opp-microvolt-speed0 = <880000>;
>> + };
>> +
>> + opp-888000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <888000000>;
>> +
>> + opp-microvolt-speed0 = <880000>;
>> + };
>> +
>> + opp-1080000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1080000000>;
>> +
>> + opp-microvolt-speed0 = <940000>;
>> + };
>> +
>> + opp-1320000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1320000000>;
>> +
>> + opp-microvolt-speed0 = <1000000>;
>> + };
>> +
>> + opp-1488000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1488000000>;
>> +
>> + opp-microvolt-speed0 = <1060000>;
>> + };
>> +
>> + opp-1608000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1608000000>;
>> +
>> + opp-microvolt-speed0 = <1090000>;
>> + };
>> +
>> + opp-1704000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1704000000>;
>> +
>> + opp-microvolt-speed0 = <1120000>;
>> + };
>> +
>> + opp-1800000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1800000000>;
>> +
>> + opp-microvolt-speed0 = <1160000>;
>> + };
>> +
>> + opp@1896000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1896000000>;
>> +
>> + opp-microvolt-speed0 = <1180000>;
>> + };
>> +
>> + opp@1968000000 {
>> + clock-latency-ns = <244144>; /* 8 32k periods */
>> + opp-hz = /bits/ 64 <1968000000>;
>> +
>> + opp-microvolt-speed0 = <1200000>;
>> + };
>> +
>> + };
>> +
>> + gpu_opp_table: opp-table-gpu {
>> + compatible = "operating-points-v2";
>> +
>> + opp-216000000 {
>> + opp-hz = /bits/ 64 <216000000>;
>> + opp-microvolt = <810000 810000 1200000>;
>> + };
>> +
>> + opp-264000000 {
>> + opp-hz = /bits/ 64 <264000000>;
>> + opp-microvolt = <810000 810000 1200000>;
>> + };
>> +
>> + opp-312000000 {
>> + opp-hz = /bits/ 64 <312000000>;
>> + opp-microvolt = <810000 810000 1200000>;
>> + };
>> +
>> + opp-336000000 {
>> + opp-hz = /bits/ 64 <336000000>;
>> + opp-microvolt = <810000 810000 1200000>;
>> + };
>> +
>> + opp-360000000 {
>> + opp-hz = /bits/ 64 <360000000>;
>> + opp-microvolt = <820000 820000 1200000>;
>> + };
>> +
>> + opp-384000000 {
>> + opp-hz = /bits/ 64 <384000000>;
>> + opp-microvolt = <830000 830000 1200000>;
>> + };
>> +
>> + opp-408000000 {
>> + opp-hz = /bits/ 64 <408000000>;
>> + opp-microvolt = <840000 840000 1200000>;
>> + };
>> +
>> + opp-420000000 {
>> + opp-hz = /bits/ 64 <420000000>;
>> + opp-microvolt = <850000 850000 1200000>;
>> + };
>> +
>> + opp-432000000 {
>> + opp-hz = /bits/ 64 <432000000>;
>> + opp-microvolt = <860000 860000 1200000>;
>> + };
>> +
>> + opp-456000000 {
>> + opp-hz = /bits/ 64 <456000000>;
>> + opp-microvolt = <870000 870000 1200000>;
>> + };
>> +
>> + opp-504000000 {
>> + opp-hz = /bits/ 64 <504000000>;
>> + opp-microvolt = <890000 890000 1200000>;
>> + };
>> +
>> + opp-540000000 {
>> + opp-hz = /bits/ 64 <540000000>;
>> + opp-microvolt = <910000 910000 1200000>;
>> + };
>> +
>> + opp-576000000 {
>> + opp-hz = /bits/ 64 <576000000>;
>> + opp-microvolt = <930000 930000 1200000>;
>> + };
>> +
>> + opp-624000000 {
>> + opp-hz = /bits/ 64 <624000000>;
>> + opp-microvolt = <950000 950000 1200000>;
>> + };
>> +
>> + opp-756000000 {
>> + opp-hz = /bits/ 64 <756000000>;
>> + opp-microvolt = <1040000 1040000 1200000>;
>> + };
>> + };
>> +
>> + chosen {
>> + stdout-path = "serial0:115200n8";
>> + };
>> +
>> + connector {
>> + compatible = "hdmi-connector";
>> + type = "a";
>> +
>> + port {
>> + hdmi_con_in: endpoint {
>> + remote-endpoint = <&hdmi_out_con>;
>> + };
>> + };
>> + };
>> +
>> + ext_osc32k: ext_osc32k_clk {
>> + #clock-cells = <0>;
>> + compatible = "fixed-clock";
>> + clock-frequency = <32768>;
>> + clock-output-names = "ext_osc32k";
>> + };
>> +
>> + leds {
>> + compatible = "gpio-leds";
>> +
>> + led-0 {
>> + label = "repka:red:power";
>> + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
>> + linux,default-trigger = "heartbeat";
>> + };
>> + };
>> +
>> + reg_vcc5v: vcc5v {
>> + /* board wide 5V supply directly from the DC jack */
>> + compatible = "regulator-fixed";
>> + regulator-name = "vcc-5v";
>> + regulator-min-microvolt = <5000000>;
>> + regulator-max-microvolt = <5000000>;
>> + regulator-always-on;
>> + };
>> +
>> + reg_vcc33_wifi: vcc33-wifi {
>> + /* Always on 3.3V regulator for WiFi and BT */
>> + compatible = "regulator-fixed";
>> + regulator-name = "vcc33-wifi";
>> + regulator-min-microvolt = <3300000>;
>> + regulator-max-microvolt = <3300000>;
>> + regulator-always-on;
>> + vin-supply = <®_vcc5v>;
>> + };
>> +
>> + reg_vcc_wifi_io: vcc-wifi-io {
>> + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
>> + compatible = "regulator-fixed";
>> + regulator-name = "vcc-wifi-io";
>> + regulator-min-microvolt = <1800000>;
>> + regulator-max-microvolt = <1800000>;
>> + regulator-always-on;
>> + vin-supply = <®_vcc33_wifi>;
>> + };
>> +
>> + wifi_pwrseq: wifi-pwrseq {
>> + compatible = "mmc-pwrseq-simple";
>> + clocks = <&rtc 1>;
>> + clock-names = "ext_clock";
>> + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
>> + post-power-on-delay-ms = <200>;
>> + };
>> +};
>> --
>> 2.42.2
>>
>> _______________________________________________
>> devel-kernel mailing list
>> devel-kernel@lists.altlinux.org
>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
--
Kind Regards!
from srebrov@altlinux.org
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-07 20:50 ` Kurachenko Anton
@ 2025-05-08 0:54 ` Vitaly Chikunov
2025-05-08 1:10 ` Anton Midyukov
0 siblings, 1 reply; 7+ messages in thread
From: Vitaly Chikunov @ 2025-05-08 0:54 UTC (permalink / raw)
To: ALT Linux kernel packages development
On Wed, May 07, 2025 at 11:50:53PM +0300, Kurachenko Anton wrote:
> 1. Я проверял сборку и работоспособность полученного результата на ядре
> 6.12.25-alt1.
Это хорошо, спасибо.
> 2. Дело в том, что загрузчик u-boot для Repka Pi 4 требует обязательного
> наличия dtb для запуска. Сейчас нам приходится заниматься скачиванием и
> распаковкой ядра repka4, затем извлекать нужный dtb и переносить его в
> /boot/devicetree/$kernelversion/allwinner ядра 6.12, чтобы хотя бы
> просто начать процесс установки. Патч призван решить эту проблему.
То есть наше 6.12 начнет загружаться на repka pi4 или это для чего-то
другого нужно?
>
> 07.05.2025 22:39, Vitaly Chikunov пишет:
> > Anton,
> >
> > On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
> > > From: Anton Kurachenko <srebrov@altlinux.org>
> > >
> > > Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
> > > u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
> > > a dtb file.
> > >
> > > Patch designed specifically for ALT and never used anywhere.
> >
> > 1. Это изменение протестировано?
> > 2. Зачем нужен этот патч, если есть флейворы repka/repka4?
> >
> > Thanks,
> >
> > >
> > > The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
> > > file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
> > > from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
> > > Represents the result of merging these files with applying some modifications.
> > >
> > > Files that were used during the creation process:
> > >
> > > sun50i-h6-repka-pi4-optimal.dts
> > > Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
> > >
> > > sun50i-h6.dtsi
> > > Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
> > >
> > > sun50i-h6-cpu-opp.dtsi
> > > Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
> > >
> > > Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
> > > ---
> > > arch/arm64/boot/dts/allwinner/Makefile | 1 +
> > > .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
> > > 2 files changed, 1919 insertions(+)
> > > create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> > >
> > > diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
> > > index 00bed412ee31..2df5189e0d44 100644
> > > --- a/arch/arm64/boot/dts/allwinner/Makefile
> > > +++ b/arch/arm64/boot/dts/allwinner/Makefile
> > > @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
> > > dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
> > > +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
> > > diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> > > new file mode 100644
> > > index 000000000000..9d95297a30b8
> > > --- /dev/null
> > > +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> > > @@ -0,0 +1,1918 @@
> > > +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> > > +// based on the dts, which is:
> > > +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
> > > +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
> > > +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
> > > +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
> > > +
> > > +/dts-v1/;
> > > +
> > > +#include <dt-bindings/interrupt-controller/arm-gic.h>
> > > +#include <dt-bindings/clock/sun50i-h6-ccu.h>
> > > +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
> > > +#include <dt-bindings/clock/sun6i-rtc.h>
> > > +#include <dt-bindings/clock/sun8i-de2.h>
> > > +#include <dt-bindings/clock/sun8i-tcon-top.h>
> > > +#include <dt-bindings/reset/sun50i-h6-ccu.h>
> > > +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
> > > +#include <dt-bindings/reset/sun8i-de2.h>
> > > +#include <dt-bindings/thermal/thermal.h>
> > > +#include <dt-bindings/gpio/gpio.h>
> > > +
> > > +/ {
> > > + interrupt-parent = <&gic>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + model = "Repka-Pi4-Optimal";
> > > + repka-freq = "1.968 GHz";
> > > + repka-pinout = "repka-pi4-base";
> > > + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
> > > +
> > > + aliases {
> > > + mmc0 = &mmc0;
> > > + mmc1 = &mmc1;
> > > + mmc2 = &mmc2;
> > > + ethernet0 = &emac;
> > > + serial0 = &uart0;
> > > + serial1 = &uart1;
> > > + serial2 = &r_uart;
> > > +
> > > + spi0 = &spi1;
> > > + i2c1 = &i2c0;
> > > + i2c2 = &i2c2;
> > > + i2c3 = &i2c1;
> > > + i2c4 = &i2c3;
> > > +
> > > + };
> > > +
> > > + reserved-memory {
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges;
> > > +
> > > + custom_region: region@40010000 {
> > > + reg = <0x40010000 0x00070000>;
> > > + no-map;
> > > + };
> > > + };
> > > +
> > > + analog: analog-codec {
> > > + compatible = "simple-audio-card";
> > > + simple-audio-card,format = "i2s";
> > > + simple-audio-card,name = "ac200-audio";
> > > + simple-audio-card,mclk-fs = <512>;
> > > + status = "okay";
> > > +
> > > + simple-audio-card,cpu {
> > > + sound-dai = <&i2s3>;
> > > + };
> > > +
> > > + simple-audio-card,codec {
> > > + sound-dai = <&ac200_codec>;
> > > + };
> > > + };
> > > +
> > > + ac200_pwm_clk: ac200_clk {
> > > + compatible = "pwm-clock";
> > > + #clock-cells = <0>;
> > > + clock-frequency = <24000000>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&pwm1_pin>;
> > > + pwms = <&pwm 1 42 0>;
> > > + status = "okay";
> > > + };
> > > +
> > > + cpus {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + cpu0: cpu@0 {
> > > + compatible = "arm,cortex-a53";
> > > + device_type = "cpu";
> > > + reg = <0>;
> > > + enable-method = "psci";
> > > + clocks = <&ccu CLK_CPUX>;
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + #cooling-cells = <2>;
> > > + operating-points-v2 = <&cpu_opp_table>;
> > > + cpu-supply = <®_dcdca>;
> > > + };
> > > +
> > > + cpu1: cpu@1 {
> > > + compatible = "arm,cortex-a53";
> > > + device_type = "cpu";
> > > + reg = <1>;
> > > + enable-method = "psci";
> > > + clocks = <&ccu CLK_CPUX>;
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + #cooling-cells = <2>;
> > > + operating-points-v2 = <&cpu_opp_table>;
> > > + };
> > > +
> > > + cpu2: cpu@2 {
> > > + compatible = "arm,cortex-a53";
> > > + device_type = "cpu";
> > > + reg = <2>;
> > > + enable-method = "psci";
> > > + clocks = <&ccu CLK_CPUX>;
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + #cooling-cells = <2>;
> > > + operating-points-v2 = <&cpu_opp_table>;
> > > + };
> > > +
> > > + cpu3: cpu@3 {
> > > + compatible = "arm,cortex-a53";
> > > + device_type = "cpu";
> > > + reg = <3>;
> > > + enable-method = "psci";
> > > + clocks = <&ccu CLK_CPUX>;
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + #cooling-cells = <2>;
> > > + operating-points-v2 = <&cpu_opp_table>;
> > > + };
> > > + };
> > > +
> > > + de: display-engine {
> > > + compatible = "allwinner,sun50i-h6-display-engine";
> > > + allwinner,pipelines = <&mixer0>;
> > > + status = "okay";
> > > + };
> > > +
> > > + osc24M: osc24M_clk {
> > > + #clock-cells = <0>;
> > > + compatible = "fixed-clock";
> > > + clock-frequency = <24000000>;
> > > + clock-output-names = "osc24M";
> > > + };
> > > +
> > > + pmu {
> > > + compatible = "arm,cortex-a53-pmu";
> > > + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
> > > + };
> > > +
> > > + psci {
> > > + compatible = "arm,psci-0.2";
> > > + method = "smc";
> > > + };
> > > +
> > > + scpi_protocol: scpi {
> > > + compatible = "arm,scpi";
> > > + mboxes = <&msgbox 2>, <&msgbox 3>;
> > > + mbox-names = "tx", "rx";
> > > + shmem = <&scpi_sram>;
> > > + };
> > > +
> > > + sound_hdmi: sound_hdmi {
> > > + compatible = "allwinner,sun9i-a80-hdmi-audio",
> > > + "allwinner,sun50i-h6-hdmi-audio";
> > > + status = "okay";
> > > + codec {
> > > + sound-dai = <&hdmi>;
> > > + };
> > > +
> > > + cpu {
> > > + sound-dai = <&i2s1>;
> > > + };
> > > + };
> > > +
> > > + timer {
> > > + compatible = "arm,armv8-timer";
> > > + arm,no-tick-in-suspend;
> > > + interrupts = <GIC_PPI 13
> > > + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> > > + <GIC_PPI 14
> > > + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> > > + <GIC_PPI 11
> > > + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> > > + <GIC_PPI 10
> > > + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> > > + };
> > > +
> > > +
> > > + soc {
> > > + compatible = "simple-bus";
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges;
> > > +
> > > + bus@1000000 {
> > > + compatible = "allwinner,sun50i-h6-de3",
> > > + "allwinner,sun50i-a64-de2";
> > > + reg = <0x1000000 0x400000>;
> > > + allwinner,sram = <&de2_sram 1>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges = <0 0x1000000 0x400000>;
> > > +
> > > + display_clocks: clock@0 {
> > > + compatible = "allwinner,sun50i-h6-de3-clk";
> > > + reg = <0x0 0x10000>;
> > > + clocks = <&ccu CLK_BUS_DE>,
> > > + <&ccu CLK_DE>;
> > > + clock-names = "bus",
> > > + "mod";
> > > + resets = <&ccu RST_BUS_DE>;
> > > + #clock-cells = <1>;
> > > + #reset-cells = <1>;
> > > + };
> > > +
> > > + mixer0: mixer@100000 {
> > > + compatible = "allwinner,sun50i-h6-de3-mixer-0";
> > > + reg = <0x100000 0x100000>;
> > > + clocks = <&display_clocks CLK_BUS_MIXER0>,
> > > + <&display_clocks CLK_MIXER0>;
> > > + clock-names = "bus",
> > > + "mod";
> > > + resets = <&display_clocks RST_MIXER0>;
> > > + iommus = <&iommu 0>;
> > > +
> > > + ports {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + mixer0_out: port@1 {
> > > + reg = <1>;
> > > +
> > > + mixer0_out_tcon_top_mixer0: endpoint {
> > > + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
> > > + };
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > +
> > > + video-codec-g2@1c00000 {
> > > + compatible = "allwinner,sun50i-h6-vpu-g2";
> > > + reg = <0x01c00000 0x1000>;
> > > + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
> > > + clock-names = "bus", "mod";
> > > + resets = <&ccu RST_BUS_VP9>;
> > > + iommus = <&iommu 5>;
> > > + };
> > > +
> > > + deinterlace: deinterlace@1420000 {
> > > + compatible = "allwinner,sun50i-h6-deinterlace";
> > > + reg = <0x01420000 0x2000>;
> > > + clocks = <&ccu CLK_BUS_DEINTERLACE>,
> > > + <&ccu CLK_DEINTERLACE>,
> > > + <&ccu CLK_MBUS_DEINTERLACE>;
> > > + clock-names = "bus", "mod", "ram";
> > > + resets = <&ccu RST_BUS_DEINTERLACE>;
> > > + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
> > > + iommus = <&iommu 2>;
> > > + };
> > > +
> > > + video-codec@1c0e000 {
> > > + compatible = "allwinner,sun50i-h6-video-engine";
> > > + reg = <0x01c0e000 0x2000>;
> > > + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
> > > + <&ccu CLK_MBUS_VE>;
> > > + clock-names = "ahb", "mod", "ram";
> > > + resets = <&ccu RST_BUS_VE>;
> > > + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
> > > + allwinner,sram = <&ve_sram 1>;
> > > + iommus = <&iommu 1>, <&iommu 3>;
> > > + };
> > > +
> > > + gpu: gpu@1800000 {
> > > + compatible = "allwinner,sun50i-h6-mali",
> > > + "arm,mali-t720";
> > > + reg = <0x01800000 0x4000>;
> > > + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "job", "mmu", "gpu";
> > > + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
> > > + clock-names = "core", "bus";
> > > + resets = <&ccu RST_BUS_GPU>;
> > > + #cooling-cells = <2>;
> > > + status = "okay";
> > > + operating-points-v2 = <&gpu_opp_table>;
> > > + mali-supply = <®_dcdcc>;
> > > + };
> > > +
> > > + crypto: crypto@1904000 {
> > > + compatible = "allwinner,sun50i-h6-crypto";
> > > + reg = <0x01904000 0x1000>;
> > > + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
> > > + clock-names = "bus", "mod", "ram";
> > > + resets = <&ccu RST_BUS_CE>;
> > > + };
> > > +
> > > + syscon: syscon@3000000 {
> > > + compatible = "allwinner,sun50i-h6-system-control",
> > > + "allwinner,sun50i-a64-system-control";
> > > + reg = <0x03000000 0x1000>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges;
> > > +
> > > + sram_a2: sram@100000 {
> > > + compatible = "mmio-sram";
> > > + reg = <0x00100000 0x18000>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges = <0 0x00100000 0x18000>;
> > > +
> > > + scpi_sram: scp-shmem@17c00 {
> > > + compatible = "arm,scp-shmem";
> > > + reg = <0x17c00 0x200>;
> > > + };
> > > + };
> > > +
> > > + sram_c: sram@28000 {
> > > + compatible = "mmio-sram";
> > > + reg = <0x00028000 0x1e000>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges = <0 0x00028000 0x1e000>;
> > > +
> > > + de2_sram: sram-section@0 {
> > > + compatible = "allwinner,sun50i-h6-sram-c",
> > > + "allwinner,sun50i-a64-sram-c";
> > > + reg = <0x0000 0x1e000>;
> > > + };
> > > + };
> > > +
> > > + sram_c1: sram@1a00000 {
> > > + compatible = "mmio-sram";
> > > + reg = <0x01a00000 0x200000>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > + ranges = <0 0x01a00000 0x200000>;
> > > +
> > > + ve_sram: sram-section@0 {
> > > + compatible = "allwinner,sun50i-h6-sram-c1",
> > > + "allwinner,sun4i-a10-sram-c1";
> > > + reg = <0x000000 0x200000>;
> > > + };
> > > + };
> > > + };
> > > +
> > > + ccu: clock@3001000 {
> > > + compatible = "allwinner,sun50i-h6-ccu";
> > > + reg = <0x03001000 0x1000>;
> > > + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
> > > + clock-names = "hosc", "losc", "iosc";
> > > + protected-clocks = <CLK_BUS_MSGBOX>;
> > > + #clock-cells = <1>;
> > > + #reset-cells = <1>;
> > > + };
> > > +
> > > + dma: dma-controller@3002000 {
> > > + compatible = "allwinner,sun50i-h6-dma";
> > > + reg = <0x03002000 0x1000>;
> > > + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
> > > + clock-names = "bus", "mbus";
> > > + dma-channels = <16>;
> > > + dma-requests = <46>;
> > > + resets = <&ccu RST_BUS_DMA>;
> > > + #dma-cells = <1>;
> > > + };
> > > +
> > > + msgbox: mailbox@3003000 {
> > > + compatible = "allwinner,sun50i-h6-msgbox",
> > > + "allwinner,sun6i-a31-msgbox";
> > > + reg = <0x03003000 0x1000>;
> > > + clocks = <&ccu CLK_BUS_MSGBOX>;
> > > + resets = <&ccu RST_BUS_MSGBOX>;
> > > + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> > > + #mbox-cells = <1>;
> > > + };
> > > +
> > > + gic: interrupt-controller@3021000 {
> > > + compatible = "arm,gic-400";
> > > + reg = <0x03021000 0x1000>,
> > > + <0x03022000 0x2000>,
> > > + <0x03024000 0x2000>,
> > > + <0x03026000 0x2000>;
> > > + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> > > + interrupt-controller;
> > > + #interrupt-cells = <3>;
> > > + };
> > > +
> > > + sid: efuse@3006000 {
> > > + compatible = "allwinner,sun50i-h6-sid";
> > > + reg = <0x03006000 0x400>;
> > > + #address-cells = <1>;
> > > + #size-cells = <1>;
> > > +
> > > + ths_calibration: thermal-sensor-calibration@14 {
> > > + reg = <0x14 0x8>;
> > > + };
> > > +
> > > + cpu_speed_grade: cpu-speed-grade@1c {
> > > + reg = <0x1c 0x4>;
> > > + };
> > > +
> > > + ephy_calib: ephy_calib@2c {
> > > + reg = <0x2c 0x2>;
> > > + };
> > > +
> > > + ac200_bg: ac200_bg@30 {
> > > + reg = <0x30 0x2>;
> > > + };
> > > + };
> > > +
> > > + timer@3009000 {
> > > + compatible = "allwinner,sun50i-h6-timer",
> > > + "allwinner,sun8i-a23-timer";
> > > + reg = <0x03009000 0xa0>;
> > > + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&osc24M>;
> > > + };
> > > +
> > > + watchdog: watchdog@30090a0 {
> > > + compatible = "allwinner,sun50i-h6-wdt",
> > > + "allwinner,sun6i-a31-wdt";
> > > + reg = <0x030090a0 0x20>;
> > > + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&osc24M>;
> > > + /* Broken on some H6 boards */
> > > + status = "disabled";
> > > + };
> > > +
> > > + pwm: pwm@300a000 {
> > > + compatible = "allwinner,sun50i-h6-pwm";
> > > + reg = <0x0300a000 0x400>;
> > > + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
> > > + clock-names = "mod", "bus";
> > > + resets = <&ccu RST_BUS_PWM>;
> > > + #pwm-cells = <3>;
> > > + status = "okay";
> > > + };
> > > +
> > > + pio: pinctrl@300b000 {
> > > + compatible = "allwinner,sun50i-h6-pinctrl";
> > > + reg = <0x0300b000 0x400>;
> > > + interrupt-parent = <&r_intc>;
> > > + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
> > > + clock-names = "apb", "hosc", "losc";
> > > + gpio-controller;
> > > + #gpio-cells = <3>;
> > > + interrupt-controller;
> > > + #interrupt-cells = <3>;
> > > + vcc-pc-supply = <®_bldo2>;
> > > + vcc-pd-supply = <®_cldo1>;
> > > + vcc-pg-supply = <®_vcc_wifi_io>;
> > > +
> > > + /omit-if-no-ref/
> > > + ext_rgmii_pins: rgmii-pins {
> > > + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
> > > + "PD5", "PD7", "PD8", "PD9", "PD10",
> > > + "PD11", "PD12", "PD13", "PD19", "PD20";
> > > + function = "emac";
> > > + drive-strength = <40>;
> > > + };
> > > +
> > > + ext_rmii_pins: rmii_pins {
> > > + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
> > > + "PA5", "PA6", "PA7", "PA8", "PA9";
> > > + function = "emac";
> > > + drive-strength = <40>;
> > > + };
> > > +
> > > + hdmi_pins: hdmi-pins {
> > > + pins = "PH8", "PH9", "PH10";
> > > + function = "hdmi";
> > > + };
> > > +
> > > + i2c0_pins: i2c0-pins {
> > > + pins = "PD25", "PD26";
> > > + function = "i2c0";
> > > + };
> > > +
> > > + i2c1_pins: i2c1-pins {
> > > + pins = "PH5", "PH6";
> > > + function = "i2c1";
> > > + };
> > > +
> > > + i2c2_pins: i2c2-pins {
> > > + pins = "PD23", "PD24";
> > > + function = "i2c2";
> > > + };
> > > +
> > > + i2c3_pins: i2c3-pins {
> > > + pins = "PB17", "PB18";
> > > + function = "i2c3";
> > > + bias-pull-up;
> > > + };
> > > +
> > > + i2s3_pins: i2s3-pins {
> > > + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
> > > + function = "i2s3";
> > > + };
> > > +
> > > + mmc0_pins: mmc0-pins {
> > > + pins = "PF0", "PF1", "PF2", "PF3",
> > > + "PF4", "PF5";
> > > + function = "mmc0";
> > > + drive-strength = <30>;
> > > + bias-pull-up;
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + mmc1_pins: mmc1-pins {
> > > + pins = "PG0", "PG1", "PG2", "PG3",
> > > + "PG4", "PG5";
> > > + function = "mmc1";
> > > + drive-strength = <30>;
> > > + bias-pull-up;
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + mmc2_pins: mmc2-pins {
> > > + pins = "PC1", "PC4", "PC5", "PC6",
> > > + "PC7", "PC8", "PC9", "PC10",
> > > + "PC11", "PC12", "PC13", "PC14";
> > > + function = "mmc2";
> > > + drive-strength = <30>;
> > > + bias-pull-up;
> > > + };
> > > +
> > > + pwm1_pin: pwm1-pin {
> > > + pins = "PB19";
> > > + function = "pwm1";
> > > + };
> > > +
> > > + pwm_pin: pwm-pin {
> > > + pins = "PD22";
> > > + function = "pwm";
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + spi0_pins: spi0-pins {
> > > + pins = "PC0", "PC2", "PC3";
> > > + function = "spi0";
> > > + };
> > > +
> > > + /* pin shared with MMC2-CMD (eMMC) */
> > > + /omit-if-no-ref/
> > > + spi0_cs_pin: spi0-cs-pin {
> > > + pins = "PC5";
> > > + function = "spi0";
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + spi1_pins: spi1-pins {
> > > + pins = "PH4", "PH5", "PH6";
> > > + function = "spi1";
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + spi1_cs_pin: spi1-cs-pin {
> > > + pins = "PH3";
> > > + function = "spi1";
> > > + };
> > > +
> > > + /omit-if-no-ref/
> > > + spdif_tx_pin: spdif-tx-pin {
> > > + pins = "PH7";
> > > + function = "spdif";
> > > + };
> > > +
> > > + uart0_ph_pins: uart0-ph-pins {
> > > + pins = "PH0", "PH1";
> > > + function = "uart0";
> > > + };
> > > +
> > > + uart1_pins: uart1-pins {
> > > + pins = "PG6", "PG7";
> > > + function = "uart1";
> > > + };
> > > +
> > > + uart1_rts_cts_pins: uart1-rts-cts-pins {
> > > + pins = "PG8", "PG9";
> > > + function = "uart1";
> > > + };
> > > +
> > > + uart2_pins: uart2-pins {
> > > + pins = "PD19", "PD20";
> > > + function = "uart2";
> > > + };
> > > +
> > > + uart2_rts_cts_pins: uart2-rts-cts-pins {
> > > + pins = "PD21", "PD22";
> > > + function = "uart2";
> > > + };
> > > +
> > > + uart3_pins: uart3-pins {
> > > + pins = "PD23", "PD24";
> > > + function = "uart3";
> > > + };
> > > +
> > > + uart3_rts_cts_pins: uart3-rts-cts-pins {
> > > + pins = "PD25", "PD26";
> > > + function = "uart3";
> > > + };
> > > +
> > > + i2s2_pins: i2s2-pins {
> > > + pins = "PG10", "PG11", "PG12", "PG13";
> > > + function = "i2s2";
> > > + };
> > > + };
> > > +
> > > + iommu: iommu@30f0000 {
> > > + compatible = "allwinner,sun50i-h6-iommu";
> > > + reg = <0x030f0000 0x10000>;
> > > + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_IOMMU>;
> > > + resets = <&ccu RST_BUS_IOMMU>;
> > > + #iommu-cells = <1>;
> > > + };
> > > +
> > > + mmc0: mmc@4020000 {
> > > + compatible = "allwinner,sun50i-h6-mmc",
> > > + "allwinner,sun50i-a64-mmc";
> > > + reg = <0x04020000 0x1000>;
> > > + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
> > > + clock-names = "ahb", "mmc";
> > > + resets = <&ccu RST_BUS_MMC0>;
> > > + reset-names = "ahb";
> > > + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&mmc0_pins>;
> > > + max-frequency = <150000000>;
> > > + status = "okay";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + vmmc-supply = <®_cldo1>;
> > > + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
> > > + bus-width = <4>;
> > > + };
> > > +
> > > + mmc1: mmc@4021000 {
> > > + compatible = "allwinner,sun50i-h6-mmc",
> > > + "allwinner,sun50i-a64-mmc";
> > > + reg = <0x04021000 0x1000>;
> > > + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
> > > + clock-names = "ahb", "mmc";
> > > + resets = <&ccu RST_BUS_MMC1>;
> > > + reset-names = "ahb";
> > > + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&mmc1_pins>;
> > > + max-frequency = <150000000>;
> > > + status = "okay";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + vmmc-supply = <®_vcc33_wifi>;
> > > + vqmmc-supply = <®_vcc_wifi_io>;
> > > + mmc-pwrseq = <&wifi_pwrseq>;
> > > + bus-width = <4>;
> > > + non-removable;
> > > +
> > > + brcm: sdio-wifi@1 {
> > > + reg = <1>;
> > > + compatible = "brcm,bcm4329-fmac";
> > > + interrupt-parent = <&r_pio>;
> > > + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
> > > + interrupt-names = "host-wake";
> > > + };
> > > + };
> > > +
> > > + mmc2: mmc@4022000 {
> > > + compatible = "allwinner,sun50i-h6-emmc";
> > > + reg = <0x04022000 0x1000>;
> > > + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
> > > + clock-names = "ahb", "mmc";
> > > + resets = <&ccu RST_BUS_MMC2>;
> > > + reset-names = "ahb";
> > > + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&mmc2_pins>;
> > > + max-frequency = <150000000>;
> > > + status = "okay";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + vmmc-supply = <®_cldo1>;
> > > + vqmmc-supply = <®_bldo2>;
> > > + cap-mmc-hw-reset;
> > > + non-removable;
> > > + bus-width = <8>;
> > > + };
> > > +
> > > + uart0: serial@5000000 {
> > > + compatible = "snps,dw-apb-uart";
> > > + reg = <0x05000000 0x400>;
> > > + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
> > > + reg-shift = <2>;
> > > + reg-io-width = <4>;
> > > + clocks = <&ccu CLK_BUS_UART0>;
> > > + resets = <&ccu RST_BUS_UART0>;
> > > + status = "okay";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&uart0_ph_pins>;
> > > + };
> > > +
> > > + uart1: serial@5000400 {
> > > + compatible = "snps,dw-apb-uart";
> > > + reg = <0x05000400 0x400>;
> > > + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
> > > + reg-shift = <2>;
> > > + reg-io-width = <4>;
> > > + clocks = <&ccu CLK_BUS_UART1>;
> > > + resets = <&ccu RST_BUS_UART1>;
> > > + status = "okay";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
> > > + uart-has-rtscts;
> > > +
> > > + bluetooth {
> > > + compatible = "brcm,bcm4345c5";
> > > + clocks = <&rtc 1>;
> > > + clock-names = "lpo";
> > > + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
> > > + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
> > > + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
> > > + max-speed = <1500000>;
> > > + };
> > > + };
> > > +
> > > + uart2: serial@5000800 {
> > > + compatible = "snps,dw-apb-uart";
> > > + reg = <0x05000800 0x400>;
> > > + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
> > > + reg-shift = <2>;
> > > + reg-io-width = <4>;
> > > + clocks = <&ccu CLK_BUS_UART2>;
> > > + resets = <&ccu RST_BUS_UART2>;
> > > + status = "disabled";
> > > + };
> > > +
> > > + uart3: serial@5000c00 {
> > > + compatible = "snps,dw-apb-uart";
> > > + reg = <0x05000c00 0x400>;
> > > + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
> > > + reg-shift = <2>;
> > > + reg-io-width = <4>;
> > > + clocks = <&ccu CLK_BUS_UART3>;
> > > + resets = <&ccu RST_BUS_UART3>;
> > > + status = "disabled";
> > > + };
> > > +
> > > + i2c0: i2c@5002000 {
> > > + compatible = "allwinner,sun50i-h6-i2c",
> > > + "allwinner,sun6i-a31-i2c";
> > > + reg = <0x05002000 0x400>;
> > > + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2C0>;
> > > + resets = <&ccu RST_BUS_I2C0>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&i2c0_pins>;
> > > + status = "disabled";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > +
> > > + i2c1: i2c@5002400 {
> > > + compatible = "allwinner,sun50i-h6-i2c",
> > > + "allwinner,sun6i-a31-i2c";
> > > + reg = <0x05002400 0x400>;
> > > + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2C1>;
> > > + resets = <&ccu RST_BUS_I2C1>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&i2c1_pins>;
> > > + status = "disabled";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > +
> > > + i2c2: i2c@5002800 {
> > > + compatible = "allwinner,sun50i-h6-i2c",
> > > + "allwinner,sun6i-a31-i2c";
> > > + reg = <0x05002800 0x400>;
> > > + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2C2>;
> > > + resets = <&ccu RST_BUS_I2C2>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&i2c2_pins>;
> > > + status = "disabled";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > +
> > > + i2c3: i2c@5002c00 {
> > > + compatible = "allwinner,sun50i-h6-i2c",
> > > + "allwinner,sun6i-a31-i2c";
> > > + reg = <0x05002c00 0x400>;
> > > + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2C3>;
> > > + resets = <&ccu RST_BUS_I2C3>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&i2c3_pins>;
> > > + clock-frequency = <100000>;
> > > + status = "okay"; /* нужно для ac200 */
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + ac200: mfd@10 {
> > > + compatible = "x-powers,ac200";
> > > + reg = <0x10>;
> > > + clocks = <&ac200_pwm_clk>;
> > > + interrupt-parent = <&pio>;
> > > + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
> > > + interrupt-controller;
> > > + #interrupt-cells = <1>;
> > > + nvmem-cells = <&ac200_bg>;
> > > + nvmem-cell-names = "bandgap";
> > > +
> > > + ac200_ephy_ctl: syscon {
> > > + compatible = "x-powers,ac200-ephy-ctl";
> > > + nvmem-cells = <&ephy_calib>;
> > > + nvmem-cell-names = "calibration";
> > > + #clock-cells = <0>;
> > > + #reset-cells = <0>;
> > > + phy-mode = "rmii";
> > > + status = "okay";
> > > + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
> > > + phy-address = <1>;
> > > + };
> > > +
> > > + ac200_codec: codec {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "x-powers,ac200-codec";
> > > + status = "okay";
> > > + avcc-supply = <®_aldo2>;
> > > + };
> > > + };
> > > + };
> > > +
> > > + spi1: spi@5011000 {
> > > + compatible = "allwinner,sun50i-h6-spi",
> > > + "allwinner,sun8i-h3-spi";
> > > + reg = <0x05011000 0x1000>;
> > > + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
> > > + clock-names = "ahb", "mod";
> > > + dmas = <&dma 23>, <&dma 23>;
> > > + dma-names = "rx", "tx";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
> > > + resets = <&ccu RST_BUS_SPI1>;
> > > + status = "disabled";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > +
> > > + emac: ethernet@5020000 {
> > > + compatible = "allwinner,sun50i-h6-emac",
> > > + "allwinner,sun50i-a64-emac";
> > > + syscon = <&syscon>;
> > > + reg = <0x05020000 0x10000>;
> > > + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "macirq";
> > > + resets = <&ccu RST_BUS_EMAC>;
> > > + reset-names = "stmmaceth";
> > > + clocks = <&ccu CLK_BUS_EMAC>;
> > > + clock-names = "stmmaceth";
> > > + status = "okay";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&ext_rmii_pins>;
> > > + phy-mode = "rmii";
> > > + phy-handle = <&ext_rmii_phy>;
> > > +
> > > + mdio: mdio {
> > > + compatible = "snps,dwmac-mdio";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + ext_rmii_phy: ethernet-phy@1 {
> > > + compatible = "ethernet-phy-id0044.1400",
> > > + "ethernet-phy-ieee802.3-c22";
> > > + reg = <1>;
> > > + resets = <&ac200_ephy_ctl>;
> > > + reset-names = "phy";
> > > + clocks = <&ac200_ephy_ctl>;
> > > + };
> > > + };
> > > + };
> > > +
> > > + i2s3: i2s@508f000 {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "allwinner,sun50i-h6-i2s";
> > > + reg = <0x0508f000 0x1000>;
> > > + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
> > > + clock-names = "apb", "mod";
> > > + dmas = <&dma 6>, <&dma 6>;
> > > + resets = <&ccu RST_BUS_I2S3>;
> > > + dma-names = "rx", "tx";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&i2s3_pins>;
> > > + status = "okay";
> > > + };
> > > +
> > > + i2s2: i2s@5092000 {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "allwinner,sun50i-h6-i2s";
> > > + reg = <0x05092000 0x1000>;
> > > + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
> > > + clock-names = "apb", "mod";
> > > + dmas = <&dma 5>, <&dma 5>;
> > > + resets = <&ccu RST_BUS_I2S2>;
> > > + dma-names = "rx", "tx";
> > > + status = "disabled";
> > > + };
> > > +
> > > + i2s1: i2s@5091000 {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "allwinner,sun50i-h6-i2s";
> > > + reg = <0x05091000 0x1000>;
> > > + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
> > > + clock-names = "apb", "mod";
> > > + dmas = <&dma 4>, <&dma 4>;
> > > + resets = <&ccu RST_BUS_I2S1>;
> > > + dma-names = "rx", "tx";
> > > + status = "okay";
> > > + };
> > > +
> > > + spdif: spdif@5093000 {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "allwinner,sun50i-h6-spdif";
> > > + reg = <0x05093000 0x400>;
> > > + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
> > > + clock-names = "apb", "spdif";
> > > + resets = <&ccu RST_BUS_SPDIF>;
> > > + dmas = <&dma 2>, <&dma 2>;
> > > + dma-names = "rx", "tx";
> > > + status = "disabled";
> > > + };
> > > +
> > > + usb2otg: usb@5100000 {
> > > + compatible = "allwinner,sun50i-h6-musb",
> > > + "allwinner,sun8i-a33-musb";
> > > + reg = <0x05100000 0x0400>;
> > > + clocks = <&ccu CLK_BUS_OTG>;
> > > + resets = <&ccu RST_BUS_OTG>;
> > > + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "mc";
> > > + phys = <&usb2phy 0>;
> > > + phy-names = "usb";
> > > + extcon = <&usb2phy 0>;
> > > + status = "okay";
> > > + dr_mode = "host";
> > > + };
> > > +
> > > + usb2phy: phy@5100400 {
> > > + compatible = "allwinner,sun50i-h6-usb-phy";
> > > + reg = <0x05100400 0x24>,
> > > + <0x05101800 0x4>,
> > > + <0x05311800 0x4>;
> > > + reg-names = "phy_ctrl",
> > > + "pmu0",
> > > + "pmu3";
> > > + clocks = <&ccu CLK_USB_PHY0>,
> > > + <&ccu CLK_USB_PHY3>;
> > > + clock-names = "usb0_phy",
> > > + "usb3_phy";
> > > + resets = <&ccu RST_USB_PHY0>,
> > > + <&ccu RST_USB_PHY3>;
> > > + reset-names = "usb0_reset",
> > > + "usb3_reset";
> > > + status = "okay";
> > > + #phy-cells = <1>;
> > > + };
> > > +
> > > + ehci0: usb@5101000 {
> > > + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> > > + reg = <0x05101000 0x100>;
> > > + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_OHCI0>,
> > > + <&ccu CLK_BUS_EHCI0>,
> > > + <&ccu CLK_USB_OHCI0>;
> > > + resets = <&ccu RST_BUS_OHCI0>,
> > > + <&ccu RST_BUS_EHCI0>;
> > > + phys = <&usb2phy 0>;
> > > + phy-names = "usb";
> > > + status = "okay";
> > > + };
> > > +
> > > + ohci0: usb@5101400 {
> > > + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> > > + reg = <0x05101400 0x100>;
> > > + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_OHCI0>,
> > > + <&ccu CLK_USB_OHCI0>;
> > > + resets = <&ccu RST_BUS_OHCI0>;
> > > + phys = <&usb2phy 0>;
> > > + phy-names = "usb";
> > > + status = "okay";
> > > + };
> > > +
> > > + dwc3: usb@5200000 {
> > > + compatible = "snps,dwc3";
> > > + reg = <0x05200000 0x10000>;
> > > + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_XHCI>,
> > > + <&ccu CLK_BUS_XHCI>,
> > > + <&rtc CLK_OSC32K>;
> > > + clock-names = "ref", "bus_early", "suspend";
> > > + resets = <&ccu RST_BUS_XHCI>;
> > > + /*
> > > + * The datasheet of the chip doesn't declare the
> > > + * peripheral function, and there's no boards known
> > > + * to have a USB Type-B port routed to the port.
> > > + * In addition, no one has tested the peripheral
> > > + * function yet.
> > > + * So set the dr_mode to "host" in the DTSI file.
> > > + */
> > > + dr_mode = "host";
> > > + phys = <&usb3phy>;
> > > + phy-names = "usb3-phy";
> > > + status = "okay";
> > > + };
> > > +
> > > + usb3phy: phy@5210000 {
> > > + compatible = "allwinner,sun50i-h6-usb3-phy";
> > > + reg = <0x5210000 0x10000>;
> > > + clocks = <&ccu CLK_USB_PHY1>;
> > > + resets = <&ccu RST_USB_PHY1>;
> > > + #phy-cells = <0>;
> > > + status = "okay";
> > > + };
> > > +
> > > + ehci3: usb@5311000 {
> > > + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> > > + reg = <0x05311000 0x100>;
> > > + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_OHCI3>,
> > > + <&ccu CLK_BUS_EHCI3>,
> > > + <&ccu CLK_USB_OHCI3>;
> > > + resets = <&ccu RST_BUS_OHCI3>,
> > > + <&ccu RST_BUS_EHCI3>;
> > > + phys = <&usb2phy 3>;
> > > + phy-names = "usb";
> > > + status = "okay";
> > > + };
> > > +
> > > + ohci3: usb@5311400 {
> > > + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> > > + reg = <0x05311400 0x100>;
> > > + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_OHCI3>,
> > > + <&ccu CLK_USB_OHCI3>;
> > > + resets = <&ccu RST_BUS_OHCI3>;
> > > + phys = <&usb2phy 3>;
> > > + phy-names = "usb";
> > > + status = "okay";
> > > + };
> > > +
> > > + pcie: pcie@5400000 {
> > > + #address-cells = <3>;
> > > + #size-cells = <2>;
> > > + compatible = "pine64,allwinner-h6-pcie-wrapped";
> > > + reg = <0x05400000 0x4000>,
> > > + <0x05410000 0x10000>;
> > > + reg-names = "dbi", "config";
> > > + device_type = "pci";
> > > + bus-range = <0x00 0xff>;
> > > + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
> > > + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
> > > + num-lanes = <1>;
> > > + max-link-speed = <2>;
> > > + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
> > > + interrupt-names = "msi", "linkup";
> > > + clocks = <&ccu CLK_PCIE_REF_OUT>,
> > > + <&ccu CLK_PCIE_MAXI>,
> > > + <&ccu CLK_PCIE_AUX>,
> > > + <&ccu CLK_BUS_PCIE>;
> > > + clock-names = "ref", "axi", "aux", "bus";
> > > + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
> > > + reset-names = "power", "bus";
> > > + #interrupt-cells = <1>;
> > > + interrupt-map-mask = <0 0 0 0>;
> > > + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
> > > + status = "okay";
> > > + vcc-supply = <®_bldo2>;
> > > + vdd-supply = <®_dcdcd>;
> > > + slot-supply = <®_vcc33_wifi>;
> > > + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
> > > + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
> > > + /* wake-gpio = <&r_pio 0 4 0>; */
> > > + };
> > > +
> > > +
> > > + hdmi: hdmi@6000000 {
> > > + #sound-dai-cells = <0>;
> > > + compatible = "allwinner,sun50i-h6-dw-hdmi";
> > > + reg = <0x06000000 0x10000>;
> > > + reg-io-width = <1>;
> > > + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
> > > + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
> > > + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
> > > + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
> > > + "hdcp-bus";
> > > + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
> > > + reset-names = "ctrl", "hdcp";
> > > + phys = <&hdmi_phy>;
> > > + phy-names = "phy";
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&hdmi_pins>;
> > > + status = "okay";
> > > +
> > > + ports {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + hdmi_in: port@0 {
> > > + reg = <0>;
> > > +
> > > + hdmi_in_tcon_top: endpoint {
> > > + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
> > > + };
> > > + };
> > > +
> > > + hdmi_out: port@1 {
> > > + reg = <1>;
> > > +
> > > + hdmi_out_con: endpoint {
> > > + remote-endpoint = <&hdmi_con_in>;
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > + hdmi_phy: hdmi-phy@6010000 {
> > > + compatible = "allwinner,sun50i-h6-hdmi-phy";
> > > + reg = <0x06010000 0x10000>;
> > > + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
> > > + clock-names = "bus", "mod";
> > > + resets = <&ccu RST_BUS_HDMI>;
> > > + reset-names = "phy";
> > > + #phy-cells = <0>;
> > > + };
> > > +
> > > + tcon_top: tcon-top@6510000 {
> > > + compatible = "allwinner,sun50i-h6-tcon-top";
> > > + reg = <0x06510000 0x1000>;
> > > + clocks = <&ccu CLK_BUS_TCON_TOP>,
> > > + <&ccu CLK_TCON_TV0>;
> > > + clock-names = "bus",
> > > + "tcon-tv0";
> > > + clock-output-names = "tcon-top-tv0";
> > > + resets = <&ccu RST_BUS_TCON_TOP>;
> > > + #clock-cells = <1>;
> > > +
> > > + ports {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + tcon_top_mixer0_in: port@0 {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + reg = <0>;
> > > +
> > > + tcon_top_mixer0_in_mixer0: endpoint@0 {
> > > + reg = <0>;
> > > + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
> > > + };
> > > + };
> > > +
> > > + tcon_top_mixer0_out: port@1 {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + reg = <1>;
> > > +
> > > + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
> > > + reg = <2>;
> > > + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
> > > + };
> > > + };
> > > +
> > > + tcon_top_hdmi_in: port@4 {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + reg = <4>;
> > > +
> > > + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
> > > + reg = <0>;
> > > + remote-endpoint = <&tcon_tv_out_tcon_top>;
> > > + };
> > > + };
> > > +
> > > + tcon_top_hdmi_out: port@5 {
> > > + reg = <5>;
> > > +
> > > + tcon_top_hdmi_out_hdmi: endpoint {
> > > + remote-endpoint = <&hdmi_in_tcon_top>;
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > + tcon_tv: lcd-controller@6515000 {
> > > + compatible = "allwinner,sun50i-h6-tcon-tv",
> > > + "allwinner,sun8i-r40-tcon-tv";
> > > + reg = <0x06515000 0x1000>;
> > > + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_TCON_TV0>,
> > > + <&tcon_top CLK_TCON_TOP_TV0>;
> > > + clock-names = "ahb",
> > > + "tcon-ch1";
> > > + resets = <&ccu RST_BUS_TCON_TV0>;
> > > + reset-names = "lcd";
> > > +
> > > + ports {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + tcon_tv_in: port@0 {
> > > + reg = <0>;
> > > +
> > > + tcon_tv_in_tcon_top_mixer0: endpoint {
> > > + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
> > > + };
> > > + };
> > > +
> > > + tcon_tv_out: port@1 {
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + reg = <1>;
> > > +
> > > + tcon_tv_out_tcon_top: endpoint@1 {
> > > + reg = <1>;
> > > + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > + r_uart: serial@7080000 {
> > > + compatible = "snps,dw-apb-uart";
> > > + reg = <0x07080000 0x400>;
> > > + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
> > > + reg-shift = <2>;
> > > + reg-io-width = <4>;
> > > + clocks = <&r_ccu CLK_R_APB2_UART>;
> > > + resets = <&r_ccu RST_R_APB2_UART>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&r_uart_pins>;
> > > + status = "disabled";
> > > + };
> > > +
> > > + rtc: rtc@7000000 {
> > > + compatible = "allwinner,sun50i-h6-rtc";
> > > + reg = <0x07000000 0x400>;
> > > + interrupt-parent = <&r_intc>;
> > > + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
> > > + clock-output-names = "osc32k", "osc32k-out", "iosc";
> > > + #clock-cells = <1>;
> > > + clocks = <&ext_osc32k>;
> > > + };
> > > +
> > > + r_ccu: clock@7010000 {
> > > + compatible = "allwinner,sun50i-h6-r-ccu";
> > > + reg = <0x07010000 0x400>;
> > > + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
> > > + <&ccu CLK_PLL_PERIPH0>;
> > > + clock-names = "hosc", "losc", "iosc", "pll-periph";
> > > + protected-clocks = <CLK_R_APB1_TWD>;
> > > + #clock-cells = <1>;
> > > + #reset-cells = <1>;
> > > + };
> > > +
> > > + r_watchdog: watchdog@7020400 {
> > > + compatible = "allwinner,sun50i-h6-wdt",
> > > + "allwinner,sun6i-a31-wdt";
> > > + reg = <0x07020400 0x20>;
> > > + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&osc24M>;
> > > + };
> > > +
> > > + r_intc: interrupt-controller@7021000 {
> > > + compatible = "allwinner,sun50i-h6-r-intc";
> > > + interrupt-controller;
> > > + #interrupt-cells = <3>;
> > > + reg = <0x07021000 0x400>;
> > > + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
> > > + };
> > > +
> > > + r_pwm: pwm@7020C00 {
> > > + compatible = "allwinner,sun50i-h6-pwm";
> > > + reg = <0x07020C00 0x400>;
> > > + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
> > > + clock-names = "mod", "bus";
> > > + resets = <&ccu RST_R_APB1_PWM>;
> > > + #pwm-cells = <3>;
> > > + status = "disabled";
> > > + };
> > > +
> > > + r_pio: pinctrl@7022000 {
> > > + compatible = "allwinner,sun50i-h6-r-pinctrl";
> > > + reg = <0x07022000 0x400>;
> > > + interrupt-parent = <&r_intc>;
> > > + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
> > > + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
> > > + <&rtc CLK_OSC32K>;
> > > + clock-names = "apb", "hosc", "losc";
> > > + gpio-controller;
> > > + #gpio-cells = <3>;
> > > + interrupt-controller;
> > > + #interrupt-cells = <3>;
> > > +
> > > + r_i2c_pins: r-i2c-pins {
> > > + pins = "PL0", "PL1";
> > > + function = "s_i2c";
> > > + };
> > > +
> > > + r_ir_rx_pin: r-ir-rx-pin {
> > > + pins = "PL9";
> > > + function = "s_cir_rx";
> > > + };
> > > +
> > > + r_rsb_pins: r-rsb-pins {
> > > + pins = "PL0", "PL1";
> > > + function = "s_rsb";
> > > + };
> > > +
> > > + r_uart_pins: r-uart-pins {
> > > + pins = "PL2", "PL3";
> > > + function = "s_uart";
> > > + };
> > > +
> > > + r_pwm_pin: r-pwm-pin {
> > > + pins = "PL8";
> > > + function = "s_pwm";
> > > + };
> > > +
> > > + };
> > > +
> > > + r_ir: ir@7040000 {
> > > + compatible = "allwinner,sun50i-h6-ir",
> > > + "allwinner,sun6i-a31-ir";
> > > + reg = <0x07040000 0x400>;
> > > + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&r_ccu CLK_R_APB1_IR>,
> > > + <&r_ccu CLK_IR>;
> > > + clock-names = "apb", "ir";
> > > + resets = <&r_ccu RST_R_APB1_IR>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&r_ir_rx_pin>;
> > > + status = "disabled";
> > > + };
> > > +
> > > + r_i2c: i2c@7081400 {
> > > + compatible = "allwinner,sun50i-h6-i2c",
> > > + "allwinner,sun6i-a31-i2c";
> > > + reg = <0x07081400 0x400>;
> > > + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&r_ccu CLK_R_APB2_I2C>;
> > > + resets = <&r_ccu RST_R_APB2_I2C>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&r_i2c_pins>;
> > > + status = "okay";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > +
> > > + axp805: pmic@36 {
> > > + compatible = "x-powers,axp805", "x-powers,axp806";
> > > + reg = <0x36>;
> > > + interrupt-parent = <&r_intc>;
> > > + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
> > > + interrupt-controller;
> > > + #interrupt-cells = <1>;
> > > + x-powers,self-working-mode;
> > > + vina-supply = <®_vcc5v>;
> > > + vinb-supply = <®_vcc5v>;
> > > + vinc-supply = <®_vcc5v>;
> > > + vind-supply = <®_vcc5v>;
> > > + vine-supply = <®_vcc5v>;
> > > + aldoin-supply = <®_vcc5v>;
> > > + bldoin-supply = <®_vcc5v>;
> > > + cldoin-supply = <®_vcc5v>;
> > > +
> > > + regulators {
> > > + reg_aldo1: aldo1 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc-pl-led-ir";
> > > + };
> > > +
> > > + reg_aldo2: aldo2 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc33-audio-tv-ephy-mac";
> > > + regulator-enable-ramp-delay = <100000>;
> > > + };
> > > +
> > > + reg_aldo3: aldo3 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
> > > + };
> > > +
> > > + reg_bldo1: bldo1 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <1800000>;
> > > + regulator-max-microvolt = <1800000>;
> > > + regulator-name = "vcc18-dram-bias-pll";
> > > + };
> > > +
> > > + reg_bldo2: bldo2 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <1800000>;
> > > + regulator-max-microvolt = <1800000>;
> > > + regulator-name = "vcc-efuse-pcie-hdmi-pc";
> > > + };
> > > +
> > > + reg_bldo3: bldo3 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <1800000>;
> > > + regulator-max-microvolt = <1800000>;
> > > + regulator-name = "vcc-dcxoio";
> > > + };
> > > +
> > > + reg_bldo4: bldo4 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <1800000>;
> > > + regulator-max-microvolt = <1800000>;
> > > + regulator-name = "vcc-dcxoio";
> > > + };
> > > +
> > > + reg_cldo1: cldo1 {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
> > > + };
> > > +
> > > + reg_cldo2: cldo2 {
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc-wifi-1";
> > > + };
> > > +
> > > + reg_cldo3: cldo3 {
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-name = "vcc-wifi-2";
> > > + };
> > > +
> > > + reg_dcdca: dcdca {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <810000>;
> > > + regulator-max-microvolt = <1200000>;
> > > + regulator-ramp-delay = <2500>;
> > > + regulator-name = "vdd-cpu";
> > > + };
> > > +
> > > + reg_dcdcc: dcdcc {
> > > + regulator-enable-ramp-delay = <32000>;
> > > + regulator-min-microvolt = <810000>;
> > > + regulator-max-microvolt = <1080000>;
> > > + regulator-ramp-delay = <2500>;
> > > + regulator-name = "vdd-gpu";
> > > + };
> > > +
> > > + reg_dcdcd: dcdcd {
> > > + regulator-always-on;
> > > + regulator-min-microvolt = <1000000>;
> > > + regulator-max-microvolt = <1000000>;
> > > + regulator-name = "vdd-sys";
> > > + };
> > > +
> > > + sw {
> > > + /* unused */
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > + r_rsb: rsb@7083000 {
> > > + compatible = "allwinner,sun8i-a23-rsb";
> > > + reg = <0x07083000 0x400>;
> > > + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&r_ccu CLK_R_APB2_RSB>;
> > > + clock-frequency = <3000000>;
> > > + resets = <&r_ccu RST_R_APB2_RSB>;
> > > + pinctrl-names = "default";
> > > + pinctrl-0 = <&r_rsb_pins>;
> > > + status = "disabled";
> > > + #address-cells = <1>;
> > > + #size-cells = <0>;
> > > + };
> > > +
> > > + ths: thermal-sensor@5070400 {
> > > + compatible = "allwinner,sun50i-h6-ths";
> > > + reg = <0x05070400 0x100>;
> > > + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
> > > + clocks = <&ccu CLK_BUS_THS>;
> > > + clock-names = "bus";
> > > + resets = <&ccu RST_BUS_THS>;
> > > + nvmem-cells = <&ths_calibration>;
> > > + nvmem-cell-names = "calibration";
> > > + #thermal-sensor-cells = <1>;
> > > + };
> > > +
> > > + sunxi-info {
> > > + compatible = "allwinner,sun50i-h6-sys-info";
> > > + status = "okay";
> > > + };
> > > +
> > > + addr_mgt: addr-mgt {
> > > + compatible = "allwinner,sunxi-addr_mgt";
> > > + type_addr_wifi = <0x2>;
> > > + type_addr_bt = <0x2>;
> > > + type_addr_eth = <0x2>;
> > > + status = "okay";
> > > + };
> > > +
> > > + dump_reg: dump_reg@20000 {
> > > + compatible = "allwinner,sunxi-dump-reg";
> > > + reg = <0x0 0x03001000 0x0 0x0f20>;
> > > + status = "okay";
> > > + };
> > > + };
> > > +
> > > + thermal-zones {
> > > + cpu-thermal {
> > > + polling-delay-passive = <250>;
> > > + polling-delay = <1000>;
> > > + thermal-sensors = <&ths 0>;
> > > +
> > > + trips {
> > > + cpu_warm: cpu_warm {
> > > + temperature = <70000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_hot0: cpu_hot0 {
> > > + temperature = <74000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_hot1: cpu_hot1 {
> > > + temperature = <76000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot0: cpu_very_hot0 {
> > > + temperature = <78000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot1: cpu_very_hot1 {
> > > + temperature = <80000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot2: cpu_very_hot2 {
> > > + temperature = <82000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot3: cpu_very_hot3 {
> > > + temperature = <84000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot4: cpu_very_hot4 {
> > > + temperature = <86000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot5: cpu_very_hot5 {
> > > + temperature = <88000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_very_hot6: cpu_very_hot6 {
> > > + temperature = <90000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + cpu_crit: cpu_crit {
> > > + temperature = <97000>;
> > > + hysteresis = <2000>;
> > > + type = "critical";
> > > + };
> > > + };
> > > +
> > > + cooling-maps {
> > > + cpu_warm_limit_cpu {
> > > + trip = <&cpu_warm>;
> > > + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
> > > + };
> > > + };
> > > + };
> > > +
> > > + gpu-thermal {
> > > + polling-delay-passive = <1000>;
> > > + polling-delay = <2000>;
> > > + thermal-sensors = <&ths 1>;
> > > +
> > > + trips {
> > > + gpu_alert0: gpu-alert-0 {
> > > + temperature = <95000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + gpu_alert1: gpu-alert-1 {
> > > + temperature = <100000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + gpu_alert2: gpu-alert-2 {
> > > + temperature = <105000>;
> > > + hysteresis = <2000>;
> > > + type = "passive";
> > > + };
> > > +
> > > + gpu-crit {
> > > + temperature = <115000>;
> > > + hysteresis = <0>;
> > > + type = "critical";
> > > + };
> > > + };
> > > +
> > > + cooling-maps {
> > > + // Forbid the GPU to go over 756MHz
> > > + map0 {
> > > + trip = <&gpu_alert0>;
> > > + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
> > > + };
> > > +
> > > + // Forbid the GPU to go over 624MHz
> > > + map1 {
> > > + trip = <&gpu_alert1>;
> > > + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
> > > + };
> > > +
> > > + // Forbid the GPU to go over 576MHz
> > > + map2 {
> > > + trip = <&gpu_alert2>;
> > > + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
> > > + };
> > > + };
> > > + };
> > > + };
> > > +
> > > + cpu_opp_table: cpu-opp-table {
> > > + compatible = "allwinner,sun50i-h6-operating-points";
> > > + nvmem-cells = <&cpu_speed_grade>;
> > > + opp-shared;
> > > +
> > > + opp-480000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <480000000>;
> > > +
> > > + opp-microvolt-speed0 = <880000>;
> > > + };
> > > +
> > > + opp-720000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <720000000>;
> > > +
> > > + opp-microvolt-speed0 = <880000>;
> > > + };
> > > +
> > > + opp-888000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <888000000>;
> > > +
> > > + opp-microvolt-speed0 = <880000>;
> > > + };
> > > +
> > > + opp-1080000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1080000000>;
> > > +
> > > + opp-microvolt-speed0 = <940000>;
> > > + };
> > > +
> > > + opp-1320000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1320000000>;
> > > +
> > > + opp-microvolt-speed0 = <1000000>;
> > > + };
> > > +
> > > + opp-1488000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1488000000>;
> > > +
> > > + opp-microvolt-speed0 = <1060000>;
> > > + };
> > > +
> > > + opp-1608000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1608000000>;
> > > +
> > > + opp-microvolt-speed0 = <1090000>;
> > > + };
> > > +
> > > + opp-1704000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1704000000>;
> > > +
> > > + opp-microvolt-speed0 = <1120000>;
> > > + };
> > > +
> > > + opp-1800000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1800000000>;
> > > +
> > > + opp-microvolt-speed0 = <1160000>;
> > > + };
> > > +
> > > + opp@1896000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1896000000>;
> > > +
> > > + opp-microvolt-speed0 = <1180000>;
> > > + };
> > > +
> > > + opp@1968000000 {
> > > + clock-latency-ns = <244144>; /* 8 32k periods */
> > > + opp-hz = /bits/ 64 <1968000000>;
> > > +
> > > + opp-microvolt-speed0 = <1200000>;
> > > + };
> > > +
> > > + };
> > > +
> > > + gpu_opp_table: opp-table-gpu {
> > > + compatible = "operating-points-v2";
> > > +
> > > + opp-216000000 {
> > > + opp-hz = /bits/ 64 <216000000>;
> > > + opp-microvolt = <810000 810000 1200000>;
> > > + };
> > > +
> > > + opp-264000000 {
> > > + opp-hz = /bits/ 64 <264000000>;
> > > + opp-microvolt = <810000 810000 1200000>;
> > > + };
> > > +
> > > + opp-312000000 {
> > > + opp-hz = /bits/ 64 <312000000>;
> > > + opp-microvolt = <810000 810000 1200000>;
> > > + };
> > > +
> > > + opp-336000000 {
> > > + opp-hz = /bits/ 64 <336000000>;
> > > + opp-microvolt = <810000 810000 1200000>;
> > > + };
> > > +
> > > + opp-360000000 {
> > > + opp-hz = /bits/ 64 <360000000>;
> > > + opp-microvolt = <820000 820000 1200000>;
> > > + };
> > > +
> > > + opp-384000000 {
> > > + opp-hz = /bits/ 64 <384000000>;
> > > + opp-microvolt = <830000 830000 1200000>;
> > > + };
> > > +
> > > + opp-408000000 {
> > > + opp-hz = /bits/ 64 <408000000>;
> > > + opp-microvolt = <840000 840000 1200000>;
> > > + };
> > > +
> > > + opp-420000000 {
> > > + opp-hz = /bits/ 64 <420000000>;
> > > + opp-microvolt = <850000 850000 1200000>;
> > > + };
> > > +
> > > + opp-432000000 {
> > > + opp-hz = /bits/ 64 <432000000>;
> > > + opp-microvolt = <860000 860000 1200000>;
> > > + };
> > > +
> > > + opp-456000000 {
> > > + opp-hz = /bits/ 64 <456000000>;
> > > + opp-microvolt = <870000 870000 1200000>;
> > > + };
> > > +
> > > + opp-504000000 {
> > > + opp-hz = /bits/ 64 <504000000>;
> > > + opp-microvolt = <890000 890000 1200000>;
> > > + };
> > > +
> > > + opp-540000000 {
> > > + opp-hz = /bits/ 64 <540000000>;
> > > + opp-microvolt = <910000 910000 1200000>;
> > > + };
> > > +
> > > + opp-576000000 {
> > > + opp-hz = /bits/ 64 <576000000>;
> > > + opp-microvolt = <930000 930000 1200000>;
> > > + };
> > > +
> > > + opp-624000000 {
> > > + opp-hz = /bits/ 64 <624000000>;
> > > + opp-microvolt = <950000 950000 1200000>;
> > > + };
> > > +
> > > + opp-756000000 {
> > > + opp-hz = /bits/ 64 <756000000>;
> > > + opp-microvolt = <1040000 1040000 1200000>;
> > > + };
> > > + };
> > > +
> > > + chosen {
> > > + stdout-path = "serial0:115200n8";
> > > + };
> > > +
> > > + connector {
> > > + compatible = "hdmi-connector";
> > > + type = "a";
> > > +
> > > + port {
> > > + hdmi_con_in: endpoint {
> > > + remote-endpoint = <&hdmi_out_con>;
> > > + };
> > > + };
> > > + };
> > > +
> > > + ext_osc32k: ext_osc32k_clk {
> > > + #clock-cells = <0>;
> > > + compatible = "fixed-clock";
> > > + clock-frequency = <32768>;
> > > + clock-output-names = "ext_osc32k";
> > > + };
> > > +
> > > + leds {
> > > + compatible = "gpio-leds";
> > > +
> > > + led-0 {
> > > + label = "repka:red:power";
> > > + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
> > > + linux,default-trigger = "heartbeat";
> > > + };
> > > + };
> > > +
> > > + reg_vcc5v: vcc5v {
> > > + /* board wide 5V supply directly from the DC jack */
> > > + compatible = "regulator-fixed";
> > > + regulator-name = "vcc-5v";
> > > + regulator-min-microvolt = <5000000>;
> > > + regulator-max-microvolt = <5000000>;
> > > + regulator-always-on;
> > > + };
> > > +
> > > + reg_vcc33_wifi: vcc33-wifi {
> > > + /* Always on 3.3V regulator for WiFi and BT */
> > > + compatible = "regulator-fixed";
> > > + regulator-name = "vcc33-wifi";
> > > + regulator-min-microvolt = <3300000>;
> > > + regulator-max-microvolt = <3300000>;
> > > + regulator-always-on;
> > > + vin-supply = <®_vcc5v>;
> > > + };
> > > +
> > > + reg_vcc_wifi_io: vcc-wifi-io {
> > > + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
> > > + compatible = "regulator-fixed";
> > > + regulator-name = "vcc-wifi-io";
> > > + regulator-min-microvolt = <1800000>;
> > > + regulator-max-microvolt = <1800000>;
> > > + regulator-always-on;
> > > + vin-supply = <®_vcc33_wifi>;
> > > + };
> > > +
> > > + wifi_pwrseq: wifi-pwrseq {
> > > + compatible = "mmc-pwrseq-simple";
> > > + clocks = <&rtc 1>;
> > > + clock-names = "ext_clock";
> > > + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
> > > + post-power-on-delay-ms = <200>;
> > > + };
> > > +};
> > > --
> > > 2.42.2
> > >
> > > _______________________________________________
> > > devel-kernel mailing list
> > > devel-kernel@lists.altlinux.org
> > > https://lists.altlinux.org/mailman/listinfo/devel-kernel
> > _______________________________________________
> > devel-kernel mailing list
> > devel-kernel@lists.altlinux.org
> > https://lists.altlinux.org/mailman/listinfo/devel-kernel
>
> --
> Kind Regards!
> from srebrov@altlinux.org
>
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-08 0:54 ` Vitaly Chikunov
@ 2025-05-08 1:10 ` Anton Midyukov
2025-05-08 1:19 ` Vitaly Chikunov
0 siblings, 1 reply; 7+ messages in thread
From: Anton Midyukov @ 2025-05-08 1:10 UTC (permalink / raw)
To: devel-kernel
08.05.2025 03:54, Vitaly Chikunov пишет:
> On Wed, May 07, 2025 at 11:50:53PM +0300, Kurachenko Anton wrote:
>> 1. Я проверял сборку и работоспособность полученного результата на ядре
>> 6.12.25-alt1.
>
> Это хорошо, спасибо.
>
>> 2. Дело в том, что загрузчик u-boot для Repka Pi 4 требует обязательного
>> наличия dtb для запуска. Сейчас нам приходится заниматься скачиванием и
>> распаковкой ядра repka4, затем извлекать нужный dtb и переносить его в
>> /boot/devicetree/$kernelversion/allwinner ядра 6.12, чтобы хотя бы
>> просто начать процесс установки. Патч призван решить эту проблему.
>
> То есть наше 6.12 начнет загружаться на repka pi4 или это для чего-то
> другого нужно?
>
Да. Будет загружаться и работать. Этого будет достаточно, чтобы установить ядро repka pi4.
Это необходимо для того, чтобы не выпускать дополнительные образы с ядром для repka pi4.
>>
>> 07.05.2025 22:39, Vitaly Chikunov пишет:
>>> Anton,
>>>
>>> On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
>>>> From: Anton Kurachenko <srebrov@altlinux.org>
>>>>
>>>> Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
>>>> u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
>>>> a dtb file.
>>>>
>>>> Patch designed specifically for ALT and never used anywhere.
>>>
>>> 1. Это изменение протестировано?
>>> 2. Зачем нужен этот патч, если есть флейворы repka/repka4?
>>>
>>> Thanks,
>>>
>>>>
>>>> The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
>>>> file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
>>>> from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
>>>> Represents the result of merging these files with applying some modifications.
>>>>
>>>> Files that were used during the creation process:
>>>>
>>>> sun50i-h6-repka-pi4-optimal.dts
>>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
>>>>
>>>> sun50i-h6.dtsi
>>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
>>>>
>>>> sun50i-h6-cpu-opp.dtsi
>>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
>>>>
>>>> Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
>>>> ---
>>>> arch/arm64/boot/dts/allwinner/Makefile | 1 +
>>>> .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
>>>> 2 files changed, 1919 insertions(+)
>>>> create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>>>>
>>>> diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
>>>> index 00bed412ee31..2df5189e0d44 100644
>>>> --- a/arch/arm64/boot/dts/allwinner/Makefile
>>>> +++ b/arch/arm64/boot/dts/allwinner/Makefile
>>>> @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
>>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
>>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
>>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
>>>> +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
>>>> diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>>>> new file mode 100644
>>>> index 000000000000..9d95297a30b8
>>>> --- /dev/null
>>>> +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>>>> @@ -0,0 +1,1918 @@
>>>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>>>> +// based on the dts, which is:
>>>> +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
>>>> +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
>>>> +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
>>>> +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
>>>> +
>>>> +/dts-v1/;
>>>> +
>>>> +#include <dt-bindings/interrupt-controller/arm-gic.h>
>>>> +#include <dt-bindings/clock/sun50i-h6-ccu.h>
>>>> +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
>>>> +#include <dt-bindings/clock/sun6i-rtc.h>
>>>> +#include <dt-bindings/clock/sun8i-de2.h>
>>>> +#include <dt-bindings/clock/sun8i-tcon-top.h>
>>>> +#include <dt-bindings/reset/sun50i-h6-ccu.h>
>>>> +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
>>>> +#include <dt-bindings/reset/sun8i-de2.h>
>>>> +#include <dt-bindings/thermal/thermal.h>
>>>> +#include <dt-bindings/gpio/gpio.h>
>>>> +
>>>> +/ {
>>>> + interrupt-parent = <&gic>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + model = "Repka-Pi4-Optimal";
>>>> + repka-freq = "1.968 GHz";
>>>> + repka-pinout = "repka-pi4-base";
>>>> + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
>>>> +
>>>> + aliases {
>>>> + mmc0 = &mmc0;
>>>> + mmc1 = &mmc1;
>>>> + mmc2 = &mmc2;
>>>> + ethernet0 = &emac;
>>>> + serial0 = &uart0;
>>>> + serial1 = &uart1;
>>>> + serial2 = &r_uart;
>>>> +
>>>> + spi0 = &spi1;
>>>> + i2c1 = &i2c0;
>>>> + i2c2 = &i2c2;
>>>> + i2c3 = &i2c1;
>>>> + i2c4 = &i2c3;
>>>> +
>>>> + };
>>>> +
>>>> + reserved-memory {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges;
>>>> +
>>>> + custom_region: region@40010000 {
>>>> + reg = <0x40010000 0x00070000>;
>>>> + no-map;
>>>> + };
>>>> + };
>>>> +
>>>> + analog: analog-codec {
>>>> + compatible = "simple-audio-card";
>>>> + simple-audio-card,format = "i2s";
>>>> + simple-audio-card,name = "ac200-audio";
>>>> + simple-audio-card,mclk-fs = <512>;
>>>> + status = "okay";
>>>> +
>>>> + simple-audio-card,cpu {
>>>> + sound-dai = <&i2s3>;
>>>> + };
>>>> +
>>>> + simple-audio-card,codec {
>>>> + sound-dai = <&ac200_codec>;
>>>> + };
>>>> + };
>>>> +
>>>> + ac200_pwm_clk: ac200_clk {
>>>> + compatible = "pwm-clock";
>>>> + #clock-cells = <0>;
>>>> + clock-frequency = <24000000>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&pwm1_pin>;
>>>> + pwms = <&pwm 1 42 0>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + cpus {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + cpu0: cpu@0 {
>>>> + compatible = "arm,cortex-a53";
>>>> + device_type = "cpu";
>>>> + reg = <0>;
>>>> + enable-method = "psci";
>>>> + clocks = <&ccu CLK_CPUX>;
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + #cooling-cells = <2>;
>>>> + operating-points-v2 = <&cpu_opp_table>;
>>>> + cpu-supply = <®_dcdca>;
>>>> + };
>>>> +
>>>> + cpu1: cpu@1 {
>>>> + compatible = "arm,cortex-a53";
>>>> + device_type = "cpu";
>>>> + reg = <1>;
>>>> + enable-method = "psci";
>>>> + clocks = <&ccu CLK_CPUX>;
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + #cooling-cells = <2>;
>>>> + operating-points-v2 = <&cpu_opp_table>;
>>>> + };
>>>> +
>>>> + cpu2: cpu@2 {
>>>> + compatible = "arm,cortex-a53";
>>>> + device_type = "cpu";
>>>> + reg = <2>;
>>>> + enable-method = "psci";
>>>> + clocks = <&ccu CLK_CPUX>;
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + #cooling-cells = <2>;
>>>> + operating-points-v2 = <&cpu_opp_table>;
>>>> + };
>>>> +
>>>> + cpu3: cpu@3 {
>>>> + compatible = "arm,cortex-a53";
>>>> + device_type = "cpu";
>>>> + reg = <3>;
>>>> + enable-method = "psci";
>>>> + clocks = <&ccu CLK_CPUX>;
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + #cooling-cells = <2>;
>>>> + operating-points-v2 = <&cpu_opp_table>;
>>>> + };
>>>> + };
>>>> +
>>>> + de: display-engine {
>>>> + compatible = "allwinner,sun50i-h6-display-engine";
>>>> + allwinner,pipelines = <&mixer0>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + osc24M: osc24M_clk {
>>>> + #clock-cells = <0>;
>>>> + compatible = "fixed-clock";
>>>> + clock-frequency = <24000000>;
>>>> + clock-output-names = "osc24M";
>>>> + };
>>>> +
>>>> + pmu {
>>>> + compatible = "arm,cortex-a53-pmu";
>>>> + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
>>>> + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
>>>> + };
>>>> +
>>>> + psci {
>>>> + compatible = "arm,psci-0.2";
>>>> + method = "smc";
>>>> + };
>>>> +
>>>> + scpi_protocol: scpi {
>>>> + compatible = "arm,scpi";
>>>> + mboxes = <&msgbox 2>, <&msgbox 3>;
>>>> + mbox-names = "tx", "rx";
>>>> + shmem = <&scpi_sram>;
>>>> + };
>>>> +
>>>> + sound_hdmi: sound_hdmi {
>>>> + compatible = "allwinner,sun9i-a80-hdmi-audio",
>>>> + "allwinner,sun50i-h6-hdmi-audio";
>>>> + status = "okay";
>>>> + codec {
>>>> + sound-dai = <&hdmi>;
>>>> + };
>>>> +
>>>> + cpu {
>>>> + sound-dai = <&i2s1>;
>>>> + };
>>>> + };
>>>> +
>>>> + timer {
>>>> + compatible = "arm,armv8-timer";
>>>> + arm,no-tick-in-suspend;
>>>> + interrupts = <GIC_PPI 13
>>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>>>> + <GIC_PPI 14
>>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>>>> + <GIC_PPI 11
>>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
>>>> + <GIC_PPI 10
>>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
>>>> + };
>>>> +
>>>> +
>>>> + soc {
>>>> + compatible = "simple-bus";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges;
>>>> +
>>>> + bus@1000000 {
>>>> + compatible = "allwinner,sun50i-h6-de3",
>>>> + "allwinner,sun50i-a64-de2";
>>>> + reg = <0x1000000 0x400000>;
>>>> + allwinner,sram = <&de2_sram 1>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges = <0 0x1000000 0x400000>;
>>>> +
>>>> + display_clocks: clock@0 {
>>>> + compatible = "allwinner,sun50i-h6-de3-clk";
>>>> + reg = <0x0 0x10000>;
>>>> + clocks = <&ccu CLK_BUS_DE>,
>>>> + <&ccu CLK_DE>;
>>>> + clock-names = "bus",
>>>> + "mod";
>>>> + resets = <&ccu RST_BUS_DE>;
>>>> + #clock-cells = <1>;
>>>> + #reset-cells = <1>;
>>>> + };
>>>> +
>>>> + mixer0: mixer@100000 {
>>>> + compatible = "allwinner,sun50i-h6-de3-mixer-0";
>>>> + reg = <0x100000 0x100000>;
>>>> + clocks = <&display_clocks CLK_BUS_MIXER0>,
>>>> + <&display_clocks CLK_MIXER0>;
>>>> + clock-names = "bus",
>>>> + "mod";
>>>> + resets = <&display_clocks RST_MIXER0>;
>>>> + iommus = <&iommu 0>;
>>>> +
>>>> + ports {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + mixer0_out: port@1 {
>>>> + reg = <1>;
>>>> +
>>>> + mixer0_out_tcon_top_mixer0: endpoint {
>>>> + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> +
>>>> + video-codec-g2@1c00000 {
>>>> + compatible = "allwinner,sun50i-h6-vpu-g2";
>>>> + reg = <0x01c00000 0x1000>;
>>>> + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
>>>> + clock-names = "bus", "mod";
>>>> + resets = <&ccu RST_BUS_VP9>;
>>>> + iommus = <&iommu 5>;
>>>> + };
>>>> +
>>>> + deinterlace: deinterlace@1420000 {
>>>> + compatible = "allwinner,sun50i-h6-deinterlace";
>>>> + reg = <0x01420000 0x2000>;
>>>> + clocks = <&ccu CLK_BUS_DEINTERLACE>,
>>>> + <&ccu CLK_DEINTERLACE>,
>>>> + <&ccu CLK_MBUS_DEINTERLACE>;
>>>> + clock-names = "bus", "mod", "ram";
>>>> + resets = <&ccu RST_BUS_DEINTERLACE>;
>>>> + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
>>>> + iommus = <&iommu 2>;
>>>> + };
>>>> +
>>>> + video-codec@1c0e000 {
>>>> + compatible = "allwinner,sun50i-h6-video-engine";
>>>> + reg = <0x01c0e000 0x2000>;
>>>> + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
>>>> + <&ccu CLK_MBUS_VE>;
>>>> + clock-names = "ahb", "mod", "ram";
>>>> + resets = <&ccu RST_BUS_VE>;
>>>> + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
>>>> + allwinner,sram = <&ve_sram 1>;
>>>> + iommus = <&iommu 1>, <&iommu 3>;
>>>> + };
>>>> +
>>>> + gpu: gpu@1800000 {
>>>> + compatible = "allwinner,sun50i-h6-mali",
>>>> + "arm,mali-t720";
>>>> + reg = <0x01800000 0x4000>;
>>>> + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
>>>> + interrupt-names = "job", "mmu", "gpu";
>>>> + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
>>>> + clock-names = "core", "bus";
>>>> + resets = <&ccu RST_BUS_GPU>;
>>>> + #cooling-cells = <2>;
>>>> + status = "okay";
>>>> + operating-points-v2 = <&gpu_opp_table>;
>>>> + mali-supply = <®_dcdcc>;
>>>> + };
>>>> +
>>>> + crypto: crypto@1904000 {
>>>> + compatible = "allwinner,sun50i-h6-crypto";
>>>> + reg = <0x01904000 0x1000>;
>>>> + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
>>>> + clock-names = "bus", "mod", "ram";
>>>> + resets = <&ccu RST_BUS_CE>;
>>>> + };
>>>> +
>>>> + syscon: syscon@3000000 {
>>>> + compatible = "allwinner,sun50i-h6-system-control",
>>>> + "allwinner,sun50i-a64-system-control";
>>>> + reg = <0x03000000 0x1000>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges;
>>>> +
>>>> + sram_a2: sram@100000 {
>>>> + compatible = "mmio-sram";
>>>> + reg = <0x00100000 0x18000>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges = <0 0x00100000 0x18000>;
>>>> +
>>>> + scpi_sram: scp-shmem@17c00 {
>>>> + compatible = "arm,scp-shmem";
>>>> + reg = <0x17c00 0x200>;
>>>> + };
>>>> + };
>>>> +
>>>> + sram_c: sram@28000 {
>>>> + compatible = "mmio-sram";
>>>> + reg = <0x00028000 0x1e000>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges = <0 0x00028000 0x1e000>;
>>>> +
>>>> + de2_sram: sram-section@0 {
>>>> + compatible = "allwinner,sun50i-h6-sram-c",
>>>> + "allwinner,sun50i-a64-sram-c";
>>>> + reg = <0x0000 0x1e000>;
>>>> + };
>>>> + };
>>>> +
>>>> + sram_c1: sram@1a00000 {
>>>> + compatible = "mmio-sram";
>>>> + reg = <0x01a00000 0x200000>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> + ranges = <0 0x01a00000 0x200000>;
>>>> +
>>>> + ve_sram: sram-section@0 {
>>>> + compatible = "allwinner,sun50i-h6-sram-c1",
>>>> + "allwinner,sun4i-a10-sram-c1";
>>>> + reg = <0x000000 0x200000>;
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + ccu: clock@3001000 {
>>>> + compatible = "allwinner,sun50i-h6-ccu";
>>>> + reg = <0x03001000 0x1000>;
>>>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
>>>> + clock-names = "hosc", "losc", "iosc";
>>>> + protected-clocks = <CLK_BUS_MSGBOX>;
>>>> + #clock-cells = <1>;
>>>> + #reset-cells = <1>;
>>>> + };
>>>> +
>>>> + dma: dma-controller@3002000 {
>>>> + compatible = "allwinner,sun50i-h6-dma";
>>>> + reg = <0x03002000 0x1000>;
>>>> + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
>>>> + clock-names = "bus", "mbus";
>>>> + dma-channels = <16>;
>>>> + dma-requests = <46>;
>>>> + resets = <&ccu RST_BUS_DMA>;
>>>> + #dma-cells = <1>;
>>>> + };
>>>> +
>>>> + msgbox: mailbox@3003000 {
>>>> + compatible = "allwinner,sun50i-h6-msgbox",
>>>> + "allwinner,sun6i-a31-msgbox";
>>>> + reg = <0x03003000 0x1000>;
>>>> + clocks = <&ccu CLK_BUS_MSGBOX>;
>>>> + resets = <&ccu RST_BUS_MSGBOX>;
>>>> + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
>>>> + #mbox-cells = <1>;
>>>> + };
>>>> +
>>>> + gic: interrupt-controller@3021000 {
>>>> + compatible = "arm,gic-400";
>>>> + reg = <0x03021000 0x1000>,
>>>> + <0x03022000 0x2000>,
>>>> + <0x03024000 0x2000>,
>>>> + <0x03026000 0x2000>;
>>>> + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <3>;
>>>> + };
>>>> +
>>>> + sid: efuse@3006000 {
>>>> + compatible = "allwinner,sun50i-h6-sid";
>>>> + reg = <0x03006000 0x400>;
>>>> + #address-cells = <1>;
>>>> + #size-cells = <1>;
>>>> +
>>>> + ths_calibration: thermal-sensor-calibration@14 {
>>>> + reg = <0x14 0x8>;
>>>> + };
>>>> +
>>>> + cpu_speed_grade: cpu-speed-grade@1c {
>>>> + reg = <0x1c 0x4>;
>>>> + };
>>>> +
>>>> + ephy_calib: ephy_calib@2c {
>>>> + reg = <0x2c 0x2>;
>>>> + };
>>>> +
>>>> + ac200_bg: ac200_bg@30 {
>>>> + reg = <0x30 0x2>;
>>>> + };
>>>> + };
>>>> +
>>>> + timer@3009000 {
>>>> + compatible = "allwinner,sun50i-h6-timer",
>>>> + "allwinner,sun8i-a23-timer";
>>>> + reg = <0x03009000 0xa0>;
>>>> + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&osc24M>;
>>>> + };
>>>> +
>>>> + watchdog: watchdog@30090a0 {
>>>> + compatible = "allwinner,sun50i-h6-wdt",
>>>> + "allwinner,sun6i-a31-wdt";
>>>> + reg = <0x030090a0 0x20>;
>>>> + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&osc24M>;
>>>> + /* Broken on some H6 boards */
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + pwm: pwm@300a000 {
>>>> + compatible = "allwinner,sun50i-h6-pwm";
>>>> + reg = <0x0300a000 0x400>;
>>>> + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
>>>> + clock-names = "mod", "bus";
>>>> + resets = <&ccu RST_BUS_PWM>;
>>>> + #pwm-cells = <3>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + pio: pinctrl@300b000 {
>>>> + compatible = "allwinner,sun50i-h6-pinctrl";
>>>> + reg = <0x0300b000 0x400>;
>>>> + interrupt-parent = <&r_intc>;
>>>> + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
>>>> + clock-names = "apb", "hosc", "losc";
>>>> + gpio-controller;
>>>> + #gpio-cells = <3>;
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <3>;
>>>> + vcc-pc-supply = <®_bldo2>;
>>>> + vcc-pd-supply = <®_cldo1>;
>>>> + vcc-pg-supply = <®_vcc_wifi_io>;
>>>> +
>>>> + /omit-if-no-ref/
>>>> + ext_rgmii_pins: rgmii-pins {
>>>> + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
>>>> + "PD5", "PD7", "PD8", "PD9", "PD10",
>>>> + "PD11", "PD12", "PD13", "PD19", "PD20";
>>>> + function = "emac";
>>>> + drive-strength = <40>;
>>>> + };
>>>> +
>>>> + ext_rmii_pins: rmii_pins {
>>>> + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
>>>> + "PA5", "PA6", "PA7", "PA8", "PA9";
>>>> + function = "emac";
>>>> + drive-strength = <40>;
>>>> + };
>>>> +
>>>> + hdmi_pins: hdmi-pins {
>>>> + pins = "PH8", "PH9", "PH10";
>>>> + function = "hdmi";
>>>> + };
>>>> +
>>>> + i2c0_pins: i2c0-pins {
>>>> + pins = "PD25", "PD26";
>>>> + function = "i2c0";
>>>> + };
>>>> +
>>>> + i2c1_pins: i2c1-pins {
>>>> + pins = "PH5", "PH6";
>>>> + function = "i2c1";
>>>> + };
>>>> +
>>>> + i2c2_pins: i2c2-pins {
>>>> + pins = "PD23", "PD24";
>>>> + function = "i2c2";
>>>> + };
>>>> +
>>>> + i2c3_pins: i2c3-pins {
>>>> + pins = "PB17", "PB18";
>>>> + function = "i2c3";
>>>> + bias-pull-up;
>>>> + };
>>>> +
>>>> + i2s3_pins: i2s3-pins {
>>>> + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
>>>> + function = "i2s3";
>>>> + };
>>>> +
>>>> + mmc0_pins: mmc0-pins {
>>>> + pins = "PF0", "PF1", "PF2", "PF3",
>>>> + "PF4", "PF5";
>>>> + function = "mmc0";
>>>> + drive-strength = <30>;
>>>> + bias-pull-up;
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + mmc1_pins: mmc1-pins {
>>>> + pins = "PG0", "PG1", "PG2", "PG3",
>>>> + "PG4", "PG5";
>>>> + function = "mmc1";
>>>> + drive-strength = <30>;
>>>> + bias-pull-up;
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + mmc2_pins: mmc2-pins {
>>>> + pins = "PC1", "PC4", "PC5", "PC6",
>>>> + "PC7", "PC8", "PC9", "PC10",
>>>> + "PC11", "PC12", "PC13", "PC14";
>>>> + function = "mmc2";
>>>> + drive-strength = <30>;
>>>> + bias-pull-up;
>>>> + };
>>>> +
>>>> + pwm1_pin: pwm1-pin {
>>>> + pins = "PB19";
>>>> + function = "pwm1";
>>>> + };
>>>> +
>>>> + pwm_pin: pwm-pin {
>>>> + pins = "PD22";
>>>> + function = "pwm";
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + spi0_pins: spi0-pins {
>>>> + pins = "PC0", "PC2", "PC3";
>>>> + function = "spi0";
>>>> + };
>>>> +
>>>> + /* pin shared with MMC2-CMD (eMMC) */
>>>> + /omit-if-no-ref/
>>>> + spi0_cs_pin: spi0-cs-pin {
>>>> + pins = "PC5";
>>>> + function = "spi0";
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + spi1_pins: spi1-pins {
>>>> + pins = "PH4", "PH5", "PH6";
>>>> + function = "spi1";
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + spi1_cs_pin: spi1-cs-pin {
>>>> + pins = "PH3";
>>>> + function = "spi1";
>>>> + };
>>>> +
>>>> + /omit-if-no-ref/
>>>> + spdif_tx_pin: spdif-tx-pin {
>>>> + pins = "PH7";
>>>> + function = "spdif";
>>>> + };
>>>> +
>>>> + uart0_ph_pins: uart0-ph-pins {
>>>> + pins = "PH0", "PH1";
>>>> + function = "uart0";
>>>> + };
>>>> +
>>>> + uart1_pins: uart1-pins {
>>>> + pins = "PG6", "PG7";
>>>> + function = "uart1";
>>>> + };
>>>> +
>>>> + uart1_rts_cts_pins: uart1-rts-cts-pins {
>>>> + pins = "PG8", "PG9";
>>>> + function = "uart1";
>>>> + };
>>>> +
>>>> + uart2_pins: uart2-pins {
>>>> + pins = "PD19", "PD20";
>>>> + function = "uart2";
>>>> + };
>>>> +
>>>> + uart2_rts_cts_pins: uart2-rts-cts-pins {
>>>> + pins = "PD21", "PD22";
>>>> + function = "uart2";
>>>> + };
>>>> +
>>>> + uart3_pins: uart3-pins {
>>>> + pins = "PD23", "PD24";
>>>> + function = "uart3";
>>>> + };
>>>> +
>>>> + uart3_rts_cts_pins: uart3-rts-cts-pins {
>>>> + pins = "PD25", "PD26";
>>>> + function = "uart3";
>>>> + };
>>>> +
>>>> + i2s2_pins: i2s2-pins {
>>>> + pins = "PG10", "PG11", "PG12", "PG13";
>>>> + function = "i2s2";
>>>> + };
>>>> + };
>>>> +
>>>> + iommu: iommu@30f0000 {
>>>> + compatible = "allwinner,sun50i-h6-iommu";
>>>> + reg = <0x030f0000 0x10000>;
>>>> + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_IOMMU>;
>>>> + resets = <&ccu RST_BUS_IOMMU>;
>>>> + #iommu-cells = <1>;
>>>> + };
>>>> +
>>>> + mmc0: mmc@4020000 {
>>>> + compatible = "allwinner,sun50i-h6-mmc",
>>>> + "allwinner,sun50i-a64-mmc";
>>>> + reg = <0x04020000 0x1000>;
>>>> + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
>>>> + clock-names = "ahb", "mmc";
>>>> + resets = <&ccu RST_BUS_MMC0>;
>>>> + reset-names = "ahb";
>>>> + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&mmc0_pins>;
>>>> + max-frequency = <150000000>;
>>>> + status = "okay";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + vmmc-supply = <®_cldo1>;
>>>> + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
>>>> + bus-width = <4>;
>>>> + };
>>>> +
>>>> + mmc1: mmc@4021000 {
>>>> + compatible = "allwinner,sun50i-h6-mmc",
>>>> + "allwinner,sun50i-a64-mmc";
>>>> + reg = <0x04021000 0x1000>;
>>>> + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
>>>> + clock-names = "ahb", "mmc";
>>>> + resets = <&ccu RST_BUS_MMC1>;
>>>> + reset-names = "ahb";
>>>> + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&mmc1_pins>;
>>>> + max-frequency = <150000000>;
>>>> + status = "okay";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + vmmc-supply = <®_vcc33_wifi>;
>>>> + vqmmc-supply = <®_vcc_wifi_io>;
>>>> + mmc-pwrseq = <&wifi_pwrseq>;
>>>> + bus-width = <4>;
>>>> + non-removable;
>>>> +
>>>> + brcm: sdio-wifi@1 {
>>>> + reg = <1>;
>>>> + compatible = "brcm,bcm4329-fmac";
>>>> + interrupt-parent = <&r_pio>;
>>>> + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
>>>> + interrupt-names = "host-wake";
>>>> + };
>>>> + };
>>>> +
>>>> + mmc2: mmc@4022000 {
>>>> + compatible = "allwinner,sun50i-h6-emmc";
>>>> + reg = <0x04022000 0x1000>;
>>>> + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
>>>> + clock-names = "ahb", "mmc";
>>>> + resets = <&ccu RST_BUS_MMC2>;
>>>> + reset-names = "ahb";
>>>> + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&mmc2_pins>;
>>>> + max-frequency = <150000000>;
>>>> + status = "okay";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + vmmc-supply = <®_cldo1>;
>>>> + vqmmc-supply = <®_bldo2>;
>>>> + cap-mmc-hw-reset;
>>>> + non-removable;
>>>> + bus-width = <8>;
>>>> + };
>>>> +
>>>> + uart0: serial@5000000 {
>>>> + compatible = "snps,dw-apb-uart";
>>>> + reg = <0x05000000 0x400>;
>>>> + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
>>>> + reg-shift = <2>;
>>>> + reg-io-width = <4>;
>>>> + clocks = <&ccu CLK_BUS_UART0>;
>>>> + resets = <&ccu RST_BUS_UART0>;
>>>> + status = "okay";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&uart0_ph_pins>;
>>>> + };
>>>> +
>>>> + uart1: serial@5000400 {
>>>> + compatible = "snps,dw-apb-uart";
>>>> + reg = <0x05000400 0x400>;
>>>> + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>>>> + reg-shift = <2>;
>>>> + reg-io-width = <4>;
>>>> + clocks = <&ccu CLK_BUS_UART1>;
>>>> + resets = <&ccu RST_BUS_UART1>;
>>>> + status = "okay";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
>>>> + uart-has-rtscts;
>>>> +
>>>> + bluetooth {
>>>> + compatible = "brcm,bcm4345c5";
>>>> + clocks = <&rtc 1>;
>>>> + clock-names = "lpo";
>>>> + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
>>>> + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
>>>> + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
>>>> + max-speed = <1500000>;
>>>> + };
>>>> + };
>>>> +
>>>> + uart2: serial@5000800 {
>>>> + compatible = "snps,dw-apb-uart";
>>>> + reg = <0x05000800 0x400>;
>>>> + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
>>>> + reg-shift = <2>;
>>>> + reg-io-width = <4>;
>>>> + clocks = <&ccu CLK_BUS_UART2>;
>>>> + resets = <&ccu RST_BUS_UART2>;
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + uart3: serial@5000c00 {
>>>> + compatible = "snps,dw-apb-uart";
>>>> + reg = <0x05000c00 0x400>;
>>>> + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
>>>> + reg-shift = <2>;
>>>> + reg-io-width = <4>;
>>>> + clocks = <&ccu CLK_BUS_UART3>;
>>>> + resets = <&ccu RST_BUS_UART3>;
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + i2c0: i2c@5002000 {
>>>> + compatible = "allwinner,sun50i-h6-i2c",
>>>> + "allwinner,sun6i-a31-i2c";
>>>> + reg = <0x05002000 0x400>;
>>>> + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2C0>;
>>>> + resets = <&ccu RST_BUS_I2C0>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&i2c0_pins>;
>>>> + status = "disabled";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + };
>>>> +
>>>> + i2c1: i2c@5002400 {
>>>> + compatible = "allwinner,sun50i-h6-i2c",
>>>> + "allwinner,sun6i-a31-i2c";
>>>> + reg = <0x05002400 0x400>;
>>>> + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2C1>;
>>>> + resets = <&ccu RST_BUS_I2C1>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&i2c1_pins>;
>>>> + status = "disabled";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + };
>>>> +
>>>> + i2c2: i2c@5002800 {
>>>> + compatible = "allwinner,sun50i-h6-i2c",
>>>> + "allwinner,sun6i-a31-i2c";
>>>> + reg = <0x05002800 0x400>;
>>>> + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2C2>;
>>>> + resets = <&ccu RST_BUS_I2C2>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&i2c2_pins>;
>>>> + status = "disabled";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + };
>>>> +
>>>> + i2c3: i2c@5002c00 {
>>>> + compatible = "allwinner,sun50i-h6-i2c",
>>>> + "allwinner,sun6i-a31-i2c";
>>>> + reg = <0x05002c00 0x400>;
>>>> + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2C3>;
>>>> + resets = <&ccu RST_BUS_I2C3>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&i2c3_pins>;
>>>> + clock-frequency = <100000>;
>>>> + status = "okay"; /* нужно для ac200 */
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + ac200: mfd@10 {
>>>> + compatible = "x-powers,ac200";
>>>> + reg = <0x10>;
>>>> + clocks = <&ac200_pwm_clk>;
>>>> + interrupt-parent = <&pio>;
>>>> + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <1>;
>>>> + nvmem-cells = <&ac200_bg>;
>>>> + nvmem-cell-names = "bandgap";
>>>> +
>>>> + ac200_ephy_ctl: syscon {
>>>> + compatible = "x-powers,ac200-ephy-ctl";
>>>> + nvmem-cells = <&ephy_calib>;
>>>> + nvmem-cell-names = "calibration";
>>>> + #clock-cells = <0>;
>>>> + #reset-cells = <0>;
>>>> + phy-mode = "rmii";
>>>> + status = "okay";
>>>> + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
>>>> + phy-address = <1>;
>>>> + };
>>>> +
>>>> + ac200_codec: codec {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "x-powers,ac200-codec";
>>>> + status = "okay";
>>>> + avcc-supply = <®_aldo2>;
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + spi1: spi@5011000 {
>>>> + compatible = "allwinner,sun50i-h6-spi",
>>>> + "allwinner,sun8i-h3-spi";
>>>> + reg = <0x05011000 0x1000>;
>>>> + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
>>>> + clock-names = "ahb", "mod";
>>>> + dmas = <&dma 23>, <&dma 23>;
>>>> + dma-names = "rx", "tx";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
>>>> + resets = <&ccu RST_BUS_SPI1>;
>>>> + status = "disabled";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + };
>>>> +
>>>> + emac: ethernet@5020000 {
>>>> + compatible = "allwinner,sun50i-h6-emac",
>>>> + "allwinner,sun50i-a64-emac";
>>>> + syscon = <&syscon>;
>>>> + reg = <0x05020000 0x10000>;
>>>> + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
>>>> + interrupt-names = "macirq";
>>>> + resets = <&ccu RST_BUS_EMAC>;
>>>> + reset-names = "stmmaceth";
>>>> + clocks = <&ccu CLK_BUS_EMAC>;
>>>> + clock-names = "stmmaceth";
>>>> + status = "okay";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&ext_rmii_pins>;
>>>> + phy-mode = "rmii";
>>>> + phy-handle = <&ext_rmii_phy>;
>>>> +
>>>> + mdio: mdio {
>>>> + compatible = "snps,dwmac-mdio";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + ext_rmii_phy: ethernet-phy@1 {
>>>> + compatible = "ethernet-phy-id0044.1400",
>>>> + "ethernet-phy-ieee802.3-c22";
>>>> + reg = <1>;
>>>> + resets = <&ac200_ephy_ctl>;
>>>> + reset-names = "phy";
>>>> + clocks = <&ac200_ephy_ctl>;
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + i2s3: i2s@508f000 {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "allwinner,sun50i-h6-i2s";
>>>> + reg = <0x0508f000 0x1000>;
>>>> + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
>>>> + clock-names = "apb", "mod";
>>>> + dmas = <&dma 6>, <&dma 6>;
>>>> + resets = <&ccu RST_BUS_I2S3>;
>>>> + dma-names = "rx", "tx";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&i2s3_pins>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + i2s2: i2s@5092000 {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "allwinner,sun50i-h6-i2s";
>>>> + reg = <0x05092000 0x1000>;
>>>> + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
>>>> + clock-names = "apb", "mod";
>>>> + dmas = <&dma 5>, <&dma 5>;
>>>> + resets = <&ccu RST_BUS_I2S2>;
>>>> + dma-names = "rx", "tx";
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + i2s1: i2s@5091000 {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "allwinner,sun50i-h6-i2s";
>>>> + reg = <0x05091000 0x1000>;
>>>> + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
>>>> + clock-names = "apb", "mod";
>>>> + dmas = <&dma 4>, <&dma 4>;
>>>> + resets = <&ccu RST_BUS_I2S1>;
>>>> + dma-names = "rx", "tx";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + spdif: spdif@5093000 {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "allwinner,sun50i-h6-spdif";
>>>> + reg = <0x05093000 0x400>;
>>>> + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
>>>> + clock-names = "apb", "spdif";
>>>> + resets = <&ccu RST_BUS_SPDIF>;
>>>> + dmas = <&dma 2>, <&dma 2>;
>>>> + dma-names = "rx", "tx";
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + usb2otg: usb@5100000 {
>>>> + compatible = "allwinner,sun50i-h6-musb",
>>>> + "allwinner,sun8i-a33-musb";
>>>> + reg = <0x05100000 0x0400>;
>>>> + clocks = <&ccu CLK_BUS_OTG>;
>>>> + resets = <&ccu RST_BUS_OTG>;
>>>> + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
>>>> + interrupt-names = "mc";
>>>> + phys = <&usb2phy 0>;
>>>> + phy-names = "usb";
>>>> + extcon = <&usb2phy 0>;
>>>> + status = "okay";
>>>> + dr_mode = "host";
>>>> + };
>>>> +
>>>> + usb2phy: phy@5100400 {
>>>> + compatible = "allwinner,sun50i-h6-usb-phy";
>>>> + reg = <0x05100400 0x24>,
>>>> + <0x05101800 0x4>,
>>>> + <0x05311800 0x4>;
>>>> + reg-names = "phy_ctrl",
>>>> + "pmu0",
>>>> + "pmu3";
>>>> + clocks = <&ccu CLK_USB_PHY0>,
>>>> + <&ccu CLK_USB_PHY3>;
>>>> + clock-names = "usb0_phy",
>>>> + "usb3_phy";
>>>> + resets = <&ccu RST_USB_PHY0>,
>>>> + <&ccu RST_USB_PHY3>;
>>>> + reset-names = "usb0_reset",
>>>> + "usb3_reset";
>>>> + status = "okay";
>>>> + #phy-cells = <1>;
>>>> + };
>>>> +
>>>> + ehci0: usb@5101000 {
>>>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
>>>> + reg = <0x05101000 0x100>;
>>>> + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_OHCI0>,
>>>> + <&ccu CLK_BUS_EHCI0>,
>>>> + <&ccu CLK_USB_OHCI0>;
>>>> + resets = <&ccu RST_BUS_OHCI0>,
>>>> + <&ccu RST_BUS_EHCI0>;
>>>> + phys = <&usb2phy 0>;
>>>> + phy-names = "usb";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + ohci0: usb@5101400 {
>>>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
>>>> + reg = <0x05101400 0x100>;
>>>> + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_OHCI0>,
>>>> + <&ccu CLK_USB_OHCI0>;
>>>> + resets = <&ccu RST_BUS_OHCI0>;
>>>> + phys = <&usb2phy 0>;
>>>> + phy-names = "usb";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + dwc3: usb@5200000 {
>>>> + compatible = "snps,dwc3";
>>>> + reg = <0x05200000 0x10000>;
>>>> + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_XHCI>,
>>>> + <&ccu CLK_BUS_XHCI>,
>>>> + <&rtc CLK_OSC32K>;
>>>> + clock-names = "ref", "bus_early", "suspend";
>>>> + resets = <&ccu RST_BUS_XHCI>;
>>>> + /*
>>>> + * The datasheet of the chip doesn't declare the
>>>> + * peripheral function, and there's no boards known
>>>> + * to have a USB Type-B port routed to the port.
>>>> + * In addition, no one has tested the peripheral
>>>> + * function yet.
>>>> + * So set the dr_mode to "host" in the DTSI file.
>>>> + */
>>>> + dr_mode = "host";
>>>> + phys = <&usb3phy>;
>>>> + phy-names = "usb3-phy";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + usb3phy: phy@5210000 {
>>>> + compatible = "allwinner,sun50i-h6-usb3-phy";
>>>> + reg = <0x5210000 0x10000>;
>>>> + clocks = <&ccu CLK_USB_PHY1>;
>>>> + resets = <&ccu RST_USB_PHY1>;
>>>> + #phy-cells = <0>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + ehci3: usb@5311000 {
>>>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
>>>> + reg = <0x05311000 0x100>;
>>>> + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_OHCI3>,
>>>> + <&ccu CLK_BUS_EHCI3>,
>>>> + <&ccu CLK_USB_OHCI3>;
>>>> + resets = <&ccu RST_BUS_OHCI3>,
>>>> + <&ccu RST_BUS_EHCI3>;
>>>> + phys = <&usb2phy 3>;
>>>> + phy-names = "usb";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + ohci3: usb@5311400 {
>>>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
>>>> + reg = <0x05311400 0x100>;
>>>> + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_OHCI3>,
>>>> + <&ccu CLK_USB_OHCI3>;
>>>> + resets = <&ccu RST_BUS_OHCI3>;
>>>> + phys = <&usb2phy 3>;
>>>> + phy-names = "usb";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + pcie: pcie@5400000 {
>>>> + #address-cells = <3>;
>>>> + #size-cells = <2>;
>>>> + compatible = "pine64,allwinner-h6-pcie-wrapped";
>>>> + reg = <0x05400000 0x4000>,
>>>> + <0x05410000 0x10000>;
>>>> + reg-names = "dbi", "config";
>>>> + device_type = "pci";
>>>> + bus-range = <0x00 0xff>;
>>>> + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
>>>> + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
>>>> + num-lanes = <1>;
>>>> + max-link-speed = <2>;
>>>> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
>>>> + interrupt-names = "msi", "linkup";
>>>> + clocks = <&ccu CLK_PCIE_REF_OUT>,
>>>> + <&ccu CLK_PCIE_MAXI>,
>>>> + <&ccu CLK_PCIE_AUX>,
>>>> + <&ccu CLK_BUS_PCIE>;
>>>> + clock-names = "ref", "axi", "aux", "bus";
>>>> + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
>>>> + reset-names = "power", "bus";
>>>> + #interrupt-cells = <1>;
>>>> + interrupt-map-mask = <0 0 0 0>;
>>>> + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
>>>> + status = "okay";
>>>> + vcc-supply = <®_bldo2>;
>>>> + vdd-supply = <®_dcdcd>;
>>>> + slot-supply = <®_vcc33_wifi>;
>>>> + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
>>>> + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
>>>> + /* wake-gpio = <&r_pio 0 4 0>; */
>>>> + };
>>>> +
>>>> +
>>>> + hdmi: hdmi@6000000 {
>>>> + #sound-dai-cells = <0>;
>>>> + compatible = "allwinner,sun50i-h6-dw-hdmi";
>>>> + reg = <0x06000000 0x10000>;
>>>> + reg-io-width = <1>;
>>>> + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
>>>> + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
>>>> + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
>>>> + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
>>>> + "hdcp-bus";
>>>> + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
>>>> + reset-names = "ctrl", "hdcp";
>>>> + phys = <&hdmi_phy>;
>>>> + phy-names = "phy";
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&hdmi_pins>;
>>>> + status = "okay";
>>>> +
>>>> + ports {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + hdmi_in: port@0 {
>>>> + reg = <0>;
>>>> +
>>>> + hdmi_in_tcon_top: endpoint {
>>>> + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
>>>> + };
>>>> + };
>>>> +
>>>> + hdmi_out: port@1 {
>>>> + reg = <1>;
>>>> +
>>>> + hdmi_out_con: endpoint {
>>>> + remote-endpoint = <&hdmi_con_in>;
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + hdmi_phy: hdmi-phy@6010000 {
>>>> + compatible = "allwinner,sun50i-h6-hdmi-phy";
>>>> + reg = <0x06010000 0x10000>;
>>>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
>>>> + clock-names = "bus", "mod";
>>>> + resets = <&ccu RST_BUS_HDMI>;
>>>> + reset-names = "phy";
>>>> + #phy-cells = <0>;
>>>> + };
>>>> +
>>>> + tcon_top: tcon-top@6510000 {
>>>> + compatible = "allwinner,sun50i-h6-tcon-top";
>>>> + reg = <0x06510000 0x1000>;
>>>> + clocks = <&ccu CLK_BUS_TCON_TOP>,
>>>> + <&ccu CLK_TCON_TV0>;
>>>> + clock-names = "bus",
>>>> + "tcon-tv0";
>>>> + clock-output-names = "tcon-top-tv0";
>>>> + resets = <&ccu RST_BUS_TCON_TOP>;
>>>> + #clock-cells = <1>;
>>>> +
>>>> + ports {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + tcon_top_mixer0_in: port@0 {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + reg = <0>;
>>>> +
>>>> + tcon_top_mixer0_in_mixer0: endpoint@0 {
>>>> + reg = <0>;
>>>> + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
>>>> + };
>>>> + };
>>>> +
>>>> + tcon_top_mixer0_out: port@1 {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + reg = <1>;
>>>> +
>>>> + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
>>>> + reg = <2>;
>>>> + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
>>>> + };
>>>> + };
>>>> +
>>>> + tcon_top_hdmi_in: port@4 {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + reg = <4>;
>>>> +
>>>> + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
>>>> + reg = <0>;
>>>> + remote-endpoint = <&tcon_tv_out_tcon_top>;
>>>> + };
>>>> + };
>>>> +
>>>> + tcon_top_hdmi_out: port@5 {
>>>> + reg = <5>;
>>>> +
>>>> + tcon_top_hdmi_out_hdmi: endpoint {
>>>> + remote-endpoint = <&hdmi_in_tcon_top>;
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + tcon_tv: lcd-controller@6515000 {
>>>> + compatible = "allwinner,sun50i-h6-tcon-tv",
>>>> + "allwinner,sun8i-r40-tcon-tv";
>>>> + reg = <0x06515000 0x1000>;
>>>> + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_TCON_TV0>,
>>>> + <&tcon_top CLK_TCON_TOP_TV0>;
>>>> + clock-names = "ahb",
>>>> + "tcon-ch1";
>>>> + resets = <&ccu RST_BUS_TCON_TV0>;
>>>> + reset-names = "lcd";
>>>> +
>>>> + ports {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + tcon_tv_in: port@0 {
>>>> + reg = <0>;
>>>> +
>>>> + tcon_tv_in_tcon_top_mixer0: endpoint {
>>>> + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
>>>> + };
>>>> + };
>>>> +
>>>> + tcon_tv_out: port@1 {
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + reg = <1>;
>>>> +
>>>> + tcon_tv_out_tcon_top: endpoint@1 {
>>>> + reg = <1>;
>>>> + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + r_uart: serial@7080000 {
>>>> + compatible = "snps,dw-apb-uart";
>>>> + reg = <0x07080000 0x400>;
>>>> + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
>>>> + reg-shift = <2>;
>>>> + reg-io-width = <4>;
>>>> + clocks = <&r_ccu CLK_R_APB2_UART>;
>>>> + resets = <&r_ccu RST_R_APB2_UART>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&r_uart_pins>;
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + rtc: rtc@7000000 {
>>>> + compatible = "allwinner,sun50i-h6-rtc";
>>>> + reg = <0x07000000 0x400>;
>>>> + interrupt-parent = <&r_intc>;
>>>> + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clock-output-names = "osc32k", "osc32k-out", "iosc";
>>>> + #clock-cells = <1>;
>>>> + clocks = <&ext_osc32k>;
>>>> + };
>>>> +
>>>> + r_ccu: clock@7010000 {
>>>> + compatible = "allwinner,sun50i-h6-r-ccu";
>>>> + reg = <0x07010000 0x400>;
>>>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
>>>> + <&ccu CLK_PLL_PERIPH0>;
>>>> + clock-names = "hosc", "losc", "iosc", "pll-periph";
>>>> + protected-clocks = <CLK_R_APB1_TWD>;
>>>> + #clock-cells = <1>;
>>>> + #reset-cells = <1>;
>>>> + };
>>>> +
>>>> + r_watchdog: watchdog@7020400 {
>>>> + compatible = "allwinner,sun50i-h6-wdt",
>>>> + "allwinner,sun6i-a31-wdt";
>>>> + reg = <0x07020400 0x20>;
>>>> + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&osc24M>;
>>>> + };
>>>> +
>>>> + r_intc: interrupt-controller@7021000 {
>>>> + compatible = "allwinner,sun50i-h6-r-intc";
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <3>;
>>>> + reg = <0x07021000 0x400>;
>>>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
>>>> + };
>>>> +
>>>> + r_pwm: pwm@7020C00 {
>>>> + compatible = "allwinner,sun50i-h6-pwm";
>>>> + reg = <0x07020C00 0x400>;
>>>> + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
>>>> + clock-names = "mod", "bus";
>>>> + resets = <&ccu RST_R_APB1_PWM>;
>>>> + #pwm-cells = <3>;
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + r_pio: pinctrl@7022000 {
>>>> + compatible = "allwinner,sun50i-h6-r-pinctrl";
>>>> + reg = <0x07022000 0x400>;
>>>> + interrupt-parent = <&r_intc>;
>>>> + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
>>>> + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
>>>> + <&rtc CLK_OSC32K>;
>>>> + clock-names = "apb", "hosc", "losc";
>>>> + gpio-controller;
>>>> + #gpio-cells = <3>;
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <3>;
>>>> +
>>>> + r_i2c_pins: r-i2c-pins {
>>>> + pins = "PL0", "PL1";
>>>> + function = "s_i2c";
>>>> + };
>>>> +
>>>> + r_ir_rx_pin: r-ir-rx-pin {
>>>> + pins = "PL9";
>>>> + function = "s_cir_rx";
>>>> + };
>>>> +
>>>> + r_rsb_pins: r-rsb-pins {
>>>> + pins = "PL0", "PL1";
>>>> + function = "s_rsb";
>>>> + };
>>>> +
>>>> + r_uart_pins: r-uart-pins {
>>>> + pins = "PL2", "PL3";
>>>> + function = "s_uart";
>>>> + };
>>>> +
>>>> + r_pwm_pin: r-pwm-pin {
>>>> + pins = "PL8";
>>>> + function = "s_pwm";
>>>> + };
>>>> +
>>>> + };
>>>> +
>>>> + r_ir: ir@7040000 {
>>>> + compatible = "allwinner,sun50i-h6-ir",
>>>> + "allwinner,sun6i-a31-ir";
>>>> + reg = <0x07040000 0x400>;
>>>> + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&r_ccu CLK_R_APB1_IR>,
>>>> + <&r_ccu CLK_IR>;
>>>> + clock-names = "apb", "ir";
>>>> + resets = <&r_ccu RST_R_APB1_IR>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&r_ir_rx_pin>;
>>>> + status = "disabled";
>>>> + };
>>>> +
>>>> + r_i2c: i2c@7081400 {
>>>> + compatible = "allwinner,sun50i-h6-i2c",
>>>> + "allwinner,sun6i-a31-i2c";
>>>> + reg = <0x07081400 0x400>;
>>>> + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&r_ccu CLK_R_APB2_I2C>;
>>>> + resets = <&r_ccu RST_R_APB2_I2C>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&r_i2c_pins>;
>>>> + status = "okay";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> +
>>>> + axp805: pmic@36 {
>>>> + compatible = "x-powers,axp805", "x-powers,axp806";
>>>> + reg = <0x36>;
>>>> + interrupt-parent = <&r_intc>;
>>>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
>>>> + interrupt-controller;
>>>> + #interrupt-cells = <1>;
>>>> + x-powers,self-working-mode;
>>>> + vina-supply = <®_vcc5v>;
>>>> + vinb-supply = <®_vcc5v>;
>>>> + vinc-supply = <®_vcc5v>;
>>>> + vind-supply = <®_vcc5v>;
>>>> + vine-supply = <®_vcc5v>;
>>>> + aldoin-supply = <®_vcc5v>;
>>>> + bldoin-supply = <®_vcc5v>;
>>>> + cldoin-supply = <®_vcc5v>;
>>>> +
>>>> + regulators {
>>>> + reg_aldo1: aldo1 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc-pl-led-ir";
>>>> + };
>>>> +
>>>> + reg_aldo2: aldo2 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc33-audio-tv-ephy-mac";
>>>> + regulator-enable-ramp-delay = <100000>;
>>>> + };
>>>> +
>>>> + reg_aldo3: aldo3 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
>>>> + };
>>>> +
>>>> + reg_bldo1: bldo1 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <1800000>;
>>>> + regulator-max-microvolt = <1800000>;
>>>> + regulator-name = "vcc18-dram-bias-pll";
>>>> + };
>>>> +
>>>> + reg_bldo2: bldo2 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <1800000>;
>>>> + regulator-max-microvolt = <1800000>;
>>>> + regulator-name = "vcc-efuse-pcie-hdmi-pc";
>>>> + };
>>>> +
>>>> + reg_bldo3: bldo3 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <1800000>;
>>>> + regulator-max-microvolt = <1800000>;
>>>> + regulator-name = "vcc-dcxoio";
>>>> + };
>>>> +
>>>> + reg_bldo4: bldo4 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <1800000>;
>>>> + regulator-max-microvolt = <1800000>;
>>>> + regulator-name = "vcc-dcxoio";
>>>> + };
>>>> +
>>>> + reg_cldo1: cldo1 {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
>>>> + };
>>>> +
>>>> + reg_cldo2: cldo2 {
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc-wifi-1";
>>>> + };
>>>> +
>>>> + reg_cldo3: cldo3 {
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-name = "vcc-wifi-2";
>>>> + };
>>>> +
>>>> + reg_dcdca: dcdca {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <810000>;
>>>> + regulator-max-microvolt = <1200000>;
>>>> + regulator-ramp-delay = <2500>;
>>>> + regulator-name = "vdd-cpu";
>>>> + };
>>>> +
>>>> + reg_dcdcc: dcdcc {
>>>> + regulator-enable-ramp-delay = <32000>;
>>>> + regulator-min-microvolt = <810000>;
>>>> + regulator-max-microvolt = <1080000>;
>>>> + regulator-ramp-delay = <2500>;
>>>> + regulator-name = "vdd-gpu";
>>>> + };
>>>> +
>>>> + reg_dcdcd: dcdcd {
>>>> + regulator-always-on;
>>>> + regulator-min-microvolt = <1000000>;
>>>> + regulator-max-microvolt = <1000000>;
>>>> + regulator-name = "vdd-sys";
>>>> + };
>>>> +
>>>> + sw {
>>>> + /* unused */
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + r_rsb: rsb@7083000 {
>>>> + compatible = "allwinner,sun8i-a23-rsb";
>>>> + reg = <0x07083000 0x400>;
>>>> + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&r_ccu CLK_R_APB2_RSB>;
>>>> + clock-frequency = <3000000>;
>>>> + resets = <&r_ccu RST_R_APB2_RSB>;
>>>> + pinctrl-names = "default";
>>>> + pinctrl-0 = <&r_rsb_pins>;
>>>> + status = "disabled";
>>>> + #address-cells = <1>;
>>>> + #size-cells = <0>;
>>>> + };
>>>> +
>>>> + ths: thermal-sensor@5070400 {
>>>> + compatible = "allwinner,sun50i-h6-ths";
>>>> + reg = <0x05070400 0x100>;
>>>> + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
>>>> + clocks = <&ccu CLK_BUS_THS>;
>>>> + clock-names = "bus";
>>>> + resets = <&ccu RST_BUS_THS>;
>>>> + nvmem-cells = <&ths_calibration>;
>>>> + nvmem-cell-names = "calibration";
>>>> + #thermal-sensor-cells = <1>;
>>>> + };
>>>> +
>>>> + sunxi-info {
>>>> + compatible = "allwinner,sun50i-h6-sys-info";
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + addr_mgt: addr-mgt {
>>>> + compatible = "allwinner,sunxi-addr_mgt";
>>>> + type_addr_wifi = <0x2>;
>>>> + type_addr_bt = <0x2>;
>>>> + type_addr_eth = <0x2>;
>>>> + status = "okay";
>>>> + };
>>>> +
>>>> + dump_reg: dump_reg@20000 {
>>>> + compatible = "allwinner,sunxi-dump-reg";
>>>> + reg = <0x0 0x03001000 0x0 0x0f20>;
>>>> + status = "okay";
>>>> + };
>>>> + };
>>>> +
>>>> + thermal-zones {
>>>> + cpu-thermal {
>>>> + polling-delay-passive = <250>;
>>>> + polling-delay = <1000>;
>>>> + thermal-sensors = <&ths 0>;
>>>> +
>>>> + trips {
>>>> + cpu_warm: cpu_warm {
>>>> + temperature = <70000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_hot0: cpu_hot0 {
>>>> + temperature = <74000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_hot1: cpu_hot1 {
>>>> + temperature = <76000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot0: cpu_very_hot0 {
>>>> + temperature = <78000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot1: cpu_very_hot1 {
>>>> + temperature = <80000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot2: cpu_very_hot2 {
>>>> + temperature = <82000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot3: cpu_very_hot3 {
>>>> + temperature = <84000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot4: cpu_very_hot4 {
>>>> + temperature = <86000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot5: cpu_very_hot5 {
>>>> + temperature = <88000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_very_hot6: cpu_very_hot6 {
>>>> + temperature = <90000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + cpu_crit: cpu_crit {
>>>> + temperature = <97000>;
>>>> + hysteresis = <2000>;
>>>> + type = "critical";
>>>> + };
>>>> + };
>>>> +
>>>> + cooling-maps {
>>>> + cpu_warm_limit_cpu {
>>>> + trip = <&cpu_warm>;
>>>> + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + gpu-thermal {
>>>> + polling-delay-passive = <1000>;
>>>> + polling-delay = <2000>;
>>>> + thermal-sensors = <&ths 1>;
>>>> +
>>>> + trips {
>>>> + gpu_alert0: gpu-alert-0 {
>>>> + temperature = <95000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + gpu_alert1: gpu-alert-1 {
>>>> + temperature = <100000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + gpu_alert2: gpu-alert-2 {
>>>> + temperature = <105000>;
>>>> + hysteresis = <2000>;
>>>> + type = "passive";
>>>> + };
>>>> +
>>>> + gpu-crit {
>>>> + temperature = <115000>;
>>>> + hysteresis = <0>;
>>>> + type = "critical";
>>>> + };
>>>> + };
>>>> +
>>>> + cooling-maps {
>>>> + // Forbid the GPU to go over 756MHz
>>>> + map0 {
>>>> + trip = <&gpu_alert0>;
>>>> + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
>>>> + };
>>>> +
>>>> + // Forbid the GPU to go over 624MHz
>>>> + map1 {
>>>> + trip = <&gpu_alert1>;
>>>> + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
>>>> + };
>>>> +
>>>> + // Forbid the GPU to go over 576MHz
>>>> + map2 {
>>>> + trip = <&gpu_alert2>;
>>>> + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
>>>> + };
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + cpu_opp_table: cpu-opp-table {
>>>> + compatible = "allwinner,sun50i-h6-operating-points";
>>>> + nvmem-cells = <&cpu_speed_grade>;
>>>> + opp-shared;
>>>> +
>>>> + opp-480000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <480000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <880000>;
>>>> + };
>>>> +
>>>> + opp-720000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <720000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <880000>;
>>>> + };
>>>> +
>>>> + opp-888000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <888000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <880000>;
>>>> + };
>>>> +
>>>> + opp-1080000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1080000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <940000>;
>>>> + };
>>>> +
>>>> + opp-1320000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1320000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1000000>;
>>>> + };
>>>> +
>>>> + opp-1488000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1488000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1060000>;
>>>> + };
>>>> +
>>>> + opp-1608000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1608000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1090000>;
>>>> + };
>>>> +
>>>> + opp-1704000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1704000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1120000>;
>>>> + };
>>>> +
>>>> + opp-1800000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1800000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1160000>;
>>>> + };
>>>> +
>>>> + opp@1896000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1896000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1180000>;
>>>> + };
>>>> +
>>>> + opp@1968000000 {
>>>> + clock-latency-ns = <244144>; /* 8 32k periods */
>>>> + opp-hz = /bits/ 64 <1968000000>;
>>>> +
>>>> + opp-microvolt-speed0 = <1200000>;
>>>> + };
>>>> +
>>>> + };
>>>> +
>>>> + gpu_opp_table: opp-table-gpu {
>>>> + compatible = "operating-points-v2";
>>>> +
>>>> + opp-216000000 {
>>>> + opp-hz = /bits/ 64 <216000000>;
>>>> + opp-microvolt = <810000 810000 1200000>;
>>>> + };
>>>> +
>>>> + opp-264000000 {
>>>> + opp-hz = /bits/ 64 <264000000>;
>>>> + opp-microvolt = <810000 810000 1200000>;
>>>> + };
>>>> +
>>>> + opp-312000000 {
>>>> + opp-hz = /bits/ 64 <312000000>;
>>>> + opp-microvolt = <810000 810000 1200000>;
>>>> + };
>>>> +
>>>> + opp-336000000 {
>>>> + opp-hz = /bits/ 64 <336000000>;
>>>> + opp-microvolt = <810000 810000 1200000>;
>>>> + };
>>>> +
>>>> + opp-360000000 {
>>>> + opp-hz = /bits/ 64 <360000000>;
>>>> + opp-microvolt = <820000 820000 1200000>;
>>>> + };
>>>> +
>>>> + opp-384000000 {
>>>> + opp-hz = /bits/ 64 <384000000>;
>>>> + opp-microvolt = <830000 830000 1200000>;
>>>> + };
>>>> +
>>>> + opp-408000000 {
>>>> + opp-hz = /bits/ 64 <408000000>;
>>>> + opp-microvolt = <840000 840000 1200000>;
>>>> + };
>>>> +
>>>> + opp-420000000 {
>>>> + opp-hz = /bits/ 64 <420000000>;
>>>> + opp-microvolt = <850000 850000 1200000>;
>>>> + };
>>>> +
>>>> + opp-432000000 {
>>>> + opp-hz = /bits/ 64 <432000000>;
>>>> + opp-microvolt = <860000 860000 1200000>;
>>>> + };
>>>> +
>>>> + opp-456000000 {
>>>> + opp-hz = /bits/ 64 <456000000>;
>>>> + opp-microvolt = <870000 870000 1200000>;
>>>> + };
>>>> +
>>>> + opp-504000000 {
>>>> + opp-hz = /bits/ 64 <504000000>;
>>>> + opp-microvolt = <890000 890000 1200000>;
>>>> + };
>>>> +
>>>> + opp-540000000 {
>>>> + opp-hz = /bits/ 64 <540000000>;
>>>> + opp-microvolt = <910000 910000 1200000>;
>>>> + };
>>>> +
>>>> + opp-576000000 {
>>>> + opp-hz = /bits/ 64 <576000000>;
>>>> + opp-microvolt = <930000 930000 1200000>;
>>>> + };
>>>> +
>>>> + opp-624000000 {
>>>> + opp-hz = /bits/ 64 <624000000>;
>>>> + opp-microvolt = <950000 950000 1200000>;
>>>> + };
>>>> +
>>>> + opp-756000000 {
>>>> + opp-hz = /bits/ 64 <756000000>;
>>>> + opp-microvolt = <1040000 1040000 1200000>;
>>>> + };
>>>> + };
>>>> +
>>>> + chosen {
>>>> + stdout-path = "serial0:115200n8";
>>>> + };
>>>> +
>>>> + connector {
>>>> + compatible = "hdmi-connector";
>>>> + type = "a";
>>>> +
>>>> + port {
>>>> + hdmi_con_in: endpoint {
>>>> + remote-endpoint = <&hdmi_out_con>;
>>>> + };
>>>> + };
>>>> + };
>>>> +
>>>> + ext_osc32k: ext_osc32k_clk {
>>>> + #clock-cells = <0>;
>>>> + compatible = "fixed-clock";
>>>> + clock-frequency = <32768>;
>>>> + clock-output-names = "ext_osc32k";
>>>> + };
>>>> +
>>>> + leds {
>>>> + compatible = "gpio-leds";
>>>> +
>>>> + led-0 {
>>>> + label = "repka:red:power";
>>>> + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
>>>> + linux,default-trigger = "heartbeat";
>>>> + };
>>>> + };
>>>> +
>>>> + reg_vcc5v: vcc5v {
>>>> + /* board wide 5V supply directly from the DC jack */
>>>> + compatible = "regulator-fixed";
>>>> + regulator-name = "vcc-5v";
>>>> + regulator-min-microvolt = <5000000>;
>>>> + regulator-max-microvolt = <5000000>;
>>>> + regulator-always-on;
>>>> + };
>>>> +
>>>> + reg_vcc33_wifi: vcc33-wifi {
>>>> + /* Always on 3.3V regulator for WiFi and BT */
>>>> + compatible = "regulator-fixed";
>>>> + regulator-name = "vcc33-wifi";
>>>> + regulator-min-microvolt = <3300000>;
>>>> + regulator-max-microvolt = <3300000>;
>>>> + regulator-always-on;
>>>> + vin-supply = <®_vcc5v>;
>>>> + };
>>>> +
>>>> + reg_vcc_wifi_io: vcc-wifi-io {
>>>> + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
>>>> + compatible = "regulator-fixed";
>>>> + regulator-name = "vcc-wifi-io";
>>>> + regulator-min-microvolt = <1800000>;
>>>> + regulator-max-microvolt = <1800000>;
>>>> + regulator-always-on;
>>>> + vin-supply = <®_vcc33_wifi>;
>>>> + };
>>>> +
>>>> + wifi_pwrseq: wifi-pwrseq {
>>>> + compatible = "mmc-pwrseq-simple";
>>>> + clocks = <&rtc 1>;
>>>> + clock-names = "ext_clock";
>>>> + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
>>>> + post-power-on-delay-ms = <200>;
>>>> + };
>>>> +};
>>>> --
>>>> 2.42.2
>>>>
>>>> _______________________________________________
>>>> devel-kernel mailing list
>>>> devel-kernel@lists.altlinux.org
>>>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
>>> _______________________________________________
>>> devel-kernel mailing list
>>> devel-kernel@lists.altlinux.org
>>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
>>
>> --
>> Kind Regards!
>> from srebrov@altlinux.org
>>
>> _______________________________________________
>> devel-kernel mailing list
>> devel-kernel@lists.altlinux.org
>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
--
best regards, Anton Midyukov <antohami@altlinux.org>
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-08 1:10 ` Anton Midyukov
@ 2025-05-08 1:19 ` Vitaly Chikunov
0 siblings, 0 replies; 7+ messages in thread
From: Vitaly Chikunov @ 2025-05-08 1:19 UTC (permalink / raw)
To: ALT Linux kernel packages development
Anton,
On Thu, May 08, 2025 at 04:10:39AM +0300, Anton Midyukov wrote:
> 08.05.2025 03:54, Vitaly Chikunov пишет:
> > On Wed, May 07, 2025 at 11:50:53PM +0300, Kurachenko Anton wrote:
> >> 1. Я проверял сборку и работоспособность полученного результата на ядре
> >> 6.12.25-alt1.
> >
> > Это хорошо, спасибо.
> >
> >> 2. Дело в том, что загрузчик u-boot для Repka Pi 4 требует обязательного
> >> наличия dtb для запуска. Сейчас нам приходится заниматься скачиванием и
> >> распаковкой ядра repka4, затем извлекать нужный dtb и переносить его в
> >> /boot/devicetree/$kernelversion/allwinner ядра 6.12, чтобы хотя бы
> >> просто начать процесс установки. Патч призван решить эту проблему.
> >
> > То есть наше 6.12 начнет загружаться на repka pi4 или это для чего-то
> > другого нужно?
> >
>
> Да. Будет загружаться и работать. Этого будет достаточно, чтобы установить ядро repka pi4.
> Это необходимо для того, чтобы не выпускать дополнительные образы с ядром для repka pi4.
Спасибо за разъяснение.
>
>
> >>
> >> 07.05.2025 22:39, Vitaly Chikunov пишет:
> >>> Anton,
> >>>
> >>> On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
> >>>> From: Anton Kurachenko <srebrov@altlinux.org>
> >>>>
> >>>> Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
> >>>> u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
> >>>> a dtb file.
> >>>>
> >>>> Patch designed specifically for ALT and never used anywhere.
> >>>
> >>> 1. Это изменение протестировано?
> >>> 2. Зачем нужен этот патч, если есть флейворы repka/repka4?
> >>>
> >>> Thanks,
> >>>
> >>>>
> >>>> The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
> >>>> file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
> >>>> from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
> >>>> Represents the result of merging these files with applying some modifications.
> >>>>
> >>>> Files that were used during the creation process:
> >>>>
> >>>> sun50i-h6-repka-pi4-optimal.dts
> >>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
> >>>>
> >>>> sun50i-h6.dtsi
> >>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
> >>>>
> >>>> sun50i-h6-cpu-opp.dtsi
> >>>> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
> >>>>
> >>>> Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
> >>>> ---
> >>>> arch/arm64/boot/dts/allwinner/Makefile | 1 +
> >>>> .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
> >>>> 2 files changed, 1919 insertions(+)
> >>>> create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> >>>>
> >>>> diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
> >>>> index 00bed412ee31..2df5189e0d44 100644
> >>>> --- a/arch/arm64/boot/dts/allwinner/Makefile
> >>>> +++ b/arch/arm64/boot/dts/allwinner/Makefile
> >>>> @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
> >>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
> >>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
> >>>> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
> >>>> +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
> >>>> diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> >>>> new file mode 100644
> >>>> index 000000000000..9d95297a30b8
> >>>> --- /dev/null
> >>>> +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> >>>> @@ -0,0 +1,1918 @@
> >>>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> >>>> +// based on the dts, which is:
> >>>> +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
> >>>> +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
> >>>> +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
> >>>> +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
> >>>> +
> >>>> +/dts-v1/;
> >>>> +
> >>>> +#include <dt-bindings/interrupt-controller/arm-gic.h>
> >>>> +#include <dt-bindings/clock/sun50i-h6-ccu.h>
> >>>> +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
> >>>> +#include <dt-bindings/clock/sun6i-rtc.h>
> >>>> +#include <dt-bindings/clock/sun8i-de2.h>
> >>>> +#include <dt-bindings/clock/sun8i-tcon-top.h>
> >>>> +#include <dt-bindings/reset/sun50i-h6-ccu.h>
> >>>> +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
> >>>> +#include <dt-bindings/reset/sun8i-de2.h>
> >>>> +#include <dt-bindings/thermal/thermal.h>
> >>>> +#include <dt-bindings/gpio/gpio.h>
> >>>> +
> >>>> +/ {
> >>>> + interrupt-parent = <&gic>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + model = "Repka-Pi4-Optimal";
> >>>> + repka-freq = "1.968 GHz";
> >>>> + repka-pinout = "repka-pi4-base";
> >>>> + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
> >>>> +
> >>>> + aliases {
> >>>> + mmc0 = &mmc0;
> >>>> + mmc1 = &mmc1;
> >>>> + mmc2 = &mmc2;
> >>>> + ethernet0 = &emac;
> >>>> + serial0 = &uart0;
> >>>> + serial1 = &uart1;
> >>>> + serial2 = &r_uart;
> >>>> +
> >>>> + spi0 = &spi1;
> >>>> + i2c1 = &i2c0;
> >>>> + i2c2 = &i2c2;
> >>>> + i2c3 = &i2c1;
> >>>> + i2c4 = &i2c3;
> >>>> +
> >>>> + };
> >>>> +
> >>>> + reserved-memory {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges;
> >>>> +
> >>>> + custom_region: region@40010000 {
> >>>> + reg = <0x40010000 0x00070000>;
> >>>> + no-map;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + analog: analog-codec {
> >>>> + compatible = "simple-audio-card";
> >>>> + simple-audio-card,format = "i2s";
> >>>> + simple-audio-card,name = "ac200-audio";
> >>>> + simple-audio-card,mclk-fs = <512>;
> >>>> + status = "okay";
> >>>> +
> >>>> + simple-audio-card,cpu {
> >>>> + sound-dai = <&i2s3>;
> >>>> + };
> >>>> +
> >>>> + simple-audio-card,codec {
> >>>> + sound-dai = <&ac200_codec>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + ac200_pwm_clk: ac200_clk {
> >>>> + compatible = "pwm-clock";
> >>>> + #clock-cells = <0>;
> >>>> + clock-frequency = <24000000>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&pwm1_pin>;
> >>>> + pwms = <&pwm 1 42 0>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + cpus {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + cpu0: cpu@0 {
> >>>> + compatible = "arm,cortex-a53";
> >>>> + device_type = "cpu";
> >>>> + reg = <0>;
> >>>> + enable-method = "psci";
> >>>> + clocks = <&ccu CLK_CPUX>;
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + #cooling-cells = <2>;
> >>>> + operating-points-v2 = <&cpu_opp_table>;
> >>>> + cpu-supply = <®_dcdca>;
> >>>> + };
> >>>> +
> >>>> + cpu1: cpu@1 {
> >>>> + compatible = "arm,cortex-a53";
> >>>> + device_type = "cpu";
> >>>> + reg = <1>;
> >>>> + enable-method = "psci";
> >>>> + clocks = <&ccu CLK_CPUX>;
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + #cooling-cells = <2>;
> >>>> + operating-points-v2 = <&cpu_opp_table>;
> >>>> + };
> >>>> +
> >>>> + cpu2: cpu@2 {
> >>>> + compatible = "arm,cortex-a53";
> >>>> + device_type = "cpu";
> >>>> + reg = <2>;
> >>>> + enable-method = "psci";
> >>>> + clocks = <&ccu CLK_CPUX>;
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + #cooling-cells = <2>;
> >>>> + operating-points-v2 = <&cpu_opp_table>;
> >>>> + };
> >>>> +
> >>>> + cpu3: cpu@3 {
> >>>> + compatible = "arm,cortex-a53";
> >>>> + device_type = "cpu";
> >>>> + reg = <3>;
> >>>> + enable-method = "psci";
> >>>> + clocks = <&ccu CLK_CPUX>;
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + #cooling-cells = <2>;
> >>>> + operating-points-v2 = <&cpu_opp_table>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + de: display-engine {
> >>>> + compatible = "allwinner,sun50i-h6-display-engine";
> >>>> + allwinner,pipelines = <&mixer0>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + osc24M: osc24M_clk {
> >>>> + #clock-cells = <0>;
> >>>> + compatible = "fixed-clock";
> >>>> + clock-frequency = <24000000>;
> >>>> + clock-output-names = "osc24M";
> >>>> + };
> >>>> +
> >>>> + pmu {
> >>>> + compatible = "arm,cortex-a53-pmu";
> >>>> + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
> >>>> + };
> >>>> +
> >>>> + psci {
> >>>> + compatible = "arm,psci-0.2";
> >>>> + method = "smc";
> >>>> + };
> >>>> +
> >>>> + scpi_protocol: scpi {
> >>>> + compatible = "arm,scpi";
> >>>> + mboxes = <&msgbox 2>, <&msgbox 3>;
> >>>> + mbox-names = "tx", "rx";
> >>>> + shmem = <&scpi_sram>;
> >>>> + };
> >>>> +
> >>>> + sound_hdmi: sound_hdmi {
> >>>> + compatible = "allwinner,sun9i-a80-hdmi-audio",
> >>>> + "allwinner,sun50i-h6-hdmi-audio";
> >>>> + status = "okay";
> >>>> + codec {
> >>>> + sound-dai = <&hdmi>;
> >>>> + };
> >>>> +
> >>>> + cpu {
> >>>> + sound-dai = <&i2s1>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + timer {
> >>>> + compatible = "arm,armv8-timer";
> >>>> + arm,no-tick-in-suspend;
> >>>> + interrupts = <GIC_PPI 13
> >>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> >>>> + <GIC_PPI 14
> >>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> >>>> + <GIC_PPI 11
> >>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> >>>> + <GIC_PPI 10
> >>>> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> >>>> + };
> >>>> +
> >>>> +
> >>>> + soc {
> >>>> + compatible = "simple-bus";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges;
> >>>> +
> >>>> + bus@1000000 {
> >>>> + compatible = "allwinner,sun50i-h6-de3",
> >>>> + "allwinner,sun50i-a64-de2";
> >>>> + reg = <0x1000000 0x400000>;
> >>>> + allwinner,sram = <&de2_sram 1>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges = <0 0x1000000 0x400000>;
> >>>> +
> >>>> + display_clocks: clock@0 {
> >>>> + compatible = "allwinner,sun50i-h6-de3-clk";
> >>>> + reg = <0x0 0x10000>;
> >>>> + clocks = <&ccu CLK_BUS_DE>,
> >>>> + <&ccu CLK_DE>;
> >>>> + clock-names = "bus",
> >>>> + "mod";
> >>>> + resets = <&ccu RST_BUS_DE>;
> >>>> + #clock-cells = <1>;
> >>>> + #reset-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + mixer0: mixer@100000 {
> >>>> + compatible = "allwinner,sun50i-h6-de3-mixer-0";
> >>>> + reg = <0x100000 0x100000>;
> >>>> + clocks = <&display_clocks CLK_BUS_MIXER0>,
> >>>> + <&display_clocks CLK_MIXER0>;
> >>>> + clock-names = "bus",
> >>>> + "mod";
> >>>> + resets = <&display_clocks RST_MIXER0>;
> >>>> + iommus = <&iommu 0>;
> >>>> +
> >>>> + ports {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + mixer0_out: port@1 {
> >>>> + reg = <1>;
> >>>> +
> >>>> + mixer0_out_tcon_top_mixer0: endpoint {
> >>>> + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> +
> >>>> + video-codec-g2@1c00000 {
> >>>> + compatible = "allwinner,sun50i-h6-vpu-g2";
> >>>> + reg = <0x01c00000 0x1000>;
> >>>> + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
> >>>> + clock-names = "bus", "mod";
> >>>> + resets = <&ccu RST_BUS_VP9>;
> >>>> + iommus = <&iommu 5>;
> >>>> + };
> >>>> +
> >>>> + deinterlace: deinterlace@1420000 {
> >>>> + compatible = "allwinner,sun50i-h6-deinterlace";
> >>>> + reg = <0x01420000 0x2000>;
> >>>> + clocks = <&ccu CLK_BUS_DEINTERLACE>,
> >>>> + <&ccu CLK_DEINTERLACE>,
> >>>> + <&ccu CLK_MBUS_DEINTERLACE>;
> >>>> + clock-names = "bus", "mod", "ram";
> >>>> + resets = <&ccu RST_BUS_DEINTERLACE>;
> >>>> + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + iommus = <&iommu 2>;
> >>>> + };
> >>>> +
> >>>> + video-codec@1c0e000 {
> >>>> + compatible = "allwinner,sun50i-h6-video-engine";
> >>>> + reg = <0x01c0e000 0x2000>;
> >>>> + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
> >>>> + <&ccu CLK_MBUS_VE>;
> >>>> + clock-names = "ahb", "mod", "ram";
> >>>> + resets = <&ccu RST_BUS_VE>;
> >>>> + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + allwinner,sram = <&ve_sram 1>;
> >>>> + iommus = <&iommu 1>, <&iommu 3>;
> >>>> + };
> >>>> +
> >>>> + gpu: gpu@1800000 {
> >>>> + compatible = "allwinner,sun50i-h6-mali",
> >>>> + "arm,mali-t720";
> >>>> + reg = <0x01800000 0x4000>;
> >>>> + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + interrupt-names = "job", "mmu", "gpu";
> >>>> + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
> >>>> + clock-names = "core", "bus";
> >>>> + resets = <&ccu RST_BUS_GPU>;
> >>>> + #cooling-cells = <2>;
> >>>> + status = "okay";
> >>>> + operating-points-v2 = <&gpu_opp_table>;
> >>>> + mali-supply = <®_dcdcc>;
> >>>> + };
> >>>> +
> >>>> + crypto: crypto@1904000 {
> >>>> + compatible = "allwinner,sun50i-h6-crypto";
> >>>> + reg = <0x01904000 0x1000>;
> >>>> + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
> >>>> + clock-names = "bus", "mod", "ram";
> >>>> + resets = <&ccu RST_BUS_CE>;
> >>>> + };
> >>>> +
> >>>> + syscon: syscon@3000000 {
> >>>> + compatible = "allwinner,sun50i-h6-system-control",
> >>>> + "allwinner,sun50i-a64-system-control";
> >>>> + reg = <0x03000000 0x1000>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges;
> >>>> +
> >>>> + sram_a2: sram@100000 {
> >>>> + compatible = "mmio-sram";
> >>>> + reg = <0x00100000 0x18000>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges = <0 0x00100000 0x18000>;
> >>>> +
> >>>> + scpi_sram: scp-shmem@17c00 {
> >>>> + compatible = "arm,scp-shmem";
> >>>> + reg = <0x17c00 0x200>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + sram_c: sram@28000 {
> >>>> + compatible = "mmio-sram";
> >>>> + reg = <0x00028000 0x1e000>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges = <0 0x00028000 0x1e000>;
> >>>> +
> >>>> + de2_sram: sram-section@0 {
> >>>> + compatible = "allwinner,sun50i-h6-sram-c",
> >>>> + "allwinner,sun50i-a64-sram-c";
> >>>> + reg = <0x0000 0x1e000>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + sram_c1: sram@1a00000 {
> >>>> + compatible = "mmio-sram";
> >>>> + reg = <0x01a00000 0x200000>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> + ranges = <0 0x01a00000 0x200000>;
> >>>> +
> >>>> + ve_sram: sram-section@0 {
> >>>> + compatible = "allwinner,sun50i-h6-sram-c1",
> >>>> + "allwinner,sun4i-a10-sram-c1";
> >>>> + reg = <0x000000 0x200000>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + ccu: clock@3001000 {
> >>>> + compatible = "allwinner,sun50i-h6-ccu";
> >>>> + reg = <0x03001000 0x1000>;
> >>>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
> >>>> + clock-names = "hosc", "losc", "iosc";
> >>>> + protected-clocks = <CLK_BUS_MSGBOX>;
> >>>> + #clock-cells = <1>;
> >>>> + #reset-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + dma: dma-controller@3002000 {
> >>>> + compatible = "allwinner,sun50i-h6-dma";
> >>>> + reg = <0x03002000 0x1000>;
> >>>> + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
> >>>> + clock-names = "bus", "mbus";
> >>>> + dma-channels = <16>;
> >>>> + dma-requests = <46>;
> >>>> + resets = <&ccu RST_BUS_DMA>;
> >>>> + #dma-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + msgbox: mailbox@3003000 {
> >>>> + compatible = "allwinner,sun50i-h6-msgbox",
> >>>> + "allwinner,sun6i-a31-msgbox";
> >>>> + reg = <0x03003000 0x1000>;
> >>>> + clocks = <&ccu CLK_BUS_MSGBOX>;
> >>>> + resets = <&ccu RST_BUS_MSGBOX>;
> >>>> + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + #mbox-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + gic: interrupt-controller@3021000 {
> >>>> + compatible = "arm,gic-400";
> >>>> + reg = <0x03021000 0x1000>,
> >>>> + <0x03022000 0x2000>,
> >>>> + <0x03024000 0x2000>,
> >>>> + <0x03026000 0x2000>;
> >>>> + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <3>;
> >>>> + };
> >>>> +
> >>>> + sid: efuse@3006000 {
> >>>> + compatible = "allwinner,sun50i-h6-sid";
> >>>> + reg = <0x03006000 0x400>;
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <1>;
> >>>> +
> >>>> + ths_calibration: thermal-sensor-calibration@14 {
> >>>> + reg = <0x14 0x8>;
> >>>> + };
> >>>> +
> >>>> + cpu_speed_grade: cpu-speed-grade@1c {
> >>>> + reg = <0x1c 0x4>;
> >>>> + };
> >>>> +
> >>>> + ephy_calib: ephy_calib@2c {
> >>>> + reg = <0x2c 0x2>;
> >>>> + };
> >>>> +
> >>>> + ac200_bg: ac200_bg@30 {
> >>>> + reg = <0x30 0x2>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + timer@3009000 {
> >>>> + compatible = "allwinner,sun50i-h6-timer",
> >>>> + "allwinner,sun8i-a23-timer";
> >>>> + reg = <0x03009000 0xa0>;
> >>>> + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&osc24M>;
> >>>> + };
> >>>> +
> >>>> + watchdog: watchdog@30090a0 {
> >>>> + compatible = "allwinner,sun50i-h6-wdt",
> >>>> + "allwinner,sun6i-a31-wdt";
> >>>> + reg = <0x030090a0 0x20>;
> >>>> + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&osc24M>;
> >>>> + /* Broken on some H6 boards */
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + pwm: pwm@300a000 {
> >>>> + compatible = "allwinner,sun50i-h6-pwm";
> >>>> + reg = <0x0300a000 0x400>;
> >>>> + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
> >>>> + clock-names = "mod", "bus";
> >>>> + resets = <&ccu RST_BUS_PWM>;
> >>>> + #pwm-cells = <3>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + pio: pinctrl@300b000 {
> >>>> + compatible = "allwinner,sun50i-h6-pinctrl";
> >>>> + reg = <0x0300b000 0x400>;
> >>>> + interrupt-parent = <&r_intc>;
> >>>> + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
> >>>> + clock-names = "apb", "hosc", "losc";
> >>>> + gpio-controller;
> >>>> + #gpio-cells = <3>;
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <3>;
> >>>> + vcc-pc-supply = <®_bldo2>;
> >>>> + vcc-pd-supply = <®_cldo1>;
> >>>> + vcc-pg-supply = <®_vcc_wifi_io>;
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + ext_rgmii_pins: rgmii-pins {
> >>>> + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
> >>>> + "PD5", "PD7", "PD8", "PD9", "PD10",
> >>>> + "PD11", "PD12", "PD13", "PD19", "PD20";
> >>>> + function = "emac";
> >>>> + drive-strength = <40>;
> >>>> + };
> >>>> +
> >>>> + ext_rmii_pins: rmii_pins {
> >>>> + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
> >>>> + "PA5", "PA6", "PA7", "PA8", "PA9";
> >>>> + function = "emac";
> >>>> + drive-strength = <40>;
> >>>> + };
> >>>> +
> >>>> + hdmi_pins: hdmi-pins {
> >>>> + pins = "PH8", "PH9", "PH10";
> >>>> + function = "hdmi";
> >>>> + };
> >>>> +
> >>>> + i2c0_pins: i2c0-pins {
> >>>> + pins = "PD25", "PD26";
> >>>> + function = "i2c0";
> >>>> + };
> >>>> +
> >>>> + i2c1_pins: i2c1-pins {
> >>>> + pins = "PH5", "PH6";
> >>>> + function = "i2c1";
> >>>> + };
> >>>> +
> >>>> + i2c2_pins: i2c2-pins {
> >>>> + pins = "PD23", "PD24";
> >>>> + function = "i2c2";
> >>>> + };
> >>>> +
> >>>> + i2c3_pins: i2c3-pins {
> >>>> + pins = "PB17", "PB18";
> >>>> + function = "i2c3";
> >>>> + bias-pull-up;
> >>>> + };
> >>>> +
> >>>> + i2s3_pins: i2s3-pins {
> >>>> + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
> >>>> + function = "i2s3";
> >>>> + };
> >>>> +
> >>>> + mmc0_pins: mmc0-pins {
> >>>> + pins = "PF0", "PF1", "PF2", "PF3",
> >>>> + "PF4", "PF5";
> >>>> + function = "mmc0";
> >>>> + drive-strength = <30>;
> >>>> + bias-pull-up;
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + mmc1_pins: mmc1-pins {
> >>>> + pins = "PG0", "PG1", "PG2", "PG3",
> >>>> + "PG4", "PG5";
> >>>> + function = "mmc1";
> >>>> + drive-strength = <30>;
> >>>> + bias-pull-up;
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + mmc2_pins: mmc2-pins {
> >>>> + pins = "PC1", "PC4", "PC5", "PC6",
> >>>> + "PC7", "PC8", "PC9", "PC10",
> >>>> + "PC11", "PC12", "PC13", "PC14";
> >>>> + function = "mmc2";
> >>>> + drive-strength = <30>;
> >>>> + bias-pull-up;
> >>>> + };
> >>>> +
> >>>> + pwm1_pin: pwm1-pin {
> >>>> + pins = "PB19";
> >>>> + function = "pwm1";
> >>>> + };
> >>>> +
> >>>> + pwm_pin: pwm-pin {
> >>>> + pins = "PD22";
> >>>> + function = "pwm";
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + spi0_pins: spi0-pins {
> >>>> + pins = "PC0", "PC2", "PC3";
> >>>> + function = "spi0";
> >>>> + };
> >>>> +
> >>>> + /* pin shared with MMC2-CMD (eMMC) */
> >>>> + /omit-if-no-ref/
> >>>> + spi0_cs_pin: spi0-cs-pin {
> >>>> + pins = "PC5";
> >>>> + function = "spi0";
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + spi1_pins: spi1-pins {
> >>>> + pins = "PH4", "PH5", "PH6";
> >>>> + function = "spi1";
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + spi1_cs_pin: spi1-cs-pin {
> >>>> + pins = "PH3";
> >>>> + function = "spi1";
> >>>> + };
> >>>> +
> >>>> + /omit-if-no-ref/
> >>>> + spdif_tx_pin: spdif-tx-pin {
> >>>> + pins = "PH7";
> >>>> + function = "spdif";
> >>>> + };
> >>>> +
> >>>> + uart0_ph_pins: uart0-ph-pins {
> >>>> + pins = "PH0", "PH1";
> >>>> + function = "uart0";
> >>>> + };
> >>>> +
> >>>> + uart1_pins: uart1-pins {
> >>>> + pins = "PG6", "PG7";
> >>>> + function = "uart1";
> >>>> + };
> >>>> +
> >>>> + uart1_rts_cts_pins: uart1-rts-cts-pins {
> >>>> + pins = "PG8", "PG9";
> >>>> + function = "uart1";
> >>>> + };
> >>>> +
> >>>> + uart2_pins: uart2-pins {
> >>>> + pins = "PD19", "PD20";
> >>>> + function = "uart2";
> >>>> + };
> >>>> +
> >>>> + uart2_rts_cts_pins: uart2-rts-cts-pins {
> >>>> + pins = "PD21", "PD22";
> >>>> + function = "uart2";
> >>>> + };
> >>>> +
> >>>> + uart3_pins: uart3-pins {
> >>>> + pins = "PD23", "PD24";
> >>>> + function = "uart3";
> >>>> + };
> >>>> +
> >>>> + uart3_rts_cts_pins: uart3-rts-cts-pins {
> >>>> + pins = "PD25", "PD26";
> >>>> + function = "uart3";
> >>>> + };
> >>>> +
> >>>> + i2s2_pins: i2s2-pins {
> >>>> + pins = "PG10", "PG11", "PG12", "PG13";
> >>>> + function = "i2s2";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + iommu: iommu@30f0000 {
> >>>> + compatible = "allwinner,sun50i-h6-iommu";
> >>>> + reg = <0x030f0000 0x10000>;
> >>>> + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_IOMMU>;
> >>>> + resets = <&ccu RST_BUS_IOMMU>;
> >>>> + #iommu-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + mmc0: mmc@4020000 {
> >>>> + compatible = "allwinner,sun50i-h6-mmc",
> >>>> + "allwinner,sun50i-a64-mmc";
> >>>> + reg = <0x04020000 0x1000>;
> >>>> + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
> >>>> + clock-names = "ahb", "mmc";
> >>>> + resets = <&ccu RST_BUS_MMC0>;
> >>>> + reset-names = "ahb";
> >>>> + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&mmc0_pins>;
> >>>> + max-frequency = <150000000>;
> >>>> + status = "okay";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + vmmc-supply = <®_cldo1>;
> >>>> + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
> >>>> + bus-width = <4>;
> >>>> + };
> >>>> +
> >>>> + mmc1: mmc@4021000 {
> >>>> + compatible = "allwinner,sun50i-h6-mmc",
> >>>> + "allwinner,sun50i-a64-mmc";
> >>>> + reg = <0x04021000 0x1000>;
> >>>> + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
> >>>> + clock-names = "ahb", "mmc";
> >>>> + resets = <&ccu RST_BUS_MMC1>;
> >>>> + reset-names = "ahb";
> >>>> + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&mmc1_pins>;
> >>>> + max-frequency = <150000000>;
> >>>> + status = "okay";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + vmmc-supply = <®_vcc33_wifi>;
> >>>> + vqmmc-supply = <®_vcc_wifi_io>;
> >>>> + mmc-pwrseq = <&wifi_pwrseq>;
> >>>> + bus-width = <4>;
> >>>> + non-removable;
> >>>> +
> >>>> + brcm: sdio-wifi@1 {
> >>>> + reg = <1>;
> >>>> + compatible = "brcm,bcm4329-fmac";
> >>>> + interrupt-parent = <&r_pio>;
> >>>> + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
> >>>> + interrupt-names = "host-wake";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + mmc2: mmc@4022000 {
> >>>> + compatible = "allwinner,sun50i-h6-emmc";
> >>>> + reg = <0x04022000 0x1000>;
> >>>> + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
> >>>> + clock-names = "ahb", "mmc";
> >>>> + resets = <&ccu RST_BUS_MMC2>;
> >>>> + reset-names = "ahb";
> >>>> + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&mmc2_pins>;
> >>>> + max-frequency = <150000000>;
> >>>> + status = "okay";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + vmmc-supply = <®_cldo1>;
> >>>> + vqmmc-supply = <®_bldo2>;
> >>>> + cap-mmc-hw-reset;
> >>>> + non-removable;
> >>>> + bus-width = <8>;
> >>>> + };
> >>>> +
> >>>> + uart0: serial@5000000 {
> >>>> + compatible = "snps,dw-apb-uart";
> >>>> + reg = <0x05000000 0x400>;
> >>>> + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + reg-shift = <2>;
> >>>> + reg-io-width = <4>;
> >>>> + clocks = <&ccu CLK_BUS_UART0>;
> >>>> + resets = <&ccu RST_BUS_UART0>;
> >>>> + status = "okay";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&uart0_ph_pins>;
> >>>> + };
> >>>> +
> >>>> + uart1: serial@5000400 {
> >>>> + compatible = "snps,dw-apb-uart";
> >>>> + reg = <0x05000400 0x400>;
> >>>> + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + reg-shift = <2>;
> >>>> + reg-io-width = <4>;
> >>>> + clocks = <&ccu CLK_BUS_UART1>;
> >>>> + resets = <&ccu RST_BUS_UART1>;
> >>>> + status = "okay";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
> >>>> + uart-has-rtscts;
> >>>> +
> >>>> + bluetooth {
> >>>> + compatible = "brcm,bcm4345c5";
> >>>> + clocks = <&rtc 1>;
> >>>> + clock-names = "lpo";
> >>>> + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
> >>>> + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
> >>>> + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
> >>>> + max-speed = <1500000>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + uart2: serial@5000800 {
> >>>> + compatible = "snps,dw-apb-uart";
> >>>> + reg = <0x05000800 0x400>;
> >>>> + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + reg-shift = <2>;
> >>>> + reg-io-width = <4>;
> >>>> + clocks = <&ccu CLK_BUS_UART2>;
> >>>> + resets = <&ccu RST_BUS_UART2>;
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + uart3: serial@5000c00 {
> >>>> + compatible = "snps,dw-apb-uart";
> >>>> + reg = <0x05000c00 0x400>;
> >>>> + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + reg-shift = <2>;
> >>>> + reg-io-width = <4>;
> >>>> + clocks = <&ccu CLK_BUS_UART3>;
> >>>> + resets = <&ccu RST_BUS_UART3>;
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + i2c0: i2c@5002000 {
> >>>> + compatible = "allwinner,sun50i-h6-i2c",
> >>>> + "allwinner,sun6i-a31-i2c";
> >>>> + reg = <0x05002000 0x400>;
> >>>> + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2C0>;
> >>>> + resets = <&ccu RST_BUS_I2C0>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&i2c0_pins>;
> >>>> + status = "disabled";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + i2c1: i2c@5002400 {
> >>>> + compatible = "allwinner,sun50i-h6-i2c",
> >>>> + "allwinner,sun6i-a31-i2c";
> >>>> + reg = <0x05002400 0x400>;
> >>>> + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2C1>;
> >>>> + resets = <&ccu RST_BUS_I2C1>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&i2c1_pins>;
> >>>> + status = "disabled";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + i2c2: i2c@5002800 {
> >>>> + compatible = "allwinner,sun50i-h6-i2c",
> >>>> + "allwinner,sun6i-a31-i2c";
> >>>> + reg = <0x05002800 0x400>;
> >>>> + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2C2>;
> >>>> + resets = <&ccu RST_BUS_I2C2>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&i2c2_pins>;
> >>>> + status = "disabled";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + i2c3: i2c@5002c00 {
> >>>> + compatible = "allwinner,sun50i-h6-i2c",
> >>>> + "allwinner,sun6i-a31-i2c";
> >>>> + reg = <0x05002c00 0x400>;
> >>>> + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2C3>;
> >>>> + resets = <&ccu RST_BUS_I2C3>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&i2c3_pins>;
> >>>> + clock-frequency = <100000>;
> >>>> + status = "okay"; /* нужно для ac200 */
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + ac200: mfd@10 {
> >>>> + compatible = "x-powers,ac200";
> >>>> + reg = <0x10>;
> >>>> + clocks = <&ac200_pwm_clk>;
> >>>> + interrupt-parent = <&pio>;
> >>>> + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <1>;
> >>>> + nvmem-cells = <&ac200_bg>;
> >>>> + nvmem-cell-names = "bandgap";
> >>>> +
> >>>> + ac200_ephy_ctl: syscon {
> >>>> + compatible = "x-powers,ac200-ephy-ctl";
> >>>> + nvmem-cells = <&ephy_calib>;
> >>>> + nvmem-cell-names = "calibration";
> >>>> + #clock-cells = <0>;
> >>>> + #reset-cells = <0>;
> >>>> + phy-mode = "rmii";
> >>>> + status = "okay";
> >>>> + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
> >>>> + phy-address = <1>;
> >>>> + };
> >>>> +
> >>>> + ac200_codec: codec {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "x-powers,ac200-codec";
> >>>> + status = "okay";
> >>>> + avcc-supply = <®_aldo2>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + spi1: spi@5011000 {
> >>>> + compatible = "allwinner,sun50i-h6-spi",
> >>>> + "allwinner,sun8i-h3-spi";
> >>>> + reg = <0x05011000 0x1000>;
> >>>> + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
> >>>> + clock-names = "ahb", "mod";
> >>>> + dmas = <&dma 23>, <&dma 23>;
> >>>> + dma-names = "rx", "tx";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
> >>>> + resets = <&ccu RST_BUS_SPI1>;
> >>>> + status = "disabled";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + emac: ethernet@5020000 {
> >>>> + compatible = "allwinner,sun50i-h6-emac",
> >>>> + "allwinner,sun50i-a64-emac";
> >>>> + syscon = <&syscon>;
> >>>> + reg = <0x05020000 0x10000>;
> >>>> + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + interrupt-names = "macirq";
> >>>> + resets = <&ccu RST_BUS_EMAC>;
> >>>> + reset-names = "stmmaceth";
> >>>> + clocks = <&ccu CLK_BUS_EMAC>;
> >>>> + clock-names = "stmmaceth";
> >>>> + status = "okay";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&ext_rmii_pins>;
> >>>> + phy-mode = "rmii";
> >>>> + phy-handle = <&ext_rmii_phy>;
> >>>> +
> >>>> + mdio: mdio {
> >>>> + compatible = "snps,dwmac-mdio";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + ext_rmii_phy: ethernet-phy@1 {
> >>>> + compatible = "ethernet-phy-id0044.1400",
> >>>> + "ethernet-phy-ieee802.3-c22";
> >>>> + reg = <1>;
> >>>> + resets = <&ac200_ephy_ctl>;
> >>>> + reset-names = "phy";
> >>>> + clocks = <&ac200_ephy_ctl>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + i2s3: i2s@508f000 {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "allwinner,sun50i-h6-i2s";
> >>>> + reg = <0x0508f000 0x1000>;
> >>>> + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
> >>>> + clock-names = "apb", "mod";
> >>>> + dmas = <&dma 6>, <&dma 6>;
> >>>> + resets = <&ccu RST_BUS_I2S3>;
> >>>> + dma-names = "rx", "tx";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&i2s3_pins>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + i2s2: i2s@5092000 {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "allwinner,sun50i-h6-i2s";
> >>>> + reg = <0x05092000 0x1000>;
> >>>> + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
> >>>> + clock-names = "apb", "mod";
> >>>> + dmas = <&dma 5>, <&dma 5>;
> >>>> + resets = <&ccu RST_BUS_I2S2>;
> >>>> + dma-names = "rx", "tx";
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + i2s1: i2s@5091000 {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "allwinner,sun50i-h6-i2s";
> >>>> + reg = <0x05091000 0x1000>;
> >>>> + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
> >>>> + clock-names = "apb", "mod";
> >>>> + dmas = <&dma 4>, <&dma 4>;
> >>>> + resets = <&ccu RST_BUS_I2S1>;
> >>>> + dma-names = "rx", "tx";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + spdif: spdif@5093000 {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "allwinner,sun50i-h6-spdif";
> >>>> + reg = <0x05093000 0x400>;
> >>>> + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
> >>>> + clock-names = "apb", "spdif";
> >>>> + resets = <&ccu RST_BUS_SPDIF>;
> >>>> + dmas = <&dma 2>, <&dma 2>;
> >>>> + dma-names = "rx", "tx";
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + usb2otg: usb@5100000 {
> >>>> + compatible = "allwinner,sun50i-h6-musb",
> >>>> + "allwinner,sun8i-a33-musb";
> >>>> + reg = <0x05100000 0x0400>;
> >>>> + clocks = <&ccu CLK_BUS_OTG>;
> >>>> + resets = <&ccu RST_BUS_OTG>;
> >>>> + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + interrupt-names = "mc";
> >>>> + phys = <&usb2phy 0>;
> >>>> + phy-names = "usb";
> >>>> + extcon = <&usb2phy 0>;
> >>>> + status = "okay";
> >>>> + dr_mode = "host";
> >>>> + };
> >>>> +
> >>>> + usb2phy: phy@5100400 {
> >>>> + compatible = "allwinner,sun50i-h6-usb-phy";
> >>>> + reg = <0x05100400 0x24>,
> >>>> + <0x05101800 0x4>,
> >>>> + <0x05311800 0x4>;
> >>>> + reg-names = "phy_ctrl",
> >>>> + "pmu0",
> >>>> + "pmu3";
> >>>> + clocks = <&ccu CLK_USB_PHY0>,
> >>>> + <&ccu CLK_USB_PHY3>;
> >>>> + clock-names = "usb0_phy",
> >>>> + "usb3_phy";
> >>>> + resets = <&ccu RST_USB_PHY0>,
> >>>> + <&ccu RST_USB_PHY3>;
> >>>> + reset-names = "usb0_reset",
> >>>> + "usb3_reset";
> >>>> + status = "okay";
> >>>> + #phy-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + ehci0: usb@5101000 {
> >>>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> >>>> + reg = <0x05101000 0x100>;
> >>>> + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_OHCI0>,
> >>>> + <&ccu CLK_BUS_EHCI0>,
> >>>> + <&ccu CLK_USB_OHCI0>;
> >>>> + resets = <&ccu RST_BUS_OHCI0>,
> >>>> + <&ccu RST_BUS_EHCI0>;
> >>>> + phys = <&usb2phy 0>;
> >>>> + phy-names = "usb";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + ohci0: usb@5101400 {
> >>>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> >>>> + reg = <0x05101400 0x100>;
> >>>> + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_OHCI0>,
> >>>> + <&ccu CLK_USB_OHCI0>;
> >>>> + resets = <&ccu RST_BUS_OHCI0>;
> >>>> + phys = <&usb2phy 0>;
> >>>> + phy-names = "usb";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + dwc3: usb@5200000 {
> >>>> + compatible = "snps,dwc3";
> >>>> + reg = <0x05200000 0x10000>;
> >>>> + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_XHCI>,
> >>>> + <&ccu CLK_BUS_XHCI>,
> >>>> + <&rtc CLK_OSC32K>;
> >>>> + clock-names = "ref", "bus_early", "suspend";
> >>>> + resets = <&ccu RST_BUS_XHCI>;
> >>>> + /*
> >>>> + * The datasheet of the chip doesn't declare the
> >>>> + * peripheral function, and there's no boards known
> >>>> + * to have a USB Type-B port routed to the port.
> >>>> + * In addition, no one has tested the peripheral
> >>>> + * function yet.
> >>>> + * So set the dr_mode to "host" in the DTSI file.
> >>>> + */
> >>>> + dr_mode = "host";
> >>>> + phys = <&usb3phy>;
> >>>> + phy-names = "usb3-phy";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + usb3phy: phy@5210000 {
> >>>> + compatible = "allwinner,sun50i-h6-usb3-phy";
> >>>> + reg = <0x5210000 0x10000>;
> >>>> + clocks = <&ccu CLK_USB_PHY1>;
> >>>> + resets = <&ccu RST_USB_PHY1>;
> >>>> + #phy-cells = <0>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + ehci3: usb@5311000 {
> >>>> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> >>>> + reg = <0x05311000 0x100>;
> >>>> + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_OHCI3>,
> >>>> + <&ccu CLK_BUS_EHCI3>,
> >>>> + <&ccu CLK_USB_OHCI3>;
> >>>> + resets = <&ccu RST_BUS_OHCI3>,
> >>>> + <&ccu RST_BUS_EHCI3>;
> >>>> + phys = <&usb2phy 3>;
> >>>> + phy-names = "usb";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + ohci3: usb@5311400 {
> >>>> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> >>>> + reg = <0x05311400 0x100>;
> >>>> + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_OHCI3>,
> >>>> + <&ccu CLK_USB_OHCI3>;
> >>>> + resets = <&ccu RST_BUS_OHCI3>;
> >>>> + phys = <&usb2phy 3>;
> >>>> + phy-names = "usb";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + pcie: pcie@5400000 {
> >>>> + #address-cells = <3>;
> >>>> + #size-cells = <2>;
> >>>> + compatible = "pine64,allwinner-h6-pcie-wrapped";
> >>>> + reg = <0x05400000 0x4000>,
> >>>> + <0x05410000 0x10000>;
> >>>> + reg-names = "dbi", "config";
> >>>> + device_type = "pci";
> >>>> + bus-range = <0x00 0xff>;
> >>>> + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
> >>>> + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
> >>>> + num-lanes = <1>;
> >>>> + max-link-speed = <2>;
> >>>> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + interrupt-names = "msi", "linkup";
> >>>> + clocks = <&ccu CLK_PCIE_REF_OUT>,
> >>>> + <&ccu CLK_PCIE_MAXI>,
> >>>> + <&ccu CLK_PCIE_AUX>,
> >>>> + <&ccu CLK_BUS_PCIE>;
> >>>> + clock-names = "ref", "axi", "aux", "bus";
> >>>> + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
> >>>> + reset-names = "power", "bus";
> >>>> + #interrupt-cells = <1>;
> >>>> + interrupt-map-mask = <0 0 0 0>;
> >>>> + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + status = "okay";
> >>>> + vcc-supply = <®_bldo2>;
> >>>> + vdd-supply = <®_dcdcd>;
> >>>> + slot-supply = <®_vcc33_wifi>;
> >>>> + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
> >>>> + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
> >>>> + /* wake-gpio = <&r_pio 0 4 0>; */
> >>>> + };
> >>>> +
> >>>> +
> >>>> + hdmi: hdmi@6000000 {
> >>>> + #sound-dai-cells = <0>;
> >>>> + compatible = "allwinner,sun50i-h6-dw-hdmi";
> >>>> + reg = <0x06000000 0x10000>;
> >>>> + reg-io-width = <1>;
> >>>> + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
> >>>> + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
> >>>> + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
> >>>> + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
> >>>> + "hdcp-bus";
> >>>> + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
> >>>> + reset-names = "ctrl", "hdcp";
> >>>> + phys = <&hdmi_phy>;
> >>>> + phy-names = "phy";
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&hdmi_pins>;
> >>>> + status = "okay";
> >>>> +
> >>>> + ports {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + hdmi_in: port@0 {
> >>>> + reg = <0>;
> >>>> +
> >>>> + hdmi_in_tcon_top: endpoint {
> >>>> + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + hdmi_out: port@1 {
> >>>> + reg = <1>;
> >>>> +
> >>>> + hdmi_out_con: endpoint {
> >>>> + remote-endpoint = <&hdmi_con_in>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + hdmi_phy: hdmi-phy@6010000 {
> >>>> + compatible = "allwinner,sun50i-h6-hdmi-phy";
> >>>> + reg = <0x06010000 0x10000>;
> >>>> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
> >>>> + clock-names = "bus", "mod";
> >>>> + resets = <&ccu RST_BUS_HDMI>;
> >>>> + reset-names = "phy";
> >>>> + #phy-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + tcon_top: tcon-top@6510000 {
> >>>> + compatible = "allwinner,sun50i-h6-tcon-top";
> >>>> + reg = <0x06510000 0x1000>;
> >>>> + clocks = <&ccu CLK_BUS_TCON_TOP>,
> >>>> + <&ccu CLK_TCON_TV0>;
> >>>> + clock-names = "bus",
> >>>> + "tcon-tv0";
> >>>> + clock-output-names = "tcon-top-tv0";
> >>>> + resets = <&ccu RST_BUS_TCON_TOP>;
> >>>> + #clock-cells = <1>;
> >>>> +
> >>>> + ports {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + tcon_top_mixer0_in: port@0 {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + reg = <0>;
> >>>> +
> >>>> + tcon_top_mixer0_in_mixer0: endpoint@0 {
> >>>> + reg = <0>;
> >>>> + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + tcon_top_mixer0_out: port@1 {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + reg = <1>;
> >>>> +
> >>>> + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
> >>>> + reg = <2>;
> >>>> + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + tcon_top_hdmi_in: port@4 {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + reg = <4>;
> >>>> +
> >>>> + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
> >>>> + reg = <0>;
> >>>> + remote-endpoint = <&tcon_tv_out_tcon_top>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + tcon_top_hdmi_out: port@5 {
> >>>> + reg = <5>;
> >>>> +
> >>>> + tcon_top_hdmi_out_hdmi: endpoint {
> >>>> + remote-endpoint = <&hdmi_in_tcon_top>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + tcon_tv: lcd-controller@6515000 {
> >>>> + compatible = "allwinner,sun50i-h6-tcon-tv",
> >>>> + "allwinner,sun8i-r40-tcon-tv";
> >>>> + reg = <0x06515000 0x1000>;
> >>>> + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_TCON_TV0>,
> >>>> + <&tcon_top CLK_TCON_TOP_TV0>;
> >>>> + clock-names = "ahb",
> >>>> + "tcon-ch1";
> >>>> + resets = <&ccu RST_BUS_TCON_TV0>;
> >>>> + reset-names = "lcd";
> >>>> +
> >>>> + ports {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + tcon_tv_in: port@0 {
> >>>> + reg = <0>;
> >>>> +
> >>>> + tcon_tv_in_tcon_top_mixer0: endpoint {
> >>>> + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + tcon_tv_out: port@1 {
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + reg = <1>;
> >>>> +
> >>>> + tcon_tv_out_tcon_top: endpoint@1 {
> >>>> + reg = <1>;
> >>>> + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + r_uart: serial@7080000 {
> >>>> + compatible = "snps,dw-apb-uart";
> >>>> + reg = <0x07080000 0x400>;
> >>>> + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + reg-shift = <2>;
> >>>> + reg-io-width = <4>;
> >>>> + clocks = <&r_ccu CLK_R_APB2_UART>;
> >>>> + resets = <&r_ccu RST_R_APB2_UART>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&r_uart_pins>;
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + rtc: rtc@7000000 {
> >>>> + compatible = "allwinner,sun50i-h6-rtc";
> >>>> + reg = <0x07000000 0x400>;
> >>>> + interrupt-parent = <&r_intc>;
> >>>> + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clock-output-names = "osc32k", "osc32k-out", "iosc";
> >>>> + #clock-cells = <1>;
> >>>> + clocks = <&ext_osc32k>;
> >>>> + };
> >>>> +
> >>>> + r_ccu: clock@7010000 {
> >>>> + compatible = "allwinner,sun50i-h6-r-ccu";
> >>>> + reg = <0x07010000 0x400>;
> >>>> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
> >>>> + <&ccu CLK_PLL_PERIPH0>;
> >>>> + clock-names = "hosc", "losc", "iosc", "pll-periph";
> >>>> + protected-clocks = <CLK_R_APB1_TWD>;
> >>>> + #clock-cells = <1>;
> >>>> + #reset-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + r_watchdog: watchdog@7020400 {
> >>>> + compatible = "allwinner,sun50i-h6-wdt",
> >>>> + "allwinner,sun6i-a31-wdt";
> >>>> + reg = <0x07020400 0x20>;
> >>>> + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&osc24M>;
> >>>> + };
> >>>> +
> >>>> + r_intc: interrupt-controller@7021000 {
> >>>> + compatible = "allwinner,sun50i-h6-r-intc";
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <3>;
> >>>> + reg = <0x07021000 0x400>;
> >>>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + };
> >>>> +
> >>>> + r_pwm: pwm@7020C00 {
> >>>> + compatible = "allwinner,sun50i-h6-pwm";
> >>>> + reg = <0x07020C00 0x400>;
> >>>> + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
> >>>> + clock-names = "mod", "bus";
> >>>> + resets = <&ccu RST_R_APB1_PWM>;
> >>>> + #pwm-cells = <3>;
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + r_pio: pinctrl@7022000 {
> >>>> + compatible = "allwinner,sun50i-h6-r-pinctrl";
> >>>> + reg = <0x07022000 0x400>;
> >>>> + interrupt-parent = <&r_intc>;
> >>>> + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
> >>>> + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
> >>>> + <&rtc CLK_OSC32K>;
> >>>> + clock-names = "apb", "hosc", "losc";
> >>>> + gpio-controller;
> >>>> + #gpio-cells = <3>;
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <3>;
> >>>> +
> >>>> + r_i2c_pins: r-i2c-pins {
> >>>> + pins = "PL0", "PL1";
> >>>> + function = "s_i2c";
> >>>> + };
> >>>> +
> >>>> + r_ir_rx_pin: r-ir-rx-pin {
> >>>> + pins = "PL9";
> >>>> + function = "s_cir_rx";
> >>>> + };
> >>>> +
> >>>> + r_rsb_pins: r-rsb-pins {
> >>>> + pins = "PL0", "PL1";
> >>>> + function = "s_rsb";
> >>>> + };
> >>>> +
> >>>> + r_uart_pins: r-uart-pins {
> >>>> + pins = "PL2", "PL3";
> >>>> + function = "s_uart";
> >>>> + };
> >>>> +
> >>>> + r_pwm_pin: r-pwm-pin {
> >>>> + pins = "PL8";
> >>>> + function = "s_pwm";
> >>>> + };
> >>>> +
> >>>> + };
> >>>> +
> >>>> + r_ir: ir@7040000 {
> >>>> + compatible = "allwinner,sun50i-h6-ir",
> >>>> + "allwinner,sun6i-a31-ir";
> >>>> + reg = <0x07040000 0x400>;
> >>>> + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&r_ccu CLK_R_APB1_IR>,
> >>>> + <&r_ccu CLK_IR>;
> >>>> + clock-names = "apb", "ir";
> >>>> + resets = <&r_ccu RST_R_APB1_IR>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&r_ir_rx_pin>;
> >>>> + status = "disabled";
> >>>> + };
> >>>> +
> >>>> + r_i2c: i2c@7081400 {
> >>>> + compatible = "allwinner,sun50i-h6-i2c",
> >>>> + "allwinner,sun6i-a31-i2c";
> >>>> + reg = <0x07081400 0x400>;
> >>>> + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&r_ccu CLK_R_APB2_I2C>;
> >>>> + resets = <&r_ccu RST_R_APB2_I2C>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&r_i2c_pins>;
> >>>> + status = "okay";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> +
> >>>> + axp805: pmic@36 {
> >>>> + compatible = "x-powers,axp805", "x-powers,axp806";
> >>>> + reg = <0x36>;
> >>>> + interrupt-parent = <&r_intc>;
> >>>> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
> >>>> + interrupt-controller;
> >>>> + #interrupt-cells = <1>;
> >>>> + x-powers,self-working-mode;
> >>>> + vina-supply = <®_vcc5v>;
> >>>> + vinb-supply = <®_vcc5v>;
> >>>> + vinc-supply = <®_vcc5v>;
> >>>> + vind-supply = <®_vcc5v>;
> >>>> + vine-supply = <®_vcc5v>;
> >>>> + aldoin-supply = <®_vcc5v>;
> >>>> + bldoin-supply = <®_vcc5v>;
> >>>> + cldoin-supply = <®_vcc5v>;
> >>>> +
> >>>> + regulators {
> >>>> + reg_aldo1: aldo1 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc-pl-led-ir";
> >>>> + };
> >>>> +
> >>>> + reg_aldo2: aldo2 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc33-audio-tv-ephy-mac";
> >>>> + regulator-enable-ramp-delay = <100000>;
> >>>> + };
> >>>> +
> >>>> + reg_aldo3: aldo3 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
> >>>> + };
> >>>> +
> >>>> + reg_bldo1: bldo1 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <1800000>;
> >>>> + regulator-max-microvolt = <1800000>;
> >>>> + regulator-name = "vcc18-dram-bias-pll";
> >>>> + };
> >>>> +
> >>>> + reg_bldo2: bldo2 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <1800000>;
> >>>> + regulator-max-microvolt = <1800000>;
> >>>> + regulator-name = "vcc-efuse-pcie-hdmi-pc";
> >>>> + };
> >>>> +
> >>>> + reg_bldo3: bldo3 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <1800000>;
> >>>> + regulator-max-microvolt = <1800000>;
> >>>> + regulator-name = "vcc-dcxoio";
> >>>> + };
> >>>> +
> >>>> + reg_bldo4: bldo4 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <1800000>;
> >>>> + regulator-max-microvolt = <1800000>;
> >>>> + regulator-name = "vcc-dcxoio";
> >>>> + };
> >>>> +
> >>>> + reg_cldo1: cldo1 {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
> >>>> + };
> >>>> +
> >>>> + reg_cldo2: cldo2 {
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc-wifi-1";
> >>>> + };
> >>>> +
> >>>> + reg_cldo3: cldo3 {
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-name = "vcc-wifi-2";
> >>>> + };
> >>>> +
> >>>> + reg_dcdca: dcdca {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <810000>;
> >>>> + regulator-max-microvolt = <1200000>;
> >>>> + regulator-ramp-delay = <2500>;
> >>>> + regulator-name = "vdd-cpu";
> >>>> + };
> >>>> +
> >>>> + reg_dcdcc: dcdcc {
> >>>> + regulator-enable-ramp-delay = <32000>;
> >>>> + regulator-min-microvolt = <810000>;
> >>>> + regulator-max-microvolt = <1080000>;
> >>>> + regulator-ramp-delay = <2500>;
> >>>> + regulator-name = "vdd-gpu";
> >>>> + };
> >>>> +
> >>>> + reg_dcdcd: dcdcd {
> >>>> + regulator-always-on;
> >>>> + regulator-min-microvolt = <1000000>;
> >>>> + regulator-max-microvolt = <1000000>;
> >>>> + regulator-name = "vdd-sys";
> >>>> + };
> >>>> +
> >>>> + sw {
> >>>> + /* unused */
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + r_rsb: rsb@7083000 {
> >>>> + compatible = "allwinner,sun8i-a23-rsb";
> >>>> + reg = <0x07083000 0x400>;
> >>>> + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&r_ccu CLK_R_APB2_RSB>;
> >>>> + clock-frequency = <3000000>;
> >>>> + resets = <&r_ccu RST_R_APB2_RSB>;
> >>>> + pinctrl-names = "default";
> >>>> + pinctrl-0 = <&r_rsb_pins>;
> >>>> + status = "disabled";
> >>>> + #address-cells = <1>;
> >>>> + #size-cells = <0>;
> >>>> + };
> >>>> +
> >>>> + ths: thermal-sensor@5070400 {
> >>>> + compatible = "allwinner,sun50i-h6-ths";
> >>>> + reg = <0x05070400 0x100>;
> >>>> + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
> >>>> + clocks = <&ccu CLK_BUS_THS>;
> >>>> + clock-names = "bus";
> >>>> + resets = <&ccu RST_BUS_THS>;
> >>>> + nvmem-cells = <&ths_calibration>;
> >>>> + nvmem-cell-names = "calibration";
> >>>> + #thermal-sensor-cells = <1>;
> >>>> + };
> >>>> +
> >>>> + sunxi-info {
> >>>> + compatible = "allwinner,sun50i-h6-sys-info";
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + addr_mgt: addr-mgt {
> >>>> + compatible = "allwinner,sunxi-addr_mgt";
> >>>> + type_addr_wifi = <0x2>;
> >>>> + type_addr_bt = <0x2>;
> >>>> + type_addr_eth = <0x2>;
> >>>> + status = "okay";
> >>>> + };
> >>>> +
> >>>> + dump_reg: dump_reg@20000 {
> >>>> + compatible = "allwinner,sunxi-dump-reg";
> >>>> + reg = <0x0 0x03001000 0x0 0x0f20>;
> >>>> + status = "okay";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + thermal-zones {
> >>>> + cpu-thermal {
> >>>> + polling-delay-passive = <250>;
> >>>> + polling-delay = <1000>;
> >>>> + thermal-sensors = <&ths 0>;
> >>>> +
> >>>> + trips {
> >>>> + cpu_warm: cpu_warm {
> >>>> + temperature = <70000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_hot0: cpu_hot0 {
> >>>> + temperature = <74000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_hot1: cpu_hot1 {
> >>>> + temperature = <76000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot0: cpu_very_hot0 {
> >>>> + temperature = <78000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot1: cpu_very_hot1 {
> >>>> + temperature = <80000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot2: cpu_very_hot2 {
> >>>> + temperature = <82000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot3: cpu_very_hot3 {
> >>>> + temperature = <84000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot4: cpu_very_hot4 {
> >>>> + temperature = <86000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot5: cpu_very_hot5 {
> >>>> + temperature = <88000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_very_hot6: cpu_very_hot6 {
> >>>> + temperature = <90000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + cpu_crit: cpu_crit {
> >>>> + temperature = <97000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "critical";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + cooling-maps {
> >>>> + cpu_warm_limit_cpu {
> >>>> + trip = <&cpu_warm>;
> >>>> + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + gpu-thermal {
> >>>> + polling-delay-passive = <1000>;
> >>>> + polling-delay = <2000>;
> >>>> + thermal-sensors = <&ths 1>;
> >>>> +
> >>>> + trips {
> >>>> + gpu_alert0: gpu-alert-0 {
> >>>> + temperature = <95000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + gpu_alert1: gpu-alert-1 {
> >>>> + temperature = <100000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + gpu_alert2: gpu-alert-2 {
> >>>> + temperature = <105000>;
> >>>> + hysteresis = <2000>;
> >>>> + type = "passive";
> >>>> + };
> >>>> +
> >>>> + gpu-crit {
> >>>> + temperature = <115000>;
> >>>> + hysteresis = <0>;
> >>>> + type = "critical";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + cooling-maps {
> >>>> + // Forbid the GPU to go over 756MHz
> >>>> + map0 {
> >>>> + trip = <&gpu_alert0>;
> >>>> + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
> >>>> + };
> >>>> +
> >>>> + // Forbid the GPU to go over 624MHz
> >>>> + map1 {
> >>>> + trip = <&gpu_alert1>;
> >>>> + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
> >>>> + };
> >>>> +
> >>>> + // Forbid the GPU to go over 576MHz
> >>>> + map2 {
> >>>> + trip = <&gpu_alert2>;
> >>>> + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + cpu_opp_table: cpu-opp-table {
> >>>> + compatible = "allwinner,sun50i-h6-operating-points";
> >>>> + nvmem-cells = <&cpu_speed_grade>;
> >>>> + opp-shared;
> >>>> +
> >>>> + opp-480000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <480000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <880000>;
> >>>> + };
> >>>> +
> >>>> + opp-720000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <720000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <880000>;
> >>>> + };
> >>>> +
> >>>> + opp-888000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <888000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <880000>;
> >>>> + };
> >>>> +
> >>>> + opp-1080000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1080000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <940000>;
> >>>> + };
> >>>> +
> >>>> + opp-1320000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1320000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1000000>;
> >>>> + };
> >>>> +
> >>>> + opp-1488000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1488000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1060000>;
> >>>> + };
> >>>> +
> >>>> + opp-1608000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1608000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1090000>;
> >>>> + };
> >>>> +
> >>>> + opp-1704000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1704000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1120000>;
> >>>> + };
> >>>> +
> >>>> + opp-1800000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1800000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1160000>;
> >>>> + };
> >>>> +
> >>>> + opp@1896000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1896000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1180000>;
> >>>> + };
> >>>> +
> >>>> + opp@1968000000 {
> >>>> + clock-latency-ns = <244144>; /* 8 32k periods */
> >>>> + opp-hz = /bits/ 64 <1968000000>;
> >>>> +
> >>>> + opp-microvolt-speed0 = <1200000>;
> >>>> + };
> >>>> +
> >>>> + };
> >>>> +
> >>>> + gpu_opp_table: opp-table-gpu {
> >>>> + compatible = "operating-points-v2";
> >>>> +
> >>>> + opp-216000000 {
> >>>> + opp-hz = /bits/ 64 <216000000>;
> >>>> + opp-microvolt = <810000 810000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-264000000 {
> >>>> + opp-hz = /bits/ 64 <264000000>;
> >>>> + opp-microvolt = <810000 810000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-312000000 {
> >>>> + opp-hz = /bits/ 64 <312000000>;
> >>>> + opp-microvolt = <810000 810000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-336000000 {
> >>>> + opp-hz = /bits/ 64 <336000000>;
> >>>> + opp-microvolt = <810000 810000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-360000000 {
> >>>> + opp-hz = /bits/ 64 <360000000>;
> >>>> + opp-microvolt = <820000 820000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-384000000 {
> >>>> + opp-hz = /bits/ 64 <384000000>;
> >>>> + opp-microvolt = <830000 830000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-408000000 {
> >>>> + opp-hz = /bits/ 64 <408000000>;
> >>>> + opp-microvolt = <840000 840000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-420000000 {
> >>>> + opp-hz = /bits/ 64 <420000000>;
> >>>> + opp-microvolt = <850000 850000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-432000000 {
> >>>> + opp-hz = /bits/ 64 <432000000>;
> >>>> + opp-microvolt = <860000 860000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-456000000 {
> >>>> + opp-hz = /bits/ 64 <456000000>;
> >>>> + opp-microvolt = <870000 870000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-504000000 {
> >>>> + opp-hz = /bits/ 64 <504000000>;
> >>>> + opp-microvolt = <890000 890000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-540000000 {
> >>>> + opp-hz = /bits/ 64 <540000000>;
> >>>> + opp-microvolt = <910000 910000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-576000000 {
> >>>> + opp-hz = /bits/ 64 <576000000>;
> >>>> + opp-microvolt = <930000 930000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-624000000 {
> >>>> + opp-hz = /bits/ 64 <624000000>;
> >>>> + opp-microvolt = <950000 950000 1200000>;
> >>>> + };
> >>>> +
> >>>> + opp-756000000 {
> >>>> + opp-hz = /bits/ 64 <756000000>;
> >>>> + opp-microvolt = <1040000 1040000 1200000>;
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + chosen {
> >>>> + stdout-path = "serial0:115200n8";
> >>>> + };
> >>>> +
> >>>> + connector {
> >>>> + compatible = "hdmi-connector";
> >>>> + type = "a";
> >>>> +
> >>>> + port {
> >>>> + hdmi_con_in: endpoint {
> >>>> + remote-endpoint = <&hdmi_out_con>;
> >>>> + };
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + ext_osc32k: ext_osc32k_clk {
> >>>> + #clock-cells = <0>;
> >>>> + compatible = "fixed-clock";
> >>>> + clock-frequency = <32768>;
> >>>> + clock-output-names = "ext_osc32k";
> >>>> + };
> >>>> +
> >>>> + leds {
> >>>> + compatible = "gpio-leds";
> >>>> +
> >>>> + led-0 {
> >>>> + label = "repka:red:power";
> >>>> + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
> >>>> + linux,default-trigger = "heartbeat";
> >>>> + };
> >>>> + };
> >>>> +
> >>>> + reg_vcc5v: vcc5v {
> >>>> + /* board wide 5V supply directly from the DC jack */
> >>>> + compatible = "regulator-fixed";
> >>>> + regulator-name = "vcc-5v";
> >>>> + regulator-min-microvolt = <5000000>;
> >>>> + regulator-max-microvolt = <5000000>;
> >>>> + regulator-always-on;
> >>>> + };
> >>>> +
> >>>> + reg_vcc33_wifi: vcc33-wifi {
> >>>> + /* Always on 3.3V regulator for WiFi and BT */
> >>>> + compatible = "regulator-fixed";
> >>>> + regulator-name = "vcc33-wifi";
> >>>> + regulator-min-microvolt = <3300000>;
> >>>> + regulator-max-microvolt = <3300000>;
> >>>> + regulator-always-on;
> >>>> + vin-supply = <®_vcc5v>;
> >>>> + };
> >>>> +
> >>>> + reg_vcc_wifi_io: vcc-wifi-io {
> >>>> + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
> >>>> + compatible = "regulator-fixed";
> >>>> + regulator-name = "vcc-wifi-io";
> >>>> + regulator-min-microvolt = <1800000>;
> >>>> + regulator-max-microvolt = <1800000>;
> >>>> + regulator-always-on;
> >>>> + vin-supply = <®_vcc33_wifi>;
> >>>> + };
> >>>> +
> >>>> + wifi_pwrseq: wifi-pwrseq {
> >>>> + compatible = "mmc-pwrseq-simple";
> >>>> + clocks = <&rtc 1>;
> >>>> + clock-names = "ext_clock";
> >>>> + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
> >>>> + post-power-on-delay-ms = <200>;
> >>>> + };
> >>>> +};
> >>>> --
> >>>> 2.42.2
> >>>>
> >>>> _______________________________________________
> >>>> devel-kernel mailing list
> >>>> devel-kernel@lists.altlinux.org
> >>>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
> >>> _______________________________________________
> >>> devel-kernel mailing list
> >>> devel-kernel@lists.altlinux.org
> >>> https://lists.altlinux.org/mailman/listinfo/devel-kernel
> >>
> >> --
> >> Kind Regards!
> >> from srebrov@altlinux.org
> >>
> >> _______________________________________________
> >> devel-kernel mailing list
> >> devel-kernel@lists.altlinux.org
> >> https://lists.altlinux.org/mailman/listinfo/devel-kernel
> > _______________________________________________
> > devel-kernel mailing list
> > devel-kernel@lists.altlinux.org
> > https://lists.altlinux.org/mailman/listinfo/devel-kernel
>
> --
> best regards, Anton Midyukov <antohami@altlinux.org>
>
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal
2025-05-06 12:28 [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal kurachenko-urup
2025-05-07 19:39 ` Vitaly Chikunov
@ 2025-05-08 1:22 ` Vitaly Chikunov
1 sibling, 0 replies; 7+ messages in thread
From: Vitaly Chikunov @ 2025-05-08 1:22 UTC (permalink / raw)
To: ALT Linux kernel packages development
Anton,
On Tue, May 06, 2025 at 03:28:28PM +0300, kurachenko-urup@ya.ru wrote:
> From: Anton Kurachenko <srebrov@altlinux.org>
>
> Patch for 6.12 kernel to resolving boot problem on repka pi4 optimal SBC with
> u-boot-2020.x (u-boot-repka4). This version of u-boot requires the presence of
> a dtb file.
>
> Patch designed specifically for ALT and never used anywhere.
>
> The final DTS in this patch is based on the sun50i-h6-repka-pi4-optimal.dts
> file, as well as modified sun50i-h6.dtsi and sun50i-h6-cpu-opp.dtsi files taken
> from the official RBS repository. Also included original sun50i-h6-gpu-opp.dtsi.
> Represents the result of merging these files with applying some modifications.
>
> Files that were used during the creation process:
>
> sun50i-h6-repka-pi4-optimal.dts
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-repka-pi4-optimal.dts
>
> sun50i-h6.dtsi
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6.dtsi
>
> sun50i-h6-cpu-opp.dtsi
> Link: https://gitflic.ru/project/npo_rbs/repka-os_kernel/blob?file=arch%2Farm64%2Fboot%2Fdts%2Fallwinner%2Fsun50i-h6-cpu-opp.dtsi
>
> Signed-off-by: Anton Kurachenko <srebrov@altlinux.org>
Applied, thanks
> ---
> arch/arm64/boot/dts/allwinner/Makefile | 1 +
> .../allwinner/sun50i-h6-repka-pi4-optimal.dts | 1918 +++++++++++++++++
> 2 files changed, 1919 insertions(+)
> create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
>
> diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
> index 00bed412ee31..2df5189e0d44 100644
> --- a/arch/arm64/boot/dts/allwinner/Makefile
> +++ b/arch/arm64/boot/dts/allwinner/Makefile
> @@ -52,3 +52,4 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-2024.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-h.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-plus.dtb
> dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h700-anbernic-rg35xx-sp.dtb
> +dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h6-repka-pi4-optimal.dtb
> diff --git a/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> new file mode 100644
> index 000000000000..9d95297a30b8
> --- /dev/null
> +++ b/arch/arm64/boot/dts/allwinner/sun50i-h6-repka-pi4-optimal.dts
> @@ -0,0 +1,1918 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +// based on the dts, which is:
> +// Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
> +// Copyright (C) 2019 Ondřej Jirman <megous@megous.com>
> +// Copyright (C) 2020 Igor Pecovnik <igor@armbian.com>
> +// Copyright (C) 2020 Clément Péron <peron.clem@gmail.com>
> +
> +/dts-v1/;
> +
> +#include <dt-bindings/interrupt-controller/arm-gic.h>
> +#include <dt-bindings/clock/sun50i-h6-ccu.h>
> +#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
> +#include <dt-bindings/clock/sun6i-rtc.h>
> +#include <dt-bindings/clock/sun8i-de2.h>
> +#include <dt-bindings/clock/sun8i-tcon-top.h>
> +#include <dt-bindings/reset/sun50i-h6-ccu.h>
> +#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
> +#include <dt-bindings/reset/sun8i-de2.h>
> +#include <dt-bindings/thermal/thermal.h>
> +#include <dt-bindings/gpio/gpio.h>
> +
> +/ {
> + interrupt-parent = <&gic>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + model = "Repka-Pi4-Optimal";
> + repka-freq = "1.968 GHz";
> + repka-pinout = "repka-pi4-base";
> + compatible = "rbs,repka-pi4", "allwinner,sun50i-h6";
> +
> + aliases {
> + mmc0 = &mmc0;
> + mmc1 = &mmc1;
> + mmc2 = &mmc2;
> + ethernet0 = &emac;
> + serial0 = &uart0;
> + serial1 = &uart1;
> + serial2 = &r_uart;
> +
> + spi0 = &spi1;
> + i2c1 = &i2c0;
> + i2c2 = &i2c2;
> + i2c3 = &i2c1;
> + i2c4 = &i2c3;
> +
> + };
> +
> + reserved-memory {
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + custom_region: region@40010000 {
> + reg = <0x40010000 0x00070000>;
> + no-map;
> + };
> + };
> +
> + analog: analog-codec {
> + compatible = "simple-audio-card";
> + simple-audio-card,format = "i2s";
> + simple-audio-card,name = "ac200-audio";
> + simple-audio-card,mclk-fs = <512>;
> + status = "okay";
> +
> + simple-audio-card,cpu {
> + sound-dai = <&i2s3>;
> + };
> +
> + simple-audio-card,codec {
> + sound-dai = <&ac200_codec>;
> + };
> + };
> +
> + ac200_pwm_clk: ac200_clk {
> + compatible = "pwm-clock";
> + #clock-cells = <0>;
> + clock-frequency = <24000000>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&pwm1_pin>;
> + pwms = <&pwm 1 42 0>;
> + status = "okay";
> + };
> +
> + cpus {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + cpu0: cpu@0 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <0>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + cpu-supply = <®_dcdca>;
> + };
> +
> + cpu1: cpu@1 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <1>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> +
> + cpu2: cpu@2 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <2>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> +
> + cpu3: cpu@3 {
> + compatible = "arm,cortex-a53";
> + device_type = "cpu";
> + reg = <3>;
> + enable-method = "psci";
> + clocks = <&ccu CLK_CPUX>;
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + #cooling-cells = <2>;
> + operating-points-v2 = <&cpu_opp_table>;
> + };
> + };
> +
> + de: display-engine {
> + compatible = "allwinner,sun50i-h6-display-engine";
> + allwinner,pipelines = <&mixer0>;
> + status = "okay";
> + };
> +
> + osc24M: osc24M_clk {
> + #clock-cells = <0>;
> + compatible = "fixed-clock";
> + clock-frequency = <24000000>;
> + clock-output-names = "osc24M";
> + };
> +
> + pmu {
> + compatible = "arm,cortex-a53-pmu";
> + interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
> + };
> +
> + psci {
> + compatible = "arm,psci-0.2";
> + method = "smc";
> + };
> +
> + scpi_protocol: scpi {
> + compatible = "arm,scpi";
> + mboxes = <&msgbox 2>, <&msgbox 3>;
> + mbox-names = "tx", "rx";
> + shmem = <&scpi_sram>;
> + };
> +
> + sound_hdmi: sound_hdmi {
> + compatible = "allwinner,sun9i-a80-hdmi-audio",
> + "allwinner,sun50i-h6-hdmi-audio";
> + status = "okay";
> + codec {
> + sound-dai = <&hdmi>;
> + };
> +
> + cpu {
> + sound-dai = <&i2s1>;
> + };
> + };
> +
> + timer {
> + compatible = "arm,armv8-timer";
> + arm,no-tick-in-suspend;
> + interrupts = <GIC_PPI 13
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 14
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 11
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
> + <GIC_PPI 10
> + (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> + };
> +
> +
> + soc {
> + compatible = "simple-bus";
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + bus@1000000 {
> + compatible = "allwinner,sun50i-h6-de3",
> + "allwinner,sun50i-a64-de2";
> + reg = <0x1000000 0x400000>;
> + allwinner,sram = <&de2_sram 1>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x1000000 0x400000>;
> +
> + display_clocks: clock@0 {
> + compatible = "allwinner,sun50i-h6-de3-clk";
> + reg = <0x0 0x10000>;
> + clocks = <&ccu CLK_BUS_DE>,
> + <&ccu CLK_DE>;
> + clock-names = "bus",
> + "mod";
> + resets = <&ccu RST_BUS_DE>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + mixer0: mixer@100000 {
> + compatible = "allwinner,sun50i-h6-de3-mixer-0";
> + reg = <0x100000 0x100000>;
> + clocks = <&display_clocks CLK_BUS_MIXER0>,
> + <&display_clocks CLK_MIXER0>;
> + clock-names = "bus",
> + "mod";
> + resets = <&display_clocks RST_MIXER0>;
> + iommus = <&iommu 0>;
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + mixer0_out: port@1 {
> + reg = <1>;
> +
> + mixer0_out_tcon_top_mixer0: endpoint {
> + remote-endpoint = <&tcon_top_mixer0_in_mixer0>;
> + };
> + };
> + };
> + };
> + };
> +
> +
> + video-codec-g2@1c00000 {
> + compatible = "allwinner,sun50i-h6-vpu-g2";
> + reg = <0x01c00000 0x1000>;
> + interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_VP9>, <&ccu CLK_VP9>;
> + clock-names = "bus", "mod";
> + resets = <&ccu RST_BUS_VP9>;
> + iommus = <&iommu 5>;
> + };
> +
> + deinterlace: deinterlace@1420000 {
> + compatible = "allwinner,sun50i-h6-deinterlace";
> + reg = <0x01420000 0x2000>;
> + clocks = <&ccu CLK_BUS_DEINTERLACE>,
> + <&ccu CLK_DEINTERLACE>,
> + <&ccu CLK_MBUS_DEINTERLACE>;
> + clock-names = "bus", "mod", "ram";
> + resets = <&ccu RST_BUS_DEINTERLACE>;
> + interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
> + iommus = <&iommu 2>;
> + };
> +
> + video-codec@1c0e000 {
> + compatible = "allwinner,sun50i-h6-video-engine";
> + reg = <0x01c0e000 0x2000>;
> + clocks = <&ccu CLK_BUS_VE>, <&ccu CLK_VE>,
> + <&ccu CLK_MBUS_VE>;
> + clock-names = "ahb", "mod", "ram";
> + resets = <&ccu RST_BUS_VE>;
> + interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
> + allwinner,sram = <&ve_sram 1>;
> + iommus = <&iommu 1>, <&iommu 3>;
> + };
> +
> + gpu: gpu@1800000 {
> + compatible = "allwinner,sun50i-h6-mali",
> + "arm,mali-t720";
> + reg = <0x01800000 0x4000>;
> + interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "job", "mmu", "gpu";
> + clocks = <&ccu CLK_GPU>, <&ccu CLK_BUS_GPU>;
> + clock-names = "core", "bus";
> + resets = <&ccu RST_BUS_GPU>;
> + #cooling-cells = <2>;
> + status = "okay";
> + operating-points-v2 = <&gpu_opp_table>;
> + mali-supply = <®_dcdcc>;
> + };
> +
> + crypto: crypto@1904000 {
> + compatible = "allwinner,sun50i-h6-crypto";
> + reg = <0x01904000 0x1000>;
> + interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>, <&ccu CLK_MBUS_CE>;
> + clock-names = "bus", "mod", "ram";
> + resets = <&ccu RST_BUS_CE>;
> + };
> +
> + syscon: syscon@3000000 {
> + compatible = "allwinner,sun50i-h6-system-control",
> + "allwinner,sun50i-a64-system-control";
> + reg = <0x03000000 0x1000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges;
> +
> + sram_a2: sram@100000 {
> + compatible = "mmio-sram";
> + reg = <0x00100000 0x18000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x00100000 0x18000>;
> +
> + scpi_sram: scp-shmem@17c00 {
> + compatible = "arm,scp-shmem";
> + reg = <0x17c00 0x200>;
> + };
> + };
> +
> + sram_c: sram@28000 {
> + compatible = "mmio-sram";
> + reg = <0x00028000 0x1e000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x00028000 0x1e000>;
> +
> + de2_sram: sram-section@0 {
> + compatible = "allwinner,sun50i-h6-sram-c",
> + "allwinner,sun50i-a64-sram-c";
> + reg = <0x0000 0x1e000>;
> + };
> + };
> +
> + sram_c1: sram@1a00000 {
> + compatible = "mmio-sram";
> + reg = <0x01a00000 0x200000>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> + ranges = <0 0x01a00000 0x200000>;
> +
> + ve_sram: sram-section@0 {
> + compatible = "allwinner,sun50i-h6-sram-c1",
> + "allwinner,sun4i-a10-sram-c1";
> + reg = <0x000000 0x200000>;
> + };
> + };
> + };
> +
> + ccu: clock@3001000 {
> + compatible = "allwinner,sun50i-h6-ccu";
> + reg = <0x03001000 0x1000>;
> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
> + clock-names = "hosc", "losc", "iosc";
> + protected-clocks = <CLK_BUS_MSGBOX>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + dma: dma-controller@3002000 {
> + compatible = "allwinner,sun50i-h6-dma";
> + reg = <0x03002000 0x1000>;
> + interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
> + clock-names = "bus", "mbus";
> + dma-channels = <16>;
> + dma-requests = <46>;
> + resets = <&ccu RST_BUS_DMA>;
> + #dma-cells = <1>;
> + };
> +
> + msgbox: mailbox@3003000 {
> + compatible = "allwinner,sun50i-h6-msgbox",
> + "allwinner,sun6i-a31-msgbox";
> + reg = <0x03003000 0x1000>;
> + clocks = <&ccu CLK_BUS_MSGBOX>;
> + resets = <&ccu RST_BUS_MSGBOX>;
> + interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
> + #mbox-cells = <1>;
> + };
> +
> + gic: interrupt-controller@3021000 {
> + compatible = "arm,gic-400";
> + reg = <0x03021000 0x1000>,
> + <0x03022000 0x2000>,
> + <0x03024000 0x2000>,
> + <0x03026000 0x2000>;
> + interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + };
> +
> + sid: efuse@3006000 {
> + compatible = "allwinner,sun50i-h6-sid";
> + reg = <0x03006000 0x400>;
> + #address-cells = <1>;
> + #size-cells = <1>;
> +
> + ths_calibration: thermal-sensor-calibration@14 {
> + reg = <0x14 0x8>;
> + };
> +
> + cpu_speed_grade: cpu-speed-grade@1c {
> + reg = <0x1c 0x4>;
> + };
> +
> + ephy_calib: ephy_calib@2c {
> + reg = <0x2c 0x2>;
> + };
> +
> + ac200_bg: ac200_bg@30 {
> + reg = <0x30 0x2>;
> + };
> + };
> +
> + timer@3009000 {
> + compatible = "allwinner,sun50i-h6-timer",
> + "allwinner,sun8i-a23-timer";
> + reg = <0x03009000 0xa0>;
> + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + };
> +
> + watchdog: watchdog@30090a0 {
> + compatible = "allwinner,sun50i-h6-wdt",
> + "allwinner,sun6i-a31-wdt";
> + reg = <0x030090a0 0x20>;
> + interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + /* Broken on some H6 boards */
> + status = "disabled";
> + };
> +
> + pwm: pwm@300a000 {
> + compatible = "allwinner,sun50i-h6-pwm";
> + reg = <0x0300a000 0x400>;
> + clocks = <&osc24M>, <&ccu CLK_BUS_PWM>;
> + clock-names = "mod", "bus";
> + resets = <&ccu RST_BUS_PWM>;
> + #pwm-cells = <3>;
> + status = "okay";
> + };
> +
> + pio: pinctrl@300b000 {
> + compatible = "allwinner,sun50i-h6-pinctrl";
> + reg = <0x0300b000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
> + clock-names = "apb", "hosc", "losc";
> + gpio-controller;
> + #gpio-cells = <3>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + vcc-pc-supply = <®_bldo2>;
> + vcc-pd-supply = <®_cldo1>;
> + vcc-pg-supply = <®_vcc_wifi_io>;
> +
> + /omit-if-no-ref/
> + ext_rgmii_pins: rgmii-pins {
> + pins = "PD0", "PD1", "PD2", "PD3", "PD4",
> + "PD5", "PD7", "PD8", "PD9", "PD10",
> + "PD11", "PD12", "PD13", "PD19", "PD20";
> + function = "emac";
> + drive-strength = <40>;
> + };
> +
> + ext_rmii_pins: rmii_pins {
> + pins = "PA0", "PA1", "PA2", "PA3", "PA4",
> + "PA5", "PA6", "PA7", "PA8", "PA9";
> + function = "emac";
> + drive-strength = <40>;
> + };
> +
> + hdmi_pins: hdmi-pins {
> + pins = "PH8", "PH9", "PH10";
> + function = "hdmi";
> + };
> +
> + i2c0_pins: i2c0-pins {
> + pins = "PD25", "PD26";
> + function = "i2c0";
> + };
> +
> + i2c1_pins: i2c1-pins {
> + pins = "PH5", "PH6";
> + function = "i2c1";
> + };
> +
> + i2c2_pins: i2c2-pins {
> + pins = "PD23", "PD24";
> + function = "i2c2";
> + };
> +
> + i2c3_pins: i2c3-pins {
> + pins = "PB17", "PB18";
> + function = "i2c3";
> + bias-pull-up;
> + };
> +
> + i2s3_pins: i2s3-pins {
> + pins = "PB12", "PB13", "PB14", "PB15", "PB16";
> + function = "i2s3";
> + };
> +
> + mmc0_pins: mmc0-pins {
> + pins = "PF0", "PF1", "PF2", "PF3",
> + "PF4", "PF5";
> + function = "mmc0";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + /omit-if-no-ref/
> + mmc1_pins: mmc1-pins {
> + pins = "PG0", "PG1", "PG2", "PG3",
> + "PG4", "PG5";
> + function = "mmc1";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + /omit-if-no-ref/
> + mmc2_pins: mmc2-pins {
> + pins = "PC1", "PC4", "PC5", "PC6",
> + "PC7", "PC8", "PC9", "PC10",
> + "PC11", "PC12", "PC13", "PC14";
> + function = "mmc2";
> + drive-strength = <30>;
> + bias-pull-up;
> + };
> +
> + pwm1_pin: pwm1-pin {
> + pins = "PB19";
> + function = "pwm1";
> + };
> +
> + pwm_pin: pwm-pin {
> + pins = "PD22";
> + function = "pwm";
> + };
> +
> + /omit-if-no-ref/
> + spi0_pins: spi0-pins {
> + pins = "PC0", "PC2", "PC3";
> + function = "spi0";
> + };
> +
> + /* pin shared with MMC2-CMD (eMMC) */
> + /omit-if-no-ref/
> + spi0_cs_pin: spi0-cs-pin {
> + pins = "PC5";
> + function = "spi0";
> + };
> +
> + /omit-if-no-ref/
> + spi1_pins: spi1-pins {
> + pins = "PH4", "PH5", "PH6";
> + function = "spi1";
> + };
> +
> + /omit-if-no-ref/
> + spi1_cs_pin: spi1-cs-pin {
> + pins = "PH3";
> + function = "spi1";
> + };
> +
> + /omit-if-no-ref/
> + spdif_tx_pin: spdif-tx-pin {
> + pins = "PH7";
> + function = "spdif";
> + };
> +
> + uart0_ph_pins: uart0-ph-pins {
> + pins = "PH0", "PH1";
> + function = "uart0";
> + };
> +
> + uart1_pins: uart1-pins {
> + pins = "PG6", "PG7";
> + function = "uart1";
> + };
> +
> + uart1_rts_cts_pins: uart1-rts-cts-pins {
> + pins = "PG8", "PG9";
> + function = "uart1";
> + };
> +
> + uart2_pins: uart2-pins {
> + pins = "PD19", "PD20";
> + function = "uart2";
> + };
> +
> + uart2_rts_cts_pins: uart2-rts-cts-pins {
> + pins = "PD21", "PD22";
> + function = "uart2";
> + };
> +
> + uart3_pins: uart3-pins {
> + pins = "PD23", "PD24";
> + function = "uart3";
> + };
> +
> + uart3_rts_cts_pins: uart3-rts-cts-pins {
> + pins = "PD25", "PD26";
> + function = "uart3";
> + };
> +
> + i2s2_pins: i2s2-pins {
> + pins = "PG10", "PG11", "PG12", "PG13";
> + function = "i2s2";
> + };
> + };
> +
> + iommu: iommu@30f0000 {
> + compatible = "allwinner,sun50i-h6-iommu";
> + reg = <0x030f0000 0x10000>;
> + interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_IOMMU>;
> + resets = <&ccu RST_BUS_IOMMU>;
> + #iommu-cells = <1>;
> + };
> +
> + mmc0: mmc@4020000 {
> + compatible = "allwinner,sun50i-h6-mmc",
> + "allwinner,sun50i-a64-mmc";
> + reg = <0x04020000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC0>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc0_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_cldo1>;
> + cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */
> + bus-width = <4>;
> + };
> +
> + mmc1: mmc@4021000 {
> + compatible = "allwinner,sun50i-h6-mmc",
> + "allwinner,sun50i-a64-mmc";
> + reg = <0x04021000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC1>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc1_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_vcc33_wifi>;
> + vqmmc-supply = <®_vcc_wifi_io>;
> + mmc-pwrseq = <&wifi_pwrseq>;
> + bus-width = <4>;
> + non-removable;
> +
> + brcm: sdio-wifi@1 {
> + reg = <1>;
> + compatible = "brcm,bcm4329-fmac";
> + interrupt-parent = <&r_pio>;
> + interrupts = <1 0 IRQ_TYPE_LEVEL_LOW>; /* PM0 */
> + interrupt-names = "host-wake";
> + };
> + };
> +
> + mmc2: mmc@4022000 {
> + compatible = "allwinner,sun50i-h6-emmc";
> + reg = <0x04022000 0x1000>;
> + clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
> + clock-names = "ahb", "mmc";
> + resets = <&ccu RST_BUS_MMC2>;
> + reset-names = "ahb";
> + interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&mmc2_pins>;
> + max-frequency = <150000000>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + vmmc-supply = <®_cldo1>;
> + vqmmc-supply = <®_bldo2>;
> + cap-mmc-hw-reset;
> + non-removable;
> + bus-width = <8>;
> + };
> +
> + uart0: serial@5000000 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000000 0x400>;
> + interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART0>;
> + resets = <&ccu RST_BUS_UART0>;
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&uart0_ph_pins>;
> + };
> +
> + uart1: serial@5000400 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000400 0x400>;
> + interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART1>;
> + resets = <&ccu RST_BUS_UART1>;
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
> + uart-has-rtscts;
> +
> + bluetooth {
> + compatible = "brcm,bcm4345c5";
> + clocks = <&rtc 1>;
> + clock-names = "lpo";
> + device-wakeup-gpios = <&r_pio 1 2 GPIO_ACTIVE_HIGH>; /* PM2 */
> + host-wakeup-gpios = <&r_pio 1 1 GPIO_ACTIVE_HIGH>; /* PM1 */
> + shutdown-gpios = <&r_pio 1 4 GPIO_ACTIVE_HIGH>; /* PM4 */
> + max-speed = <1500000>;
> + };
> + };
> +
> + uart2: serial@5000800 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000800 0x400>;
> + interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART2>;
> + resets = <&ccu RST_BUS_UART2>;
> + status = "disabled";
> + };
> +
> + uart3: serial@5000c00 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x05000c00 0x400>;
> + interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&ccu CLK_BUS_UART3>;
> + resets = <&ccu RST_BUS_UART3>;
> + status = "disabled";
> + };
> +
> + i2c0: i2c@5002000 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002000 0x400>;
> + interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C0>;
> + resets = <&ccu RST_BUS_I2C0>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c0_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c1: i2c@5002400 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002400 0x400>;
> + interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C1>;
> + resets = <&ccu RST_BUS_I2C1>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c1_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c2: i2c@5002800 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002800 0x400>;
> + interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C2>;
> + resets = <&ccu RST_BUS_I2C2>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c2_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + i2c3: i2c@5002c00 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x05002c00 0x400>;
> + interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2C3>;
> + resets = <&ccu RST_BUS_I2C3>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2c3_pins>;
> + clock-frequency = <100000>;
> + status = "okay"; /* нужно для ac200 */
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + ac200: mfd@10 {
> + compatible = "x-powers,ac200";
> + reg = <0x10>;
> + clocks = <&ac200_pwm_clk>;
> + interrupt-parent = <&pio>;
> + interrupts = <1 20 IRQ_TYPE_LEVEL_LOW>;
> + interrupt-controller;
> + #interrupt-cells = <1>;
> + nvmem-cells = <&ac200_bg>;
> + nvmem-cell-names = "bandgap";
> +
> + ac200_ephy_ctl: syscon {
> + compatible = "x-powers,ac200-ephy-ctl";
> + nvmem-cells = <&ephy_calib>;
> + nvmem-cell-names = "calibration";
> + #clock-cells = <0>;
> + #reset-cells = <0>;
> + phy-mode = "rmii";
> + status = "okay";
> + x-powers,led-polarity = <GPIO_ACTIVE_HIGH>;
> + phy-address = <1>;
> + };
> +
> + ac200_codec: codec {
> + #sound-dai-cells = <0>;
> + compatible = "x-powers,ac200-codec";
> + status = "okay";
> + avcc-supply = <®_aldo2>;
> + };
> + };
> + };
> +
> + spi1: spi@5011000 {
> + compatible = "allwinner,sun50i-h6-spi",
> + "allwinner,sun8i-h3-spi";
> + reg = <0x05011000 0x1000>;
> + interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
> + clock-names = "ahb", "mod";
> + dmas = <&dma 23>, <&dma 23>;
> + dma-names = "rx", "tx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&spi1_pins>, <&spi1_cs_pin>;
> + resets = <&ccu RST_BUS_SPI1>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + emac: ethernet@5020000 {
> + compatible = "allwinner,sun50i-h6-emac",
> + "allwinner,sun50i-a64-emac";
> + syscon = <&syscon>;
> + reg = <0x05020000 0x10000>;
> + interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "macirq";
> + resets = <&ccu RST_BUS_EMAC>;
> + reset-names = "stmmaceth";
> + clocks = <&ccu CLK_BUS_EMAC>;
> + clock-names = "stmmaceth";
> + status = "okay";
> + pinctrl-names = "default";
> + pinctrl-0 = <&ext_rmii_pins>;
> + phy-mode = "rmii";
> + phy-handle = <&ext_rmii_phy>;
> +
> + mdio: mdio {
> + compatible = "snps,dwmac-mdio";
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + ext_rmii_phy: ethernet-phy@1 {
> + compatible = "ethernet-phy-id0044.1400",
> + "ethernet-phy-ieee802.3-c22";
> + reg = <1>;
> + resets = <&ac200_ephy_ctl>;
> + reset-names = "phy";
> + clocks = <&ac200_ephy_ctl>;
> + };
> + };
> + };
> +
> + i2s3: i2s@508f000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x0508f000 0x1000>;
> + interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S3>, <&ccu CLK_I2S3>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 6>, <&dma 6>;
> + resets = <&ccu RST_BUS_I2S3>;
> + dma-names = "rx", "tx";
> + pinctrl-names = "default";
> + pinctrl-0 = <&i2s3_pins>;
> + status = "okay";
> + };
> +
> + i2s2: i2s@5092000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x05092000 0x1000>;
> + interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S2>, <&ccu CLK_I2S2>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 5>, <&dma 5>;
> + resets = <&ccu RST_BUS_I2S2>;
> + dma-names = "rx", "tx";
> + status = "disabled";
> + };
> +
> + i2s1: i2s@5091000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-i2s";
> + reg = <0x05091000 0x1000>;
> + interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_I2S1>, <&ccu CLK_I2S1>;
> + clock-names = "apb", "mod";
> + dmas = <&dma 4>, <&dma 4>;
> + resets = <&ccu RST_BUS_I2S1>;
> + dma-names = "rx", "tx";
> + status = "okay";
> + };
> +
> + spdif: spdif@5093000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-spdif";
> + reg = <0x05093000 0x400>;
> + interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
> + clock-names = "apb", "spdif";
> + resets = <&ccu RST_BUS_SPDIF>;
> + dmas = <&dma 2>, <&dma 2>;
> + dma-names = "rx", "tx";
> + status = "disabled";
> + };
> +
> + usb2otg: usb@5100000 {
> + compatible = "allwinner,sun50i-h6-musb",
> + "allwinner,sun8i-a33-musb";
> + reg = <0x05100000 0x0400>;
> + clocks = <&ccu CLK_BUS_OTG>;
> + resets = <&ccu RST_BUS_OTG>;
> + interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "mc";
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + extcon = <&usb2phy 0>;
> + status = "okay";
> + dr_mode = "host";
> + };
> +
> + usb2phy: phy@5100400 {
> + compatible = "allwinner,sun50i-h6-usb-phy";
> + reg = <0x05100400 0x24>,
> + <0x05101800 0x4>,
> + <0x05311800 0x4>;
> + reg-names = "phy_ctrl",
> + "pmu0",
> + "pmu3";
> + clocks = <&ccu CLK_USB_PHY0>,
> + <&ccu CLK_USB_PHY3>;
> + clock-names = "usb0_phy",
> + "usb3_phy";
> + resets = <&ccu RST_USB_PHY0>,
> + <&ccu RST_USB_PHY3>;
> + reset-names = "usb0_reset",
> + "usb3_reset";
> + status = "okay";
> + #phy-cells = <1>;
> + };
> +
> + ehci0: usb@5101000 {
> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> + reg = <0x05101000 0x100>;
> + interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI0>,
> + <&ccu CLK_BUS_EHCI0>,
> + <&ccu CLK_USB_OHCI0>;
> + resets = <&ccu RST_BUS_OHCI0>,
> + <&ccu RST_BUS_EHCI0>;
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + ohci0: usb@5101400 {
> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> + reg = <0x05101400 0x100>;
> + interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI0>,
> + <&ccu CLK_USB_OHCI0>;
> + resets = <&ccu RST_BUS_OHCI0>;
> + phys = <&usb2phy 0>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + dwc3: usb@5200000 {
> + compatible = "snps,dwc3";
> + reg = <0x05200000 0x10000>;
> + interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_XHCI>,
> + <&ccu CLK_BUS_XHCI>,
> + <&rtc CLK_OSC32K>;
> + clock-names = "ref", "bus_early", "suspend";
> + resets = <&ccu RST_BUS_XHCI>;
> + /*
> + * The datasheet of the chip doesn't declare the
> + * peripheral function, and there's no boards known
> + * to have a USB Type-B port routed to the port.
> + * In addition, no one has tested the peripheral
> + * function yet.
> + * So set the dr_mode to "host" in the DTSI file.
> + */
> + dr_mode = "host";
> + phys = <&usb3phy>;
> + phy-names = "usb3-phy";
> + status = "okay";
> + };
> +
> + usb3phy: phy@5210000 {
> + compatible = "allwinner,sun50i-h6-usb3-phy";
> + reg = <0x5210000 0x10000>;
> + clocks = <&ccu CLK_USB_PHY1>;
> + resets = <&ccu RST_USB_PHY1>;
> + #phy-cells = <0>;
> + status = "okay";
> + };
> +
> + ehci3: usb@5311000 {
> + compatible = "allwinner,sun50i-h6-ehci", "generic-ehci";
> + reg = <0x05311000 0x100>;
> + interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI3>,
> + <&ccu CLK_BUS_EHCI3>,
> + <&ccu CLK_USB_OHCI3>;
> + resets = <&ccu RST_BUS_OHCI3>,
> + <&ccu RST_BUS_EHCI3>;
> + phys = <&usb2phy 3>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + ohci3: usb@5311400 {
> + compatible = "allwinner,sun50i-h6-ohci", "generic-ohci";
> + reg = <0x05311400 0x100>;
> + interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_OHCI3>,
> + <&ccu CLK_USB_OHCI3>;
> + resets = <&ccu RST_BUS_OHCI3>;
> + phys = <&usb2phy 3>;
> + phy-names = "usb";
> + status = "okay";
> + };
> +
> + pcie: pcie@5400000 {
> + #address-cells = <3>;
> + #size-cells = <2>;
> + compatible = "pine64,allwinner-h6-pcie-wrapped";
> + reg = <0x05400000 0x4000>,
> + <0x05410000 0x10000>;
> + reg-names = "dbi", "config";
> + device_type = "pci";
> + bus-range = <0x00 0xff>;
> + ranges = <0x81000000 0 0 0x05e00000 0 0x00010000 /* downstream I/O */
> + 0x82000000 0 0x05500000 0x05500000 0 0x00800000>; /* non-prefetchable memory */
> + num-lanes = <1>;
> + max-link-speed = <2>;
> + interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
> + interrupt-names = "msi", "linkup";
> + clocks = <&ccu CLK_PCIE_REF_OUT>,
> + <&ccu CLK_PCIE_MAXI>,
> + <&ccu CLK_PCIE_AUX>,
> + <&ccu CLK_BUS_PCIE>;
> + clock-names = "ref", "axi", "aux", "bus";
> + resets = <&ccu RST_PCIE_POWERUP>, <&ccu RST_BUS_PCIE>;
> + reset-names = "power", "bus";
> + #interrupt-cells = <1>;
> + interrupt-map-mask = <0 0 0 0>;
> + interrupt-map = <0 0 0 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
> + status = "okay";
> + vcc-supply = <®_bldo2>;
> + vdd-supply = <®_dcdcd>;
> + slot-supply = <®_vcc33_wifi>;
> + perst-gpio = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
> + /* clkreq-gpio = <&r_pio 0 5 GPIO_ACTIVE_LOW>; */
> + /* wake-gpio = <&r_pio 0 4 0>; */
> + };
> +
> +
> + hdmi: hdmi@6000000 {
> + #sound-dai-cells = <0>;
> + compatible = "allwinner,sun50i-h6-dw-hdmi";
> + reg = <0x06000000 0x10000>;
> + reg-io-width = <1>;
> + interrupts = <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>,
> + <&ccu CLK_HDMI>, <&ccu CLK_HDMI_CEC>,
> + <&ccu CLK_HDCP>, <&ccu CLK_BUS_HDCP>;
> + clock-names = "iahb", "isfr", "tmds", "cec", "hdcp",
> + "hdcp-bus";
> + resets = <&ccu RST_BUS_HDMI_SUB>, <&ccu RST_BUS_HDCP>;
> + reset-names = "ctrl", "hdcp";
> + phys = <&hdmi_phy>;
> + phy-names = "phy";
> + pinctrl-names = "default";
> + pinctrl-0 = <&hdmi_pins>;
> + status = "okay";
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + hdmi_in: port@0 {
> + reg = <0>;
> +
> + hdmi_in_tcon_top: endpoint {
> + remote-endpoint = <&tcon_top_hdmi_out_hdmi>;
> + };
> + };
> +
> + hdmi_out: port@1 {
> + reg = <1>;
> +
> + hdmi_out_con: endpoint {
> + remote-endpoint = <&hdmi_con_in>;
> + };
> + };
> + };
> + };
> +
> + hdmi_phy: hdmi-phy@6010000 {
> + compatible = "allwinner,sun50i-h6-hdmi-phy";
> + reg = <0x06010000 0x10000>;
> + clocks = <&ccu CLK_BUS_HDMI>, <&ccu CLK_HDMI_SLOW>;
> + clock-names = "bus", "mod";
> + resets = <&ccu RST_BUS_HDMI>;
> + reset-names = "phy";
> + #phy-cells = <0>;
> + };
> +
> + tcon_top: tcon-top@6510000 {
> + compatible = "allwinner,sun50i-h6-tcon-top";
> + reg = <0x06510000 0x1000>;
> + clocks = <&ccu CLK_BUS_TCON_TOP>,
> + <&ccu CLK_TCON_TV0>;
> + clock-names = "bus",
> + "tcon-tv0";
> + clock-output-names = "tcon-top-tv0";
> + resets = <&ccu RST_BUS_TCON_TOP>;
> + #clock-cells = <1>;
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + tcon_top_mixer0_in: port@0 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0>;
> +
> + tcon_top_mixer0_in_mixer0: endpoint@0 {
> + reg = <0>;
> + remote-endpoint = <&mixer0_out_tcon_top_mixer0>;
> + };
> + };
> +
> + tcon_top_mixer0_out: port@1 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <1>;
> +
> + tcon_top_mixer0_out_tcon_tv: endpoint@2 {
> + reg = <2>;
> + remote-endpoint = <&tcon_tv_in_tcon_top_mixer0>;
> + };
> + };
> +
> + tcon_top_hdmi_in: port@4 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <4>;
> +
> + tcon_top_hdmi_in_tcon_tv: endpoint@0 {
> + reg = <0>;
> + remote-endpoint = <&tcon_tv_out_tcon_top>;
> + };
> + };
> +
> + tcon_top_hdmi_out: port@5 {
> + reg = <5>;
> +
> + tcon_top_hdmi_out_hdmi: endpoint {
> + remote-endpoint = <&hdmi_in_tcon_top>;
> + };
> + };
> + };
> + };
> +
> + tcon_tv: lcd-controller@6515000 {
> + compatible = "allwinner,sun50i-h6-tcon-tv",
> + "allwinner,sun8i-r40-tcon-tv";
> + reg = <0x06515000 0x1000>;
> + interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_TCON_TV0>,
> + <&tcon_top CLK_TCON_TOP_TV0>;
> + clock-names = "ahb",
> + "tcon-ch1";
> + resets = <&ccu RST_BUS_TCON_TV0>;
> + reset-names = "lcd";
> +
> + ports {
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + tcon_tv_in: port@0 {
> + reg = <0>;
> +
> + tcon_tv_in_tcon_top_mixer0: endpoint {
> + remote-endpoint = <&tcon_top_mixer0_out_tcon_tv>;
> + };
> + };
> +
> + tcon_tv_out: port@1 {
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <1>;
> +
> + tcon_tv_out_tcon_top: endpoint@1 {
> + reg = <1>;
> + remote-endpoint = <&tcon_top_hdmi_in_tcon_tv>;
> + };
> + };
> + };
> + };
> +
> + r_uart: serial@7080000 {
> + compatible = "snps,dw-apb-uart";
> + reg = <0x07080000 0x400>;
> + interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
> + reg-shift = <2>;
> + reg-io-width = <4>;
> + clocks = <&r_ccu CLK_R_APB2_UART>;
> + resets = <&r_ccu RST_R_APB2_UART>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_uart_pins>;
> + status = "disabled";
> + };
> +
> + rtc: rtc@7000000 {
> + compatible = "allwinner,sun50i-h6-rtc";
> + reg = <0x07000000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
> + clock-output-names = "osc32k", "osc32k-out", "iosc";
> + #clock-cells = <1>;
> + clocks = <&ext_osc32k>;
> + };
> +
> + r_ccu: clock@7010000 {
> + compatible = "allwinner,sun50i-h6-r-ccu";
> + reg = <0x07010000 0x400>;
> + clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
> + <&ccu CLK_PLL_PERIPH0>;
> + clock-names = "hosc", "losc", "iosc", "pll-periph";
> + protected-clocks = <CLK_R_APB1_TWD>;
> + #clock-cells = <1>;
> + #reset-cells = <1>;
> + };
> +
> + r_watchdog: watchdog@7020400 {
> + compatible = "allwinner,sun50i-h6-wdt",
> + "allwinner,sun6i-a31-wdt";
> + reg = <0x07020400 0x20>;
> + interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&osc24M>;
> + };
> +
> + r_intc: interrupt-controller@7021000 {
> + compatible = "allwinner,sun50i-h6-r-intc";
> + interrupt-controller;
> + #interrupt-cells = <3>;
> + reg = <0x07021000 0x400>;
> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
> + };
> +
> + r_pwm: pwm@7020C00 {
> + compatible = "allwinner,sun50i-h6-pwm";
> + reg = <0x07020C00 0x400>;
> + clocks = <&osc24M>, <&ccu CLK_R_APB1_PWM>;
> + clock-names = "mod", "bus";
> + resets = <&ccu RST_R_APB1_PWM>;
> + #pwm-cells = <3>;
> + status = "disabled";
> + };
> +
> + r_pio: pinctrl@7022000 {
> + compatible = "allwinner,sun50i-h6-r-pinctrl";
> + reg = <0x07022000 0x400>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
> + <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
> + <&rtc CLK_OSC32K>;
> + clock-names = "apb", "hosc", "losc";
> + gpio-controller;
> + #gpio-cells = <3>;
> + interrupt-controller;
> + #interrupt-cells = <3>;
> +
> + r_i2c_pins: r-i2c-pins {
> + pins = "PL0", "PL1";
> + function = "s_i2c";
> + };
> +
> + r_ir_rx_pin: r-ir-rx-pin {
> + pins = "PL9";
> + function = "s_cir_rx";
> + };
> +
> + r_rsb_pins: r-rsb-pins {
> + pins = "PL0", "PL1";
> + function = "s_rsb";
> + };
> +
> + r_uart_pins: r-uart-pins {
> + pins = "PL2", "PL3";
> + function = "s_uart";
> + };
> +
> + r_pwm_pin: r-pwm-pin {
> + pins = "PL8";
> + function = "s_pwm";
> + };
> +
> + };
> +
> + r_ir: ir@7040000 {
> + compatible = "allwinner,sun50i-h6-ir",
> + "allwinner,sun6i-a31-ir";
> + reg = <0x07040000 0x400>;
> + interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB1_IR>,
> + <&r_ccu CLK_IR>;
> + clock-names = "apb", "ir";
> + resets = <&r_ccu RST_R_APB1_IR>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_ir_rx_pin>;
> + status = "disabled";
> + };
> +
> + r_i2c: i2c@7081400 {
> + compatible = "allwinner,sun50i-h6-i2c",
> + "allwinner,sun6i-a31-i2c";
> + reg = <0x07081400 0x400>;
> + interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB2_I2C>;
> + resets = <&r_ccu RST_R_APB2_I2C>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_i2c_pins>;
> + status = "okay";
> + #address-cells = <1>;
> + #size-cells = <0>;
> +
> + axp805: pmic@36 {
> + compatible = "x-powers,axp805", "x-powers,axp806";
> + reg = <0x36>;
> + interrupt-parent = <&r_intc>;
> + interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_LOW>;
> + interrupt-controller;
> + #interrupt-cells = <1>;
> + x-powers,self-working-mode;
> + vina-supply = <®_vcc5v>;
> + vinb-supply = <®_vcc5v>;
> + vinc-supply = <®_vcc5v>;
> + vind-supply = <®_vcc5v>;
> + vine-supply = <®_vcc5v>;
> + aldoin-supply = <®_vcc5v>;
> + bldoin-supply = <®_vcc5v>;
> + cldoin-supply = <®_vcc5v>;
> +
> + regulators {
> + reg_aldo1: aldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-pl-led-ir";
> + };
> +
> + reg_aldo2: aldo2 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-audio-tv-ephy-mac";
> + regulator-enable-ramp-delay = <100000>;
> + };
> +
> + reg_aldo3: aldo3 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-1";
> + };
> +
> + reg_bldo1: bldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc18-dram-bias-pll";
> + };
> +
> + reg_bldo2: bldo2 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-efuse-pcie-hdmi-pc";
> + };
> +
> + reg_bldo3: bldo3 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-dcxoio";
> + };
> +
> + reg_bldo4: bldo4 {
> + regulator-always-on;
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-name = "vcc-dcxoio";
> + };
> +
> + reg_cldo1: cldo1 {
> + regulator-always-on;
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc33-io-pd-emmc-sd-usb-uart-2";
> + };
> +
> + reg_cldo2: cldo2 {
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-wifi-1";
> + };
> +
> + reg_cldo3: cldo3 {
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-name = "vcc-wifi-2";
> + };
> +
> + reg_dcdca: dcdca {
> + regulator-always-on;
> + regulator-min-microvolt = <810000>;
> + regulator-max-microvolt = <1200000>;
> + regulator-ramp-delay = <2500>;
> + regulator-name = "vdd-cpu";
> + };
> +
> + reg_dcdcc: dcdcc {
> + regulator-enable-ramp-delay = <32000>;
> + regulator-min-microvolt = <810000>;
> + regulator-max-microvolt = <1080000>;
> + regulator-ramp-delay = <2500>;
> + regulator-name = "vdd-gpu";
> + };
> +
> + reg_dcdcd: dcdcd {
> + regulator-always-on;
> + regulator-min-microvolt = <1000000>;
> + regulator-max-microvolt = <1000000>;
> + regulator-name = "vdd-sys";
> + };
> +
> + sw {
> + /* unused */
> + };
> + };
> + };
> + };
> +
> + r_rsb: rsb@7083000 {
> + compatible = "allwinner,sun8i-a23-rsb";
> + reg = <0x07083000 0x400>;
> + interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&r_ccu CLK_R_APB2_RSB>;
> + clock-frequency = <3000000>;
> + resets = <&r_ccu RST_R_APB2_RSB>;
> + pinctrl-names = "default";
> + pinctrl-0 = <&r_rsb_pins>;
> + status = "disabled";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + };
> +
> + ths: thermal-sensor@5070400 {
> + compatible = "allwinner,sun50i-h6-ths";
> + reg = <0x05070400 0x100>;
> + interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
> + clocks = <&ccu CLK_BUS_THS>;
> + clock-names = "bus";
> + resets = <&ccu RST_BUS_THS>;
> + nvmem-cells = <&ths_calibration>;
> + nvmem-cell-names = "calibration";
> + #thermal-sensor-cells = <1>;
> + };
> +
> + sunxi-info {
> + compatible = "allwinner,sun50i-h6-sys-info";
> + status = "okay";
> + };
> +
> + addr_mgt: addr-mgt {
> + compatible = "allwinner,sunxi-addr_mgt";
> + type_addr_wifi = <0x2>;
> + type_addr_bt = <0x2>;
> + type_addr_eth = <0x2>;
> + status = "okay";
> + };
> +
> + dump_reg: dump_reg@20000 {
> + compatible = "allwinner,sunxi-dump-reg";
> + reg = <0x0 0x03001000 0x0 0x0f20>;
> + status = "okay";
> + };
> + };
> +
> + thermal-zones {
> + cpu-thermal {
> + polling-delay-passive = <250>;
> + polling-delay = <1000>;
> + thermal-sensors = <&ths 0>;
> +
> + trips {
> + cpu_warm: cpu_warm {
> + temperature = <70000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_hot0: cpu_hot0 {
> + temperature = <74000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_hot1: cpu_hot1 {
> + temperature = <76000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot0: cpu_very_hot0 {
> + temperature = <78000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot1: cpu_very_hot1 {
> + temperature = <80000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot2: cpu_very_hot2 {
> + temperature = <82000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot3: cpu_very_hot3 {
> + temperature = <84000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot4: cpu_very_hot4 {
> + temperature = <86000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot5: cpu_very_hot5 {
> + temperature = <88000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_very_hot6: cpu_very_hot6 {
> + temperature = <90000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + cpu_crit: cpu_crit {
> + temperature = <97000>;
> + hysteresis = <2000>;
> + type = "critical";
> + };
> + };
> +
> + cooling-maps {
> + cpu_warm_limit_cpu {
> + trip = <&cpu_warm>;
> + cooling-device = <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
> + };
> + };
> + };
> +
> + gpu-thermal {
> + polling-delay-passive = <1000>;
> + polling-delay = <2000>;
> + thermal-sensors = <&ths 1>;
> +
> + trips {
> + gpu_alert0: gpu-alert-0 {
> + temperature = <95000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu_alert1: gpu-alert-1 {
> + temperature = <100000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu_alert2: gpu-alert-2 {
> + temperature = <105000>;
> + hysteresis = <2000>;
> + type = "passive";
> + };
> +
> + gpu-crit {
> + temperature = <115000>;
> + hysteresis = <0>;
> + type = "critical";
> + };
> + };
> +
> + cooling-maps {
> + // Forbid the GPU to go over 756MHz
> + map0 {
> + trip = <&gpu_alert0>;
> + cooling-device = <&gpu 1 THERMAL_NO_LIMIT>;
> + };
> +
> + // Forbid the GPU to go over 624MHz
> + map1 {
> + trip = <&gpu_alert1>;
> + cooling-device = <&gpu 2 THERMAL_NO_LIMIT>;
> + };
> +
> + // Forbid the GPU to go over 576MHz
> + map2 {
> + trip = <&gpu_alert2>;
> + cooling-device = <&gpu 3 THERMAL_NO_LIMIT>;
> + };
> + };
> + };
> + };
> +
> + cpu_opp_table: cpu-opp-table {
> + compatible = "allwinner,sun50i-h6-operating-points";
> + nvmem-cells = <&cpu_speed_grade>;
> + opp-shared;
> +
> + opp-480000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <480000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-720000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <720000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-888000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <888000000>;
> +
> + opp-microvolt-speed0 = <880000>;
> + };
> +
> + opp-1080000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1080000000>;
> +
> + opp-microvolt-speed0 = <940000>;
> + };
> +
> + opp-1320000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1320000000>;
> +
> + opp-microvolt-speed0 = <1000000>;
> + };
> +
> + opp-1488000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1488000000>;
> +
> + opp-microvolt-speed0 = <1060000>;
> + };
> +
> + opp-1608000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1608000000>;
> +
> + opp-microvolt-speed0 = <1090000>;
> + };
> +
> + opp-1704000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1704000000>;
> +
> + opp-microvolt-speed0 = <1120000>;
> + };
> +
> + opp-1800000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1800000000>;
> +
> + opp-microvolt-speed0 = <1160000>;
> + };
> +
> + opp@1896000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1896000000>;
> +
> + opp-microvolt-speed0 = <1180000>;
> + };
> +
> + opp@1968000000 {
> + clock-latency-ns = <244144>; /* 8 32k periods */
> + opp-hz = /bits/ 64 <1968000000>;
> +
> + opp-microvolt-speed0 = <1200000>;
> + };
> +
> + };
> +
> + gpu_opp_table: opp-table-gpu {
> + compatible = "operating-points-v2";
> +
> + opp-216000000 {
> + opp-hz = /bits/ 64 <216000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-264000000 {
> + opp-hz = /bits/ 64 <264000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-312000000 {
> + opp-hz = /bits/ 64 <312000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-336000000 {
> + opp-hz = /bits/ 64 <336000000>;
> + opp-microvolt = <810000 810000 1200000>;
> + };
> +
> + opp-360000000 {
> + opp-hz = /bits/ 64 <360000000>;
> + opp-microvolt = <820000 820000 1200000>;
> + };
> +
> + opp-384000000 {
> + opp-hz = /bits/ 64 <384000000>;
> + opp-microvolt = <830000 830000 1200000>;
> + };
> +
> + opp-408000000 {
> + opp-hz = /bits/ 64 <408000000>;
> + opp-microvolt = <840000 840000 1200000>;
> + };
> +
> + opp-420000000 {
> + opp-hz = /bits/ 64 <420000000>;
> + opp-microvolt = <850000 850000 1200000>;
> + };
> +
> + opp-432000000 {
> + opp-hz = /bits/ 64 <432000000>;
> + opp-microvolt = <860000 860000 1200000>;
> + };
> +
> + opp-456000000 {
> + opp-hz = /bits/ 64 <456000000>;
> + opp-microvolt = <870000 870000 1200000>;
> + };
> +
> + opp-504000000 {
> + opp-hz = /bits/ 64 <504000000>;
> + opp-microvolt = <890000 890000 1200000>;
> + };
> +
> + opp-540000000 {
> + opp-hz = /bits/ 64 <540000000>;
> + opp-microvolt = <910000 910000 1200000>;
> + };
> +
> + opp-576000000 {
> + opp-hz = /bits/ 64 <576000000>;
> + opp-microvolt = <930000 930000 1200000>;
> + };
> +
> + opp-624000000 {
> + opp-hz = /bits/ 64 <624000000>;
> + opp-microvolt = <950000 950000 1200000>;
> + };
> +
> + opp-756000000 {
> + opp-hz = /bits/ 64 <756000000>;
> + opp-microvolt = <1040000 1040000 1200000>;
> + };
> + };
> +
> + chosen {
> + stdout-path = "serial0:115200n8";
> + };
> +
> + connector {
> + compatible = "hdmi-connector";
> + type = "a";
> +
> + port {
> + hdmi_con_in: endpoint {
> + remote-endpoint = <&hdmi_out_con>;
> + };
> + };
> + };
> +
> + ext_osc32k: ext_osc32k_clk {
> + #clock-cells = <0>;
> + compatible = "fixed-clock";
> + clock-frequency = <32768>;
> + clock-output-names = "ext_osc32k";
> + };
> +
> + leds {
> + compatible = "gpio-leds";
> +
> + led-0 {
> + label = "repka:red:power";
> + gpios = <&r_pio 0 9 GPIO_ACTIVE_LOW>; /* PL9 */
> + linux,default-trigger = "heartbeat";
> + };
> + };
> +
> + reg_vcc5v: vcc5v {
> + /* board wide 5V supply directly from the DC jack */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc-5v";
> + regulator-min-microvolt = <5000000>;
> + regulator-max-microvolt = <5000000>;
> + regulator-always-on;
> + };
> +
> + reg_vcc33_wifi: vcc33-wifi {
> + /* Always on 3.3V regulator for WiFi and BT */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc33-wifi";
> + regulator-min-microvolt = <3300000>;
> + regulator-max-microvolt = <3300000>;
> + regulator-always-on;
> + vin-supply = <®_vcc5v>;
> + };
> +
> + reg_vcc_wifi_io: vcc-wifi-io {
> + /* Always on 1.8V/300mA regulator for WiFi and BT IO */
> + compatible = "regulator-fixed";
> + regulator-name = "vcc-wifi-io";
> + regulator-min-microvolt = <1800000>;
> + regulator-max-microvolt = <1800000>;
> + regulator-always-on;
> + vin-supply = <®_vcc33_wifi>;
> + };
> +
> + wifi_pwrseq: wifi-pwrseq {
> + compatible = "mmc-pwrseq-simple";
> + clocks = <&rtc 1>;
> + clock-names = "ext_clock";
> + reset-gpios = <&r_pio 1 3 GPIO_ACTIVE_LOW>; /* PM3 */
> + post-power-on-delay-ms = <200>;
> + };
> +};
> --
> 2.42.2
>
> _______________________________________________
> devel-kernel mailing list
> devel-kernel@lists.altlinux.org
> https://lists.altlinux.org/mailman/listinfo/devel-kernel
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2025-05-08 1:22 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-05-06 12:28 [d-kernel] [PATCH] arm64: dts: add devicetree for repka pi4 optimal kurachenko-urup
2025-05-07 19:39 ` Vitaly Chikunov
2025-05-07 20:50 ` Kurachenko Anton
2025-05-08 0:54 ` Vitaly Chikunov
2025-05-08 1:10 ` Anton Midyukov
2025-05-08 1:19 ` Vitaly Chikunov
2025-05-08 1:22 ` Vitaly Chikunov
ALT Linux kernel packages development
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel-kernel/0 devel-kernel/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 devel-kernel devel-kernel/ http://lore.altlinux.org/devel-kernel \
devel-kernel@altlinux.org devel-kernel@altlinux.ru devel-kernel@altlinux.com
public-inbox-index devel-kernel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel-kernel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git