]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
arm: dts: Import HI3660 devicetree from Linux
authorManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Fri, 2 Aug 2019 15:10:07 +0000 (20:40 +0530)
committerTom Rini <trini@konsulko.com>
Sun, 11 Aug 2019 20:43:41 +0000 (16:43 -0400)
This commit imports HI3660 SoC devicetree from Linux

Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
arch/arm/dts/hi3660.dtsi [new file with mode: 0644]
arch/arm/dts/hikey960-pinctrl.dtsi [new file with mode: 0644]
include/dt-bindings/clock/hi3660-clock.h [new file with mode: 0644]

diff --git a/arch/arm/dts/hi3660.dtsi b/arch/arm/dts/hi3660.dtsi
new file mode 100644 (file)
index 0000000..65a45b0
--- /dev/null
@@ -0,0 +1,1157 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * dts file for Hisilicon Hi3660 SoC
+ *
+ * Copyright (C) 2016, Hisilicon Ltd.
+ */
+
+#include <dt-bindings/interrupt-controller/arm-gic.h>
+#include <dt-bindings/clock/hi3660-clock.h>
+#include <dt-bindings/thermal/thermal.h>
+
+/ {
+       compatible = "hisilicon,hi3660";
+       interrupt-parent = <&gic>;
+       #address-cells = <2>;
+       #size-cells = <2>;
+
+       psci {
+               compatible = "arm,psci-0.2";
+               method = "smc";
+       };
+
+       cpus {
+               #address-cells = <2>;
+               #size-cells = <0>;
+
+               cpu-map {
+                       cluster0 {
+                               core0 {
+                                       cpu = <&cpu0>;
+                               };
+                               core1 {
+                                       cpu = <&cpu1>;
+                               };
+                               core2 {
+                                       cpu = <&cpu2>;
+                               };
+                               core3 {
+                                       cpu = <&cpu3>;
+                               };
+                       };
+                       cluster1 {
+                               core0 {
+                                       cpu = <&cpu4>;
+                               };
+                               core1 {
+                                       cpu = <&cpu5>;
+                               };
+                               core2 {
+                                       cpu = <&cpu6>;
+                               };
+                               core3 {
+                                       cpu = <&cpu7>;
+                               };
+                       };
+               };
+
+               cpu0: cpu@0 {
+                       compatible = "arm,cortex-a53";
+                       device_type = "cpu";
+                       reg = <0x0 0x0>;
+                       enable-method = "psci";
+                       next-level-cache = <&A53_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
+                       capacity-dmips-mhz = <592>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER0>;
+                       operating-points-v2 = <&cluster0_opp>;
+                       #cooling-cells = <2>;
+                       dynamic-power-coefficient = <110>;
+               };
+
+               cpu1: cpu@1 {
+                       compatible = "arm,cortex-a53";
+                       device_type = "cpu";
+                       reg = <0x0 0x1>;
+                       enable-method = "psci";
+                       next-level-cache = <&A53_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
+                       capacity-dmips-mhz = <592>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER0>;
+                       operating-points-v2 = <&cluster0_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               cpu2: cpu@2 {
+                       compatible = "arm,cortex-a53";
+                       device_type = "cpu";
+                       reg = <0x0 0x2>;
+                       enable-method = "psci";
+                       next-level-cache = <&A53_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
+                       capacity-dmips-mhz = <592>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER0>;
+                       operating-points-v2 = <&cluster0_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               cpu3: cpu@3 {
+                       compatible = "arm,cortex-a53";
+                       device_type = "cpu";
+                       reg = <0x0 0x3>;
+                       enable-method = "psci";
+                       next-level-cache = <&A53_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
+                       capacity-dmips-mhz = <592>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER0>;
+                       operating-points-v2 = <&cluster0_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               cpu4: cpu@100 {
+                       compatible = "arm,cortex-a73";
+                       device_type = "cpu";
+                       reg = <0x0 0x100>;
+                       enable-method = "psci";
+                       next-level-cache = <&A73_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_1 &CLUSTER_SLEEP_1>;
+                       capacity-dmips-mhz = <1024>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER1>;
+                       operating-points-v2 = <&cluster1_opp>;
+                       #cooling-cells = <2>;
+                       dynamic-power-coefficient = <550>;
+               };
+
+               cpu5: cpu@101 {
+                       compatible = "arm,cortex-a73";
+                       device_type = "cpu";
+                       reg = <0x0 0x101>;
+                       enable-method = "psci";
+                       next-level-cache = <&A73_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_1 &CLUSTER_SLEEP_1>;
+                       capacity-dmips-mhz = <1024>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER1>;
+                       operating-points-v2 = <&cluster1_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               cpu6: cpu@102 {
+                       compatible = "arm,cortex-a73";
+                       device_type = "cpu";
+                       reg = <0x0 0x102>;
+                       enable-method = "psci";
+                       next-level-cache = <&A73_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_1 &CLUSTER_SLEEP_1>;
+                       capacity-dmips-mhz = <1024>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER1>;
+                       operating-points-v2 = <&cluster1_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               cpu7: cpu@103 {
+                       compatible = "arm,cortex-a73";
+                       device_type = "cpu";
+                       reg = <0x0 0x103>;
+                       enable-method = "psci";
+                       next-level-cache = <&A73_L2>;
+                       cpu-idle-states = <&CPU_SLEEP_1 &CLUSTER_SLEEP_1>;
+                       capacity-dmips-mhz = <1024>;
+                       clocks = <&stub_clock HI3660_CLK_STUB_CLUSTER1>;
+                       operating-points-v2 = <&cluster1_opp>;
+                       #cooling-cells = <2>;
+               };
+
+               idle-states {
+                       entry-method = "psci";
+
+                       CPU_SLEEP_0: cpu-sleep-0 {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x0010000>;
+                               entry-latency-us = <400>;
+                               exit-latency-us = <650>;
+                               min-residency-us = <1500>;
+                       };
+                       CLUSTER_SLEEP_0: cluster-sleep-0 {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x1010000>;
+                               entry-latency-us = <500>;
+                               exit-latency-us = <1600>;
+                               min-residency-us = <3500>;
+                       };
+
+
+                       CPU_SLEEP_1: cpu-sleep-1 {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x0010000>;
+                               entry-latency-us = <400>;
+                               exit-latency-us = <550>;
+                               min-residency-us = <1500>;
+                       };
+
+                       CLUSTER_SLEEP_1: cluster-sleep-1 {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x1010000>;
+                               entry-latency-us = <800>;
+                               exit-latency-us = <2900>;
+                               min-residency-us = <3500>;
+                       };
+               };
+
+               A53_L2: l2-cache0 {
+                       compatible = "cache";
+               };
+
+               A73_L2: l2-cache1 {
+                       compatible = "cache";
+               };
+       };
+
+       cluster0_opp: opp_table0 {
+               compatible = "operating-points-v2";
+               opp-shared;
+
+               opp00 {
+                       opp-hz = /bits/ 64 <533000000>;
+                       opp-microvolt = <700000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp01 {
+                       opp-hz = /bits/ 64 <999000000>;
+                       opp-microvolt = <800000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp02 {
+                       opp-hz = /bits/ 64 <1402000000>;
+                       opp-microvolt = <900000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp03 {
+                       opp-hz = /bits/ 64 <1709000000>;
+                       opp-microvolt = <1000000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp04 {
+                       opp-hz = /bits/ 64 <1844000000>;
+                       opp-microvolt = <1100000>;
+                       clock-latency-ns = <300000>;
+               };
+       };
+
+       cluster1_opp: opp_table1 {
+               compatible = "operating-points-v2";
+               opp-shared;
+
+               opp10 {
+                       opp-hz = /bits/ 64 <903000000>;
+                       opp-microvolt = <700000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp11 {
+                       opp-hz = /bits/ 64 <1421000000>;
+                       opp-microvolt = <800000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp12 {
+                       opp-hz = /bits/ 64 <1805000000>;
+                       opp-microvolt = <900000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp13 {
+                       opp-hz = /bits/ 64 <2112000000>;
+                       opp-microvolt = <1000000>;
+                       clock-latency-ns = <300000>;
+               };
+
+               opp14 {
+                       opp-hz = /bits/ 64 <2362000000>;
+                       opp-microvolt = <1100000>;
+                       clock-latency-ns = <300000>;
+               };
+       };
+
+       gic: interrupt-controller@e82b0000 {
+               compatible = "arm,gic-400";
+               reg = <0x0 0xe82b1000 0 0x1000>, /* GICD */
+                     <0x0 0xe82b2000 0 0x2000>, /* GICC */
+                     <0x0 0xe82b4000 0 0x2000>, /* GICH */
+                     <0x0 0xe82b6000 0 0x2000>; /* GICV */
+               #address-cells = <0>;
+               #interrupt-cells = <3>;
+               interrupt-controller;
+               interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(8) |
+                                        IRQ_TYPE_LEVEL_HIGH)>;
+       };
+
+       a53-pmu {
+               compatible = "arm,cortex-a53-pmu";
+               interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
+               interrupt-affinity = <&cpu0>,
+                                    <&cpu1>,
+                                    <&cpu2>,
+                                    <&cpu3>;
+       };
+
+       a73-pmu {
+               compatible = "arm,cortex-a73-pmu";
+               interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>,
+                            <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
+               interrupt-affinity = <&cpu4>,
+                                    <&cpu5>,
+                                    <&cpu6>,
+                                    <&cpu7>;
+       };
+
+       timer {
+               compatible = "arm,armv8-timer";
+               interrupt-parent = <&gic>;
+               interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(8) |
+                                         IRQ_TYPE_LEVEL_LOW)>,
+                            <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(8) |
+                                         IRQ_TYPE_LEVEL_LOW)>,
+                            <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(8) |
+                                         IRQ_TYPE_LEVEL_LOW)>,
+                            <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(8) |
+                                         IRQ_TYPE_LEVEL_LOW)>;
+       };
+
+       soc {
+               compatible = "simple-bus";
+               #address-cells = <2>;
+               #size-cells = <2>;
+               ranges;
+
+               crg_ctrl: crg_ctrl@fff35000 {
+                       compatible = "hisilicon,hi3660-crgctrl", "syscon";
+                       reg = <0x0 0xfff35000 0x0 0x1000>;
+                       #clock-cells = <1>;
+               };
+
+               crg_rst: crg_rst_controller {
+                       compatible = "hisilicon,hi3660-reset";
+                       #reset-cells = <2>;
+                       hisi,rst-syscon = <&crg_ctrl>;
+               };
+
+
+               pctrl: pctrl@e8a09000 {
+                       compatible = "hisilicon,hi3660-pctrl", "syscon";
+                       reg = <0x0 0xe8a09000 0x0 0x2000>;
+                       #clock-cells = <1>;
+               };
+
+               pmuctrl: crg_ctrl@fff34000 {
+                       compatible = "hisilicon,hi3660-pmuctrl", "syscon";
+                       reg = <0x0 0xfff34000 0x0 0x1000>;
+                       #clock-cells = <1>;
+               };
+
+               sctrl: sctrl@fff0a000 {
+                       compatible = "hisilicon,hi3660-sctrl", "syscon";
+                       reg = <0x0 0xfff0a000 0x0 0x1000>;
+                       #clock-cells = <1>;
+               };
+
+               iomcu: iomcu@ffd7e000 {
+                       compatible = "hisilicon,hi3660-iomcu", "syscon";
+                       reg = <0x0 0xffd7e000 0x0 0x1000>;
+                       #clock-cells = <1>;
+
+               };
+
+               iomcu_rst: reset {
+                       compatible = "hisilicon,hi3660-reset";
+                       hisi,rst-syscon = <&iomcu>;
+                       #reset-cells = <2>;
+               };
+
+               mailbox: mailbox@e896b000 {
+                       compatible = "hisilicon,hi3660-mbox";
+                       reg = <0x0 0xe896b000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>,
+                                    <GIC_SPI 193 IRQ_TYPE_LEVEL_HIGH>;
+                       #mbox-cells = <3>;
+               };
+
+               stub_clock: stub_clock@e896b500 {
+                       compatible = "hisilicon,hi3660-stub-clk";
+                       reg = <0x0 0xe896b500 0x0 0x0100>;
+                       #clock-cells = <1>;
+                       mboxes = <&mailbox 13 3 0>;
+               };
+
+               dual_timer0: timer@fff14000 {
+                       compatible = "arm,sp804", "arm,primecell";
+                       reg = <0x0 0xfff14000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
+                                    <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_OSC32K>,
+                                <&crg_ctrl HI3660_OSC32K>,
+                                <&crg_ctrl HI3660_OSC32K>;
+                       clock-names = "timer1", "timer2", "apb_pclk";
+               };
+
+               i2c0: i2c@ffd71000 {
+                       compatible = "snps,designware-i2c";
+                       reg = <0x0 0xffd71000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       clock-frequency = <400000>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_I2C0>;
+                       resets = <&iomcu_rst 0x20 3>;
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&i2c0_pmx_func &i2c0_cfg_func>;
+                       status = "disabled";
+               };
+
+               i2c1: i2c@ffd72000 {
+                       compatible = "snps,designware-i2c";
+                       reg = <0x0 0xffd72000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       clock-frequency = <400000>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_I2C1>;
+                       resets = <&iomcu_rst 0x20 4>;
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&i2c1_pmx_func &i2c1_cfg_func>;
+                       status = "disabled";
+               };
+
+               i2c3: i2c@fdf0c000 {
+                       compatible = "snps,designware-i2c";
+                       reg = <0x0 0xfdf0c000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       clock-frequency = <400000>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_I2C3>;
+                       resets = <&crg_rst 0x78 7>;
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&i2c3_pmx_func &i2c3_cfg_func>;
+                       status = "disabled";
+               };
+
+               i2c7: i2c@fdf0b000 {
+                       compatible = "snps,designware-i2c";
+                       reg = <0x0 0xfdf0b000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 314 IRQ_TYPE_LEVEL_HIGH>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       clock-frequency = <400000>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_I2C7>;
+                       resets = <&crg_rst 0x60 14>;
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&i2c7_pmx_func &i2c7_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart0: serial@fdf02000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfdf02000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_MUX_UART0>,
+                                <&crg_ctrl HI3660_PCLK>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart0_pmx_func &uart0_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart1: serial@fdf00000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfdf00000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
+                       dma-names = "rx", "tx";
+                       dmas =  <&dma0 2 &dma0 3>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_UART1>,
+                                <&crg_ctrl HI3660_CLK_GATE_UART1>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart1_pmx_func &uart1_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart2: serial@fdf03000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfdf03000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
+                       dma-names = "rx", "tx";
+                       dmas =  <&dma0 4 &dma0 5>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_UART2>,
+                                <&crg_ctrl HI3660_PCLK>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart2_pmx_func &uart2_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart3: serial@ffd74000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xffd74000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_FACTOR_UART3>,
+                                <&crg_ctrl HI3660_PCLK>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart3_pmx_func &uart3_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart4: serial@fdf01000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfdf01000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
+                       dma-names = "rx", "tx";
+                       dmas =  <&dma0 6 &dma0 7>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_UART4>,
+                                <&crg_ctrl HI3660_CLK_GATE_UART4>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart4_pmx_func &uart4_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart5: serial@fdf05000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfdf05000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
+                       dma-names = "rx", "tx";
+                       dmas =  <&dma0 8 &dma0 9>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_UART5>,
+                                <&crg_ctrl HI3660_CLK_GATE_UART5>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart5_pmx_func &uart5_cfg_func>;
+                       status = "disabled";
+               };
+
+               uart6: serial@fff32000 {
+                       compatible = "arm,pl011", "arm,primecell";
+                       reg = <0x0 0xfff32000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
+                       clock = <19200000>;
+                       clocks = <&crg_ctrl HI3660_CLK_UART6>,
+                                <&crg_ctrl HI3660_PCLK>;
+                       clock-names = "uartclk", "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&uart6_pmx_func &uart6_cfg_func>;
+                       status = "disabled";
+               };
+
+               dma0: dma@fdf30000 {
+                       compatible = "hisilicon,k3-dma-1.0";
+                       reg = <0x0 0xfdf30000 0x0 0x1000>;
+                       #dma-cells = <1>;
+                       dma-channels = <16>;
+                       dma-requests = <32>;
+                       dma-channel-mask = <0xfffe>;
+                       interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_DMAC>;
+                       dma-no-cci;
+                       dma-type = "hi3660_dma";
+               };
+
+               asp_dmac: dma-controller@e804b000 {
+                       compatible = "hisilicon,hisi-pcm-asp-dma-1.0";
+                       reg = <0x0 0xe804b000 0x0 0x1000>;
+                       #dma-cells = <1>;
+                       dma-channels = <16>;
+                       dma-requests = <32>;
+                       interrupts = <GIC_SPI 216 IRQ_TYPE_LEVEL_HIGH>;
+                       interrupt-names = "asp_dma_irq";
+               };
+
+               rtc0: rtc@fff04000 {
+                       compatible = "arm,pl031", "arm,primecell";
+                       reg = <0x0 0Xfff04000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_PCLK>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio0: gpio@e8a0b000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a0b000 0 0x1000>;
+                       interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 1 0 7>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO0>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio1: gpio@e8a0c000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a0c000 0 0x1000>;
+                       interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 1 7 7>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO1>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio2: gpio@e8a0d000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a0d000 0 0x1000>;
+                       interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 14 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO2>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio3: gpio@e8a0e000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a0e000 0 0x1000>;
+                       interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 22 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO3>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio4: gpio@e8a0f000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a0f000 0 0x1000>;
+                       interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 30 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO4>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio5: gpio@e8a10000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a10000 0 0x1000>;
+                       interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 38 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO5>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio6: gpio@e8a11000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a11000 0 0x1000>;
+                       interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 46 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO6>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio7: gpio@e8a12000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a12000 0 0x1000>;
+                       interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 54 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO7>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio8: gpio@e8a13000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a13000 0 0x1000>;
+                       interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 62 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO8>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio9: gpio@e8a14000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a14000 0 0x1000>;
+                       interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 70 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO9>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio10: gpio@e8a15000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a15000 0 0x1000>;
+                       interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 78 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO10>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio11: gpio@e8a16000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a16000 0 0x1000>;
+                       interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 86 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO11>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio12: gpio@e8a17000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a17000 0 0x1000>;
+                       interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 94 3 &pmx0 7 101 1>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO12>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio13: gpio@e8a18000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a18000 0 0x1000>;
+                       interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 102 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO13>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio14: gpio@e8a19000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a19000 0 0x1000>;
+                       interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 110 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO14>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio15: gpio@e8a1a000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a1a000 0 0x1000>;
+                       interrupts = <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx0 0 118 6>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO15>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio16: gpio@e8a1b000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a1b000 0 0x1000>;
+                       interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO16>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio17: gpio@e8a1c000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a1c000 0 0x1000>;
+                       interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO17>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio18: gpio@ff3b4000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xff3b4000 0 0x1000>;
+                       interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx2 0 0 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO18>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio19: gpio@ff3b5000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xff3b5000 0 0x1000>;
+                       interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx2 0 8 4>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO19>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio20: gpio@e8a1f000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a1f000 0 0x1000>;
+                       interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       gpio-ranges = <&pmx1 0 0 6>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO20>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio21: gpio@e8a20000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xe8a20000 0 0x1000>;
+                       interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       gpio-ranges = <&pmx3 0 0 6>;
+                       clocks = <&crg_ctrl HI3660_PCLK_GPIO21>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio22: gpio@fff0b000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff0b000 0 0x1000>;
+                       interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO176 */
+                       gpio-ranges = <&pmx4 2 0 6>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO0>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio23: gpio@fff0c000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff0c000 0 0x1000>;
+                       interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO184 */
+                       gpio-ranges = <&pmx4 0 6 7>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO1>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio24: gpio@fff0d000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff0d000 0 0x1000>;
+                       interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO192 */
+                       gpio-ranges = <&pmx4 0 13 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO2>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio25: gpio@fff0e000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff0e000 0 0x1000>;
+                       interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO200 */
+                       gpio-ranges = <&pmx4 0 21 4 &pmx4 5 25 3>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO3>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio26: gpio@fff0f000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff0f000 0 0x1000>;
+                       interrupts = <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO208 */
+                       gpio-ranges = <&pmx4 0 28 8>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO4>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio27: gpio@fff10000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff10000 0 0x1000>;
+                       interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       /* GPIO216 */
+                       gpio-ranges = <&pmx4 0 36 6>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO5>;
+                       clock-names = "apb_pclk";
+               };
+
+               gpio28: gpio@fff1d000 {
+                       compatible = "arm,pl061", "arm,primecell";
+                       reg = <0 0xfff1d000 0 0x1000>;
+                       interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
+                       gpio-controller;
+                       #gpio-cells = <2>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       clocks = <&sctrl HI3660_PCLK_AO_GPIO6>;
+                       clock-names = "apb_pclk";
+               };
+
+               spi2: spi@ffd68000 {
+                       compatible = "arm,pl022", "arm,primecell";
+                       reg = <0x0 0xffd68000 0x0 0x1000>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       interrupts = <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_SPI2>;
+                       clock-names = "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&spi2_pmx_func>;
+                       num-cs = <1>;
+                       cs-gpios = <&gpio27 2 0>;
+                       status = "disabled";
+               };
+
+               spi3: spi@ff3b3000 {
+                       compatible = "arm,pl022", "arm,primecell";
+                       reg = <0x0 0xff3b3000 0x0 0x1000>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       interrupts = <GIC_SPI 312 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_SPI3>;
+                       clock-names = "apb_pclk";
+                       pinctrl-names = "default";
+                       pinctrl-0 = <&spi3_pmx_func>;
+                       num-cs = <1>;
+                       cs-gpios = <&gpio18 5 0>;
+                       status = "disabled";
+               };
+
+               pcie@f4000000 {
+                       compatible = "hisilicon,kirin960-pcie";
+                       reg = <0x0 0xf4000000 0x0 0x1000>,
+                             <0x0 0xff3fe000 0x0 0x1000>,
+                             <0x0 0xf3f20000 0x0 0x40000>,
+                             <0x0 0xf5000000 0x0 0x2000>;
+                       reg-names = "dbi", "apb", "phy", "config";
+                       bus-range = <0x0  0x1>;
+                       #address-cells = <3>;
+                       #size-cells = <2>;
+                       device_type = "pci";
+                       ranges = <0x02000000 0x0 0x00000000
+                                 0x0 0xf6000000
+                                 0x0 0x02000000>;
+                       num-lanes = <1>;
+                       #interrupt-cells = <1>;
+                       interrupts = <0 283 4>;
+                       interrupt-names = "msi";
+                       interrupt-map-mask = <0xf800 0 0 7>;
+                       interrupt-map = <0x0 0 0 1
+                                        &gic GIC_SPI 282 IRQ_TYPE_LEVEL_HIGH>,
+                                       <0x0 0 0 2
+                                        &gic GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>,
+                                       <0x0 0 0 3
+                                        &gic GIC_SPI 284 IRQ_TYPE_LEVEL_HIGH>,
+                                       <0x0 0 0 4
+                                        &gic GIC_SPI 285 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_PCIEPHY_REF>,
+                                <&crg_ctrl HI3660_CLK_GATE_PCIEAUX>,
+                                <&crg_ctrl HI3660_PCLK_GATE_PCIE_PHY>,
+                                <&crg_ctrl HI3660_PCLK_GATE_PCIE_SYS>,
+                                <&crg_ctrl HI3660_ACLK_GATE_PCIE>;
+                       clock-names = "pcie_phy_ref", "pcie_aux",
+                                     "pcie_apb_phy", "pcie_apb_sys",
+                                     "pcie_aclk";
+                       reset-gpios = <&gpio11 1 0 >;
+               };
+
+               /* UFS */
+               ufs: ufs@ff3b0000 {
+                       compatible = "hisilicon,hi3660-ufs", "jedec,ufs-1.1";
+                       /* 0: HCI standard */
+                       /* 1: UFS SYS CTRL */
+                       reg = <0x0 0xff3b0000 0x0 0x1000>,
+                               <0x0 0xff3b1000 0x0 0x1000>;
+                       interrupt-parent = <&gic>;
+                       interrupts = <GIC_SPI 278 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_UFSIO_REF>,
+                               <&crg_ctrl HI3660_CLK_GATE_UFSPHY_CFG>;
+                       clock-names = "ref_clk", "phy_clk";
+                       freq-table-hz = <0 0>, <0 0>;
+                       /* offset: 0x84; bit: 12 */
+                       resets = <&crg_rst 0x84 12>;
+                       reset-names = "rst";
+               };
+
+               /* SD */
+               dwmmc1: dwmmc1@ff37f000 {
+                       compatible = "hisilicon,hi3660-dw-mshc";
+                       reg = <0x0 0xff37f000 0x0 0x1000>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_SD>,
+                               <&crg_ctrl HI3660_HCLK_GATE_SD>;
+                       clock-names = "ciu", "biu";
+                       clock-frequency = <3200000>;
+                       resets = <&crg_rst 0x94 18>;
+                       reset-names = "reset";
+                       hisilicon,peripheral-syscon = <&sctrl>;
+                       card-detect-delay = <200>;
+                       status = "disabled";
+               };
+
+               /* SDIO */
+               dwmmc2: dwmmc2@ff3ff000 {
+                       compatible = "hisilicon,hi3660-dw-mshc";
+                       reg = <0x0 0xff3ff000 0x0 0x1000>;
+                       #address-cells = <0x1>;
+                       #size-cells = <0x0>;
+                       interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_CLK_GATE_SDIO0>,
+                                <&crg_ctrl HI3660_HCLK_GATE_SDIO0>;
+                       clock-names = "ciu", "biu";
+                       resets = <&crg_rst 0x94 20>;
+                       reset-names = "reset";
+                       card-detect-delay = <200>;
+                       status = "disabled";
+               };
+
+               watchdog0: watchdog@e8a06000 {
+                       compatible = "arm,sp805-wdt", "arm,primecell";
+                       reg = <0x0 0xe8a06000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_OSC32K>;
+                       clock-names = "apb_pclk";
+               };
+
+               watchdog1: watchdog@e8a07000 {
+                       compatible = "arm,sp805-wdt", "arm,primecell";
+                       reg = <0x0 0xe8a07000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
+                       clocks = <&crg_ctrl HI3660_OSC32K>;
+                       clock-names = "apb_pclk";
+               };
+
+               tsensor: tsensor@fff30000 {
+                       compatible = "hisilicon,hi3660-tsensor";
+                       reg = <0x0 0xfff30000 0x0 0x1000>;
+                       interrupts = <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>;
+                       #thermal-sensor-cells = <1>;
+               };
+
+               thermal-zones {
+
+                       cls0: cls0 {
+                               polling-delay = <1000>;
+                               polling-delay-passive = <100>;
+                               sustainable-power = <4500>;
+
+                               /* sensor ID */
+                               thermal-sensors = <&tsensor 1>;
+
+                               trips {
+                                       threshold: trip-point@0 {
+                                               temperature = <65000>;
+                                               hysteresis = <1000>;
+                                               type = "passive";
+                                       };
+
+                                       target: trip-point@1 {
+                                               temperature = <75000>;
+                                               hysteresis = <1000>;
+                                               type = "passive";
+                                       };
+                               };
+
+                               cooling-maps {
+                                       map0 {
+                                               trip = <&target>;
+                                               contribution = <1024>;
+                                               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>;
+                                       };
+                                       map1 {
+                                               trip = <&target>;
+                                               contribution = <512>;
+                                               cooling-device = <&cpu4 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
+                                                                <&cpu5 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
+                                                                <&cpu6 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
+                                                                <&cpu7 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
+                                       };
+                               };
+                       };
+               };
+       };
+};
diff --git a/arch/arm/dts/hikey960-pinctrl.dtsi b/arch/arm/dts/hikey960-pinctrl.dtsi
new file mode 100644 (file)
index 0000000..d11efc8
--- /dev/null
@@ -0,0 +1,1060 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * pinctrl dts fils for Hislicon HiKey960 development board
+ *
+ */
+
+#include <dt-bindings/pinctrl/hisi.h>
+
+/ {
+       soc {
+               /* [IOMG_000, IOMG_123] */
+               range: gpio-range {
+                       #pinctrl-single,gpio-range-cells = <3>;
+               };
+
+               pmx0: pinmux@e896c000 {
+                       compatible = "pinctrl-single";
+                       reg = <0x0 0xe896c000 0x0 0x1f0>;
+                       #pinctrl-cells = <1>;
+                       #gpio-range-cells = <0x3>;
+                       pinctrl-single,register-width = <0x20>;
+                       pinctrl-single,function-mask = <0x7>;
+                       /* pin base, nr pins & gpio function */
+                       pinctrl-single,gpio-range = <
+                               &range 0 7 0
+                               &range 8 116 0>;
+
+                       pmu_pmx_func: pmu_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x008 MUX_M1 /* PMU1_SSI */
+                                       0x00c MUX_M1 /* PMU2_SSI */
+                                       0x010 MUX_M1 /* PMU_CLKOUT */
+                                       0x100 MUX_M1 /* PMU_HKADC_SSI */
+                               >;
+                       };
+
+                       csi0_pwd_n_pmx_func: csi0_pwd_n_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x044 MUX_M0 /* CSI0_PWD_N */
+                               >;
+                       };
+
+                       csi1_pwd_n_pmx_func: csi1_pwd_n_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x04c MUX_M0 /* CSI1_PWD_N */
+                               >;
+                       };
+
+                       isp0_pmx_func: isp0_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x058 MUX_M1 /* ISP_CLK0 */
+                                       0x064 MUX_M1 /* ISP_SCL0 */
+                                       0x068 MUX_M1 /* ISP_SDA0 */
+                               >;
+                       };
+
+                       isp1_pmx_func: isp1_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x05c MUX_M1 /* ISP_CLK1 */
+                                       0x06c MUX_M1 /* ISP_SCL1 */
+                                       0x070 MUX_M1 /* ISP_SDA1 */
+                               >;
+                       };
+
+                       pwr_key_pmx_func: pwr_key_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x080 MUX_M0 /* GPIO_034 */
+                               >;
+                       };
+
+                       i2c3_pmx_func: i2c3_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x02c MUX_M1 /* I2C3_SCL */
+                                       0x030 MUX_M1 /* I2C3_SDA */
+                               >;
+                       };
+
+                       i2c4_pmx_func: i2c4_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x090 MUX_M1 /* I2C4_SCL */
+                                       0x094 MUX_M1 /* I2C4_SDA */
+                               >;
+                       };
+
+                       pcie_perstn_pmx_func: pcie_perstn_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x15c MUX_M1 /* PCIE_PERST_N */
+                               >;
+                       };
+
+                       usbhub5734_pmx_func: usbhub5734_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x11c MUX_M0 /* GPIO_073 */
+                                       0x120 MUX_M0 /* GPIO_074 */
+                               >;
+                       };
+
+                       uart0_pmx_func: uart0_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0cc MUX_M2 /* UART0_RXD */
+                                       0x0d0 MUX_M2 /* UART0_TXD */
+                               >;
+                       };
+
+                       uart1_pmx_func: uart1_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0b0 MUX_M2 /* UART1_CTS_N */
+                                       0x0b4 MUX_M2 /* UART1_RTS_N */
+                                       0x0a8 MUX_M2 /* UART1_RXD */
+                                       0x0ac MUX_M2 /* UART1_TXD */
+                               >;
+                       };
+
+                       uart2_pmx_func: uart2_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0bc MUX_M2 /* UART2_CTS_N */
+                                       0x0c0 MUX_M2 /* UART2_RTS_N */
+                                       0x0c8 MUX_M2 /* UART2_RXD */
+                                       0x0c4 MUX_M2 /* UART2_TXD */
+                               >;
+                       };
+
+                       uart3_pmx_func: uart3_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0dc MUX_M1 /* UART3_CTS_N */
+                                       0x0e0 MUX_M1 /* UART3_RTS_N */
+                                       0x0e4 MUX_M1 /* UART3_RXD */
+                                       0x0e8 MUX_M1 /* UART3_TXD */
+                               >;
+                       };
+
+                       uart4_pmx_func: uart4_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0ec MUX_M1 /* UART4_CTS_N */
+                                       0x0f0 MUX_M1 /* UART4_RTS_N */
+                                       0x0f4 MUX_M1 /* UART4_RXD */
+                                       0x0f8 MUX_M1 /* UART4_TXD */
+                               >;
+                       };
+
+                       uart5_pmx_func: uart5_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0c4 MUX_M3 /* UART5_CTS_N */
+                                       0x0c8 MUX_M3 /* UART5_RTS_N */
+                                       0x0bc MUX_M3 /* UART5_RXD */
+                                       0x0c0 MUX_M3 /* UART5_TXD */
+                               >;
+                       };
+
+                       uart6_pmx_func: uart6_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0cc MUX_M1 /* UART6_CTS_N */
+                                       0x0d0 MUX_M1 /* UART6_RTS_N */
+                                       0x0d4 MUX_M1 /* UART6_RXD */
+                                       0x0d8 MUX_M1 /* UART6_TXD */
+                               >;
+                       };
+
+                       cam0_rst_pmx_func: cam0_rst_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x0c8 MUX_M0 /* CAM0_RST */
+                               >;
+                       };
+
+                       cam1_rst_pmx_func: cam1_rst_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x124 MUX_M0 /* CAM1_RST */
+                               >;
+                       };
+               };
+
+               /* [IOMG_MMC0_000, IOMG_MMC0_005] */
+               pmx1: pinmux@ff37e000 {
+                       compatible = "pinctrl-single";
+                       reg = <0x0 0xff37e000 0x0 0x18>;
+                       #gpio-range-cells = <0x3>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+                       pinctrl-single,function-mask = <0x7>;
+                       /* pin base, nr pins & gpio function */
+                       pinctrl-single,gpio-range = <&range 0 6 0>;
+
+                       sd_pmx_func: sd_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x000 MUX_M1 /* SD_CLK */
+                                       0x004 MUX_M1 /* SD_CMD */
+                                       0x008 MUX_M1 /* SD_DATA0 */
+                                       0x00c MUX_M1 /* SD_DATA1 */
+                                       0x010 MUX_M1 /* SD_DATA2 */
+                                       0x014 MUX_M1 /* SD_DATA3 */
+                               >;
+                       };
+               };
+
+               /* [IOMG_FIX_000, IOMG_FIX_011] */
+               pmx2: pinmux@ff3b6000 {
+                       compatible = "pinctrl-single";
+                       reg = <0x0 0xff3b6000 0x0 0x30>;
+                       #pinctrl-cells = <1>;
+                       #gpio-range-cells = <0x3>;
+                       pinctrl-single,register-width = <0x20>;
+                       pinctrl-single,function-mask = <0x7>;
+                       /* pin base, nr pins & gpio function */
+                       pinctrl-single,gpio-range = <&range 0 12 0>;
+
+                       ufs_pmx_func: ufs_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x000 MUX_M1 /* UFS_REF_CLK */
+                                       0x004 MUX_M1 /* UFS_RST_N */
+                               >;
+                       };
+
+                       spi3_pmx_func: spi3_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x008 MUX_M1 /* SPI3_CLK */
+                                       0x00c MUX_M1 /* SPI3_DI */
+                                       0x010 MUX_M1 /* SPI3_DO */
+                                       0x014 MUX_M1 /* SPI3_CS0_N */
+                               >;
+                       };
+               };
+
+               /* [IOMG_MMC1_000, IOMG_MMC1_005] */
+               pmx3: pinmux@ff3fd000 {
+                       compatible = "pinctrl-single";
+                       reg = <0x0 0xff3fd000 0x0 0x18>;
+                       #pinctrl-cells = <1>;
+                       #gpio-range-cells = <0x3>;
+                       pinctrl-single,register-width = <0x20>;
+                       pinctrl-single,function-mask = <0x7>;
+                       /* pin base, nr pins & gpio function */
+                       pinctrl-single,gpio-range = <&range 0 6 0>;
+
+                       sdio_pmx_func: sdio_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x000 MUX_M1 /* SDIO_CLK */
+                                       0x004 MUX_M1 /* SDIO_CMD */
+                                       0x008 MUX_M1 /* SDIO_DATA0 */
+                                       0x00c MUX_M1 /* SDIO_DATA1 */
+                                       0x010 MUX_M1 /* SDIO_DATA2 */
+                                       0x014 MUX_M1 /* SDIO_DATA3 */
+                               >;
+                       };
+               };
+
+               /* [IOMG_AO_000, IOMG_AO_041] */
+               pmx4: pinmux@fff11000 {
+                       compatible = "pinctrl-single";
+                       reg = <0x0 0xfff11000 0x0 0xa8>;
+                       #pinctrl-cells = <1>;
+                       #gpio-range-cells = <0x3>;
+                       pinctrl-single,register-width = <0x20>;
+                       pinctrl-single,function-mask = <0x7>;
+                       /* pin base in node, nr pins & gpio function */
+                       pinctrl-single,gpio-range = <&range 0 42 0>;
+
+                       i2s2_pmx_func: i2s2_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x044 MUX_M1 /* I2S2_DI */
+                                       0x048 MUX_M1 /* I2S2_DO */
+                                       0x04c MUX_M1 /* I2S2_XCLK */
+                                       0x050 MUX_M1 /* I2S2_XFS */
+                               >;
+                       };
+
+                       slimbus_pmx_func: slimbus_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x02c MUX_M1 /* SLIMBUS_CLK */
+                                       0x030 MUX_M1 /* SLIMBUS_DATA */
+                               >;
+                       };
+
+                       i2c0_pmx_func: i2c0_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x014 MUX_M1 /* I2C0_SCL */
+                                       0x018 MUX_M1 /* I2C0_SDA */
+                               >;
+                       };
+
+                       i2c1_pmx_func: i2c1_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x01c MUX_M1 /* I2C1_SCL */
+                                       0x020 MUX_M1 /* I2C1_SDA */
+                               >;
+                       };
+
+                       i2c7_pmx_func: i2c7_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x024 MUX_M3 /* I2C7_SCL */
+                                       0x028 MUX_M3 /* I2C7_SDA */
+                               >;
+                       };
+
+                       pcie_pmx_func: pcie_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x084 MUX_M1 /* PCIE_CLKREQ_N */
+                                       0x088 MUX_M1 /* PCIE_WAKE_N */
+                               >;
+                       };
+
+                       spi2_pmx_func: spi2_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x08c MUX_M1 /* SPI2_CLK */
+                                       0x090 MUX_M1 /* SPI2_DI */
+                                       0x094 MUX_M1 /* SPI2_DO */
+                                       0x098 MUX_M1 /* SPI2_CS0_N */
+                               >;
+                       };
+
+                       i2s0_pmx_func: i2s0_pmx_func {
+                               pinctrl-single,pins = <
+                                       0x034 MUX_M1 /* I2S0_DI */
+                                       0x038 MUX_M1 /* I2S0_DO */
+                                       0x03c MUX_M1 /* I2S0_XCLK */
+                                       0x040 MUX_M1 /* I2S0_XFS */
+                               >;
+                       };
+               };
+
+               pmx5: pinmux@e896c800 {
+                       compatible = "pinconf-single";
+                       reg = <0x0 0xe896c800 0x0 0x200>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+
+                       pmu_cfg_func: pmu_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x010 0x0 /* PMU1_SSI */
+                                       0x014 0x0 /* PMU2_SSI */
+                                       0x018 0x0 /* PMU_CLKOUT */
+                                       0x10c 0x0 /* PMU_HKADC_SSI */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_06MA DRIVE6_MASK
+                               >;
+                       };
+
+                       i2c3_cfg_func: i2c3_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x038 0x0 /* I2C3_SCL */
+                                       0x03c 0x0 /* I2C3_SDA */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       csi0_pwd_n_cfg_func: csi0_pwd_n_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x050 0x0 /* CSI0_PWD_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK
+                               >;
+                       };
+
+                       csi1_pwd_n_cfg_func: csi1_pwd_n_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x058 0x0 /* CSI1_PWD_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK
+                               >;
+                       };
+
+                       isp0_cfg_func: isp0_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x064 0x0 /* ISP_CLK0 */
+                                       0x070 0x0 /* ISP_SCL0 */
+                                       0x074 0x0 /* ISP_SDA0 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK>;
+                       };
+
+                       isp1_cfg_func: isp1_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x068 0x0 /* ISP_CLK1 */
+                                       0x078 0x0 /* ISP_SCL1 */
+                                       0x07c 0x0 /* ISP_SDA1 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK
+                               >;
+                       };
+
+                       pwr_key_cfg_func: pwr_key_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x08c 0x0 /* GPIO_034 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart1_cfg_func: uart1_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0b4 0x0 /* UART1_RXD */
+                                       0x0b8 0x0 /* UART1_TXD */
+                                       0x0bc 0x0 /* UART1_CTS_N */
+                                       0x0c0 0x0 /* UART1_RTS_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart2_cfg_func: uart2_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0c8 0x0 /* UART2_CTS_N */
+                                       0x0cc 0x0 /* UART2_RTS_N */
+                                       0x0d0 0x0 /* UART2_TXD */
+                                       0x0d4 0x0 /* UART2_RXD */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart5_cfg_func: uart5_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0c8 0x0 /* UART5_RXD */
+                                       0x0cc 0x0 /* UART5_TXD */
+                                       0x0d0 0x0 /* UART5_CTS_N */
+                                       0x0d4 0x0 /* UART5_RTS_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       cam0_rst_cfg_func: cam0_rst_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0d4 0x0 /* CAM0_RST */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart0_cfg_func: uart0_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0d8 0x0 /* UART0_RXD */
+                                       0x0dc 0x0 /* UART0_TXD */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart6_cfg_func: uart6_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0d8 0x0 /* UART6_CTS_N */
+                                       0x0dc 0x0 /* UART6_RTS_N */
+                                       0x0e0 0x0 /* UART6_RXD */
+                                       0x0e4 0x0 /* UART6_TXD */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart3_cfg_func: uart3_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0e8 0x0 /* UART3_CTS_N */
+                                       0x0ec 0x0 /* UART3_RTS_N */
+                                       0x0f0 0x0 /* UART3_RXD */
+                                       0x0f4 0x0 /* UART3_TXD */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       uart4_cfg_func: uart4_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0f8 0x0 /* UART4_CTS_N */
+                                       0x0fc 0x0 /* UART4_RTS_N */
+                                       0x100 0x0 /* UART4_RXD */
+                                       0x104 0x0 /* UART4_TXD */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       cam1_rst_cfg_func: cam1_rst_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x130 0x0 /* CAM1_RST */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_04MA DRIVE6_MASK
+                               >;
+                       };
+               };
+
+               pmx6: pinmux@ff3b6800 {
+                       compatible = "pinconf-single";
+                       reg = <0x0 0xff3b6800 0x0 0x18>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+
+                       ufs_cfg_func: ufs_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x000 0x0 /* UFS_REF_CLK */
+                                       0x004 0x0 /* UFS_RST_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_08MA DRIVE6_MASK
+                               >;
+                       };
+
+                       spi3_cfg_func: spi3_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x008 0x0 /* SPI3_CLK */
+                                       0x0 /* SPI3_DI */
+                                       0x010 0x0 /* SPI3_DO */
+                                       0x014 0x0 /* SPI3_CS0_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+               };
+
+               pmx7: pinmux@ff3fd800 {
+                       compatible = "pinconf-single";
+                       reg = <0x0 0xff3fd800 0x0 0x18>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+
+                       sdio_clk_cfg_func: sdio_clk_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x000 0x0 /* SDIO_CLK */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE6_32MA DRIVE6_MASK
+                               >;
+                       };
+
+                       sdio_cfg_func: sdio_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x004 0x0 /* SDIO_CMD */
+                                       0x008 0x0 /* SDIO_DATA0 */
+                                       0x00c 0x0 /* SDIO_DATA1 */
+                                       0x010 0x0 /* SDIO_DATA2 */
+                                       0x014 0x0 /* SDIO_DATA3 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE6_19MA DRIVE6_MASK
+                               >;
+                       };
+               };
+
+               pmx8: pinmux@ff37e800 {
+                       compatible = "pinconf-single";
+                       reg = <0x0 0xff37e800 0x0 0x18>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+
+                       sd_clk_cfg_func: sd_clk_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x000 0x0 /* SD_CLK */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_DIS
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE6_32MA
+                                       DRIVE6_MASK
+                               >;
+                       };
+
+                       sd_cfg_func: sd_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x004 0x0 /* SD_CMD */
+                                       0x008 0x0 /* SD_DATA0 */
+                                       0x00c 0x0 /* SD_DATA1 */
+                                       0x010 0x0 /* SD_DATA2 */
+                                       0x014 0x0 /* SD_DATA3 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE6_19MA
+                                       DRIVE6_MASK
+                               >;
+                       };
+               };
+
+               pmx9: pinmux@fff11800 {
+                       compatible = "pinconf-single";
+                       reg = <0x0 0xfff11800 0x0 0xbc>;
+                       #pinctrl-cells = <1>;
+                       pinctrl-single,register-width = <0x20>;
+
+                       i2c0_cfg_func: i2c0_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x01c 0x0 /* I2C0_SCL */
+                                       0x020 0x0 /* I2C0_SDA */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       i2c1_cfg_func: i2c1_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x024 0x0 /* I2C1_SCL */
+                                       0x028 0x0 /* I2C1_SDA */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       i2c7_cfg_func: i2c7_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x02c 0x0 /* I2C7_SCL */
+                                       0x030 0x0 /* I2C7_SDA */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       slimbus_cfg_func: slimbus_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x034 0x0 /* SLIMBUS_CLK */
+                                       0x038 0x0 /* SLIMBUS_DATA */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       i2s0_cfg_func: i2s0_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x040 0x0 /* I2S0_DI */
+                                       0x044 0x0 /* I2S0_DO */
+                                       0x048 0x0 /* I2S0_XCLK */
+                                       0x04c 0x0 /* I2S0_XFS */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       i2s2_cfg_func: i2s2_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x050 0x0 /* I2S2_DI */
+                                       0x054 0x0 /* I2S2_DO */
+                                       0x058 0x0 /* I2S2_XCLK */
+                                       0x05c 0x0 /* I2S2_XFS */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       pcie_cfg_func: pcie_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x094 0x0 /* PCIE_CLKREQ_N */
+                                       0x098 0x0 /* PCIE_WAKE_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       spi2_cfg_func: spi2_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x09c 0x0 /* SPI2_CLK */
+                                       0x0a0 0x0 /* SPI2_DI */
+                                       0x0a4 0x0 /* SPI2_DO */
+                                       0x0a8 0x0 /* SPI2_CS0_N */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+
+                       usb_cfg_func: usb_cfg_func {
+                               pinctrl-single,pins = <
+                                       0x0ac 0x0 /* GPIO_219 */
+                               >;
+                               pinctrl-single,bias-pulldown = <
+                                       PULL_DIS
+                                       PULL_DOWN
+                                       PULL_DIS
+                                       PULL_DOWN
+                               >;
+                               pinctrl-single,bias-pullup = <
+                                       PULL_UP
+                                       PULL_UP
+                                       PULL_DIS
+                                       PULL_UP
+                               >;
+                               pinctrl-single,drive-strength = <
+                                       DRIVE7_02MA DRIVE6_MASK
+                               >;
+                       };
+               };
+       };
+};
diff --git a/include/dt-bindings/clock/hi3660-clock.h b/include/dt-bindings/clock/hi3660-clock.h
new file mode 100644 (file)
index 0000000..e1374e1
--- /dev/null
@@ -0,0 +1,214 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later */
+/*
+ * Copyright (c) 2016-2017 Linaro Ltd.
+ * Copyright (c) 2016-2017 HiSilicon Technologies Co., Ltd.
+ */
+
+#ifndef __DTS_HI3660_CLOCK_H
+#define __DTS_HI3660_CLOCK_H
+
+/* fixed rate clocks */
+#define HI3660_CLKIN_SYS               0
+#define HI3660_CLKIN_REF               1
+#define HI3660_CLK_FLL_SRC             2
+#define HI3660_CLK_PPLL0               3
+#define HI3660_CLK_PPLL1               4
+#define HI3660_CLK_PPLL2               5
+#define HI3660_CLK_PPLL3               6
+#define HI3660_CLK_SCPLL               7
+#define HI3660_PCLK                    8
+#define HI3660_CLK_UART0_DBG           9
+#define HI3660_CLK_UART6               10
+#define HI3660_OSC32K                  11
+#define HI3660_OSC19M                  12
+#define HI3660_CLK_480M                        13
+#define HI3660_CLK_INV                 14
+
+/* clk in crgctrl */
+#define HI3660_FACTOR_UART3            15
+#define HI3660_CLK_FACTOR_MMC          16
+#define HI3660_CLK_GATE_I2C0           17
+#define HI3660_CLK_GATE_I2C1           18
+#define HI3660_CLK_GATE_I2C2           19
+#define HI3660_CLK_GATE_I2C6           20
+#define HI3660_CLK_DIV_SYSBUS          21
+#define HI3660_CLK_DIV_320M            22
+#define HI3660_CLK_DIV_A53             23
+#define HI3660_CLK_GATE_SPI0           24
+#define HI3660_CLK_GATE_SPI2           25
+#define HI3660_PCIEPHY_REF             26
+#define HI3660_CLK_ABB_USB             27
+#define HI3660_HCLK_GATE_SDIO0         28
+#define HI3660_HCLK_GATE_SD            29
+#define HI3660_CLK_GATE_AOMM           30
+#define HI3660_PCLK_GPIO0              31
+#define HI3660_PCLK_GPIO1              32
+#define HI3660_PCLK_GPIO2              33
+#define HI3660_PCLK_GPIO3              34
+#define HI3660_PCLK_GPIO4              35
+#define HI3660_PCLK_GPIO5              36
+#define HI3660_PCLK_GPIO6              37
+#define HI3660_PCLK_GPIO7              38
+#define HI3660_PCLK_GPIO8              39
+#define HI3660_PCLK_GPIO9              40
+#define HI3660_PCLK_GPIO10             41
+#define HI3660_PCLK_GPIO11             42
+#define HI3660_PCLK_GPIO12             43
+#define HI3660_PCLK_GPIO13             44
+#define HI3660_PCLK_GPIO14             45
+#define HI3660_PCLK_GPIO15             46
+#define HI3660_PCLK_GPIO16             47
+#define HI3660_PCLK_GPIO17             48
+#define HI3660_PCLK_GPIO18             49
+#define HI3660_PCLK_GPIO19             50
+#define HI3660_PCLK_GPIO20             51
+#define HI3660_PCLK_GPIO21             52
+#define HI3660_CLK_GATE_SPI3           53
+#define HI3660_CLK_GATE_I2C7           54
+#define HI3660_CLK_GATE_I2C3           55
+#define HI3660_CLK_GATE_SPI1           56
+#define HI3660_CLK_GATE_UART1          57
+#define HI3660_CLK_GATE_UART2          58
+#define HI3660_CLK_GATE_UART4          59
+#define HI3660_CLK_GATE_UART5          60
+#define HI3660_CLK_GATE_I2C4           61
+#define HI3660_CLK_GATE_DMAC           62
+#define HI3660_PCLK_GATE_DSS           63
+#define HI3660_ACLK_GATE_DSS           64
+#define HI3660_CLK_GATE_LDI1           65
+#define HI3660_CLK_GATE_LDI0           66
+#define HI3660_CLK_GATE_VIVOBUS                67
+#define HI3660_CLK_GATE_EDC0           68
+#define HI3660_CLK_GATE_TXDPHY0_CFG    69
+#define HI3660_CLK_GATE_TXDPHY0_REF    70
+#define HI3660_CLK_GATE_TXDPHY1_CFG    71
+#define HI3660_CLK_GATE_TXDPHY1_REF    72
+#define HI3660_ACLK_GATE_USB3OTG       73
+#define HI3660_CLK_GATE_SPI4           74
+#define HI3660_CLK_GATE_SD             75
+#define HI3660_CLK_GATE_SDIO0          76
+#define HI3660_CLK_GATE_UFS_SUBSYS     77
+#define HI3660_PCLK_GATE_DSI0          78
+#define HI3660_PCLK_GATE_DSI1          79
+#define HI3660_ACLK_GATE_PCIE          80
+#define HI3660_PCLK_GATE_PCIE_SYS       81
+#define HI3660_CLK_GATE_PCIEAUX                82
+#define HI3660_PCLK_GATE_PCIE_PHY      83
+#define HI3660_CLK_ANDGT_LDI0          84
+#define HI3660_CLK_ANDGT_LDI1          85
+#define HI3660_CLK_ANDGT_EDC0          86
+#define HI3660_CLK_GATE_UFSPHY_GT      87
+#define HI3660_CLK_ANDGT_MMC           88
+#define HI3660_CLK_ANDGT_SD            89
+#define HI3660_CLK_A53HPM_ANDGT                90
+#define HI3660_CLK_ANDGT_SDIO          91
+#define HI3660_CLK_ANDGT_UART0         92
+#define HI3660_CLK_ANDGT_UART1         93
+#define HI3660_CLK_ANDGT_UARTH         94
+#define HI3660_CLK_ANDGT_SPI           95
+#define HI3660_CLK_VIVOBUS_ANDGT       96
+#define HI3660_CLK_AOMM_ANDGT          97
+#define HI3660_CLK_320M_PLL_GT         98
+#define HI3660_AUTODIV_EMMC0BUS                99
+#define HI3660_AUTODIV_SYSBUS          100
+#define HI3660_CLK_GATE_UFSPHY_CFG     101
+#define HI3660_CLK_GATE_UFSIO_REF      102
+#define HI3660_CLK_MUX_SYSBUS          103
+#define HI3660_CLK_MUX_UART0           104
+#define HI3660_CLK_MUX_UART1           105
+#define HI3660_CLK_MUX_UARTH           106
+#define HI3660_CLK_MUX_SPI             107
+#define HI3660_CLK_MUX_I2C             108
+#define HI3660_CLK_MUX_MMC_PLL         109
+#define HI3660_CLK_MUX_LDI1            110
+#define HI3660_CLK_MUX_LDI0            111
+#define HI3660_CLK_MUX_SD_PLL          112
+#define HI3660_CLK_MUX_SD_SYS          113
+#define HI3660_CLK_MUX_EDC0            114
+#define HI3660_CLK_MUX_SDIO_SYS                115
+#define HI3660_CLK_MUX_SDIO_PLL                116
+#define HI3660_CLK_MUX_VIVOBUS         117
+#define HI3660_CLK_MUX_A53HPM          118
+#define HI3660_CLK_MUX_320M            119
+#define HI3660_CLK_MUX_IOPERI          120
+#define HI3660_CLK_DIV_UART0           121
+#define HI3660_CLK_DIV_UART1           122
+#define HI3660_CLK_DIV_UARTH           123
+#define HI3660_CLK_DIV_MMC             124
+#define HI3660_CLK_DIV_SD              125
+#define HI3660_CLK_DIV_EDC0            126
+#define HI3660_CLK_DIV_LDI0            127
+#define HI3660_CLK_DIV_SDIO            128
+#define HI3660_CLK_DIV_LDI1            129
+#define HI3660_CLK_DIV_SPI             130
+#define HI3660_CLK_DIV_VIVOBUS         131
+#define HI3660_CLK_DIV_I2C             132
+#define HI3660_CLK_DIV_UFSPHY          133
+#define HI3660_CLK_DIV_CFGBUS          134
+#define HI3660_CLK_DIV_MMC0BUS         135
+#define HI3660_CLK_DIV_MMC1BUS         136
+#define HI3660_CLK_DIV_UFSPERI         137
+#define HI3660_CLK_DIV_AOMM            138
+#define HI3660_CLK_DIV_IOPERI          139
+#define HI3660_VENC_VOLT_HOLD          140
+#define HI3660_PERI_VOLT_HOLD          141
+#define HI3660_CLK_GATE_VENC           142
+#define HI3660_CLK_GATE_VDEC           143
+#define HI3660_CLK_ANDGT_VENC          144
+#define HI3660_CLK_ANDGT_VDEC          145
+#define HI3660_CLK_MUX_VENC            146
+#define HI3660_CLK_MUX_VDEC            147
+#define HI3660_CLK_DIV_VENC            148
+#define HI3660_CLK_DIV_VDEC            149
+#define HI3660_CLK_FAC_ISP_SNCLK       150
+#define HI3660_CLK_GATE_ISP_SNCLK0     151
+#define HI3660_CLK_GATE_ISP_SNCLK1     152
+#define HI3660_CLK_GATE_ISP_SNCLK2     153
+#define HI3660_CLK_ANGT_ISP_SNCLK      154
+#define HI3660_CLK_MUX_ISP_SNCLK       155
+#define HI3660_CLK_DIV_ISP_SNCLK       156
+
+/* clk in pmuctrl */
+#define HI3660_GATE_ABB_192            0
+
+/* clk in pctrl */
+#define HI3660_GATE_UFS_TCXO_EN                0
+#define HI3660_GATE_USB_TCXO_EN                1
+
+/* clk in sctrl */
+#define HI3660_PCLK_AO_GPIO0           0
+#define HI3660_PCLK_AO_GPIO1           1
+#define HI3660_PCLK_AO_GPIO2           2
+#define HI3660_PCLK_AO_GPIO3           3
+#define HI3660_PCLK_AO_GPIO4           4
+#define HI3660_PCLK_AO_GPIO5           5
+#define HI3660_PCLK_AO_GPIO6           6
+#define HI3660_PCLK_GATE_MMBUF         7
+#define HI3660_CLK_GATE_DSS_AXI_MM     8
+#define HI3660_PCLK_MMBUF_ANDGT                9
+#define HI3660_CLK_MMBUF_PLL_ANDGT     10
+#define HI3660_CLK_FLL_MMBUF_ANDGT     11
+#define HI3660_CLK_SYS_MMBUF_ANDGT     12
+#define HI3660_CLK_GATE_PCIEPHY_GT     13
+#define HI3660_ACLK_MUX_MMBUF          14
+#define HI3660_CLK_SW_MMBUF            15
+#define HI3660_CLK_DIV_AOBUS           16
+#define HI3660_PCLK_DIV_MMBUF          17
+#define HI3660_ACLK_DIV_MMBUF          18
+#define HI3660_CLK_DIV_PCIEPHY         19
+
+/* clk in iomcu */
+#define HI3660_CLK_I2C0_IOMCU          0
+#define HI3660_CLK_I2C1_IOMCU          1
+#define HI3660_CLK_I2C2_IOMCU          2
+#define HI3660_CLK_I2C6_IOMCU          3
+#define HI3660_CLK_IOMCU_PERI0         4
+
+/* clk in stub clock */
+#define HI3660_CLK_STUB_CLUSTER0       0
+#define HI3660_CLK_STUB_CLUSTER1       1
+#define HI3660_CLK_STUB_GPU            2
+#define HI3660_CLK_STUB_DDR            3
+#define HI3660_CLK_STUB_NUM            4
+
+#endif /* __DTS_HI3660_CLOCK_H */