[PATCH v3 09/12] arm: dts: rockchip: sync rk3288.dtsi from Linux

Johan Jonker jbx6244 at gmail.com
Fri Apr 15 12:19:44 CEST 2022



On 4/15/22 02:40, Kever Yang wrote:
> Hi Johan,
> 
>     I got build fail for phycore-rk3288 after this patch:
> 
> +Error: SPL image is too large (size 0x8800 than 0x8000)
> +Error: Bad parameters for image type

Hi,

Could you disclose your bash commands for reproducing?
I've downloaded from your git on April 15th 2022.
Added missing patches and compiled.
No warning seen here.

u-boot-spl.bin size 31.9 KiB (32675 bytes) ==> 0x7FA3 so below 0x8000 ==
32768 bytes.

===

For rk3288 SPL images with OF_PLATDATA the ns16550.c and
serial_rockchip.c driver are now included due to DM_DRIVER_ALIAS fix for
SPL_OF_PLATDATA, but this config is compiled with CONFIG_SPL_OF_REAL=y.

===

Your patch for:
 rockchip: fix boot_devices constants
contains a warning:
check for migrated symbols...

What does it check and is that something I can fix?

===

For patches 9,10 and 11 I'm planning a v4 with:

ec-interrupt in u-boot-xxxx.dtsi

===

The driver rk_edp.c needs too fixing to comply with current Linux DP node.

I need board maintainers with hardware for that to fix and check.

compatible ="cnm,n116bgeea2","simple-panel";
vs.
compatible = "innolux,n116bge";
==> compatible = "simple-panel";

compatible = "rockchip,rk3288-edp";
vs.
compatible = "rockchip,rk3288-dp";

	ret = uclass_get_device_by_phandle(UCLASS_PANEL, dev, "rockchip,panel",
					   &priv->panel);


                clock-names = "clk_edp", "clk_edp_24m", "pclk_edp"; //
U-boot
		ret = clk_get_by_index(dev, 1, &clk);

vs.
                clock-names = "dp", "pclk"; // Linux



	ret = reset_get_by_name(dev, "dp", &dp_rst);
vs.
                reset-names = "edp"; //rk3288
                reset-names = "dp";  //rk3399

===
Let me know what you prefere.
Please offload the (dt-header) patches that are ready, so that I don't
have to resend them all the time.

===

Kind regards,


Johan

===

git clone --depth 40
https://source.denx.de/u-boot/custodians/u-boot-rockchip.git

git am v3-0009-arm-dts-rockchip-sync-rk3288.dtsi-from-Linux.patch
git am v3-0010-arm-dts-rockchip-sync-rk3288-DT-boards-from-Linux.patch
git am v3-0011-arm-dts-rockchip-sync-rk3288-veyron-DT-from-Linux.patch

make CROSS_COMPILE=arm-linux-gnueabihf- phycore-rk3288_defconfig all

mkimage ???


> 
> Thanks,
> 
> - Kever
> 
> On 2022/3/4 07:52, Johan Jonker wrote:
>> Sync rk3288.dtsi from Linux version 5.17.
>>
>> Signed-off-by: Johan Jonker <jbx6244 at gmail.com>
>> ---
>>
>> Changed V3:
>>    change reg size
>>
>> Changed V2:
>>    rename mipi_dsi0 label
>>    move io_domains
>>    remove hdmi_audio veyron node
>>    change memory at 0 reg size
>> ---
>>   arch/arm/dts/rk3288-evb.dtsi         |    2 +-
>>   arch/arm/dts/rk3288-miqi.dtsi        |   28 +-
>>   arch/arm/dts/rk3288-phycore-som.dtsi |   30 +-
>>   arch/arm/dts/rk3288-popmetal.dtsi    |   30 +-
>>   arch/arm/dts/rk3288-thermal.dtsi     |   87 --
>>   arch/arm/dts/rk3288-veyron-jerry.dts |    6 -
>>   arch/arm/dts/rk3288-veyron.dtsi      |   33 +-
>>   arch/arm/dts/rk3288.dtsi             | 1367 +++++++++++++++++---------
>>   8 files changed, 970 insertions(+), 613 deletions(-)
>>   delete mode 100644 arch/arm/dts/rk3288-thermal.dtsi
>>
>> diff --git a/arch/arm/dts/rk3288-evb.dtsi b/arch/arm/dts/rk3288-evb.dtsi
>> index 04902c0b..72da8847 100644
>> --- a/arch/arm/dts/rk3288-evb.dtsi
>> +++ b/arch/arm/dts/rk3288-evb.dtsi
>> @@ -448,7 +448,7 @@
>>       status = "okay";
>>   };
>>   -&mipi_dsi0 {
>> +&mipi_dsi {
>>       status = "disabled";
>>       rockchip,panel = <&panel>;
>>       display-timings {
>> diff --git a/arch/arm/dts/rk3288-miqi.dtsi
>> b/arch/arm/dts/rk3288-miqi.dtsi
>> index cb80cbf2..b1c286c9 100644
>> --- a/arch/arm/dts/rk3288-miqi.dtsi
>> +++ b/arch/arm/dts/rk3288-miqi.dtsi
>> @@ -18,21 +18,6 @@
>>           clock-output-names = "ext_gmac";
>>       };
>>   -    io_domains: io-domains {
>> -        compatible = "rockchip,rk3288-io-voltage-domain";
>> -        rockchip,grf = <&grf>;
>> -
>> -        audio-supply = <&vcca_33>;
>> -        flash0-supply = <&vcc_flash>;
>> -        flash1-supply = <&vcc_lan>;
>> -        gpio30-supply = <&vcc_io>;
>> -        gpio1830-supply = <&vcc_io>;
>> -        lcdc-supply = <&vcc_io>;
>> -        sdcard-supply = <&vccio_sd>;
>> -        wifi-supply = <&vcc_18>;
>> -    };
>> -
>> -
>>       leds {
>>           compatible = "gpio-leds";
>>   @@ -277,6 +262,19 @@
>>       status = "okay";
>>   };
>>   +&io_domains {
>> +    status = "okay";
>> +
>> +    audio-supply = <&vcca_33>;
>> +    flash0-supply = <&vcc_flash>;
>> +    flash1-supply = <&vcc_lan>;
>> +    gpio30-supply = <&vcc_io>;
>> +    gpio1830-supply = <&vcc_io>;
>> +    lcdc-supply = <&vcc_io>;
>> +    sdcard-supply = <&vccio_sd>;
>> +    wifi-supply = <&vcc_18>;
>> +};
>> +
>>   &pinctrl {
>>       pcfg_output_high: pcfg-output-high {
>>           output-high;
>> diff --git a/arch/arm/dts/rk3288-phycore-som.dtsi
>> b/arch/arm/dts/rk3288-phycore-som.dtsi
>> index 821525f7..8ac695c8 100644
>> --- a/arch/arm/dts/rk3288-phycore-som.dtsi
>> +++ b/arch/arm/dts/rk3288-phycore-som.dtsi
>> @@ -71,22 +71,6 @@
>>           clock-output-names = "ext_gmac";
>>       };
>>   -    io_domains: io_domains {
>> -        compatible = "rockchip,rk3288-io-voltage-domain";
>> -
>> -        status = "okay";
>> -        sdcard-supply = <&vdd_io_sd>;
>> -        flash0-supply = <&vdd_emmc_io>;
>> -        flash1-supply = <&vdd_misc_1v8>;
>> -        gpio1830-supply = <&vdd_3v3_io>;
>> -        gpio30-supply = <&vdd_3v3_io>;
>> -        bb-supply = <&vdd_3v3_io>;
>> -        dvp-supply = <&vdd_3v3_io>;
>> -        lcdc-supply = <&vdd_3v3_io>;
>> -        wifi-supply = <&vdd_3v3_io>;
>> -        audio-supply = <&vdd_3v3_io>;
>> -    };
>> -
>>       leds: user-leds {
>>           compatible = "gpio-leds";
>>           pinctrl-names = "default";
>> @@ -197,6 +181,20 @@
>>       ddc-i2c-bus = <&i2c5>;
>>   };
>>   +&io_domains {
>> +    status = "okay";
>> +    sdcard-supply = <&vdd_io_sd>;
>> +    flash0-supply = <&vdd_emmc_io>;
>> +    flash1-supply = <&vdd_misc_1v8>;
>> +    gpio1830-supply = <&vdd_3v3_io>;
>> +    gpio30-supply = <&vdd_3v3_io>;
>> +    bb-supply = <&vdd_3v3_io>;
>> +    dvp-supply = <&vdd_3v3_io>;
>> +    lcdc-supply = <&vdd_3v3_io>;
>> +    wifi-supply = <&vdd_3v3_io>;
>> +    audio-supply = <&vdd_3v3_io>;
>> +};
>> +
>>   &i2c0 {
>>       status = "okay";
>>       clock-frequency = <400000>;
>> diff --git a/arch/arm/dts/rk3288-popmetal.dtsi
>> b/arch/arm/dts/rk3288-popmetal.dtsi
>> index 63785eb5..bcd8fded 100644
>> --- a/arch/arm/dts/rk3288-popmetal.dtsi
>> +++ b/arch/arm/dts/rk3288-popmetal.dtsi
>> @@ -69,22 +69,6 @@
>>           };
>>       };
>>   -    io_domains: io-domains {
>> -        compatible = "rockchip,rk3288-io-voltage-domain";
>> -        rockchip,grf = <&grf>;
>> -
>> -        audio-supply = <&vcca_33>;
>> -        bb-supply = <&vcc_io>;
>> -        dvp-supply = <&vcc18_dvp>;
>> -        flash0-supply = <&vcc_flash>;
>> -        flash1-supply = <&vcc_lan>;
>> -        gpio30-supply = <&vcc_io>;
>> -        gpio1830-supply = <&vcc_io>;
>> -        lcdc-supply = <&vcc_io>;
>> -        sdcard-supply = <&vccio_sd>;
>> -        wifi-supply = <&vccio_wl>;
>> -    };
>> -
>>       ir: ir-receiver {
>>           compatible = "gpio-ir-receiver";
>>           gpios = <&gpio0 6 GPIO_ACTIVE_LOW>;
>> @@ -441,6 +425,20 @@
>>       status = "okay";
>>   };
>>   +&io_domains {
>> +    status = "okay";
>> +    audio-supply = <&vcca_33>;
>> +    bb-supply = <&vcc_io>;
>> +    dvp-supply = <&vcc18_dvp>;
>> +    flash0-supply = <&vcc_flash>;
>> +    flash1-supply = <&vcc_lan>;
>> +    gpio30-supply = <&vcc_io>;
>> +    gpio1830-supply = <&vcc_io>;
>> +    lcdc-supply = <&vcc_io>;
>> +    sdcard-supply = <&vccio_sd>;
>> +    wifi-supply = <&vccio_wl>;
>> +};
>> +
>>   &pinctrl {
>>       ak8963 {
>>           comp_int: comp-int {
>> diff --git a/arch/arm/dts/rk3288-thermal.dtsi
>> b/arch/arm/dts/rk3288-thermal.dtsi
>> deleted file mode 100644
>> index 87dd8142..00000000
>> --- a/arch/arm/dts/rk3288-thermal.dtsi
>> +++ /dev/null
>> @@ -1,87 +0,0 @@
>> -// SPDX-License-Identifier: GPL-2.0
>> -/*
>> - * Device Tree Source for RK3288 SoC thermal
>> - *
>> - * Copyright (c) 2014, Fuzhou Rockchip Electronics Co., Ltd
>> - */
>> -
>> -#include <dt-bindings/thermal/thermal.h>
>> -
>> -reserve_thermal: reserve_thermal {
>> -    polling-delay-passive = <1000>; /* milliseconds */
>> -    polling-delay = <5000>; /* milliseconds */
>> -
>> -            /* sensor    ID */
>> -    thermal-sensors = <&tsadc    0>;
>> -
>> -};
>> -
>> -cpu_thermal: cpu_thermal {
>> -    polling-delay-passive = <100>; /* milliseconds */
>> -    polling-delay = <5000>; /* milliseconds */
>> -
>> -            /* sensor    ID */
>> -    thermal-sensors = <&tsadc    1>;
>> -    linux,hwmon;
>> -
>> -    trips {
>> -        cpu_alert0: cpu_alert0 {
>> -            temperature = <70000>; /* millicelsius */
>> -            hysteresis = <2000>; /* millicelsius */
>> -            type = "passive";
>> -        };
>> -        cpu_alert1: cpu_alert1 {
>> -            temperature = <75000>; /* millicelsius */
>> -            hysteresis = <2000>; /* millicelsius */
>> -            type = "passive";
>> -        };
>> -        cpu_crit: cpu_crit {
>> -            temperature = <100000>; /* millicelsius */
>> -            hysteresis = <2000>; /* millicelsius */
>> -            type = "critical";
>> -        };
>> -    };
>> -
>> -    cooling-maps {
>> -        map0 {
>> -            trip = <&cpu_alert0>;
>> -            cooling-device =
>> -                <&cpu0 THERMAL_NO_LIMIT 6>;
>> -        };
>> -        map1 {
>> -            trip = <&cpu_alert1>;
>> -            cooling-device =
>> -                <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>> -        };
>> -    };
>> -};
>> -
>> -gpu_thermal: gpu_thermal {
>> -    polling-delay-passive = <100>; /* milliseconds */
>> -    polling-delay = <5000>; /* milliseconds */
>> -
>> -            /* sensor    ID */
>> -    thermal-sensors = <&tsadc    2>;
>> -    linux,hwmon;
>> -
>> -    trips {
>> -        gpu_alert0: gpu_alert0 {
>> -            temperature = <80000>; /* millicelsius */
>> -            hysteresis = <2000>; /* millicelsius */
>> -            type = "passive";
>> -        };
>> -        gpu_crit: gpu_crit {
>> -            temperature = <100000>; /* millicelsius */
>> -            hysteresis = <2000>; /* millicelsius */
>> -            type = "critical";
>> -        };
>> -    };
>> -
>> -    cooling-maps {
>> -        map0 {
>> -            trip = <&gpu_alert0>;
>> -            cooling-device =
>> -                <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>> -        };
>> -    };
>> -};
>> diff --git a/arch/arm/dts/rk3288-veyron-jerry.dts
>> b/arch/arm/dts/rk3288-veyron-jerry.dts
>> index ff7669eb..40fee55c 100644
>> --- a/arch/arm/dts/rk3288-veyron-jerry.dts
>> +++ b/arch/arm/dts/rk3288-veyron-jerry.dts
>> @@ -137,12 +137,6 @@
>>           };
>>       };
>>   -    edp {
>> -        edp_hpd: edp_hpd {
>> -            rockchip,pins = <7 11 RK_FUNC_2 &pcfg_pull_down>;
>> -        };
>> -    };
>> -
>>       emmc {
>>           /* Make sure eMMC is not in reset */
>>           emmc_deassert_reset: emmc-deassert-reset {
>> diff --git a/arch/arm/dts/rk3288-veyron.dtsi
>> b/arch/arm/dts/rk3288-veyron.dtsi
>> index 4a9c27a4..ac9e815e 100644
>> --- a/arch/arm/dts/rk3288-veyron.dtsi
>> +++ b/arch/arm/dts/rk3288-veyron.dtsi
>> @@ -198,21 +198,6 @@
>>           /* Faux input supply.  See bt_regulator description. */
>>           vin-supply = <&bt_regulator>;
>>       };
>> -
>> -    io-domains {
>> -        compatible = "rockchip,rk3288-io-voltage-domain";
>> -        rockchip,grf = <&grf>;
>> -
>> -        audio-supply = <&vcc18_codec>;
>> -        bb-supply = <&vcc33_io>;
>> -        dvp-supply = <&vcc_18>;
>> -        flash0-supply = <&vcc18_flashio>;
>> -        gpio1830-supply = <&vcc33_io>;
>> -        gpio30-supply = <&vcc33_io>;
>> -        lcdc-supply = <&vcc33_lcd>;
>> -        sdcard-supply = <&vccio_sd>;
>> -        wifi-supply = <&vcc18_wl>;
>> -    };
>>   };
>>     &cpu0 {
>> @@ -503,6 +488,20 @@
>>       clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>, <&cru SCLK_I2S0_OUT>;
>>   };
>>   +&io_domains {
>> +    status = "okay";
>> +
>> +    audio-supply = <&vcc18_codec>;
>> +    bb-supply = <&vcc33_io>;
>> +    dvp-supply = <&vcc_18>;
>> +    flash0-supply = <&vcc18_flashio>;
>> +    gpio1830-supply = <&vcc33_io>;
>> +    gpio30-supply = <&vcc33_io>;
>> +    lcdc-supply = <&vcc33_lcd>;
>> +    sdcard-supply = <&vccio_sd>;
>> +    wifi-supply = <&vcc18_wl>;
>> +};
>> +
>>   &wdt {
>>       status = "okay";
>>   };
>> @@ -560,10 +559,6 @@
>>       status = "okay";
>>   };
>>   -&hdmi_audio {
>> -    status = "okay";
>> -};
>> -
>>   &gpu {
>>       status = "okay";
>>   };
>> diff --git a/arch/arm/dts/rk3288.dtsi b/arch/arm/dts/rk3288.dtsi
>> index c4abfa37..14a3f8e8 100644
>> --- a/arch/arm/dts/rk3288.dtsi
>> +++ b/arch/arm/dts/rk3288.dtsi
>> @@ -1,4 +1,4 @@
>> -// SPDX-License-Identifier: GPL-2.0+
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>>     #include <dt-bindings/gpio/gpio.h>
>>   #include <dt-bindings/interrupt-controller/irq.h>
>> @@ -7,14 +7,18 @@
>>   #include <dt-bindings/clock/rk3288-cru.h>
>>   #include <dt-bindings/power/rk3288-power.h>
>>   #include <dt-bindings/thermal/thermal.h>
>> -#include <dt-bindings/video/rk3288.h>
>> -#include "skeleton.dtsi"
>> +#include <dt-bindings/soc/rockchip,boot-mode.h>
>>     / {
>> +    #address-cells = <1>;
>> +    #size-cells = <1>;
>> +
>>       compatible = "rockchip,rk3288";
>>         interrupt-parent = <&gic>;
>> +
>>       aliases {
>> +        ethernet0 = &gmac;
>>           i2c0 = &i2c0;
>>           i2c1 = &i2c1;
>>           i2c2 = &i2c2;
>> @@ -35,6 +39,15 @@
>>           spi2 = &spi2;
>>       };
>>   +    arm-pmu {
>> +        compatible = "arm,cortex-a12-pmu";
>> +        interrupts = <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 152 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>;
>> +        interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
>> +    };
>> +
>>       cpus {
>>           #address-cells = <1>;
>>           #size-cells = <0>;
>> @@ -45,85 +58,119 @@
>>               device_type = "cpu";
>>               compatible = "arm,cortex-a12";
>>               reg = <0x500>;
>> -            operating-points = <
>> -                /* KHz    uV */
>> -                1800000 1400000
>> -                1704000 1350000
>> -                1608000 1300000
>> -                1512000 1250000
>> -                1416000 1200000
>> -                1200000 1100000
>> -                1008000 1050000
>> -                 816000 1000000
>> -                 696000  950000
>> -                 600000  900000
>> -                 408000  900000
>> -                 216000  900000
>> -                 126000  900000
>> -            >;
>> +            resets = <&cru SRST_CORE0>;
>> +            operating-points-v2 = <&cpu_opp_table>;
>>               #cooling-cells = <2>; /* min followed by max */
>>               clock-latency = <40000>;
>>               clocks = <&cru ARMCLK>;
>> -            resets = <&cru SRST_CORE0>;
>> +            dynamic-power-coefficient = <370>;
>>           };
>> -        cpu at 501 {
>> +        cpu1: cpu at 501 {
>>               device_type = "cpu";
>>               compatible = "arm,cortex-a12";
>>               reg = <0x501>;
>>               resets = <&cru SRST_CORE1>;
>> +            operating-points-v2 = <&cpu_opp_table>;
>> +            #cooling-cells = <2>; /* min followed by max */
>> +            clock-latency = <40000>;
>> +            clocks = <&cru ARMCLK>;
>> +            dynamic-power-coefficient = <370>;
>>           };
>> -        cpu at 502 {
>> +        cpu2: cpu at 502 {
>>               device_type = "cpu";
>>               compatible = "arm,cortex-a12";
>>               reg = <0x502>;
>>               resets = <&cru SRST_CORE2>;
>> +            operating-points-v2 = <&cpu_opp_table>;
>> +            #cooling-cells = <2>; /* min followed by max */
>> +            clock-latency = <40000>;
>> +            clocks = <&cru ARMCLK>;
>> +            dynamic-power-coefficient = <370>;
>>           };
>> -        cpu at 503 {
>> +        cpu3: cpu at 503 {
>>               device_type = "cpu";
>>               compatible = "arm,cortex-a12";
>>               reg = <0x503>;
>>               resets = <&cru SRST_CORE3>;
>> +            operating-points-v2 = <&cpu_opp_table>;
>> +            #cooling-cells = <2>; /* min followed by max */
>> +            clock-latency = <40000>;
>> +            clocks = <&cru ARMCLK>;
>> +            dynamic-power-coefficient = <370>;
>>           };
>>       };
>>   -    amba {
>> -        compatible = "arm,amba-bus";
>> +    cpu_opp_table: opp-table-0 {
>> +        compatible = "operating-points-v2";
>> +        opp-shared;
>> +
>> +        opp-126000000 {
>> +            opp-hz = /bits/ 64 <126000000>;
>> +            opp-microvolt = <900000>;
>> +        };
>> +        opp-216000000 {
>> +            opp-hz = /bits/ 64 <216000000>;
>> +            opp-microvolt = <900000>;
>> +        };
>> +        opp-312000000 {
>> +            opp-hz = /bits/ 64 <312000000>;
>> +            opp-microvolt = <900000>;
>> +        };
>> +        opp-408000000 {
>> +            opp-hz = /bits/ 64 <408000000>;
>> +            opp-microvolt = <900000>;
>> +        };
>> +        opp-600000000 {
>> +            opp-hz = /bits/ 64 <600000000>;
>> +            opp-microvolt = <900000>;
>> +        };
>> +        opp-696000000 {
>> +            opp-hz = /bits/ 64 <696000000>;
>> +            opp-microvolt = <950000>;
>> +        };
>> +        opp-816000000 {
>> +            opp-hz = /bits/ 64 <816000000>;
>> +            opp-microvolt = <1000000>;
>> +        };
>> +        opp-1008000000 {
>> +            opp-hz = /bits/ 64 <1008000000>;
>> +            opp-microvolt = <1050000>;
>> +        };
>> +        opp-1200000000 {
>> +            opp-hz = /bits/ 64 <1200000000>;
>> +            opp-microvolt = <1100000>;
>> +        };
>> +        opp-1416000000 {
>> +            opp-hz = /bits/ 64 <1416000000>;
>> +            opp-microvolt = <1200000>;
>> +        };
>> +        opp-1512000000 {
>> +            opp-hz = /bits/ 64 <1512000000>;
>> +            opp-microvolt = <1300000>;
>> +        };
>> +        opp-1608000000 {
>> +            opp-hz = /bits/ 64 <1608000000>;
>> +            opp-microvolt = <1350000>;
>> +        };
>> +    };
>> +
>> +    reserved-memory {
>>           #address-cells = <1>;
>>           #size-cells = <1>;
>>           ranges;
>>   -        dmac_peri: dma-controller at ff250000 {
>> -            compatible = "arm,pl330", "arm,primecell";
>> -            broken-no-flushp;
>> -            reg = <0xff250000 0x4000>;
>> -            interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
>> -                     <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
>> -            #dma-cells = <1>;
>> -            clocks = <&cru ACLK_DMAC2>;
>> -            clock-names = "apb_pclk";
>> -        };
>> -
>> -        dmac_bus_ns: dma-controller at ff600000 {
>> -            compatible = "arm,pl330", "arm,primecell";
>> -            broken-no-flushp;
>> -            reg = <0xff600000 0x4000>;
>> -            interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
>> -                     <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>> -            #dma-cells = <1>;
>> -            clocks = <&cru ACLK_DMAC1>;
>> -            clock-names = "apb_pclk";
>> -            status = "disabled";
>> -        };
>> -
>> -        dmac_bus_s: dma-controller at ffb20000 {
>> -            compatible = "arm,pl330", "arm,primecell";
>> -            broken-no-flushp;
>> -            reg = <0xffb20000 0x4000>;
>> -            interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
>> -                     <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>> -            #dma-cells = <1>;
>> -            clocks = <&cru ACLK_DMAC1>;
>> -            clock-names = "apb_pclk";
>> +        /*
>> +         * The rk3288 cannot use the memory area above 0xfe000000
>> +         * for dma operations for some reason. While there is
>> +         * probably a better solution available somewhere, we
>> +         * haven't found it yet and while devices with 2GB of ram
>> +         * are not affected, this issue prevents 4GB from booting.
>> +         * So to make these devices at least bootable, block
>> +         * this area for the time being until the real solution
>> +         * is found.
>> +         */
>> +        dma-unusable at fe000000 {
>> +            reg = <0xfe000000 0x1000000>;
>>           };
>>       };
>>   @@ -135,14 +182,22 @@
>>       };
>>         timer {
>> -            arm,use-physical-timer;
>>           compatible = "arm,armv7-timer";
>> +        arm,cpu-registers-not-fw-configured;
>>           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)>;
>>           clock-frequency = <24000000>;
>> -        always-on;
>> +        arm,no-tick-in-suspend;
>> +    };
>> +
>> +    timer: timer at ff810000 {
>> +        compatible = "rockchip,rk3288-timer";
>> +        reg = <0xff810000 0x20>;
>> +        interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru PCLK_TIMER>, <&xin24m>;
>> +        clock-names = "pclk", "timer";
>>       };
>>         display-subsystem {
>> @@ -150,51 +205,59 @@
>>           ports = <&vopl_out>, <&vopb_out>;
>>       };
>>   -    sdmmc: dwmmc at ff0c0000 {
>> +    sdmmc: mmc at ff0c0000 {
>>           compatible = "rockchip,rk3288-dw-mshc";
>>           max-frequency = <150000000>;
>>           clocks = <&cru HCLK_SDMMC>, <&cru SCLK_SDMMC>,
>>                <&cru SCLK_SDMMC_DRV>, <&cru SCLK_SDMMC_SAMPLE>;
>> -        clock-names = "biu", "ciu", "ciu_drv", "ciu_sample";
>> +        clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
>>           fifo-depth = <0x100>;
>>           interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
>>           reg = <0xff0c0000 0x4000>;
>> +        resets = <&cru SRST_MMC0>;
>> +        reset-names = "reset";
>>           status = "disabled";
>>       };
>>   -    sdio0: dwmmc at ff0d0000 {
>> +    sdio0: mmc at ff0d0000 {
>>           compatible = "rockchip,rk3288-dw-mshc";
>>           max-frequency = <150000000>;
>>           clocks = <&cru HCLK_SDIO0>, <&cru SCLK_SDIO0>,
>>                <&cru SCLK_SDIO0_DRV>, <&cru SCLK_SDIO0_SAMPLE>;
>> -        clock-names = "biu", "ciu", "ciu_drv", "ciu_sample";
>> +        clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
>>           fifo-depth = <0x100>;
>>           interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
>>           reg = <0xff0d0000 0x4000>;
>> +        resets = <&cru SRST_SDIO0>;
>> +        reset-names = "reset";
>>           status = "disabled";
>>       };
>>   -    sdio1: dwmmc at ff0e0000 {
>> +    sdio1: mmc at ff0e0000 {
>>           compatible = "rockchip,rk3288-dw-mshc";
>>           max-frequency = <150000000>;
>>           clocks = <&cru HCLK_SDIO1>, <&cru SCLK_SDIO1>,
>>                <&cru SCLK_SDIO1_DRV>, <&cru SCLK_SDIO1_SAMPLE>;
>> -        clock-names = "biu", "ciu", "ciu_drv", "ciu_sample";
>> +        clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
>>           fifo-depth = <0x100>;
>>           interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
>>           reg = <0xff0e0000 0x4000>;
>> +        resets = <&cru SRST_SDIO1>;
>> +        reset-names = "reset";
>>           status = "disabled";
>>       };
>>   -    emmc: dwmmc at ff0f0000 {
>> +    emmc: mmc at ff0f0000 {
>>           compatible = "rockchip,rk3288-dw-mshc";
>>           max-frequency = <150000000>;
>>           clocks = <&cru HCLK_EMMC>, <&cru SCLK_EMMC>,
>>                <&cru SCLK_EMMC_DRV>, <&cru SCLK_EMMC_SAMPLE>;
>> -        clock-names = "biu", "ciu", "ciu_drv", "ciu_sample";
>> +        clock-names = "biu", "ciu", "ciu-drive", "ciu-sample";
>>           fifo-depth = <0x100>;
>>           interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
>>           reg = <0xff0f0000 0x4000>;
>> +        resets = <&cru SRST_EMMC>;
>> +        reset-names = "reset";
>>           status = "disabled";
>>       };
>>   @@ -205,6 +268,8 @@
>>           #io-channel-cells = <1>;
>>           clocks = <&cru SCLK_SARADC>, <&cru PCLK_SARADC>;
>>           clock-names = "saradc", "apb_pclk";
>> +        resets = <&cru SRST_SARADC>;
>> +        reset-names = "saradc-apb";
>>           status = "disabled";
>>       };
>>   @@ -304,6 +369,7 @@
>>           pinctrl-0 = <&i2c5_xfer>;
>>           status = "disabled";
>>       };
>> +
>>       uart0: serial at ff180000 {
>>           compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
>>           reg = <0xff180000 0x100>;
>> @@ -312,6 +378,8 @@
>>           reg-io-width = <4>;
>>           clocks = <&cru SCLK_UART0>, <&cru PCLK_UART0>;
>>           clock-names = "baudclk", "apb_pclk";
>> +        dmas = <&dmac_peri 1>, <&dmac_peri 2>;
>> +        dma-names = "tx", "rx";
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&uart0_xfer>;
>>           status = "disabled";
>> @@ -325,6 +393,8 @@
>>           reg-io-width = <4>;
>>           clocks = <&cru SCLK_UART1>, <&cru PCLK_UART1>;
>>           clock-names = "baudclk", "apb_pclk";
>> +        dmas = <&dmac_peri 3>, <&dmac_peri 4>;
>> +        dma-names = "tx", "rx";
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&uart1_xfer>;
>>           status = "disabled";
>> @@ -342,6 +412,7 @@
>>           pinctrl-0 = <&uart2_xfer>;
>>           status = "disabled";
>>       };
>> +
>>       uart3: serial at ff1b0000 {
>>           compatible = "rockchip,rk3288-uart", "snps,dw-apb-uart";
>>           reg = <0xff1b0000 0x100>;
>> @@ -350,6 +421,8 @@
>>           reg-io-width = <4>;
>>           clocks = <&cru SCLK_UART3>, <&cru PCLK_UART3>;
>>           clock-names = "baudclk", "apb_pclk";
>> +        dmas = <&dmac_peri 7>, <&dmac_peri 8>;
>> +        dma-names = "tx", "rx";
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&uart3_xfer>;
>>           status = "disabled";
>> @@ -363,12 +436,104 @@
>>           reg-io-width = <4>;
>>           clocks = <&cru SCLK_UART4>, <&cru PCLK_UART4>;
>>           clock-names = "baudclk", "apb_pclk";
>> +        dmas = <&dmac_peri 9>, <&dmac_peri 10>;
>> +        dma-names = "tx", "rx";
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&uart4_xfer>;
>>           status = "disabled";
>>       };
>> -    thermal: thermal-zones {
>> -        #include "rk3288-thermal.dtsi"
>> +
>> +    dmac_peri: dma-controller at ff250000 {
>> +        compatible = "arm,pl330", "arm,primecell";
>> +        reg = <0xff250000 0x4000>;
>> +        interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
>> +        #dma-cells = <1>;
>> +        arm,pl330-broken-no-flushp;
>> +        arm,pl330-periph-burst;
>> +        clocks = <&cru ACLK_DMAC2>;
>> +        clock-names = "apb_pclk";
>> +    };
>> +
>> +    thermal-zones {
>> +        reserve_thermal: reserve-thermal {
>> +            polling-delay-passive = <1000>; /* milliseconds */
>> +            polling-delay = <5000>; /* milliseconds */
>> +
>> +            thermal-sensors = <&tsadc 0>;
>> +        };
>> +
>> +        cpu_thermal: cpu-thermal {
>> +            polling-delay-passive = <100>; /* milliseconds */
>> +            polling-delay = <5000>; /* milliseconds */
>> +
>> +            thermal-sensors = <&tsadc 1>;
>> +
>> +            trips {
>> +                cpu_alert0: cpu_alert0 {
>> +                    temperature = <70000>; /* millicelsius */
>> +                    hysteresis = <2000>; /* millicelsius */
>> +                    type = "passive";
>> +                };
>> +                cpu_alert1: cpu_alert1 {
>> +                    temperature = <75000>; /* millicelsius */
>> +                    hysteresis = <2000>; /* millicelsius */
>> +                    type = "passive";
>> +                };
>> +                cpu_crit: cpu_crit {
>> +                    temperature = <90000>; /* millicelsius */
>> +                    hysteresis = <2000>; /* millicelsius */
>> +                    type = "critical";
>> +                };
>> +            };
>> +
>> +            cooling-maps {
>> +                map0 {
>> +                    trip = <&cpu_alert0>;
>> +                    cooling-device =
>> +                        <&cpu0 THERMAL_NO_LIMIT 6>,
>> +                        <&cpu1 THERMAL_NO_LIMIT 6>,
>> +                        <&cpu2 THERMAL_NO_LIMIT 6>,
>> +                        <&cpu3 THERMAL_NO_LIMIT 6>;
>> +                };
>> +                map1 {
>> +                    trip = <&cpu_alert1>;
>> +                    cooling-device =
>> +                        <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
>> +                        <&cpu1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
>> +                        <&cpu2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
>> +                        <&cpu3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>> +                };
>> +            };
>> +        };
>> +
>> +        gpu_thermal: gpu-thermal {
>> +            polling-delay-passive = <100>; /* milliseconds */
>> +            polling-delay = <5000>; /* milliseconds */
>> +
>> +            thermal-sensors = <&tsadc 2>;
>> +
>> +            trips {
>> +                gpu_alert0: gpu_alert0 {
>> +                    temperature = <70000>; /* millicelsius */
>> +                    hysteresis = <2000>; /* millicelsius */
>> +                    type = "passive";
>> +                };
>> +                gpu_crit: gpu_crit {
>> +                    temperature = <90000>; /* millicelsius */
>> +                    hysteresis = <2000>; /* millicelsius */
>> +                    type = "critical";
>> +                };
>> +            };
>> +
>> +            cooling-maps {
>> +                map0 {
>> +                    trip = <&gpu_alert0>;
>> +                    cooling-device =
>> +                        <&gpu THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
>> +                };
>> +            };
>> +        };
>>       };
>>         tsadc: tsadc at ff280000 {
>> @@ -379,18 +544,22 @@
>>           clock-names = "tsadc", "apb_pclk";
>>           resets = <&cru SRST_TSADC>;
>>           reset-names = "tsadc-apb";
>> -        pinctrl-names = "otp_out";
>> -        pinctrl-0 = <&otp_out>;
>> +        pinctrl-names = "init", "default", "sleep";
>> +        pinctrl-0 = <&otp_pin>;
>> +        pinctrl-1 = <&otp_out>;
>> +        pinctrl-2 = <&otp_pin>;
>>           #thermal-sensor-cells = <1>;
>> -        hw-shut-temp = <125000>;
>> +        rockchip,grf = <&grf>;
>> +        rockchip,hw-tshut-temp = <95000>;
>>           status = "disabled";
>>       };
>>         gmac: ethernet at ff290000 {
>>           compatible = "rockchip,rk3288-gmac";
>>           reg = <0xff290000 0x10000>;
>> -        interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
>> -        interrupt-names = "macirq";
>> +        interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>,
>> +                <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
>> +        interrupt-names = "macirq", "eth_wake_irq";
>>           rockchip,grf = <&grf>;
>>           clocks = <&cru SCLK_MAC>,
>>               <&cru SCLK_MAC_RX>, <&cru SCLK_MAC_TX>,
>> @@ -400,6 +569,9 @@
>>               "mac_clk_rx", "mac_clk_tx",
>>               "clk_mac_ref", "clk_mac_refout",
>>               "aclk_mac", "pclk_mac";
>> +        resets = <&cru SRST_MAC>;
>> +        reset-names = "stmmaceth";
>> +        status = "disabled";
>>       };
>>         usb_host0_ehci: usb at ff500000 {
>> @@ -407,16 +579,15 @@
>>           reg = <0xff500000 0x100>;
>>           interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru HCLK_USBHOST0>;
>> -        clock-names = "usbhost";
>>           phys = <&usbphy1>;
>>           phy-names = "usb";
>>           status = "disabled";
>>       };
>>   -    /* NOTE: doesn't work on RK3288, but fixed on RK3288W */
>> +    /* NOTE: doesn't work on RK3288, but was fixed on RK3288W */
>>       usb_host0_ohci: usb at ff520000 {
>>           compatible = "generic-ohci";
>> -        reg = <0x0 0xff520000 0x0 0x100>;
>> +        reg = <0xff520000 0x100>;
>>           interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru HCLK_USBHOST0>;
>>           phys = <&usbphy1>;
>> @@ -431,8 +602,10 @@
>>           interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru HCLK_USBHOST1>;
>>           clock-names = "otg";
>> +        dr_mode = "host";
>>           phys = <&usbphy2>;
>>           phy-names = "usb2-phy";
>> +        snps,reset-phy-on-wake;
>>           status = "disabled";
>>       };
>>   @@ -444,6 +617,9 @@
>>           clocks = <&cru HCLK_OTG0>;
>>           clock-names = "otg";
>>           dr_mode = "otg";
>> +        g-np-tx-fifo-size = <16>;
>> +        g-rx-fifo-size = <275>;
>> +        g-tx-fifo-size = <256 128 128 64 64 32>;
>>           phys = <&usbphy0>;
>>           phy-names = "usb2-phy";
>>           status = "disabled";
>> @@ -454,7 +630,19 @@
>>           reg = <0xff5c0000 0x100>;
>>           interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru HCLK_HSIC>;
>> -        clock-names = "usbhost";
>> +        status = "disabled";
>> +    };
>> +
>> +    dmac_bus_ns: dma-controller at ff600000 {
>> +        compatible = "arm,pl330", "arm,primecell";
>> +        reg = <0xff600000 0x4000>;
>> +        interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>> +        #dma-cells = <1>;
>> +        arm,pl330-broken-no-flushp;
>> +        arm,pl330-periph-burst;
>> +        clocks = <&cru ACLK_DMAC1>;
>> +        clock-names = "apb_pclk";
>>           status = "disabled";
>>       };
>>   @@ -490,9 +678,7 @@
>>           #pwm-cells = <3>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&pwm0_pin>;
>> -        clocks = <&cru PCLK_PWM>;
>> -        clock-names = "pwm";
>> -        rockchip,grf = <&grf>;
>> +        clocks = <&cru PCLK_RKPWM>;
>>           status = "disabled";
>>       };
>>   @@ -502,9 +688,7 @@
>>           #pwm-cells = <3>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&pwm1_pin>;
>> -        clocks = <&cru PCLK_PWM>;
>> -        clock-names = "pwm";
>> -        rockchip,grf = <&grf>;
>> +        clocks = <&cru PCLK_RKPWM>;
>>           status = "disabled";
>>       };
>>   @@ -514,25 +698,21 @@
>>           #pwm-cells = <3>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&pwm2_pin>;
>> -        clocks = <&cru PCLK_PWM>;
>> -        clock-names = "pwm";
>> -        rockchip,grf = <&grf>;
>> +        clocks = <&cru PCLK_RKPWM>;
>>           status = "disabled";
>>       };
>>         pwm3: pwm at ff680030 {
>>           compatible = "rockchip,rk3288-pwm";
>>           reg = <0xff680030 0x10>;
>> -        #pwm-cells = <2>;
>> +        #pwm-cells = <3>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&pwm3_pin>;
>> -        clocks = <&cru PCLK_PWM>;
>> -        clock-names = "pwm";
>> -        rockchip,grf = <&grf>;
>> +        clocks = <&cru PCLK_RKPWM>;
>>           status = "disabled";
>>       };
>>   -    bus_intmem: bus_intmem at ff700000 {
>> +    bus_intmem: sram at ff700000 {
>>           compatible = "mmio-sram";
>>           reg = <0xff700000 0x18000>;
>>           #address-cells = <1>;
>> @@ -544,14 +724,134 @@
>>           };
>>       };
>>   -    sram at ff720000 {
>> +    pmu_sram: sram at ff720000 {
>>           compatible = "rockchip,rk3288-pmu-sram", "mmio-sram";
>>           reg = <0xff720000 0x1000>;
>>       };
>>         pmu: power-management at ff730000 {
>> -        compatible = "rockchip,rk3288-pmu", "syscon";
>> +        compatible = "rockchip,rk3288-pmu", "syscon", "simple-mfd";
>>           reg = <0xff730000 0x100>;
>> +
>> +        power: power-controller {
>> +            compatible = "rockchip,rk3288-power-controller";
>> +            #power-domain-cells = <1>;
>> +            #address-cells = <1>;
>> +            #size-cells = <0>;
>> +
>> +            assigned-clocks = <&cru SCLK_EDP_24M>;
>> +            assigned-clock-parents = <&xin24m>;
>> +
>> +            /*
>> +             * Note: Although SCLK_* are the working clocks
>> +             * of device without including on the NOC, needed for
>> +             * synchronous reset.
>> +             *
>> +             * The clocks on the which NOC:
>> +             * ACLK_IEP/ACLK_VIP/ACLK_VOP0 are on ACLK_VIO0_NIU.
>> +             * ACLK_ISP/ACLK_VOP1 are on ACLK_VIO1_NIU.
>> +             * ACLK_RGA is on ACLK_RGA_NIU.
>> +             * The others (HCLK_*,PLCK_*) are on HCLK_VIO_NIU.
>> +             *
>> +             * Which clock are device clocks:
>> +             *    clocks        devices
>> +             *    *_IEP        IEP:Image Enhancement Processor
>> +             *    *_ISP        ISP:Image Signal Processing
>> +             *    *_VIP        VIP:Video Input Processor
>> +             *    *_VOP*        VOP:Visual Output Processor
>> +             *    *_RGA        RGA
>> +             *    *_EDP*        EDP
>> +             *    *_LVDS_*    LVDS
>> +             *    *_HDMI        HDMI
>> +             *    *_MIPI_*    MIPI
>> +             */
>> +            power-domain at RK3288_PD_VIO {
>> +                reg = <RK3288_PD_VIO>;
>> +                clocks = <&cru ACLK_IEP>,
>> +                     <&cru ACLK_ISP>,
>> +                     <&cru ACLK_RGA>,
>> +                     <&cru ACLK_VIP>,
>> +                     <&cru ACLK_VOP0>,
>> +                     <&cru ACLK_VOP1>,
>> +                     <&cru DCLK_VOP0>,
>> +                     <&cru DCLK_VOP1>,
>> +                     <&cru HCLK_IEP>,
>> +                     <&cru HCLK_ISP>,
>> +                     <&cru HCLK_RGA>,
>> +                     <&cru HCLK_VIP>,
>> +                     <&cru HCLK_VOP0>,
>> +                     <&cru HCLK_VOP1>,
>> +                     <&cru PCLK_EDP_CTRL>,
>> +                     <&cru PCLK_HDMI_CTRL>,
>> +                     <&cru PCLK_LVDS_PHY>,
>> +                     <&cru PCLK_MIPI_CSI>,
>> +                     <&cru PCLK_MIPI_DSI0>,
>> +                     <&cru PCLK_MIPI_DSI1>,
>> +                     <&cru SCLK_EDP_24M>,
>> +                     <&cru SCLK_EDP>,
>> +                     <&cru SCLK_ISP_JPE>,
>> +                     <&cru SCLK_ISP>,
>> +                     <&cru SCLK_RGA>;
>> +                pm_qos = <&qos_vio0_iep>,
>> +                     <&qos_vio1_vop>,
>> +                     <&qos_vio1_isp_w0>,
>> +                     <&qos_vio1_isp_w1>,
>> +                     <&qos_vio0_vop>,
>> +                     <&qos_vio0_vip>,
>> +                     <&qos_vio2_rga_r>,
>> +                     <&qos_vio2_rga_w>,
>> +                     <&qos_vio1_isp_r>;
>> +                #power-domain-cells = <0>;
>> +            };
>> +
>> +            /*
>> +             * Note: The following 3 are HEVC(H.265) clocks,
>> +             * and on the ACLK_HEVC_NIU (NOC).
>> +             */
>> +            power-domain at RK3288_PD_HEVC {
>> +                reg = <RK3288_PD_HEVC>;
>> +                clocks = <&cru ACLK_HEVC>,
>> +                     <&cru SCLK_HEVC_CABAC>,
>> +                     <&cru SCLK_HEVC_CORE>;
>> +                pm_qos = <&qos_hevc_r>,
>> +                     <&qos_hevc_w>;
>> +                #power-domain-cells = <0>;
>> +            };
>> +
>> +            /*
>> +             * Note: ACLK_VCODEC/HCLK_VCODEC are VCODEC
>> +             * (video endecoder & decoder) clocks that on the
>> +             * ACLK_VCODEC_NIU and HCLK_VCODEC_NIU (NOC).
>> +             */
>> +            power-domain at RK3288_PD_VIDEO {
>> +                reg = <RK3288_PD_VIDEO>;
>> +                clocks = <&cru ACLK_VCODEC>,
>> +                     <&cru HCLK_VCODEC>;
>> +                pm_qos = <&qos_video>;
>> +                #power-domain-cells = <0>;
>> +            };
>> +
>> +            /*
>> +             * Note: ACLK_GPU is the GPU clock,
>> +             * and on the ACLK_GPU_NIU (NOC).
>> +             */
>> +            power-domain at RK3288_PD_GPU {
>> +                reg = <RK3288_PD_GPU>;
>> +                clocks = <&cru ACLK_GPU>;
>> +                pm_qos = <&qos_gpu_r>,
>> +                     <&qos_gpu_w>;
>> +                #power-domain-cells = <0>;
>> +            };
>> +        };
>> +
>> +        reboot-mode {
>> +            compatible = "syscon-reboot-mode";
>> +            offset = <0x94>;
>> +            mode-normal = <BOOT_NORMAL>;
>> +            mode-recovery = <BOOT_RECOVERY>;
>> +            mode-bootloader = <BOOT_FASTBOOT>;
>> +            mode-loader = <BOOT_BL_DOWNLOAD>;
>> +        };
>>       };
>>         sgrf: syscon at ff740000 {
>> @@ -578,15 +878,65 @@
>>       };
>>         grf: syscon at ff770000 {
>> -        compatible = "rockchip,rk3288-grf", "syscon";
>> +        compatible = "rockchip,rk3288-grf", "syscon", "simple-mfd";
>>           reg = <0xff770000 0x1000>;
>> +
>> +        edp_phy: edp-phy {
>> +            compatible = "rockchip,rk3288-dp-phy";
>> +            clocks = <&cru SCLK_EDP_24M>;
>> +            clock-names = "24m";
>> +            #phy-cells = <0>;
>> +            status = "disabled";
>> +        };
>> +
>> +        io_domains: io-domains {
>> +            compatible = "rockchip,rk3288-io-voltage-domain";
>> +            status = "disabled";
>> +        };
>> +
>> +        usbphy: usbphy {
>> +            compatible = "rockchip,rk3288-usb-phy";
>> +            #address-cells = <1>;
>> +            #size-cells = <0>;
>> +            status = "disabled";
>> +
>> +            usbphy0: usb-phy at 320 {
>> +                #phy-cells = <0>;
>> +                reg = <0x320>;
>> +                clocks = <&cru SCLK_OTGPHY0>;
>> +                clock-names = "phyclk";
>> +                #clock-cells = <0>;
>> +                resets = <&cru SRST_USBOTG_PHY>;
>> +                reset-names = "phy-reset";
>> +            };
>> +
>> +            usbphy1: usb-phy at 334 {
>> +                #phy-cells = <0>;
>> +                reg = <0x334>;
>> +                clocks = <&cru SCLK_OTGPHY1>;
>> +                clock-names = "phyclk";
>> +                #clock-cells = <0>;
>> +                resets = <&cru SRST_USBHOST0_PHY>;
>> +                reset-names = "phy-reset";
>> +            };
>> +
>> +            usbphy2: usb-phy at 348 {
>> +                #phy-cells = <0>;
>> +                reg = <0x348>;
>> +                clocks = <&cru SCLK_OTGPHY2>;
>> +                clock-names = "phyclk";
>> +                #clock-cells = <0>;
>> +                resets = <&cru SRST_USBHOST1_PHY>;
>> +                reset-names = "phy-reset";
>> +            };
>> +        };
>>       };
>>         wdt: watchdog at ff800000 {
>>           compatible = "rockchip,rk3288-wdt", "snps,dw-wdt";
>>           reg = <0xff800000 0x100>;
>>           clocks = <&cru PCLK_WDT>;
>> -        interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
>> +        interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
>>           status = "disabled";
>>       };
>>   @@ -594,11 +944,11 @@
>>           compatible = "rockchip,rk3288-spdif", "rockchip,rk3066-spdif";
>>           reg = <0xff8b0000 0x10000>;
>>           #sound-dai-cells = <0>;
>> -        clock-names = "hclk", "mclk";
>> -        clocks = <&cru HCLK_SPDIF8CH>, <&cru SCLK_SPDIF8CH>;
>> +        clocks = <&cru SCLK_SPDIF8CH>, <&cru HCLK_SPDIF8CH>;
>> +        clock-names = "mclk", "hclk";
>>           dmas = <&dmac_bus_s 3>;
>>           dma-names = "tx";
>> -        interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
>> +        interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&spdif_tx>;
>>           rockchip,grf = <&grf>;
>> @@ -608,50 +958,97 @@
>>       i2s: i2s at ff890000 {
>>           compatible = "rockchip,rk3288-i2s", "rockchip,rk3066-i2s";
>>           reg = <0xff890000 0x10000>;
>> -        interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
>> -        #address-cells = <1>;
>> -        #size-cells = <0>;
>> -        #sound-dai-cells = <1>;
>> +        #sound-dai-cells = <0>;
>> +        interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru SCLK_I2S0>, <&cru HCLK_I2S0>;
>> +        clock-names = "i2s_clk", "i2s_hclk";
>>           dmas = <&dmac_bus_s 0>, <&dmac_bus_s 1>;
>>           dma-names = "tx", "rx";
>> -        clock-names = "i2s_hclk", "i2s_clk";
>> -        clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
>>           pinctrl-names = "default";
>>           pinctrl-0 = <&i2s0_bus>;
>> +        rockchip,playback-channels = <8>;
>> +        rockchip,capture-channels = <2>;
>> +        status = "disabled";
>> +    };
>> +
>> +    crypto: cypto-controller at ff8a0000 {
>> +        compatible = "rockchip,rk3288-crypto";
>> +        reg = <0xff8a0000 0x4000>;
>> +        interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru ACLK_CRYPTO>, <&cru HCLK_CRYPTO>,
>> +             <&cru SCLK_CRYPTO>, <&cru ACLK_DMAC1>;
>> +        clock-names = "aclk", "hclk", "sclk", "apb_pclk";
>> +        resets = <&cru SRST_CRYPTO>;
>> +        reset-names = "crypto-rst";
>> +    };
>> +
>> +    iep_mmu: iommu at ff900800 {
>> +        compatible = "rockchip,iommu";
>> +        reg = <0xff900800 0x40>;
>> +        interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru ACLK_IEP>, <&cru HCLK_IEP>;
>> +        clock-names = "aclk", "iface";
>> +        #iommu-cells = <0>;
>> +        status = "disabled";
>> +    };
>> +
>> +    isp_mmu: iommu at ff914000 {
>> +        compatible = "rockchip,iommu";
>> +        reg = <0xff914000 0x100>, <0xff915000 0x100>;
>> +        interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru ACLK_ISP>, <&cru HCLK_ISP>;
>> +        clock-names = "aclk", "iface";
>> +        #iommu-cells = <0>;
>> +        rockchip,disable-mmu-reset;
>>           status = "disabled";
>>       };
>>   +    rga: rga at ff920000 {
>> +        compatible = "rockchip,rk3288-rga";
>> +        reg = <0xff920000 0x180>;
>> +        interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru ACLK_RGA>, <&cru HCLK_RGA>, <&cru SCLK_RGA>;
>> +        clock-names = "aclk", "hclk", "sclk";
>> +        power-domains = <&power RK3288_PD_VIO>;
>> +        resets = <&cru SRST_RGA_CORE>, <&cru SRST_RGA_AXI>, <&cru
>> SRST_RGA_AHB>;
>> +        reset-names = "core", "axi", "ahb";
>> +    };
>> +
>>       vopb: vop at ff930000 {
>>           compatible = "rockchip,rk3288-vop";
>> -        reg = <0xff930000 0x19c>;
>> +        reg = <0xff930000 0x19c>, <0xff931000 0x1000>;
>>           interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru ACLK_VOP0>, <&cru DCLK_VOP0>, <&cru HCLK_VOP0>;
>>           clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
>> +        power-domains = <&power RK3288_PD_VIO>;
>>           resets = <&cru SRST_LCDC0_AXI>, <&cru SRST_LCDC0_AHB>, <&cru
>> SRST_LCDC0_DCLK>;
>>           reset-names = "axi", "ahb", "dclk";
>>           iommus = <&vopb_mmu>;
>> -        power-domains = <&power RK3288_PD_VIO>;
>>           status = "disabled";
>> +
>>           vopb_out: port {
>>               #address-cells = <1>;
>>               #size-cells = <0>;
>> -            vopb_out_edp: endpoint at 0 {
>> +
>> +            vopb_out_hdmi: endpoint at 0 {
>>                   reg = <0>;
>> -                remote-endpoint = <&edp_in_vopb>;
>> +                remote-endpoint = <&hdmi_in_vopb>;
>>               };
>> -            vopb_out_hdmi: endpoint at 1 {
>> +
>> +            vopb_out_edp: endpoint at 1 {
>>                   reg = <1>;
>> -                remote-endpoint = <&hdmi_in_vopb>;
>> +                remote-endpoint = <&edp_in_vopb>;
>>               };
>> -            vopb_out_lvds: endpoint at 2 {
>> +
>> +            vopb_out_mipi: endpoint at 2 {
>>                   reg = <2>;
>> -                remote-endpoint = <&lvds_in_vopb>;
>> -            };
>> -            vopb_out_mipi: endpoint at 3 {
>> -                reg = <3>;
>>                   remote-endpoint = <&mipi_in_vopb>;
>>               };
>>   +            vopb_out_lvds: endpoint at 3 {
>> +                reg = <3>;
>> +                remote-endpoint = <&lvds_in_vopb>;
>> +            };
>>           };
>>       };
>>   @@ -659,7 +1056,8 @@
>>           compatible = "rockchip,iommu";
>>           reg = <0xff930300 0x100>;
>>           interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
>> -        interrupt-names = "vopb_mmu";
>> +        clocks = <&cru ACLK_VOP0>, <&cru HCLK_VOP0>;
>> +        clock-names = "aclk", "iface";
>>           power-domains = <&power RK3288_PD_VIO>;
>>           #iommu-cells = <0>;
>>           status = "disabled";
>> @@ -667,35 +1065,39 @@
>>         vopl: vop at ff940000 {
>>           compatible = "rockchip,rk3288-vop";
>> -        reg = <0xff940000 0x19c>;
>> +        reg = <0xff940000 0x19c>, <0xff941000 0x1000>;
>>           interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
>>           clocks = <&cru ACLK_VOP1>, <&cru DCLK_VOP1>, <&cru HCLK_VOP1>;
>>           clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
>> +        power-domains = <&power RK3288_PD_VIO>;
>>           resets = <&cru SRST_LCDC1_AXI>, <&cru SRST_LCDC1_AHB>, <&cru
>> SRST_LCDC1_DCLK>;
>>           reset-names = "axi", "ahb", "dclk";
>>           iommus = <&vopl_mmu>;
>> -        power-domains = <&power RK3288_PD_VIO>;
>>           status = "disabled";
>> +
>>           vopl_out: port {
>>               #address-cells = <1>;
>>               #size-cells = <0>;
>> -            vopl_out_edp: endpoint at 0 {
>> +
>> +            vopl_out_hdmi: endpoint at 0 {
>>                   reg = <0>;
>> -                remote-endpoint = <&edp_in_vopl>;
>> +                remote-endpoint = <&hdmi_in_vopl>;
>>               };
>> -            vopl_out_hdmi: endpoint at 1 {
>> +
>> +            vopl_out_edp: endpoint at 1 {
>>                   reg = <1>;
>> -                remote-endpoint = <&hdmi_in_vopl>;
>> +                remote-endpoint = <&edp_in_vopl>;
>>               };
>> -            vopl_out_lvds: endpoint at 2 {
>> +
>> +            vopl_out_mipi: endpoint at 2 {
>>                   reg = <2>;
>> -                remote-endpoint = <&lvds_in_vopl>;
>> -            };
>> -            vopl_out_mipi: endpoint at 3 {
>> -                reg = <3>;
>>                   remote-endpoint = <&mipi_in_vopl>;
>>               };
>>   +            vopl_out_lvds: endpoint at 3 {
>> +                reg = <3>;
>> +                remote-endpoint = <&lvds_in_vopl>;
>> +            };
>>           };
>>       };
>>   @@ -703,60 +1105,34 @@
>>           compatible = "rockchip,iommu";
>>           reg = <0xff940300 0x100>;
>>           interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
>> -        interrupt-names = "vopl_mmu";
>> +        clocks = <&cru ACLK_VOP1>, <&cru HCLK_VOP1>;
>> +        clock-names = "aclk", "iface";
>>           power-domains = <&power RK3288_PD_VIO>;
>>           #iommu-cells = <0>;
>>           status = "disabled";
>>       };
>>   -    edp: edp at ff970000 {
>> -        compatible = "rockchip,rk3288-edp";
>> -        reg = <0xff970000 0x4000>;
>> -        interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
>> -        clocks = <&cru SCLK_EDP>, <&cru SCLK_EDP_24M>, <&cru
>> PCLK_EDP_CTRL>;
>> -        rockchip,grf = <&grf>;
>> -        clock-names = "clk_edp", "clk_edp_24m", "pclk_edp";
>> -        resets = <&cru 111>;
>> -        reset-names = "edp";
>> +    mipi_dsi: mipi at ff960000 {
>> +        compatible = "rockchip,rk3288-mipi-dsi", "snps,dw-mipi-dsi";
>> +        reg = <0xff960000 0x4000>;
>> +        interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru SCLK_MIPIDSI_24M>, <&cru PCLK_MIPI_DSI0>;
>> +        clock-names = "ref", "pclk";
>>           power-domains = <&power RK3288_PD_VIO>;
>> -        status = "disabled";
>> -        ports {
>> -            edp_in: port {
>> -                #address-cells = <1>;
>> -                #size-cells = <0>;
>> -                edp_in_vopb: endpoint at 0 {
>> -                    reg = <0>;
>> -                    remote-endpoint = <&vopb_out_edp>;
>> -                };
>> -                edp_in_vopl: endpoint at 1 {
>> -                    reg = <1>;
>> -                    remote-endpoint = <&vopl_out_edp>;
>> -                };
>> -            };
>> -        };
>> -    };
>> -
>> -    hdmi: hdmi at ff980000 {
>> -        compatible = "rockchip,rk3288-dw-hdmi";
>> -        reg = <0xff980000 0x20000>;
>> -        reg-io-width = <4>;
>> -        ddc-i2c-bus = <&i2c5>;
>>           rockchip,grf = <&grf>;
>> -        interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
>> -        clocks = <&cru  PCLK_HDMI_CTRL>, <&cru SCLK_HDMI_HDCP>;
>> -        clock-names = "iahb", "isfr";
>>           status = "disabled";
>> +
>>           ports {
>> -            hdmi_in: port {
>> +            mipi_in: port {
>>                   #address-cells = <1>;
>>                   #size-cells = <0>;
>> -                hdmi_in_vopb: endpoint at 0 {
>> +                mipi_in_vopb: endpoint at 0 {
>>                       reg = <0>;
>> -                    remote-endpoint = <&vopb_out_hdmi>;
>> +                    remote-endpoint = <&vopb_out_mipi>;
>>                   };
>> -                hdmi_in_vopl: endpoint at 1 {
>> +                mipi_in_vopl: endpoint at 1 {
>>                       reg = <1>;
>> -                    remote-endpoint = <&vopl_out_hdmi>;
>> +                    remote-endpoint = <&vopl_out_mipi>;
>>                   };
>>               };
>>           };
>> @@ -767,17 +1143,22 @@
>>           reg = <0xff96c000 0x4000>;
>>           clocks = <&cru PCLK_LVDS_PHY>;
>>           clock-names = "pclk_lvds";
>> -        pinctrl-names = "default";
>> -        pinctrl-0 = <&lcdc0_ctl>;
>> +        pinctrl-names = "lcdc";
>> +        pinctrl-0 = <&lcdc_ctl>;
>> +        power-domains = <&power RK3288_PD_VIO>;
>>           rockchip,grf = <&grf>;
>>           status = "disabled";
>> +
>>           ports {
>>               #address-cells = <1>;
>>               #size-cells = <0>;
>> +
>>               lvds_in: port at 0 {
>>                   reg = <0>;
>> +
>>                   #address-cells = <1>;
>>                   #size-cells = <0>;
>> +
>>                   lvds_in_vopb: endpoint at 0 {
>>                       reg = <0>;
>>                       remote-endpoint = <&vopb_out_lvds>;
>> @@ -790,90 +1171,233 @@
>>           };
>>       };
>>   -    mipi_dsi0: mipi at ff960000 {
>> -        compatible = "rockchip,rk3288_mipi_dsi";
>> -        reg = <0xff960000 0x4000>;
>> -        clocks = <&cru PCLK_MIPI_DSI0>;
>> -        clock-names = "pclk_mipi";
>> -        /*pinctrl-names = "default";
>> -        pinctrl-0 = <&lcdc0_ctl>;*/
>> +    edp: dp at ff970000 {
>> +        compatible = "rockchip,rk3288-dp";
>> +        reg = <0xff970000 0x4000>;
>> +        interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru SCLK_EDP>, <&cru PCLK_EDP_CTRL>;
>> +        clock-names = "dp", "pclk";
>> +        phys = <&edp_phy>;
>> +        phy-names = "dp";
>> +        resets = <&cru SRST_EDP>;
>> +        reset-names = "dp";
>>           rockchip,grf = <&grf>;
>> -        #address-cells = <1>;
>> -        #size-cells = <0>;
>>           status = "disabled";
>> +
>>           ports {
>> -            reg = <1>;
>> -            mipi_in: port {
>> +            #address-cells = <1>;
>> +            #size-cells = <0>;
>> +            edp_in: port at 0 {
>> +                reg = <0>;
>>                   #address-cells = <1>;
>>                   #size-cells = <0>;
>> -                mipi_in_vopb: endpoint at 0 {
>> +                edp_in_vopb: endpoint at 0 {
>>                       reg = <0>;
>> -                    remote-endpoint = <&vopb_out_mipi>;
>> +                    remote-endpoint = <&vopb_out_edp>;
>>                   };
>> -                mipi_in_vopl: endpoint at 1 {
>> +                edp_in_vopl: endpoint at 1 {
>>                       reg = <1>;
>> -                    remote-endpoint = <&vopl_out_mipi>;
>> +                    remote-endpoint = <&vopl_out_edp>;
>>                   };
>>               };
>>           };
>>       };
>>   -    hdmi_audio: hdmi_audio {
>> -        compatible = "rockchip,rk3288-hdmi-audio";
>> -        i2s-controller = <&i2s>;
>> -        status = "disable";
>> +    hdmi: hdmi at ff980000 {
>> +        compatible = "rockchip,rk3288-dw-hdmi";
>> +        reg = <0xff980000 0x20000>;
>> +        reg-io-width = <4>;
>> +        #sound-dai-cells = <0>;
>> +        rockchip,grf = <&grf>;
>> +        interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru  PCLK_HDMI_CTRL>, <&cru SCLK_HDMI_HDCP>, <&cru
>> SCLK_HDMI_CEC>;
>> +        clock-names = "iahb", "isfr", "cec";
>> +        power-domains = <&power RK3288_PD_VIO>;
>> +        status = "disabled";
>> +
>> +        ports {
>> +            hdmi_in: port {
>> +                #address-cells = <1>;
>> +                #size-cells = <0>;
>> +                hdmi_in_vopb: endpoint at 0 {
>> +                    reg = <0>;
>> +                    remote-endpoint = <&vopb_out_hdmi>;
>> +                };
>> +                hdmi_in_vopl: endpoint at 1 {
>> +                    reg = <1>;
>> +                    remote-endpoint = <&vopl_out_hdmi>;
>> +                };
>> +            };
>> +        };
>>       };
>>         vpu: video-codec at ff9a0000 {
>>           compatible = "rockchip,rk3288-vpu";
>>           reg = <0xff9a0000 0x800>;
>>           interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>,
>> -                <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
>> +                 <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
>>           interrupt-names = "vepu", "vdpu";
>>           clocks = <&cru ACLK_VCODEC>, <&cru HCLK_VCODEC>;
>> -        clock-names = "aclk_vcodec", "hclk_vcodec";
>> -        power-domains = <&power RK3288_PD_VIDEO>;
>> +        clock-names = "aclk", "hclk";
>>           iommus = <&vpu_mmu>;
>> +        power-domains = <&power RK3288_PD_VIDEO>;
>>       };
>>         vpu_mmu: iommu at ff9a0800 {
>>           compatible = "rockchip,iommu";
>>           reg = <0xff9a0800 0x100>;
>>           interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
>> -        interrupt-names = "vpu_mmu";
>> +        clocks = <&cru ACLK_VCODEC>, <&cru HCLK_VCODEC>;
>> +        clock-names = "aclk", "iface";
>> +        #iommu-cells = <0>;
>>           power-domains = <&power RK3288_PD_VIDEO>;
>> +    };
>> +
>> +    hevc_mmu: iommu at ff9c0440 {
>> +        compatible = "rockchip,iommu";
>> +        reg = <0xff9c0440 0x40>, <0xff9c0480 0x40>;
>> +        interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
>> +        clocks = <&cru ACLK_HEVC>, <&cru HCLK_HEVC>;
>> +        clock-names = "aclk", "iface";
>>           #iommu-cells = <0>;
>> +        status = "disabled";
>>       };
>>         gpu: gpu at ffa30000 {
>> -        compatible = "arm,malit764",
>> -                 "arm,malit76x",
>> -                 "arm,malit7xx",
>> -                 "arm,mali-midgard";
>> +        compatible = "rockchip,rk3288-mali", "arm,mali-t760";
>>           reg = <0xffa30000 0x10000>;
>>           interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
>>                    <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>,
>>                    <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
>> -        interrupt-names = "JOB", "MMU", "GPU";
>> +        interrupt-names = "job", "mmu", "gpu";
>>           clocks = <&cru ACLK_GPU>;
>> -        clock-names = "aclk_gpu";
>> -        operating-points = <
>> -            /* KHz uV */
>> -            100000 950000
>> -            200000 950000
>> -            300000 1000000
>> -            400000 1100000
>> -            /* 500000 1200000 - See crosbug.com/p/33857 */
>> -            600000 1250000
>> -        >;
>> +        operating-points-v2 = <&gpu_opp_table>;
>> +        #cooling-cells = <2>; /* min followed by max */
>>           power-domains = <&power RK3288_PD_GPU>;
>>           status = "disabled";
>>       };
>>   +    gpu_opp_table: opp-table-1 {
>> +        compatible = "operating-points-v2";
>> +
>> +        opp-100000000 {
>> +            opp-hz = /bits/ 64 <100000000>;
>> +            opp-microvolt = <950000>;
>> +        };
>> +        opp-200000000 {
>> +            opp-hz = /bits/ 64 <200000000>;
>> +            opp-microvolt = <950000>;
>> +        };
>> +        opp-300000000 {
>> +            opp-hz = /bits/ 64 <300000000>;
>> +            opp-microvolt = <1000000>;
>> +        };
>> +        opp-400000000 {
>> +            opp-hz = /bits/ 64 <400000000>;
>> +            opp-microvolt = <1100000>;
>> +        };
>> +        opp-600000000 {
>> +            opp-hz = /bits/ 64 <600000000>;
>> +            opp-microvolt = <1250000>;
>> +        };
>> +    };
>> +
>> +    qos_gpu_r: qos at ffaa0000 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffaa0000 0x20>;
>> +    };
>> +
>> +    qos_gpu_w: qos at ffaa0080 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffaa0080 0x20>;
>> +    };
>> +
>> +    qos_vio1_vop: qos at ffad0000 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0000 0x20>;
>> +    };
>> +
>> +    qos_vio1_isp_w0: qos at ffad0100 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0100 0x20>;
>> +    };
>> +
>> +    qos_vio1_isp_w1: qos at ffad0180 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0180 0x20>;
>> +    };
>> +
>> +    qos_vio0_vop: qos at ffad0400 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0400 0x20>;
>> +    };
>> +
>> +    qos_vio0_vip: qos at ffad0480 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0480 0x20>;
>> +    };
>> +
>> +    qos_vio0_iep: qos at ffad0500 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0500 0x20>;
>> +    };
>> +
>> +    qos_vio2_rga_r: qos at ffad0800 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0800 0x20>;
>> +    };
>> +
>> +    qos_vio2_rga_w: qos at ffad0880 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0x0 0xffad0880 0x0 0x20>;
>> +    };
>> +
>> +    qos_vio1_isp_r: qos at ffad0900 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffad0900 0x20>;
>> +    };
>> +
>> +    qos_video: qos at ffae0000 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffae0000 0x20>;
>> +    };
>> +
>> +    qos_hevc_r: qos at ffaf0000 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffaf0000 0x20>;
>> +    };
>> +
>> +    qos_hevc_w: qos at ffaf0080 {
>> +        compatible = "rockchip,rk3288-qos", "syscon";
>> +        reg = <0xffaf0080 0x20>;
>> +    };
>> +
>> +    dmac_bus_s: dma-controller at ffb20000 {
>> +        compatible = "arm,pl330", "arm,primecell";
>> +        reg = <0xffb20000 0x4000>;
>> +        interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
>> +                 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
>> +        #dma-cells = <1>;
>> +        arm,pl330-broken-no-flushp;
>> +        arm,pl330-periph-burst;
>> +        clocks = <&cru ACLK_DMAC1>;
>> +        clock-names = "apb_pclk";
>> +    };
>> +
>>       efuse: efuse at ffb40000 {
>>           compatible = "rockchip,rk3288-efuse";
>> -        reg = <0xffb40000 0x10000>;
>> -        status = "disabled";
>> +        reg = <0xffb40000 0x20>;
>> +        #address-cells = <1>;
>> +        #size-cells = <1>;
>> +        clocks = <&cru PCLK_EFUSE256>;
>> +        clock-names = "pclk_efuse";
>> +
>> +        cpu_id: cpu-id at 7 {
>> +            reg = <0x07 0x10>;
>> +        };
>> +        cpu_leakage: cpu_leakage at 17 {
>> +            reg = <0x17 0x1>;
>> +        };
>>       };
>>         gic: interrupt-controller at ffc01000 {
>> @@ -883,45 +1407,12 @@
>>           #address-cells = <0>;
>>             reg = <0xffc01000 0x1000>,
>> -              <0xffc02000 0x1000>,
>> +              <0xffc02000 0x2000>,
>>                 <0xffc04000 0x2000>,
>>                 <0xffc06000 0x2000>;
>>           interrupts = <GIC_PPI 9 0xf04>;
>>       };
>>   -    cpuidle: cpuidle {
>> -        compatible = "rockchip,rk3288-cpuidle";
>> -    };
>> -
>> -    usbphy: phy {
>> -        compatible = "rockchip,rk3288-usb-phy";
>> -        rockchip,grf = <&grf>;
>> -        #address-cells = <1>;
>> -        #size-cells = <0>;
>> -        status = "disabled";
>> -
>> -        usbphy0: usb-phy0 {
>> -            #phy-cells = <0>;
>> -            reg = <0x320>;
>> -            clocks = <&cru SCLK_OTGPHY0>;
>> -            clock-names = "phyclk";
>> -        };
>> -
>> -        usbphy1: usb-phy1 {
>> -            #phy-cells = <0>;
>> -            reg = <0x334>;
>> -            clocks = <&cru SCLK_OTGPHY1>;
>> -            clock-names = "phyclk";
>> -        };
>> -
>> -        usbphy2: usb-phy2 {
>> -            #phy-cells = <0>;
>> -            reg = <0x348>;
>> -            clocks = <&cru SCLK_OTGPHY2>;
>> -            clock-names = "phyclk";
>> -        };
>> -    };
>> -
>>       pinctrl: pinctrl {
>>           compatible = "rockchip,rk3288-pinctrl";
>>           rockchip,grf = <&grf>;
>> @@ -930,9 +1421,9 @@
>>           #size-cells = <1>;
>>           ranges;
>>   -        gpio0: gpio0 at ff750000 {
>> +        gpio0: gpio at ff750000 {
>>               compatible = "rockchip,gpio-bank";
>> -            reg =    <0xff750000 0x100>;
>> +            reg = <0xff750000 0x100>;
>>               interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
>>               clocks = <&cru PCLK_GPIO0>;
>>   @@ -943,7 +1434,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio1: gpio1 at ff780000 {
>> +        gpio1: gpio at ff780000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff780000 0x100>;
>>               interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -956,7 +1447,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio2: gpio2 at ff790000 {
>> +        gpio2: gpio at ff790000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff790000 0x100>;
>>               interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -969,7 +1460,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio3: gpio3 at ff7a0000 {
>> +        gpio3: gpio at ff7a0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7a0000 0x100>;
>>               interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -982,7 +1473,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio4: gpio4 at ff7b0000 {
>> +        gpio4: gpio at ff7b0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7b0000 0x100>;
>>               interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -995,7 +1486,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio5: gpio5 at ff7c0000 {
>> +        gpio5: gpio at ff7c0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7c0000 0x100>;
>>               interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -1008,7 +1499,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio6: gpio6 at ff7d0000 {
>> +        gpio6: gpio at ff7d0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7d0000 0x100>;
>>               interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -1021,7 +1512,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio7: gpio7 at ff7e0000 {
>> +        gpio7: gpio at ff7e0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7e0000 0x100>;
>>               interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -1034,7 +1525,7 @@
>>               #interrupt-cells = <2>;
>>           };
>>   -        gpio8: gpio8 at ff7f0000 {
>> +        gpio8: gpio at ff7f0000 {
>>               compatible = "rockchip,gpio-bank";
>>               reg = <0xff7f0000 0x100>;
>>               interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
>> @@ -1051,6 +1542,24 @@
>>               hdmi_cec_c0: hdmi-cec-c0 {
>>                   rockchip,pins = <7 RK_PC0 2 &pcfg_pull_none>;
>>               };
>> +
>> +            hdmi_cec_c7: hdmi-cec-c7 {
>> +                rockchip,pins = <7 RK_PC7 4 &pcfg_pull_none>;
>> +            };
>> +
>> +            hdmi_ddc: hdmi-ddc {
>> +                rockchip,pins = <7 RK_PC3 2 &pcfg_pull_none>,
>> +                        <7 RK_PC4 2 &pcfg_pull_none>;
>> +            };
>> +
>> +            hdmi_ddc_unwedge: hdmi-ddc-unwedge {
>> +                rockchip,pins = <7 RK_PC3 RK_FUNC_GPIO
>> &pcfg_output_low>,
>> +                        <7 RK_PC4 2 &pcfg_pull_none>;
>> +            };
>> +        };
>> +
>> +        pcfg_output_low: pcfg-output-low {
>> +            output-low;
>>           };
>>             pcfg_pull_up: pcfg-pull-up {
>> @@ -1070,472 +1579,424 @@
>>               drive-strength = <12>;
>>           };
>>   -        sleep {
>> +        suspend {
>>               global_pwroff: global-pwroff {
>> -                rockchip,pins = <0 0 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <0 RK_PA0 1 &pcfg_pull_none>;
>>               };
>>                 ddrio_pwroff: ddrio-pwroff {
>> -                rockchip,pins = <0 1 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <0 RK_PA1 1 &pcfg_pull_none>;
>>               };
>>                 ddr0_retention: ddr0-retention {
>> -                rockchip,pins = <0 2 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <0 RK_PA2 1 &pcfg_pull_up>;
>>               };
>>                 ddr1_retention: ddr1-retention {
>> -                rockchip,pins = <0 3 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <0 RK_PA3 1 &pcfg_pull_up>;
>> +            };
>> +        };
>> +
>> +        edp {
>> +            edp_hpd: edp-hpd {
>> +                rockchip,pins = <7 RK_PB3 2 &pcfg_pull_down>;
>>               };
>>           };
>>             i2c0 {
>>               i2c0_xfer: i2c0-xfer {
>> -                rockchip,pins = <0 15 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <0 16 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <0 RK_PB7 1 &pcfg_pull_none>,
>> +                        <0 RK_PC0 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2c1 {
>>               i2c1_xfer: i2c1-xfer {
>> -                rockchip,pins = <8 4 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <8 5 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <8 RK_PA4 1 &pcfg_pull_none>,
>> +                        <8 RK_PA5 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2c2 {
>>               i2c2_xfer: i2c2-xfer {
>> -                rockchip,pins = <6 9 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 10 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <6 RK_PB1 1 &pcfg_pull_none>,
>> +                        <6 RK_PB2 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2c3 {
>>               i2c3_xfer: i2c3-xfer {
>> -                rockchip,pins = <2 16 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <2 17 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <2 RK_PC0 1 &pcfg_pull_none>,
>> +                        <2 RK_PC1 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2c4 {
>>               i2c4_xfer: i2c4-xfer {
>> -                rockchip,pins = <7 17 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <7 18 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PC1 1 &pcfg_pull_none>,
>> +                        <7 RK_PC2 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2c5 {
>>               i2c5_xfer: i2c5-xfer {
>> -                rockchip,pins = <7 19 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <7 20 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PC3 1 &pcfg_pull_none>,
>> +                        <7 RK_PC4 1 &pcfg_pull_none>;
>>               };
>>           };
>>             i2s0 {
>>               i2s0_bus: i2s0-bus {
>> -                rockchip,pins = <6 0 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 1 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 2 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 3 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 4 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <6 8 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <6 RK_PA0 1 &pcfg_pull_none>,
>> +                        <6 RK_PA1 1 &pcfg_pull_none>,
>> +                        <6 RK_PA2 1 &pcfg_pull_none>,
>> +                        <6 RK_PA3 1 &pcfg_pull_none>,
>> +                        <6 RK_PA4 1 &pcfg_pull_none>,
>> +                        <6 RK_PB0 1 &pcfg_pull_none>;
>>               };
>>           };
>>   -        lcdc0 {
>> -            lcdc0_ctl: lcdc0-ctl {
>> -                rockchip,pins = <1 24 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <1 25 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <1 26 RK_FUNC_1 &pcfg_pull_none>,
>> -                        <1 27 RK_FUNC_1 &pcfg_pull_none>;
>> +        lcdc {
>> +            lcdc_ctl: lcdc-ctl {
>> +                rockchip,pins = <1 RK_PD0 1 &pcfg_pull_none>,
>> +                        <1 RK_PD1 1 &pcfg_pull_none>,
>> +                        <1 RK_PD2 1 &pcfg_pull_none>,
>> +                        <1 RK_PD3 1 &pcfg_pull_none>;
>>               };
>>           };
>>             sdmmc {
>>               sdmmc_clk: sdmmc-clk {
>> -                rockchip,pins = <6 20 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <6 RK_PC4 1 &pcfg_pull_none>;
>>               };
>>                 sdmmc_cmd: sdmmc-cmd {
>> -                rockchip,pins = <6 21 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <6 RK_PC5 1 &pcfg_pull_up>;
>>               };
>>   -            sdmmc_cd: sdmcc-cd {
>> -                rockchip,pins = <6 22 RK_FUNC_1 &pcfg_pull_up>;
>> +            sdmmc_cd: sdmmc-cd {
>> +                rockchip,pins = <6 RK_PC6 1 &pcfg_pull_up>;
>>               };
>>                 sdmmc_bus1: sdmmc-bus1 {
>> -                rockchip,pins = <6 16 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <6 RK_PC0 1 &pcfg_pull_up>;
>>               };
>>                 sdmmc_bus4: sdmmc-bus4 {
>> -                rockchip,pins = <6 16 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <6 17 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <6 18 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <6 19 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <6 RK_PC0 1 &pcfg_pull_up>,
>> +                        <6 RK_PC1 1 &pcfg_pull_up>,
>> +                        <6 RK_PC2 1 &pcfg_pull_up>,
>> +                        <6 RK_PC3 1 &pcfg_pull_up>;
>>               };
>>           };
>>             sdio0 {
>>               sdio0_bus1: sdio0-bus1 {
>> -                rockchip,pins = <4 20 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PC4 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_bus4: sdio0-bus4 {
>> -                rockchip,pins = <4 20 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <4 21 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <4 22 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <4 23 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PC4 1 &pcfg_pull_up>,
>> +                        <4 RK_PC5 1 &pcfg_pull_up>,
>> +                        <4 RK_PC6 1 &pcfg_pull_up>,
>> +                        <4 RK_PC7 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_cmd: sdio0-cmd {
>> -                rockchip,pins = <4 24 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD0 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_clk: sdio0-clk {
>> -                rockchip,pins = <4 25 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <4 RK_PD1 1 &pcfg_pull_none>;
>>               };
>>                 sdio0_cd: sdio0-cd {
>> -                rockchip,pins = <4 26 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD2 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_wp: sdio0-wp {
>> -                rockchip,pins = <4 27 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD3 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_pwr: sdio0-pwr {
>> -                rockchip,pins = <4 28 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD4 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_bkpwr: sdio0-bkpwr {
>> -                rockchip,pins = <4 29 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD5 1 &pcfg_pull_up>;
>>               };
>>                 sdio0_int: sdio0-int {
>> -                rockchip,pins = <4 30 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PD6 1 &pcfg_pull_up>;
>>               };
>>           };
>>             sdio1 {
>>               sdio1_bus1: sdio1-bus1 {
>> -                rockchip,pins = <3 24 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD0 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_bus4: sdio1-bus4 {
>> -                rockchip,pins = <3 24 RK_FUNC_4 &pcfg_pull_up>,
>> -                        <3 25 RK_FUNC_4 &pcfg_pull_up>,
>> -                        <3 26 RK_FUNC_4 &pcfg_pull_up>,
>> -                        <3 27 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD0 4 &pcfg_pull_up>,
>> +                        <3 RK_PD1 4 &pcfg_pull_up>,
>> +                        <3 RK_PD2 4 &pcfg_pull_up>,
>> +                        <3 RK_PD3 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_cd: sdio1-cd {
>> -                rockchip,pins = <3 28 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD4 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_wp: sdio1-wp {
>> -                rockchip,pins = <3 29 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD5 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_bkpwr: sdio1-bkpwr {
>> -                rockchip,pins = <3 30 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD6 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_int: sdio1-int {
>> -                rockchip,pins = <3 31 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PD7 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_cmd: sdio1-cmd {
>> -                rockchip,pins = <4 6 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PA6 4 &pcfg_pull_up>;
>>               };
>>                 sdio1_clk: sdio1-clk {
>> -                rockchip,pins = <4 7 RK_FUNC_4 &pcfg_pull_none>;
>> +                rockchip,pins = <4 RK_PA7 4 &pcfg_pull_none>;
>>               };
>>                 sdio1_pwr: sdio1-pwr {
>> -                rockchip,pins = <4 9 RK_FUNC_4 &pcfg_pull_up>;
>> +                rockchip,pins = <4 RK_PB1 4 &pcfg_pull_up>;
>>               };
>>           };
>>             emmc {
>>               emmc_clk: emmc-clk {
>> -                rockchip,pins = <3 18 RK_FUNC_2 &pcfg_pull_none>;
>> +                rockchip,pins = <3 RK_PC2 2 &pcfg_pull_none>;
>>               };
>>                 emmc_cmd: emmc-cmd {
>> -                rockchip,pins = <3 16 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PC0 2 &pcfg_pull_up>;
>>               };
>>                 emmc_pwr: emmc-pwr {
>> -                rockchip,pins = <3 9 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PB1 2 &pcfg_pull_up>;
>>               };
>>                 emmc_bus1: emmc-bus1 {
>> -                rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PA0 2 &pcfg_pull_up>;
>>               };
>>                 emmc_bus4: emmc-bus4 {
>> -                rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 1 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 2 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 3 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PA0 2 &pcfg_pull_up>,
>> +                        <3 RK_PA1 2 &pcfg_pull_up>,
>> +                        <3 RK_PA2 2 &pcfg_pull_up>,
>> +                        <3 RK_PA3 2 &pcfg_pull_up>;
>>               };
>>                 emmc_bus8: emmc-bus8 {
>> -                rockchip,pins = <3 0 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 1 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 2 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 3 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 4 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 5 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 6 RK_FUNC_2 &pcfg_pull_up>,
>> -                        <3 7 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <3 RK_PA0 2 &pcfg_pull_up>,
>> +                        <3 RK_PA1 2 &pcfg_pull_up>,
>> +                        <3 RK_PA2 2 &pcfg_pull_up>,
>> +                        <3 RK_PA3 2 &pcfg_pull_up>,
>> +                        <3 RK_PA4 2 &pcfg_pull_up>,
>> +                        <3 RK_PA5 2 &pcfg_pull_up>,
>> +                        <3 RK_PA6 2 &pcfg_pull_up>,
>> +                        <3 RK_PA7 2 &pcfg_pull_up>;
>>               };
>>           };
>>             spi0 {
>>               spi0_clk: spi0-clk {
>> -                rockchip,pins = <5 12 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <5 RK_PB4 1 &pcfg_pull_up>;
>>               };
>>               spi0_cs0: spi0-cs0 {
>> -                rockchip,pins = <5 13 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <5 RK_PB5 1 &pcfg_pull_up>;
>>               };
>>               spi0_tx: spi0-tx {
>> -                rockchip,pins = <5 14 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <5 RK_PB6 1 &pcfg_pull_up>;
>>               };
>>               spi0_rx: spi0-rx {
>> -                rockchip,pins = <5 15 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <5 RK_PB7 1 &pcfg_pull_up>;
>>               };
>>               spi0_cs1: spi0-cs1 {
>> -                rockchip,pins = <5 16 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <5 RK_PC0 1 &pcfg_pull_up>;
>>               };
>>           };
>>           spi1 {
>>               spi1_clk: spi1-clk {
>> -                rockchip,pins = <7 12 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <7 RK_PB4 2 &pcfg_pull_up>;
>>               };
>>               spi1_cs0: spi1-cs0 {
>> -                rockchip,pins = <7 13 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <7 RK_PB5 2 &pcfg_pull_up>;
>>               };
>>               spi1_rx: spi1-rx {
>> -                rockchip,pins = <7 14 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <7 RK_PB6 2 &pcfg_pull_up>;
>>               };
>>               spi1_tx: spi1-tx {
>> -                rockchip,pins = <7 15 RK_FUNC_2 &pcfg_pull_up>;
>> +                rockchip,pins = <7 RK_PB7 2 &pcfg_pull_up>;
>>               };
>>           };
>>             spi2 {
>>               spi2_cs1: spi2-cs1 {
>> -                rockchip,pins = <8 3 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <8 RK_PA3 1 &pcfg_pull_up>;
>>               };
>>               spi2_clk: spi2-clk {
>> -                rockchip,pins = <8 6 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <8 RK_PA6 1 &pcfg_pull_up>;
>>               };
>>               spi2_cs0: spi2-cs0 {
>> -                rockchip,pins = <8 7 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <8 RK_PA7 1 &pcfg_pull_up>;
>>               };
>>               spi2_rx: spi2-rx {
>> -                rockchip,pins = <8 8 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <8 RK_PB0 1 &pcfg_pull_up>;
>>               };
>>               spi2_tx: spi2-tx {
>> -                rockchip,pins = <8 9 RK_FUNC_1 &pcfg_pull_up>;
>> +                rockchip,pins = <8 RK_PB1 1 &pcfg_pull_up>;
>>               };
>>           };
>>             uart0 {
>>               uart0_xfer: uart0-xfer {
>> -                rockchip,pins = <4 16 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <4 17 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <4 RK_PC0 1 &pcfg_pull_up>,
>> +                        <4 RK_PC1 1 &pcfg_pull_none>;
>>               };
>>                 uart0_cts: uart0-cts {
>> -                rockchip,pins = <4 18 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <4 RK_PC2 1 &pcfg_pull_up>;
>>               };
>>                 uart0_rts: uart0-rts {
>> -                rockchip,pins = <4 19 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <4 RK_PC3 1 &pcfg_pull_none>;
>>               };
>>           };
>>             uart1 {
>>               uart1_xfer: uart1-xfer {
>> -                rockchip,pins = <5 8 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <5 9 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB0 1 &pcfg_pull_up>,
>> +                        <5 RK_PB1 1 &pcfg_pull_none>;
>>               };
>>                 uart1_cts: uart1-cts {
>> -                rockchip,pins = <5 10 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB2 1 &pcfg_pull_up>;
>>               };
>>                 uart1_rts: uart1-rts {
>> -                rockchip,pins = <5 11 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB3 1 &pcfg_pull_none>;
>>               };
>>           };
>>             uart2 {
>>               uart2_xfer: uart2-xfer {
>> -                rockchip,pins = <7 22 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <7 23 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PC6 1 &pcfg_pull_up>,
>> +                        <7 RK_PC7 1 &pcfg_pull_none>;
>>               };
>>               /* no rts / cts for uart2 */
>>           };
>>             uart3 {
>>               uart3_xfer: uart3-xfer {
>> -                rockchip,pins = <7 7 RK_FUNC_1 &pcfg_pull_up>,
>> -                        <7 8 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PA7 1 &pcfg_pull_up>,
>> +                        <7 RK_PB0 1 &pcfg_pull_none>;
>>               };
>>                 uart3_cts: uart3-cts {
>> -                rockchip,pins = <7 9 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PB1 1 &pcfg_pull_up>;
>>               };
>>                 uart3_rts: uart3-rts {
>> -                rockchip,pins = <7 10 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PB2 1 &pcfg_pull_none>;
>>               };
>>           };
>>             uart4 {
>>               uart4_xfer: uart4-xfer {
>> -                rockchip,pins = <5 12 3 &pcfg_pull_up>,
>> -                        <5 13 3 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB7 3 &pcfg_pull_up>,
>> +                        <5 RK_PB6 3 &pcfg_pull_none>;
>>               };
>>                 uart4_cts: uart4-cts {
>> -                rockchip,pins = <5 14 3 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB4 3 &pcfg_pull_up>;
>>               };
>>                 uart4_rts: uart4-rts {
>> -                rockchip,pins = <5 15 3 &pcfg_pull_none>;
>> +                rockchip,pins = <5 RK_PB5 3 &pcfg_pull_none>;
>>               };
>>           };
>>             tsadc {
>> +            otp_pin: otp-pin {
>> +                rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>;
>> +            };
>> +
>>               otp_out: otp-out {
>> -                rockchip,pins = <0 10 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <0 RK_PB2 1 &pcfg_pull_none>;
>>               };
>>           };
>>             pwm0 {
>>               pwm0_pin: pwm0-pin {
>> -                rockchip,pins = <7 0 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PA0 1 &pcfg_pull_none>;
>>               };
>>           };
>>             pwm1 {
>>               pwm1_pin: pwm1-pin {
>> -                rockchip,pins = <7 1 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PA1 1 &pcfg_pull_none>;
>>               };
>>           };
>>             pwm2 {
>>               pwm2_pin: pwm2-pin {
>> -                rockchip,pins = <7 22 RK_FUNC_3 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PC6 3 &pcfg_pull_none>;
>>               };
>>           };
>>             pwm3 {
>>               pwm3_pin: pwm3-pin {
>> -                rockchip,pins = <7 23 RK_FUNC_3 &pcfg_pull_none>;
>> +                rockchip,pins = <7 RK_PC7 3 &pcfg_pull_none>;
>>               };
>>           };
>>             gmac {
>>               rgmii_pins: rgmii-pins {
>> -                rockchip,pins = <3 30 3 &pcfg_pull_none>,
>> -                        <3 31 3 &pcfg_pull_none>,
>> -                        <3 26 3 &pcfg_pull_none>,
>> -                        <3 27 3 &pcfg_pull_none>,
>> -                        <3 28 3 &pcfg_pull_none_12ma>,
>> -                        <3 29 3 &pcfg_pull_none_12ma>,
>> -                        <3 24 3 &pcfg_pull_none_12ma>,
>> -                        <3 25 3 &pcfg_pull_none_12ma>,
>> -                        <4 0 3 &pcfg_pull_none>,
>> -                        <4 5 3 &pcfg_pull_none>,
>> -                        <4 6 3 &pcfg_pull_none>,
>> -                        <4 9 3 &pcfg_pull_none_12ma>,
>> -                        <4 4 3 &pcfg_pull_none_12ma>,
>> -                        <4 1 3 &pcfg_pull_none>,
>> -                        <4 3 3 &pcfg_pull_none>;
>> +                rockchip,pins = <3 RK_PD6 3 &pcfg_pull_none>,
>> +                        <3 RK_PD7 3 &pcfg_pull_none>,
>> +                        <3 RK_PD2 3 &pcfg_pull_none>,
>> +                        <3 RK_PD3 3 &pcfg_pull_none>,
>> +                        <3 RK_PD4 3 &pcfg_pull_none_12ma>,
>> +                        <3 RK_PD5 3 &pcfg_pull_none_12ma>,
>> +                        <3 RK_PD0 3 &pcfg_pull_none_12ma>,
>> +                        <3 RK_PD1 3 &pcfg_pull_none_12ma>,
>> +                        <4 RK_PA0 3 &pcfg_pull_none>,
>> +                        <4 RK_PA5 3 &pcfg_pull_none>,
>> +                        <4 RK_PA6 3 &pcfg_pull_none>,
>> +                        <4 RK_PB1 3 &pcfg_pull_none_12ma>,
>> +                        <4 RK_PA4 3 &pcfg_pull_none_12ma>,
>> +                        <4 RK_PA1 3 &pcfg_pull_none>,
>> +                        <4 RK_PA3 3 &pcfg_pull_none>;
>>               };
>>                 rmii_pins: rmii-pins {
>> -                rockchip,pins = <3 30 3 &pcfg_pull_none>,
>> -                        <3 31 3 &pcfg_pull_none>,
>> -                        <3 28 3 &pcfg_pull_none>,
>> -                        <3 29 3 &pcfg_pull_none>,
>> -                        <4 0 3 &pcfg_pull_none>,
>> -                        <4 5 3 &pcfg_pull_none>,
>> -                        <4 4 3 &pcfg_pull_none>,
>> -                        <4 1 3 &pcfg_pull_none>,
>> -                        <4 2 3 &pcfg_pull_none>,
>> -                        <4 3 3 &pcfg_pull_none>;
>> +                rockchip,pins = <3 RK_PD6 3 &pcfg_pull_none>,
>> +                        <3 RK_PD7 3 &pcfg_pull_none>,
>> +                        <3 RK_PD4 3 &pcfg_pull_none>,
>> +                        <3 RK_PD5 3 &pcfg_pull_none>,
>> +                        <4 RK_PA0 3 &pcfg_pull_none>,
>> +                        <4 RK_PA5 3 &pcfg_pull_none>,
>> +                        <4 RK_PA4 3 &pcfg_pull_none>,
>> +                        <4 RK_PA1 3 &pcfg_pull_none>,
>> +                        <4 RK_PA2 3 &pcfg_pull_none>,
>> +                        <4 RK_PA3 3 &pcfg_pull_none>;
>>               };
>>           };
>>             spdif {
>>               spdif_tx: spdif-tx {
>> -                rockchip,pins = <RK_GPIO6 11 RK_FUNC_1 &pcfg_pull_none>;
>> +                rockchip,pins = <6 RK_PB3 1 &pcfg_pull_none>;
>>               };
>>           };
>>       };
>> -
>> -    power: power-controller {
>> -        compatible = "rockchip,rk3288-power-controller";
>> -        #power-domain-cells = <1>;
>> -        rockchip,pmu = <&pmu>;
>> -        #address-cells = <1>;
>> -        #size-cells = <0>;
>> -
>> -        pd_gpu {
>> -            reg = <RK3288_PD_GPU>;
>> -            clocks = <&cru ACLK_GPU>;
>> -        };
>> -
>> -        pd_hevc {
>> -            reg = <RK3288_PD_HEVC>;
>> -            clocks = <&cru ACLK_HEVC>,
>> -                 <&cru SCLK_HEVC_CABAC>,
>> -                 <&cru SCLK_HEVC_CORE>,
>> -                 <&cru HCLK_HEVC>;
>> -        };
>> -
>> -        pd_vio {
>> -            reg = <RK3288_PD_VIO>;
>> -            clocks = <&cru ACLK_IEP>,
>> -                 <&cru ACLK_ISP>,
>> -                 <&cru ACLK_RGA>,
>> -                 <&cru ACLK_VIP>,
>> -                 <&cru ACLK_VOP0>,
>> -                 <&cru ACLK_VOP1>,
>> -                 <&cru DCLK_VOP0>,
>> -                 <&cru DCLK_VOP1>,
>> -                 <&cru HCLK_IEP>,
>> -                 <&cru HCLK_ISP>,
>> -                 <&cru HCLK_RGA>,
>> -                 <&cru HCLK_VIP>,
>> -                 <&cru HCLK_VOP0>,
>> -                 <&cru HCLK_VOP1>,
>> -                 <&cru PCLK_EDP_CTRL>,
>> -                 <&cru PCLK_HDMI_CTRL>,
>> -                 <&cru PCLK_LVDS_PHY>,
>> -                 <&cru PCLK_MIPI_CSI>,
>> -                 <&cru PCLK_MIPI_DSI0>,
>> -                 <&cru PCLK_MIPI_DSI1>,
>> -                 <&cru SCLK_EDP_24M>,
>> -                 <&cru SCLK_EDP>,
>> -                 <&cru SCLK_HDMI_CEC>,
>> -                 <&cru SCLK_HDMI_HDCP>,
>> -                 <&cru SCLK_ISP_JPE>,
>> -                 <&cru SCLK_ISP>,
>> -                 <&cru SCLK_RGA>;
>> -        };
>> -
>> -        pd_video {
>> -            reg = <RK3288_PD_VIDEO>;
>> -            clocks = <&cru ACLK_VCODEC>,
>> -                 <&cru HCLK_VCODEC>;
>> -        };
>> -    };
>>   };


More information about the U-Boot mailing list