基于firefly-rk3568-pc适配-rock-pi-3a(二)

内容纲要

一、设备树修改

1.修改文件位置

./u-boot/arch/arm/dts/rk3568-rock-3a.dts ./kernel/arch/arm64/boot/dts/rockchip/rk3568-rock-3a.dtsi ./kernel/arch/arm64/boot/dts/rockchip/rk3568-rockpi-core.dtsi ./kernel/arch/arm64/boot/dts/rockchip/rk3568-rockpi-port.dtsi ./kernel/arch/arm64/boot/dts/rockchip/rk3568-rock-3ab-cameras.dtsi ./kernel/arch/arm64/boot/dts/rockchip/rk3568-rock-3a.dts

<p><strong>1.1 uboot 设备树文件修改rk3568-rock-3a.dts</strong></p>
<pre><code class="language-c">/*
  • SPDX-License-Identifier: GPL-2.0+
  • (C) Copyright 2020 Rockchip Electronics Co., Ltd
    */

/dts-v1/;

include "rk3568.dtsi"

include "rk3568-u-boot-rock.dtsi"

include <dt-bindings/input/input.h>

/ {
model = "Radxa ROCK3 Model A";
compatible = "radxa,rock3a", "rockchip,rk3568";

dc_12v: dc-12v {
    u-boot,dm-pre-reloc;
    compatible = "regulator-fixed";
    regulator-name = "dc_12v";
    regulator-always-on;
    regulator-boot-on;
    regulator-min-microvolt = <12000000>;
    regulator-max-microvolt = <12000000>;
};

vcc5v0_sys: vcc5v0-sys {
    u-boot,dm-pre-reloc;
    compatible = "regulator-fixed";
    regulator-name = "vcc5v0_sys";
    regulator-always-on;
    regulator-boot-on;
    regulator-min-microvolt = <5000000>;
    regulator-max-microvolt = <5000000>;
    vin-supply = <&dc_12v>;
};

vcc3v3_sys: vcc3v3-sys {
    u-boot,dm-pre-reloc;
    compatible = "regulator-fixed";
    regulator-name = "vcc3v3_sys";
    regulator-always-on;
    regulator-boot-on;
    regulator-min-microvolt = <3300000>;
    regulator-max-microvolt = <3300000>;
    vin-supply = <&vcc5v0_sys>;
};

led_sys: led-sys {
    u-boot,dm-pre-reloc;
    compatible = "regulator-fixed";
    regulator-name = "led_sys";
    enable-active-high;
    gpio = <&gpio0 RK_PB7 GPIO_ACTIVE_HIGH>; // Turn on blue led
    regulator-boot-on;
    regulator-always-on;
    vin-supply = <&vcc3v3_sys>;
};

vcc3v3_pcie: gpio-regulator {
    u-boot,dm-pre-reloc;
    compatible = "regulator-fixed";
    regulator-name = "vcc3v3_pcie";
    regulator-min-microvolt = <3300000>;
    regulator-max-microvolt = <3300000>;
    enable-active-high;
    gpio = <&gpio0 RK_PD4 GPIO_ACTIVE_HIGH>;
    startup-delay-us = <5000>;
    vin-supply = <&vcc5v0_sys>;
};

adc-keys {
    compatible = "adc-keys";
    io-channels = <&saradc 0>;
    io-channel-names = "buttons";
    keyup-threshold-microvolt = <1800000>;
    u-boot,dm-spl;
    status = "okay";

    volumeup-key {
        u-boot,dm-spl;
        linux,code = ;
        label = "volume up";
        press-threshold-microvolt = <9>;
    };
};

};

&crypto {
status = "okay";
};

&uart2 {
status = "okay";
};

&pmu_io_domains {
status = "okay";
pmuio1-supply = <&vcc3v3_pmu>;
pmuio2-supply = <&vcc3v3_pmu>;
vccio1-supply = <&vccio_acodec>;
vccio3-supply = <&vccio_sd>;
vccio4-supply = <&vcc_1v8>;
vccio5-supply = <&vcc_3v3>;
vccio6-supply = <&vcc_1v8>;
vccio7-supply = <&vcc_3v3>;
u-boot,dm-pre-reloc;
};

&gpio0 {
u-boot,dm-pre-reloc;
};
/
&sdhci {
bus-width = <8>;
supports-emmc;
non-removable;
max-frequency = <200000000>;
status = "okay";
};
/

&i2c0 {
status = "okay";
u-boot,dm-pre-reloc;
clock-frequency = <100000>;

vdd_cpu: tcs4525@1c {
    u-boot,dm-pre-reloc;
    compatible = "tcs,tcs452x";
    reg = <0x1c>;
    vin-supply = <&vcc5v0_sys>;
    regulator-compatible = "fan53555-reg";
    regulator-name = "vdd_cpu";
    regulator-min-microvolt = <712500>;
    regulator-max-microvolt = <1390000>;
    regulator-ramp-delay = <2300>;
    fcs,suspend-voltage-selector = <1>;
    regulator-boot-on;
    regulator-always-on;
    regulator-state-mem {
        u-boot,dm-pre-reloc;
        regulator-off-in-suspend;
    };
};

rk809: pmic@20 {
    u-boot,dm-pre-reloc;
    status = "okay";
    compatible = "rockchip,rk809";
    reg = <0x20>;
    interrupt-parent = <&gpio0>;
    interrupts = <3 IRQ_TYPE_LEVEL_LOW>;

    pinctrl-names = "default", "pmic-sleep",
            "pmic-power-off", "pmic-reset";
    pinctrl-0 = <&pmic_int>;
    pinctrl-1 = <&soc_slppin_slp>, <&rk817_slppin_slp>;
    pinctrl-2 = <&soc_slppin_gpio>, <&rk817_slppin_pwrdn>;
    pinctrl-3 = <&soc_slppin_gpio>, <&rk817_slppin_rst>;

    rockchip,system-power-controller;
    wakeup-source;
    #clock-cells = <1>;
    clock-output-names = "rk808-clkout1", "rk808-clkout2";
    //fb-inner-reg-idxs = <2>;
    /* 1: rst regs (default in codes), 0: rst the pmic */
    pmic-reset-func = <0>;
    /* not save the PMIC_POWER_EN register in uboot */
    not-save-power-en = <1>;

    vcc1-supply = <&vcc3v3_sys>;
    vcc2-supply = <&vcc3v3_sys>;
    vcc3-supply = <&vcc3v3_sys>;
    vcc4-supply = <&vcc3v3_sys>;
    vcc5-supply = <&vcc3v3_sys>;
    vcc6-supply = <&vcc3v3_sys>;
    vcc7-supply = <&vcc3v3_sys>;
    vcc8-supply = <&vcc3v3_sys>;
    vcc9-supply = <&vcc3v3_sys>;

    pwrkey {
        status = "okay";
        u-boot,dm-pre-reloc;
    };

    pinctrl_rk8xx: pinctrl_rk8xx {
        u-boot,dm-pre-reloc;
        gpio-controller;
        #gpio-cells = <2>;

        rk817_slppin_null: rk817_slppin_null {
            pins = "gpio_slp";
            function = "pin_fun0";
            u-boot,dm-pre-reloc;
        };

        rk817_slppin_slp: rk817_slppin_slp {
            pins = "gpio_slp";
            function = "pin_fun1";
            u-boot,dm-pre-reloc;
        };

        rk817_slppin_pwrdn: rk817_slppin_pwrdn {
            pins = "gpio_slp";
            function = "pin_fun2";
            u-boot,dm-pre-reloc;
        };

        rk817_slppin_rst: rk817_slppin_rst {
            pins = "gpio_slp";
            function = "pin_fun3";
            u-boot,dm-pre-reloc;
        };
    };

    regulators {
        u-boot,dm-pre-reloc;
        vdd_logic: DCDC_REG1 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <500000>;
            regulator-max-microvolt = <1350000>;
            regulator-init-microvolt = <900000>;
            regulator-ramp-delay = <6001>;
            regulator-initial-mode = <0x2>;
            regulator-name = "vdd_logic";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
            };
        };

        vdd_gpu: DCDC_REG2 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <500000>;
            regulator-max-microvolt = <1350000>;
            regulator-init-microvolt = <900000>;
            regulator-ramp-delay = <6001>;
            regulator-initial-mode = <0x2>;
            regulator-name = "vdd_gpu";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
            };
        };

        vcc_ddr: DCDC_REG3 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-initial-mode = <0x2>;
            regulator-name = "vcc_ddr";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
            };
        };

        vdd_npu: DCDC_REG4 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <500000>;
            regulator-max-microvolt = <1350000>;
            regulator-init-microvolt = <900000>;
            regulator-ramp-delay = <6001>;
            regulator-initial-mode = <0x2>;
            regulator-name = "vdd_npu";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
            };
        };

        vdda0v9_image: LDO_REG1 {
            u-boot,dm-pre-reloc;
            regulator-boot-on;
            regulator-always-on;
            regulator-min-microvolt = <900000>;
            regulator-max-microvolt = <900000>;
            regulator-name = "vdda0v9_image";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vdda_0v9: LDO_REG2 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <900000>;
            regulator-max-microvolt = <900000>;
            regulator-name = "vdda_0v9";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vdda0v9_pmu: LDO_REG3 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <900000>;
            regulator-max-microvolt = <900000>;
            regulator-name = "vdda0v9_pmu";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
                regulator-suspend-microvolt = <900000>;
            };
        };

        vccio_acodec: LDO_REG4 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <3300000>;
            regulator-max-microvolt = <3300000>;
            regulator-name = "vccio_acodec";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vccio_sd: LDO_REG5 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <3300000>;
            regulator-name = "vccio_sd";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vcc3v3_pmu: LDO_REG6 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <3300000>;
            regulator-max-microvolt = <3300000>;
            regulator-name = "vcc3v3_pmu";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
                regulator-suspend-microvolt = <3300000>;
            };
        };

        vcca_1v8: LDO_REG7 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <1800000>;
            regulator-name = "vcca_1v8";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vcca1v8_pmu: LDO_REG8 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <1800000>;
            regulator-name = "vcca1v8_pmu";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-on-in-suspend;
                regulator-suspend-microvolt = <1800000>;
            };
        };

        vcca1v8_image: LDO_REG9 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <1800000>;
            regulator-name = "vcca1v8_image";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vcc_1v8: DCDC_REG5 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <1800000>;
            regulator-name = "vcc_1v8";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vcc_3v3: SWITCH_REG1 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-name = "vcc_3v3";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };

        vcc3v3_sd: SWITCH_REG2 {
            u-boot,dm-pre-reloc;
            regulator-always-on;
            regulator-boot-on;
            regulator-name = "vcc3v3_sd";
            regulator-state-mem {
                u-boot,dm-pre-reloc;
                regulator-off-in-suspend;
            };
        };
    };
};

};

&pcie30_phy_grf {
u-boot,dm-pre-reloc;
};

&pcie3x2 {
u-boot,dm-pre-reloc;
vpcie3v3-supply = <&vcc3v3_pcie>;
reset-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
status = "okay";
};

&pcie30phy {
u-boot,dm-pre-reloc;
status = "okay";
};

&pinctrl {
u-boot,dm-spl;
pmic {
u-boot,dm-pre-reloc;
pmic_int: pmic_int {
u-boot,dm-pre-reloc;
rockchip,pins =
<0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;
};

    soc_slppin_gpio: soc_slppin_gpio {
        u-boot,dm-pre-reloc;
        rockchip,pins =
            <0 RK_PA2 RK_FUNC_GPIO &pcfg_output_low>;
    };

    soc_slppin_slp: soc_slppin_slp {
        u-boot,dm-pre-reloc;
        rockchip,pins =
            <0 RK_PA2 RK_FUNC_1 &pcfg_pull_none>;
    };

    soc_slppin_rst: soc_slppin_rst {
        u-boot,dm-pre-reloc;
        rockchip,pins =
            <0 RK_PA2 RK_FUNC_2 &pcfg_pull_none>;
    };
};

};

1.2 kernel修改设备树位置

rk3568-rock-3a.dtsi 文件修改
    #include "rk3568-rockpi-port.dtsi"
    / {
    fiq_debugger: fiq-debugger {
        compatible = "rockchip,fiq-debugger";
        rockchip,serial-id = <2>;
        rockchip,wake-irq = <0>;
        /* If enable uart uses irq instead of fiq */
        rockchip,irq-mode-enable = <1>;
        rockchip,baudrate = <1500000>;  /* Only 115200 and 1500000 */
        interrupts = ;
        pinctrl-names = "default";
        pinctrl-0 = <&uart2m0_xfer>;
        status = "okay";
    };

    debug: debug@fd904000 {
        compatible = "rockchip,debug";
        reg = <0x0 0xfd904000 0x0 0x1000>,
            <0x0 0xfd905000 0x0 0x1000>,
            <0x0 0xfd906000 0x0 0x1000>,
            <0x0 0xfd907000 0x0 0x1000>;
    };

    vcc_hub_power: vcc-hub-power-regulator {
        compatible = "regulator-fixed";
        enable-active-high;
        gpio = <&gpio3 RK_PA2 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&vcc_hub_power_en>;
        regulator-name = "vcc_hub_power_en";
        regulator-always-on;
    };

    vcc_hub_reset: vcc-hub-reset-regulator {
        compatible = "regulator-fixed";
        enable-active-high;
        gpio = <&gpio3 RK_PA6 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&vcc_hub_reset_en>;
        regulator-name = "vcc_hub_reset_en";
        regulator-always-on;
    };

    pcie_pi6c_oe: pcie-pi6c-oe-regulator {
        compatible = "regulator-fixed";
        //enable-active-high;
        gpio = <&gpio3 RK_PA7 GPIO_ACTIVE_LOW>;
        pinctrl-names = "default";
        pinctrl-0 = <&pcie_pi6c_oe_en>;
        regulator-name = "pcie_pi6c_oe_en";
        regulator-always-on;
    };

    vcc_4g_power: vcc-4g-power-regulator {
        compatible = "regulator-fixed";
        enable-active-high;
        gpio = <&gpio0 RK_PB0 GPIO_ACTIVE_HIGH>;
        pinctrl-names = "default";
        pinctrl-0 = <&vcc_4g_power_en>;
        regulator-name = "vcc_4g_power_en";
        regulator-always-on;
    };

    gpio_leds: gpio-leds {
        compatible = "gpio-leds";
        status = "okay";

        user-led {
            gpios = <&gpio0 RK_PB7 GPIO_ACTIVE_HIGH>;
            linux,default-trigger = "timer";
            default-state = "on";
            pinctrl-0 = <&user_led>;
        };

        wifi-led {
            gpios = <&gpio2 RK_PB0 GPIO_ACTIVE_HIGH>;
            linux,default-trigger = "rfkill2";
            default-state = "on";
            pinctrl-0 = <&wifi_led>;
        };
    };

    };

    &csi2_dphy0 {
        status = "disabled";
    };

    &csi2_dphy1 {
        status = "disabled";
        /*
        * dphy1 only used for split mode,
        * can be used  concurrently  with dphy2
        * full mode and split mode are mutually exclusive
        */
    };

    &csi2_dphy2 {
        status = "disabled";
        /*
        * dphy2 only used for split mode,
        * can be used  concurrently  with dphy1
        * full mode and split mode are mutually exclusive
        */
    };

    &rkisp_vir0 {
        status = "disabled";
    };

    &rkisp_vir1 {
        status = "disabled";
    };

    &i2c0 {
    status = "okay";
    vdd_cpu: tcs4525@1c {
        compatible = "tcs,tcs452x";
        reg = <0x1c>;
        vin-supply = <&vcc5v0_sys>;
        regulator-compatible = "fan53555-reg";
        regulator-name = "vdd_cpu";
        regulator-min-microvolt = <712500>;
        regulator-max-microvolt = <1390000>;
        regulator-ramp-delay = <2300>;
        fcs,suspend-voltage-selector = <1>;
        regulator-boot-on;
        regulator-always-on;
        regulator-state-mem {
            regulator-off-in-suspend;
        };
    };

    rk809: pmic@20 {
        compatible = "rockchip,rk809";
        reg = <0x20>;
        interrupt-parent = <&gpio0>;
        interrupts = <3 IRQ_TYPE_LEVEL_LOW>;

        pinctrl-names = "default", "pmic-sleep",
                "pmic-power-off", "pmic-reset";
        pinctrl-0 = <&pmic_int>;
        pinctrl-1 = <&soc_slppin_slp>, <&rk817_slppin_slp>;
        pinctrl-2 = <&soc_slppin_gpio>, <&rk817_slppin_pwrdn>;
        pinctrl-3 = <&soc_slppin_gpio>, <&rk817_slppin_rst>;

        rockchip,system-power-controller;
        wakeup-source;
        #clock-cells = <1>;
        clock-output-names = "rk808-clkout1", "rk808-clkout2";
        //fb-inner-reg-idxs = <2>;
        /* 1: rst regs (default in codes), 0: rst the pmic */
        pmic-reset-func = <0>;
        /* not save the PMIC_POWER_EN register in uboot */
        not-save-power-en = <1>;

        vcc1-supply = <&vcc3v3_sys>;
        vcc2-supply = <&vcc3v3_sys>;
        vcc3-supply = <&vcc3v3_sys>;
        vcc4-supply = <&vcc3v3_sys>;
        vcc5-supply = <&vcc3v3_sys>;
        vcc6-supply = <&vcc3v3_sys>;
        vcc7-supply = <&vcc3v3_sys>;
        vcc8-supply = <&vcc3v3_sys>;
        vcc9-supply = <&vcc3v3_sys>;

        pwrkey {
            status = "okay";
        };

        pinctrl_rk8xx: pinctrl_rk8xx {
            gpio-controller;
            #gpio-cells = <2>;

            rk817_slppin_null: rk817_slppin_null {
                pins = "gpio_slp";
                function = "pin_fun0";
            };

            rk817_slppin_slp: rk817_slppin_slp {
                pins = "gpio_slp";
                function = "pin_fun1";
            };

            rk817_slppin_pwrdn: rk817_slppin_pwrdn {
                pins = "gpio_slp";
                function = "pin_fun2";
            };

            rk817_slppin_rst: rk817_slppin_rst {
                pins = "gpio_slp";
                function = "pin_fun3";
            };
        };
                regulators {
            vdd_logic: DCDC_REG1 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <500000>;
                regulator-max-microvolt = <1350000>;
                regulator-init-microvolt = <900000>;
                regulator-ramp-delay = <6001>;
                regulator-initial-mode = <0x2>;
                regulator-name = "vdd_logic";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vdd_gpu: DCDC_REG2 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <500000>;
                regulator-max-microvolt = <1350000>;
                regulator-init-microvolt = <900000>;
                regulator-ramp-delay = <6001>;
                regulator-initial-mode = <0x2>;
                regulator-name = "vdd_gpu";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcc_ddr: DCDC_REG3 {
                regulator-always-on;
                regulator-boot-on;
                regulator-initial-mode = <0x2>;
                regulator-name = "vcc_ddr";
                regulator-state-mem {
                    regulator-on-in-suspend;
                };
            };

            vdd_npu: DCDC_REG4 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <500000>;
                regulator-max-microvolt = <1350000>;
                regulator-init-microvolt = <900000>;
                regulator-ramp-delay = <6001>;
                regulator-initial-mode = <0x2>;
                regulator-name = "vdd_npu";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vdda0v9_image: LDO_REG1 {
                regulator-boot-on;
                regulator-always-on;
                regulator-min-microvolt = <900000>;
                regulator-max-microvolt = <900000>;
                regulator-name = "vdda0v9_image";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vdda_0v9: LDO_REG2 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <900000>;
                regulator-max-microvolt = <900000>;
                regulator-name = "vdda_0v9";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vdda0v9_pmu: LDO_REG3 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <900000>;
                regulator-max-microvolt = <900000>;
                regulator-name = "vdda0v9_pmu";
                regulator-state-mem {
                    regulator-on-in-suspend;
                    regulator-suspend-microvolt = <900000>;
                };
            };

            vccio_acodec: LDO_REG4 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <3000000>;
                regulator-max-microvolt = <3000000>;
                regulator-name = "vccio_acodec";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vccio_sd: LDO_REG5 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <1800000>;
                regulator-max-microvolt = <3300000>;
                regulator-name = "vccio_sd";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcc3v3_pmu: LDO_REG6 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <3300000>;
                regulator-max-microvolt = <3300000>;
                regulator-name = "vcc3v3_pmu";
                regulator-state-mem {
                    regulator-on-in-suspend;
                    regulator-suspend-microvolt = <3300000>;
                };
            };

            vcca_1v8: LDO_REG7 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <1800000>;
                regulator-max-microvolt = <1800000>;
                regulator-name = "vcca_1v8";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcca1v8_pmu: LDO_REG8 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <1800000>;
                regulator-max-microvolt = <1800000>;
                regulator-name = "vcca1v8_pmu";
                regulator-state-mem {
                    regulator-on-in-suspend;
                    regulator-suspend-microvolt = <1800000>;
                };
            };

            vcca1v8_image: LDO_REG9 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <1800000>;
                regulator-max-microvolt = <1800000>;
                regulator-name = "vcca1v8_image";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcc_1v8: DCDC_REG5 {
                regulator-always-on;
                regulator-boot-on;
                regulator-min-microvolt = <1800000>;
                regulator-max-microvolt = <1800000>;
                regulator-name = "vcc_1v8";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcc_3v3: SWITCH_REG1 {
                regulator-always-on;
                regulator-boot-on;
                regulator-name = "vcc_3v3";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };

            vcc3v3_sd: SWITCH_REG2 {
                regulator-always-on;
                regulator-boot-on;
                regulator-name = "vcc3v3_sd";
                regulator-state-mem {
                    regulator-off-in-suspend;
                };
            };
        };
        rk809_codec: codec {
            #sound-dai-cells = <0>;
            compatible = "rockchip,rk809-codec", "rockchip,rk817-codec";
            clocks = <&cru I2S1_MCLKOUT>;
            clock-names = "mclk";
            assigned-clocks = <&cru I2S1_MCLKOUT>, <&cru I2S1_MCLK_TX_IOE>;
            assigned-clock-rates = <12288000>;
            assigned-clock-parents = <&cru I2S1_MCLKOUT_TX>, <&cru I2S1_MCLKOUT_TX>;
            pinctrl-names = "default";
            pinctrl-0 = <&i2s1m0_mclk>;
            hp-volume = <20>;
            spk-volume = <3>;
            mic-in-differential;
            status = "okay";
        };
    };
    };

    &pmu_io_domains {
    status = "okay";
    pmuio1-supply = <&vcc3v3_pmu>;
    pmuio2-supply = <&vcc3v3_pmu>;
    vccio1-supply = <&vccio_acodec>;
    vccio3-supply = <&vccio_sd>;
    vccio4-supply = <&vcc_1v8>;
    vccio5-supply = <&vcc_3v3>;
    vccio6-supply = <&vcc_1v8>;
    vccio7-supply = <&vcc_3v3>;
    };

    &i2c4 {
    status = "disabled";
    };

    &i2c5 {
        status = "okay";
    };

    &hym8563 {
        status = "okay";
    };

    &mc3230 {
        status = "okay";
    };

    &rkisp {
        status = "okay";
    };

    &rkisp_mmu {
        status = "okay";
    };

    &uart1 {
        status = "okay";
        pinctrl-names = "default";
        pinctrl-0 = <&uart1m0_xfer &uart1m0_ctsn>;
    };
    &reserved_memory {
    ramoops: ramoops@110000 {
        compatible = "ramoops";
        reg = <0x0 0x110000 0x0 0xf0000>;
        record-size = <0x20000>;
        console-size = <0x80000>;
        ftrace-size = <0x00000>;
        pmsg-size = <0x50000>;
    };
    };

    &rng {
        status = "okay";
    };

    &rockchip_suspend {
        status = "okay";
    };

    &pcie30phy {
           status = "okay";
    };
    &pcie3x2 {
            reset-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
            vpcie3v3-supply = <&pcie30_3v3>;
            //num-lanes = <2>;
            pinctrl-0 = <&pcie30x2m1_pins>; 
            status = "okay";
    };
    &combphy2_psq {
        status = "okay";
    };

    &pcie2x1 {
        reset-gpios = <&gpio3 RK_PC1 GPIO_ACTIVE_HIGH>; 
        vpcie3v3-supply = <&pcie30_3v3>;
        pinctrl-0 = <&pcie20m1_pins>; 
        status = "okay";
    };
    &its {
        status = "okay";
    };
    &sdio_pwrseq {
        status = "okay";
        reset-gpios = <&gpio3 RK_PD5 GPIO_ACTIVE_LOW>;
        post-power-on-delay-ms = <100>;
    };

    &sdmmc0 {
        status = "okay";
    };

    &sdmmc2 {
        status = "okay";
    };

    &wireless_wlan {
        wifi_chip_type = "ap6275s";
        status = "okay";
    };

    &wireless_bluetooth {
        BT,wake_gpio     = <&gpio3 RK_PB5 GPIO_ACTIVE_HIGH>;
        BT,wake_host_irq = <&gpio2 RK_PD7 GPIO_ACTIVE_HIGH>;
        status = "okay";
    };

    &spdif_8ch{
        status = "disabled";
    };

    &rk809_codec {
        hp-ctl-gpios = <&gpio1 RK_PB0 GPIO_ACTIVE_HIGH>;
        hp-det-adc-value = <500>;
        hp-adc-drift-scope = <500>; // adc value range 500±500 to cover all earphones
    };

    &rk809 {
        rtc {
            status = "disabled";
        };
    };

    /*&pwm0 {
        status = "okay";
    };

    &pwm11 {
        status = "okay";
        pinctrl-0 = <&pwm11m1_pins>;
    };*/

    &sata2 {
        status = "okay";
    };

    &usbdrd_dwc3 {
        dr_mode = "host";
    };

    &pinctrl {

        usb {

            vcc_hub_power_en: vcc-hub-power-en {
                rockchip,pins = <3 RK_PA2 RK_FUNC_GPIO &pcfg_pull_none>;
            };

            vcc_hub_reset_en: vcc-hub-reset-en {
                rockchip,pins = <3 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };
        pcie {
            pcie_pi6c_oe_en: pcie-pi6c-oe-en {
                rockchip,pins = <3 RK_PA7 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        4g {
            vcc_4g_power_en: vcc-4g-power-en {
                rockchip,pins = <0 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        leds {
            user_led: user-led {
                rockchip,pins = <0 RK_PB7 RK_FUNC_GPIO &pcfg_pull_none>;
            };

            wifi_led: wifi-led {
                rockchip,pins = <2 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };
    };

1.3 rk3568-rock-3a.dtsi 文件修改

    /dts-v1/;
    #include "rk3568-rock-3a.dtsi"
    / {
        model = "RADXA ROCK 3A HDMI (Linux)";
        compatible = "rockchip,rk3568-rock-3a", "rockchip,rk3568";
    };
    &route_hdmi {
        status = "okay";
        connect = <&vp0_out_hdmi>;
    };

1.4 rk3568-rockpi-port.dtsi 添加

    // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
    /*
     * Copyright (c) 2020 Rockchip Electronics Co., Ltd.
     *
     */

    /dts-v1/;

    #include 
    #include 
    #include 
    #include "rk3568-rockpi-core.dtsi"
    #include "rk3568-linux.dtsi"

    / {
        compatible = "rockchip,rk3568-rockpi-port", "rockchip,rk3568";

        adc_keys: adc-keys {
            compatible = "adc-keys";
            io-channels = <&saradc 0>;
            io-channel-names = "buttons";
            keyup-threshold-microvolt = <1800000>;
            poll-interval = <100>;

            recovery-key {
                label = "F12";
                linux,code = ;
                press-threshold-microvolt = <1750>;
            };

            vol-down-key {
                label = "volume down";
                linux,code = ;
                press-threshold-microvolt = <297500>;
            };

            menu-key {
                label = "menu";
                linux,code = ;
                press-threshold-microvolt = <980000>;
            };

            back-key {
                label = "back";
                linux,code = ;
                press-threshold-microvolt = <1305500>;
            };
        };

        vcc2v5_sys: vcc2v5-ddr {
            compatible = "regulator-fixed";
            regulator-name = "vcc2v5-sys";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <2500000>;
            regulator-max-microvolt = <2500000>;
            vin-supply = <&vcc3v3_sys>;
        };

        vcc3v3_vga: vcc3v3-vga {
            compatible = "regulator-fixed";
            regulator-name = "vcc3v3_vga";
            regulator-always-on;
            regulator-boot-on;
            gpio = <&gpio0 RK_PD5 GPIO_ACTIVE_HIGH>;
            enable-active-high;
            vin-supply = <&vcc3v3_sys>;
        };

        pcie30_avdd0v9: pcie30-avdd0v9 {
            compatible = "regulator-fixed";
            regulator-name = "pcie30_avdd0v9";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <900000>;
            regulator-max-microvolt = <900000>;
            vin-supply = <&vcc3v3_sys>;
        };

        pcie30_avdd1v8: pcie30-avdd1v8 {
            compatible = "regulator-fixed";
            regulator-name = "pcie30_avdd1v8";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <1800000>;
            regulator-max-microvolt = <1800000>;
            vin-supply = <&vcc3v3_sys>;
        };

        pcie30_3v3: gpio-regulator {
            compatible = "regulator-gpio";
            regulator-name = "pcie30_3v3";
            regulator-min-microvolt = <100000>;
            regulator-max-microvolt = <3300000>;
            gpios = <&gpio0 RK_PD4 GPIO_ACTIVE_HIGH>;
            gpios-states = <0x1>;
            states = <100000 0x0
                  3300000 0x1>;
        };

        vcc3v3_bu: vcc3v3-bu {
            compatible = "regulator-fixed";
            regulator-name = "vcc3v3_bu";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <3300000>;
            regulator-max-microvolt = <3300000>;
            vin-supply = <&vcc5v0_sys>;
        };

        sdio_pwrseq: sdio-pwrseq {
            compatible = "mmc-pwrseq-simple";
            clocks = <&rk809 1>;
            clock-names = "ext_clock";
            pinctrl-names = "default";
            pinctrl-0 = <&wifi_enable_h>;
            /*
                * On the module itself this is one of these (depending
                * on the actual card populated):
                * - SDIO_RESET_L_WL_REG_ON
                * - PDN (power down when low)
            */
            post-power-on-delay-ms = <200>;
            reset-gpios = <&gpio3 RK_PD5 GPIO_ACTIVE_LOW>;
        };

        wireless_wlan: wireless-wlan {
            compatible = "wlan-platdata";
            rockchip,grf = <&grf>;
            wifi_chip_type = "ap6398s";
            pinctrl-names = "default";
            pinctrl-0 = <&wifi_host_wake_irq>;
            WIFI,host_wake_irq = <&gpio3 RK_PD4 GPIO_ACTIVE_HIGH>;
            status = "disabled";
        };

        wireless_bluetooth: wireless-bluetooth {
            compatible = "bluetooth-platdata";
            clocks = <&rk809 1>;
            clock-names = "ext_clock";
            //wifi-bt-power-toggle;
            uart_rts_gpios = <&gpio2 RK_PB1 GPIO_ACTIVE_LOW>;
            pinctrl-names = "default", "rts_gpio";
            pinctrl-0 = <&uart8m0_rtsn>;
            pinctrl-1 = <&uart8_gpios>;
            BT,reset_gpio    = <&gpio3 RK_PA0 GPIO_ACTIVE_HIGH>;
            BT,wake_gpio     = <&gpio3 RK_PA1 GPIO_ACTIVE_HIGH>;
            BT,wake_host_irq = <&gpio3 RK_PA2 GPIO_ACTIVE_HIGH>;
            status = "disabled";
        };

        flash_led: flash-led {
            compatible = "led,rgb13h";
            label = "pwm-flash-led";
            led-max-microamp = <20000>;
            flash-max-microamp = <20000>;
            flash-max-timeout-us = <1000000>;
            pwms = <&pwm11 0 25000 0>;
            rockchip,camera-module-index = <1>;
            rockchip,camera-module-facing = "front";
            status = "disabled";
        };

        /*vcc_camera: vcc-camera-regulator {
            compatible = "regulator-fixed";
            //gpio = <&pca9555 PCA_IO0_0 GPIO_ACTIVE_HIGH>;
            gpio = <&pca9555 PCA_IO0_3 GPIO_ACTIVE_HIGH>;
            pinctrl-names = "default";
            pinctrl-0 = <&vcc_cam>;
            regulator-name = "vcc_camera";
            enable-active-high;
            status = "disabled";
        };*/
    };

    &combphy0_us {
        status = "okay";
    };

    &combphy1_usq {
        status = "okay";
    };

    &combphy2_psq {
        status = "okay";
    };

    &csi2_dphy_hw {
        status = "okay";
    };

    &csi2_dphy0 {
        status = "okay";

        ports {
            #address-cells = <1>;
            #size-cells = <0>;
            port@0 {
                reg = <0>;
                #address-cells = <1>;
                #size-cells = <0>;

                mipi_in_ucam0: endpoint@1 {
                    reg = <1>;
                    remote-endpoint = <&ucam_out0>;
                    data-lanes = <1 2 3 4>;
                };
                mipi_in_ucam1: endpoint@2 {
                    reg = <2>;
                    remote-endpoint = <&gc8034_out>;
                    data-lanes = <1 2 3 4>;
                };
                mipi_in_ucam2: endpoint@3 {
                    reg = <3>;
                    remote-endpoint = <&ov5695_out>;
                    data-lanes = <1 2>;
                };
            };
            port@1 {
                reg = <1>;
                #address-cells = <1>;
                #size-cells = <0>;

                csidphy_out: endpoint@0 {
                    reg = <0>;
                    remote-endpoint = <&isp0_in>;
                };
            };
        };
    };

    &gmac1 {
        phy-mode = "rgmii";
        clock_in_out = "output";

        snps,reset-gpio = <&gpio3 RK_PB0 GPIO_ACTIVE_LOW>;
        snps,reset-active-low;
        /* Reset time is 20ms, 100ms for rtl8211f */
        snps,reset-delays-us = <0 20000 100000>;

        assigned-clocks = <&cru SCLK_GMAC1_RX_TX>, <&cru SCLK_GMAC1>;
        assigned-clock-parents = <&cru SCLK_GMAC1_RGMII_SPEED>;
        assigned-clock-rates = <0>, <125000000>;

        pinctrl-names = "default";
        pinctrl-0 = <&gmac1m1_miim
                 &gmac1m1_tx_bus2
                 &gmac1m1_rx_bus2
                 &gmac1m1_rgmii_clk
                 &gmac1m1_rgmii_bus>;

        tx_delay = <0x42>;
        rx_delay = <0x28>;

        phy-handle = <&rgmii_phy1>;
        status = "okay";
    };

    &mdio1 {
        rgmii_phy1: phy@0 {
            compatible = "ethernet-phy-ieee802.3-c22";
            reg = <0x0>;
        };
    };

    /*
     * power-supply should switche to vcc3v3_lcd1_n
     * when mipi panel is connected to dsi1.
     */

    &i2c4 {
        status = "okay";
        gc8034: gc8034@37 {
            compatible = "galaxycore,gc8034";
            status = "disabled";
            reg = <0x37>;
            clocks = <&cru CLK_CIF_OUT>;
            clock-names = "xvclk";
            pinctrl-names = "default";
            pinctrl-0 = <&cif_clk>;
            reset-gpios = <&gpio3 RK_PB6 GPIO_ACTIVE_LOW>;
            pwdn-gpios = <&gpio4 RK_PB4 GPIO_ACTIVE_LOW>;
            rockchip,grf = <&grf>;
            rockchip,camera-module-index = <0>;
            rockchip,camera-module-facing = "back";
            rockchip,camera-module-name = "RK-CMK-8M-2-v1";
            rockchip,camera-module-lens-name = "CK8401";
            port {
                gc8034_out: endpoint {
                    remote-endpoint = <&mipi_in_ucam1>;
                    data-lanes = <1 2 3 4>;
                };
            };
        };
        os04a10: os04a10@36 {
            status = "disabled";
            compatible = "ovti,os04a10";
            reg = <0x36>;
            clocks = <&cru CLK_CIF_OUT>;
            clock-names = "xvclk";
            power-domains = <&power RK3568_PD_VI>;
            pinctrl-names = "default";
            pinctrl-0 = <&cif_clk>;
            reset-gpios = <&gpio3 RK_PB6 GPIO_ACTIVE_LOW>;
            pwdn-gpios = <&gpio4 RK_PB4 GPIO_ACTIVE_HIGH>;
            rockchip,camera-module-index = <0>;
            rockchip,camera-module-facing = "back";
            rockchip,camera-module-name = "CMK-OT1607-FV1";
            rockchip,camera-module-lens-name = "M12-40IRC-4MP-F16";
            port {
                ucam_out0: endpoint {
                    remote-endpoint = <&mipi_in_ucam0>;
                    data-lanes = <1 2 3 4>;
                };
            };
        };
        ov5695: ov5695@36 {
            status = "disabled";
            compatible = "ovti,ov5695";
            reg = <0x36>;
            clocks = <&cru CLK_CIF_OUT>;
            clock-names = "xvclk";
            power-domains = <&power RK3568_PD_VI>;
            pinctrl-names = "default";
            pinctrl-0 = <&cif_clk>;
            reset-gpios = <&gpio3 RK_PB6 GPIO_ACTIVE_HIGH>;
            pwdn-gpios = <&gpio4 RK_PB4 GPIO_ACTIVE_HIGH>;
            rockchip,camera-module-index = <0>;
            rockchip,camera-module-facing = "back";
            rockchip,camera-module-name = "TongJu";
            rockchip,camera-module-lens-name = "CHT842-MD";
            port {
                ov5695_out: endpoint {
                    remote-endpoint = <&mipi_in_ucam2>;
                    data-lanes = <1 2>;
                };
            };
        };
    };

    &i2c1 {
        status = "disabled";
        clock-frequency = <100000>;

        pca9555: gpio@21 {
            status = "disabled";
            compatible = "nxp,pca9555";
            reg = <0x21>;
            gpio-controller;
            #gpio-cells = <2>;
            gpio-group-num = <200>;
        };

        gt1x: gt1x@14 {
            status = "disabled";
            compatible = "goodix,gt1x";
            reg = <0x14>;
            pinctrl-names = "default";
            pinctrl-0 = <&touch_gpio>;
            goodix,rst-gpio = <&gpio0 RK_PB6 GPIO_ACTIVE_HIGH>;
            goodix,irq-gpio = <&gpio0 RK_PB5 IRQ_TYPE_LEVEL_LOW>;
        };
    };

    &i2c5 {
        status = "okay";

        hym8563: hym8563@51 {
            status = "okay";
            compatible = "haoyu,hym8563";
            reg = <0x51>;
            #clock-cells = <0>;
            rtc-irq-gpio = <&gpio0 RK_PD3 IRQ_TYPE_EDGE_FALLING>;
            clock-frequency = <32768>;
            //clock-output-names = "xin32k";
            /* rtc_int is not connected */
        };

        mc3230: mc3230sensor@4c {
            compatible = "gs_mc3230";
            reg = <0x4c>;
            type = ;
            irq_enable = <0>;
            poll_delay_ms = <30>;
            layout = <4>;
            status = "disabled";
        };

        mxc6655xa: mxc6655xa@15 {
            status = "disabled";
            compatible = "gs_mxc6655xa";
            pinctrl-names = "default";
            pinctrl-0 = <&mxc6655xa_irq_gpio>;
            reg = <0x15>;
            irq-gpio = <&gpio3 RK_PC1 IRQ_TYPE_LEVEL_LOW>;
            irq_enable = <0>;
            poll_delay_ms = <30>;
            type = ;
            power-off-in-suspend = <1>;
            layout = <1>;
        };
    };

    &pcie30phy {
        status = "disabled";
    };

    &pcie3x2 {
        reset-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_HIGH>;
        vpcie3v3-supply = <&pcie30_3v3>;
        status = "disabled";
    };
    /*
    &rk809_sound {
        /delete-property/ simple-audio-card,hp-det-gpio;
    };*/

    &rk809_codec {
        pinctrl-0 = <&i2s1m0_mclk>;
    };

    &rkisp {
        status = "okay";
    };

    &rkisp_mmu {
        status = "okay";
    };

    &rkisp_vir0 {
        status = "okay";

        port {
            #address-cells = <1>;
            #size-cells = <0>;

            isp0_in: endpoint@0 {
                reg = <0>;
                remote-endpoint = <&csidphy_out>;
            };
        };
    };

    &sata2 {
        status = "disabled";
    };

    &sdmmc0 {
        max-frequency = <150000000>;
        supports-sd;
        bus-width = <4>;
        cap-mmc-highspeed;
        cap-sd-highspeed;
        disable-wp;
        sd-uhs-sdr104;
        vmmc-supply = <&vcc3v3_sd>;
        vqmmc-supply = <&vccio_sd>;
        pinctrl-names = "default";
        pinctrl-0 = <&sdmmc0_bus4 &sdmmc0_clk &sdmmc0_cmd &sdmmc0_det>;
        status = "disabled";
    };

    &sdmmc2 {
        max-frequency = <150000000>;
        no-sd;
        no-mmc;
        bus-width = <4>;
        disable-wp;
        cap-sd-highspeed;
        cap-sdio-irq;
        keep-power-in-suspend;
        pinctrl-names = "default";
        pinctrl-0 = <&sdmmc2m0_bus4 &sdmmc2m0_cmd &sdmmc2m0_clk>;
        sd-uhs-sdr104;
        mmc-pwrseq = <&sdio_pwrseq>;
        non-removable;
        status = "disabled";
    };

    &spdif_8ch {
        status = "disabled";
        pinctrl-names = "default";
        pinctrl-0 = <&spdifm1_tx>;
    };

    &uart3 {
        status = "disabled";
        pinctrl-names = "default";
        pinctrl-0 = <&uart3m1_xfer>;
    };

    &uart4 {
        status = "disabled";
        pinctrl-names = "default";
        pinctrl-0 = <&uart4m1_xfer>;
    };

    &uart8 {
        status = "okay";
        pinctrl-names = "default";
        pinctrl-0 = <&uart8m0_xfer &uart8m0_ctsn>;
    };

    &can1 {
        status = "disabled";
        compatible = "rockchip,rk3568-can-2.0";
        assigned-clocks = <&cru CLK_CAN1>;
        assigned-clock-rates = <200000000>;
        pinctrl-names = "default";
        pinctrl-0 = <&can1m1_pins>;
    };

    &can2 {
        status = "disabled";
        compatible = "rockchip,rk3568-can-2.0";
        assigned-clocks = <&cru CLK_CAN2>;
        assigned-clock-rates = <200000000>;
        pinctrl-names = "default";
        pinctrl-0 = <&can2m0_pins>;
    };

    &spi1 {
        status = "disabled";
        max-freq = <48000000>;
        dev-port = <0>;
        pinctrl-0 = <&spi1m1_pins>;
        pinctrl-1 = <&spi1m1_pins_hs>;

        spi_wk2xxx: spi_wk2xxx@0{
            status = "disabled";
            compatible = "firefly,spi-wk2xxx";
            reg = <0x00>;
            spi-max-frequency = <10000000>;
            power-gpio = <&pca9555 PCA_IO1_7 GPIO_ACTIVE_HIGH>;
            reset-gpio = <&pca9555 PCA_IO1_1 GPIO_ACTIVE_HIGH>;
            irq-gpio = <&gpio0 RK_PA6 IRQ_TYPE_EDGE_FALLING>;
            cs-gpio = <&gpio3 RK_PA1 GPIO_ACTIVE_HIGH>;
            /* rk3399 driver support SPI_CPOL | SPI_CPHA | SPI_CS_HIGH */
            //spi-cpha;     /* SPI mode: CPHA=1 */
            //spi-cpol;     /* SPI mode: CPOL=1 */
            //spi-cs-high;
        };
    };

    &pwm7 {
        status = "disabled";

        compatible = "rockchip,remotectl-pwm";
        interrupts = ;
        remote_pwm_id = <3>;
        handle_cpu_id = <1>;
        remote_support_psci = <0>;
        pinctrl-names = "default";
        pinctrl-0 = <&pwm7_pins>;

        ir_key_firefly{
            rockchip,usercode = <0xff00>;
            rockchip,key_table =
                <0xeb   KEY_POWER>,
                <0xec   KEY_MENU>,
                <0xfe   KEY_BACK>,
                <0xb7   KEY_HOME>,
                <0xa3   KEY_WWW>,
                <0xf4   KEY_VOLUMEUP>,
                <0xa7   KEY_VOLUMEDOWN>,
                <0xf8   KEY_REPLY>,
                <0xfc   KEY_UP>,
                <0xfd   KEY_DOWN>,
                <0xf1   KEY_LEFT>,
                <0xe5   KEY_RIGHT>;
        };
    };

    &pinctrl {
        cam {
            vcc_cam: vcc-cam {
                rockchip,pins =
                    /* camera power en */
                    <0 RK_PC1 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        sdio-pwrseq {
            wifi_enable_h: wifi-enable-h {
                rockchip,pins = <3 RK_PD4 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        wireless-wlan {
            wifi_host_wake_irq: wifi-host-wake-irq {
                rockchip,pins = <3 RK_PD5 RK_FUNC_GPIO &pcfg_pull_down>;
            };
        };

        wireless-bluetooth {
            uart8_gpios: uart8-gpios {
                rockchip,pins = <2 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        touch {
            touch_gpio: touch-gpio {
                rockchip,pins =
                    <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_up>,
                    <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        mxc6655xa {
            mxc6655xa_irq_gpio: mxc6655xa_irq_gpio {
                rockchip,pins = <3 RK_PC1 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };
    };

    &sfc{
        pinctrl-names = "default";
        pinctrl-0 = <&fspi_pins>;
        assigned-clock-rates = <50000000>;
        status = "okay";
        flash@0 {
            compatible = "jedec,spi-nor";
            reg = <0>;
            spi-max-frequency = <50000000>;
            spi-rx-bus-width = <1>;
            spi-tx-bus-width = <1>;
        };
    };

1.5 rk3568-rockpi-core.dtsi 添加

    // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
    /*
     * Copyright (c) 2020 Rockchip Electronics Co., Ltd.
     *
     */

     /dts-v1/;

    #include 
    #include 
    #include 
    #include 
    #include 
    #include 
    #include "rk3568.dtsi"

    / {
        compatible = "rockchip,rk3568-rockpi-core", "rockchip,rk3568";

        audiopwmout_diff: audiopwmout-diff {
            status = "disabled";
            compatible = "simple-audio-card";
            simple-audio-card,format = "i2s";
            simple-audio-card,name = "rockchip,audiopwmout-diff";
            simple-audio-card,mclk-fs = <256>;
            simple-audio-card,bitclock-master = <&master>;
            simple-audio-card,frame-master = <&master>;
            simple-audio-card,cpu {
                sound-dai = <&i2s3_2ch>;
            };
            master: simple-audio-card,codec {
                sound-dai = <&dig_acodec>;
            };
        };

        dc_12v: dc-12v {
            compatible = "regulator-fixed";
            regulator-name = "dc_12v";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <12000000>;
            regulator-max-microvolt = <12000000>;
        };

        hdmi_sound: hdmi-sound {
            compatible = "simple-audio-card";
            simple-audio-card,format = "i2s";
            simple-audio-card,mclk-fs = <128>;
            simple-audio-card,name = "rockchip,hdmi";
            status = "okay";

            simple-audio-card,cpu {
                    sound-dai = <&i2s0_8ch>;
            };
            simple-audio-card,codec {
                    sound-dai = <&hdmi>;
            };
        };

        /*rk_headset: rk-headset {
            status = "disabled";
            compatible = "rockchip_headset";
            headset_gpio = <&gpio2 RK_PD2 GPIO_ACTIVE_LOW>;
            pinctrl-names = "default";
            pinctrl-0 = <&hp_det>;
        };*/

        rk_headset: rk-headset {
            compatible = "rockchip_headset";
            headset_gpio = <&gpio2 RK_PD2 GPIO_ACTIVE_HIGH>;
            pinctrl-names = "default";
            pinctrl-0 = <&hp_det>;
            io-channels = <&saradc 2>;    //HP_HOOK pin
        };

        pdmics: dummy-codec {
            status = "disabled";
            compatible = "rockchip,dummy-codec";
            #sound-dai-cells = <0>;
        };

        pdm_mic_array: pdm-mic-array {
            status = "disabled";
            compatible = "simple-audio-card";
            simple-audio-card,name = "rockchip,pdm-mic-array";
            simple-audio-card,cpu {
                sound-dai = <&pdm>;
            };
            simple-audio-card,codec {
                sound-dai = <&pdmics>;
            };
        };

        reserved-memory {
            #address-cells = <2>;
            #size-cells = <2>;
            ranges;

            rknpu_reserved: rknpu {
                compatible = "shared-dma-pool";
                inactive;
                reusable;
                size = <0x0 0x20000000>;
                alignment = <0x0 0x1000>;
            };
        };

        // rk809_sound: rk809-sound {
        //  status = "disabled";
        //  compatible = "simple-audio-card";
        //  simple-audio-card,format = "i2s";
        //  simple-audio-card,name = "rockchip,rk809-codec";
        //  simple-audio-card,mclk-fs = <256>;
        //  simple-audio-card,widgets =
        //                     "Microphone", "Mic Jack",
        //                     "Headphone", "Headphone Jack";
        //     simple-audio-card,routing =
        //                     "Mic Jack", "MICBIAS1",
        //                     "IN1P", "Mic Jack",
        //                     "Headphone Jack", "HPOL",
        //                     "Headphone Jack", "HPOR";
        //  simple-audio-card,cpu {
        //      sound-dai = <&i2s1_8ch>;
        //  };
        //  simple-audio-card,codec {
        //      sound-dai = <&rk809_codec>;
        //  };
        // };

        rk809_sound: rk809-sound {
            status = "okay";
            compatible = "rockchip,multicodecs-card";
            simple-audio-card,format = "i2s";
            simple-audio-card,name = "rockchip,rk809-codec";
            simple-audio-card,mclk-fs = <256>;

            simple-audio-card,cpu {
                sound-dai = <&i2s1_8ch>;
            };
            simple-audio-card,codec {
                sound-dai = <&rk809_codec>;
            };
        };

        /*spdif-sound {
            status = "okay";
            compatible = "simple-audio-card";
            simple-audio-card,name = "ROCKCHIP,SPDIF";
            simple-audio-card,cpu {
                    sound-dai = <&spdif_8ch>;
            };
            simple-audio-card,codec {
                    sound-dai = <&spdif_out>;
            };
        };

        spdif_out: spdif-out {
                status = "okay";
                compatible = "linux,spdif-dit";
                #sound-dai-cells = <0>;
        };*/

    /*
        vad_sound: vad-sound {
            status = "disabled";
            compatible = "rockchip,multicodecs-card";
            rockchip,card-name = "rockchip,rk3568-vad";
            rockchip,cpu = <&i2s1_8ch>;
            rockchip,codec = <&rk809_codec>, <&vad>;
        };*/

        vcc3v3_sys: vcc3v3-sys {
            compatible = "regulator-fixed";
            regulator-name = "vcc3v3_sys";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <3300000>;
            regulator-max-microvolt = <3300000>;
            vin-supply = <&dc_12v>;
        };

        vcc5v0_sys: vcc5v0-sys {
            compatible = "regulator-fixed";
            regulator-name = "vcc5v0_sys";
            regulator-always-on;
            regulator-boot-on;
            regulator-min-microvolt = <5000000>;
            regulator-max-microvolt = <5000000>;
            vin-supply = <&dc_12v>;
        };

        vcc5v0_host: vcc5v0-host-regulator {
            compatible = "regulator-fixed";
            enable-active-high;
            gpio = <&gpio0 RK_PA6 GPIO_ACTIVE_HIGH>;
            pinctrl-names = "default";
            pinctrl-0 = <&vcc5v0_host_en>;
            regulator-name = "vcc5v0_host";
            regulator-always-on;
            regulator-boot-on;
        };

        vcc5v0_otg: vcc5v0-otg-regulator {
            compatible = "regulator-fixed";
            enable-active-high;
            gpio = <&gpio0 RK_PA5 GPIO_ACTIVE_HIGH>;
            pinctrl-names = "default";
            pinctrl-0 = <&vcc5v0_otg_en>;
            regulator-name = "vcc5v0_otg";
        };

        vcc5v0_usbhub: vcc5v0-usbhub-regulator {
            compatible = "regulator-fixed";
            enable-active-high;
            gpio = <&gpio0 RK_PD5 GPIO_ACTIVE_HIGH>;
            pinctrl-names = "default";
            pinctrl-0 = <&vcc5v0_hub_en>;
            regulator-name = "vcc5v0_hub";
            regulator-always-on;
        };

        vcc3v3_lcd0_n: vcc3v3-lcd0-n {
            compatible = "regulator-fixed";
            regulator-name = "vcc3v3_lcd0_n";
            regulator-boot-on;
            regulator-state-mem {
                regulator-off-in-suspend;
            };
        };

        vcc3v3_lcd1_n: vcc3v3-lcd1-n {
            compatible = "regulator-fixed";
            regulator-name = "vcc3v3_lcd1_n";
            regulator-boot-on;
            regulator-state-mem {
                regulator-off-in-suspend;
            };
        };

        test-power {
            status = "okay";
        };
    };

    &cpu0 {
        cpu-supply = <&vdd_cpu>;
    };

    &dfi {
        status = "okay";
    };

    &dmc {
        center-supply = <&vdd_logic>;
        status = "okay";
    };

    &video_phy0 {
        status = "okay";
    };

    &display_subsystem {
        status = "okay";
    };

    &gpu {
        mali-supply = <&vdd_gpu>;
        status = "okay";
    };

    &hdmi {
        status = "okay";
    };

    &hdmi_in_vp0 {
        status = "okay";
    };

    &hdmi_in_vp1 {
        status = "disabled";
    };

    &hdmi_sound {
        status = "okay";
    };

    &i2c0 {
        status = "okay";

        vdd_cpu: tcs4525@1c {
            compatible = "tcs,tcs452x";
            reg = <0x1c>;
            vin-supply = <&vcc5v0_sys>;
            regulator-compatible = "fan53555-reg";
            regulator-name = "vdd_cpu";
            regulator-min-microvolt = <712500>;
            regulator-max-microvolt = <1390000>;
            regulator-ramp-delay = <2300>;
            fcs,suspend-voltage-selector = <1>;
            regulator-boot-on;
            regulator-always-on;
            regulator-state-mem {
                regulator-off-in-suspend;
            };
        };

        rk809: pmic@20 {
            compatible = "rockchip,rk809";
            reg = <0x20>;
            interrupt-parent = <&gpio0>;
            interrupts = <3 IRQ_TYPE_LEVEL_LOW>;

            pinctrl-names = "default", "pmic-sleep",
                    "pmic-power-off", "pmic-reset";
            pinctrl-0 = <&pmic_int>;
            pinctrl-1 = <&soc_slppin_slp>, <&rk817_slppin_slp>;
            pinctrl-2 = <&soc_slppin_gpio>, <&rk817_slppin_pwrdn>;
            pinctrl-3 = <&soc_slppin_gpio>, <&rk817_slppin_rst>;

            rockchip,system-power-controller;
            wakeup-source;
            #clock-cells = <1>;
            clock-output-names = "rk808-clkout1", "rk808-clkout2";
            //fb-inner-reg-idxs = <2>;
            /* 1: rst regs (default in codes), 0: rst the pmic */
            pmic-reset-func = <0>;
            /* not save the PMIC_POWER_EN register in uboot */
            not-save-power-en = <1>;

            vcc1-supply = <&vcc3v3_sys>;
            vcc2-supply = <&vcc3v3_sys>;
            vcc3-supply = <&vcc3v3_sys>;
            vcc4-supply = <&vcc3v3_sys>;
            vcc5-supply = <&vcc3v3_sys>;
            vcc6-supply = <&vcc3v3_sys>;
            vcc7-supply = <&vcc3v3_sys>;
            vcc8-supply = <&vcc3v3_sys>;
            vcc9-supply = <&vcc3v3_sys>;

            pwrkey {
                status = "okay";
            };

            pinctrl_rk8xx: pinctrl_rk8xx {
                gpio-controller;
                #gpio-cells = <2>;

                rk817_slppin_null: rk817_slppin_null {
                    pins = "gpio_slp";
                    function = "pin_fun0";
                };

                rk817_slppin_slp: rk817_slppin_slp {
                    pins = "gpio_slp";
                    function = "pin_fun1";
                };

                rk817_slppin_pwrdn: rk817_slppin_pwrdn {
                    pins = "gpio_slp";
                    function = "pin_fun2";
                };

                rk817_slppin_rst: rk817_slppin_rst {
                    pins = "gpio_slp";
                    function = "pin_fun3";
                };
            };

            regulators {
                vdd_logic: DCDC_REG1 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <500000>;
                    regulator-max-microvolt = <1350000>;
                    regulator-init-microvolt = <900000>;
                    regulator-ramp-delay = <6001>;
                    regulator-initial-mode = <0x2>;
                    regulator-name = "vdd_logic";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vdd_gpu: DCDC_REG2 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <500000>;
                    regulator-max-microvolt = <1350000>;
                    regulator-init-microvolt = <900000>;
                    regulator-ramp-delay = <6001>;
                    regulator-initial-mode = <0x2>;
                    regulator-name = "vdd_gpu";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcc_ddr: DCDC_REG3 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-initial-mode = <0x2>;
                    regulator-name = "vcc_ddr";
                    regulator-state-mem {
                        regulator-on-in-suspend;
                    };
                };

                vdd_npu: DCDC_REG4 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <500000>;
                    regulator-max-microvolt = <1350000>;
                    regulator-init-microvolt = <900000>;
                    regulator-ramp-delay = <6001>;
                    regulator-initial-mode = <0x2>;
                    regulator-name = "vdd_npu";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vdda0v9_image: LDO_REG1 {
                    regulator-boot-on;
                    regulator-always-on;
                    regulator-min-microvolt = <900000>;
                    regulator-max-microvolt = <900000>;
                    regulator-name = "vdda0v9_image";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vdda_0v9: LDO_REG2 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <900000>;
                    regulator-max-microvolt = <900000>;
                    regulator-name = "vdda_0v9";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vdda0v9_pmu: LDO_REG3 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <900000>;
                    regulator-max-microvolt = <900000>;
                    regulator-name = "vdda0v9_pmu";
                    regulator-state-mem {
                        regulator-on-in-suspend;
                        regulator-suspend-microvolt = <900000>;
                    };
                };

                vccio_acodec: LDO_REG4 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <3300000>;
                    regulator-max-microvolt = <3300000>;
                    regulator-name = "vccio_acodec";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vccio_sd: LDO_REG5 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <1800000>;
                    regulator-max-microvolt = <3300000>;
                    regulator-name = "vccio_sd";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcc3v3_pmu: LDO_REG6 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <3300000>;
                    regulator-max-microvolt = <3300000>;
                    regulator-name = "vcc3v3_pmu";
                    regulator-state-mem {
                        regulator-on-in-suspend;
                        regulator-suspend-microvolt = <3300000>;
                    };
                };

                vcca_1v8: LDO_REG7 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <1800000>;
                    regulator-max-microvolt = <1800000>;
                    regulator-name = "vcca_1v8";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcca1v8_pmu: LDO_REG8 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <1800000>;
                    regulator-max-microvolt = <1800000>;
                    regulator-name = "vcca1v8_pmu";
                    regulator-state-mem {
                        regulator-on-in-suspend;
                        regulator-suspend-microvolt = <1800000>;
                    };
                };

                vcca1v8_image: LDO_REG9 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <1800000>;
                    regulator-max-microvolt = <1800000>;
                    regulator-name = "vcca1v8_image";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcc_1v8: DCDC_REG5 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-min-microvolt = <1800000>;
                    regulator-max-microvolt = <1800000>;
                    regulator-name = "vcc_1v8";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcc_3v3: SWITCH_REG1 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-name = "vcc_3v3";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };

                vcc3v3_sd: SWITCH_REG2 {
                    regulator-always-on;
                    regulator-boot-on;
                    regulator-name = "vcc3v3_sd";
                    regulator-state-mem {
                        regulator-off-in-suspend;
                    };
                };
            };

            rk809_codec: codec {
                #sound-dai-cells = <0>;
                compatible = "rockchip,rk809-codec", "rockchip,rk817-codec";
                clocks = <&cru I2S1_MCLKOUT>;
                clock-names = "mclk";
                assigned-clocks = <&cru I2S1_MCLKOUT>, <&cru I2S1_MCLK_TX_IOE>;
                assigned-clock-rates = <12288000>;
                assigned-clock-parents = <&cru I2S1_MCLKOUT_TX>, <&cru I2S1_MCLKOUT_TX>;
                pinctrl-names = "default","spk_gpio";
                pinctrl-0 = <&i2s1m0_mclk>;
                pinctrl-1 = <&spk_ctl_gpio>;
                hp-volume = <20>;
                spk-volume = <3>;
                mic-in-differential;

                capture-volume = <0>;
                io-channels = <&saradc 4>;
                hp-det-adc-value = <1000>;
                spk-ctl-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
                status = "okay";
            };
        };
    };

    &i2s0_8ch {
        status = "okay";
    };

    &i2s1_8ch {
        status = "okay";
        rockchip,clk-trcm = <1>;
        pinctrl-names = "default";
        pinctrl-0 = <&i2s1m0_sclktx
                 &i2s1m0_lrcktx
                 &i2s1m0_sdi0
                 &i2s1m0_sdo0>;
    };

    &iep {
        status = "okay";
    };

    &iep_mmu {
        status = "okay";
    };

    &jpegd {
        status = "okay";
    };

    &jpegd_mmu {
        status = "okay";
    };

    &mpp_srv {
        status = "okay";
    };

    &pmu_io_domains {
        status = "okay";
        pmuio1-supply = <&vcc3v3_pmu>;
        pmuio2-supply = <&vcc3v3_pmu>;
        vccio1-supply = <&vccio_acodec>;
        vccio3-supply = <&vccio_sd>;
        vccio4-supply = <&vcc_1v8>;
        vccio5-supply = <&vcc_3v3>;
        vccio6-supply = <&vcc_1v8>;
        vccio7-supply = <&vcc_3v3>;
    };

    &rk_rga {
        status = "okay";
    };

    &rkvdec {
        status = "okay";
    };

    &rkvdec_mmu {
        status = "okay";
    };

    &rkvenc {
        venc-supply = <&vdd_logic>;
        status = "okay";
    };

    &rkvenc_mmu {
        status = "okay";
    };

    &rknpu {

        memory-region = <&rknpu_reserved>;
        rknpu-supply = <&vdd_npu>;
        status = "okay";
    };

    &rknpu_mmu {
        status = "okay";
    };

    &bus_npu {
        bus-supply = <&vdd_logic>;
        pvtm-supply = <&vdd_cpu>;
        status = "okay";
    };

    &saradc {
        status = "okay";
        vref-supply = <&vcca_1v8>;
    };

    &sdhci {
        bus-width = <8>;
        no-sdio;
        no-sd;
        non-removable;
        max-frequency = <200000000>;
        full-pwr-cycle-in-suspend;
        status = "okay";
    };

    &sdmmc0 {
        max-frequency = <150000000>;
        no-sdio;
        no-mmc;
        bus-width = <4>;
        cap-mmc-highspeed;
        cap-sd-highspeed;
        disable-wp;
        sd-uhs-sdr104;
        vmmc-supply = <&vcc3v3_sd>;
        vqmmc-supply = <&vccio_sd>;
        pinctrl-names = "default";
        pinctrl-0 = <&sdmmc0_bus4 &sdmmc0_clk &sdmmc0_cmd &sdmmc0_det>;
        status = "okay";
    };

    &spdif_8ch {
        status = "okay";
    };

    &sfc {
        status = "okay";
    };

    &tsadc {
        status = "okay";
    };

    &u2phy0_host {
        phy-supply = <&vcc5v0_host>;
        status = "okay";
    };

    &u2phy0_otg {
        vbus-supply = <&vcc5v0_otg>;
        status = "okay";
    };

    &u2phy1_host {
        phy-supply = <&vcc5v0_host>;
        status = "okay";
    };

    &u2phy1_otg {
        phy-supply = <&vcc5v0_host>;
        status = "okay";
    };

    &usb2phy0 {
        status = "okay";
    };

    &usb2phy1 {
        status = "okay";
    };

    &usb_host0_ehci {
        status = "okay";
    };

    &usb_host0_ohci {
        status = "okay";
    };

    &usb_host1_ehci {
        status = "okay";
    };

    &usb_host1_ohci {
        status = "okay";
    };

    &usbdrd_dwc3 {
        dr_mode = "otg";
        extcon = <&usb2phy0>;
        status = "okay";
    };

    &usbdrd30 {
        status = "okay";
    };

    &usbhost_dwc3 {
        status = "okay";
    };

    &usbhost30 {
        status = "okay";
    };

    &combphy0_us {
        status = "okay";
    };

    &combphy1_usq {
        status = "okay";
    };

    /*
    &vad {
        rockchip,audio-src = <&i2s1_8ch>;
        rockchip,buffer-time-ms = <128>;
        rockchip,det-channel = <0>;
        rockchip,mode = <0>;
    };*/

    &sata0 {
        status = "disabled";
    };

    &sata1 {
        status = "disabled";
    };

    &xpcs {
        status="disabled";
    };

    &vdpu {
        status = "okay";
    };

    &vdpu_mmu {
        status = "okay";
    };

    &vepu {
        status = "okay";
    };

    &vepu_mmu {
        status = "okay";
    };

    &vop {
        status = "okay";
        assigned-clocks = <&cru DCLK_VOP0>, <&cru DCLK_VOP1>;
        assigned-clock-parents = <&pmucru PLL_HPLL>, <&cru PLL_VPLL>;
    };

    &vop_mmu {
        status = "okay";
    };

    &pinctrl {

        pmic {
            pmic_int: pmic_int {
                rockchip,pins =
                    <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_up>;
            };

            soc_slppin_gpio: soc_slppin_gpio {
                rockchip,pins =
                    <0 RK_PA2 RK_FUNC_GPIO &pcfg_output_low_pull_down>;
            };

            soc_slppin_slp: soc_slppin_slp {
                rockchip,pins =
                    <0 RK_PA2 1 &pcfg_pull_none>;
            };

            soc_slppin_rst: soc_slppin_rst {
                rockchip,pins =
                    <0 RK_PA2 2 &pcfg_pull_none>;
            };

            spk_ctl_gpio: spk_ctl_gpio {
                rockchip,pins = <3 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>;
            };
        };

        usb {
            vcc5v0_host_en: vcc5v0-host-en {
                rockchip,pins = <0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
            };

            vcc5v0_otg_en: vcc5v0-otg-en {
                rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_none>;
            };

            vcc5v0_hub_en: vcc5v0-hub-en {
                rockchip,pins = <0 RK_PD5 RK_FUNC_GPIO &pcfg_pull_none>;
            };
        };

        headphone {
            hp_det: hp-det {
                rockchip,pins = <2 RK_PD2 RK_FUNC_GPIO &pcfg_pull_up>;
            };
        };
    };

二、开发板介绍

  1. ROCK3 Model A的默认波特率为1500000(1.5Mbps),检查FT232 USB转UART串口模块是否支持 1.5Mbps 波特率,我们这里使用的是FT232 USB转UART串口模块。

  2. USB转TTL连接ROCK3 Model A,首先查看ROCK 3A引脚图,我们需要用到的引脚是6(GND)、8(TX)和10(RX)。
    file
    file

  3. 点击OK以后,按下回车,输入登录名和登录密码就可以登陆了
    file

三、烧录介绍

  1. 下载安装瑞芯微刷机工具RKDevTool_Release-刷机工具和RK驱动助手DriverAssitant-RK驱动助手。

  2. 打开RK驱动助手DriverAssitant安装 ROCK3 Model A USB 驱动程序,此过程无需连接ROCK3 Model A,安装完成后重启电脑。
    file

  3. 安装上EMMC,板子如果有TF卡,要先移除TF卡。

  4. 使用跳线帽和排针短接ROCK3 Model A引脚,如图,从左往右数,第三个引脚留出,然后用排针和跳线帽短接图中两个焊点:
    file

  5. 将type A双公口USB3.0线一端连接电脑USB端口,另一端连接ROCK3 Model A的OTG接口(Rock 3A上方的USB3.0接口)

  6. 先给ROCK3 Model A接通电源,然后保留左边“1”处排针上的跳线帽,拔掉右边“2”处两个焊点的排针和跳线帽。

  7. RKDevTool工具烧录
    打开瑞芯微刷机工具RKDevTool,此时会看到设备处于“maskrom 模式
    file
    双击第二行“Parameter”,将名字改为“image”
    file

    勾选第一行“Loader”和第二行“image”,在①处选择放置rk356x_spl_loader_ddr1056-固件位置,在②处选择放置镜像Radxa的路径。
    file
    点击执行,就可以看到右边写入内容了, 显示下载完成就写入成功了,同时也会显示没有发现设备,拔掉“1”处跳线帽,拔掉电源,重新开机,ROCK3 Model A开机成功后,会看到板载的绿灯常亮,蓝灯闪烁。
    file
    Debian/Ubuntu 默认用户帐户(非root用户)
    登录名:rock
    登录密码:rock

版权声明

版权声明

内容来源及使用限制

欢迎访问 TomgZHE研习社(网址:https://blog.tomgzhe.com)。本网站部分文章内容源自网络,仅作学习交流与参考分享;若您发现有内容涉嫌侵权,请立即联系 tomgzhe@qq.com,我们将在接到通知后的 48 小时内核实并删除相关侵权内容。

软件资源相关规定

本网站为个人非盈利性质的站点,所有软件资源均来自网络。这些资源仅用于个人学习、研究和参考,严禁用于任何商业用途。您下载和使用本网站软件资源即表示您同意仅将其用于学习目的,若因违反此规定导致任何法律纠纷或损失,责任由您自行承担。

原创版权

本网站上的原创内容,包括但不限于文字作品、自行设计的图片、独家制作的音频视频等,其版权均归本网站所有。未经本网站书面授权,任何组织或个人不得擅自复制、转载、摘编、传播或以其他任何方式使用这些原创内容。如需使用,请提前与我们联系并获得书面许可,同时需在显著位置注明出处及作者信息。

转载与引用规范

若您需转载本网站文章,务必注明文章来源为 “[],原文链接:[]”;对于有明确作者署名的文章,还需完整保留作者姓名。在引用本网站内容时,请确保内容准确无误,并遵循学术及行业的引用规范。

Like (1)
Donate 微信扫一扫打赏 微信扫一扫打赏 支付宝扫一扫打赏 支付宝扫一扫打赏
tomgzhe的头像tomgzhe
Previous 2024年5月14日 22:57
Next 2024年7月18日 11:45

相关推荐

发表回复

Please Login to Comment
联系我们

联系我们

400-800-6666

在线咨询: QQ交谈 邮件:tomgzhe@qq.com 工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
关注微信
SHARE
TOP
蛇年新气象!从2025年2月起,本博客将在保留科技板块基础上,新增生活美学、个人成长等多元内容,希望能为大家带来更丰富的阅读体验,敬请期待!