arm64: dts: hi3660: enable idle states
authorLeo Yan <leo.yan@linaro.org>
Mon, 14 Aug 2017 09:50:40 +0000 (17:50 +0800)
committerWei Xu <xuwei5@hisilicon.com>
Wed, 16 Aug 2017 08:32:06 +0000 (09:32 +0100)
There are two clusters on the Hi3660, the first one is Cortex-A53 based
and the other one is Cortex-A73 based. These two clusters have different
idle states.

Thanks to Daniel Lezcano's recent changes, the generic ARM cpuidle
driver can now support several clusters with different idle states, thus
supporting the big.Little architecture.

In addition to the WFI idle state which is the default shallowest state
for all ARM cpus, the Hi3660 supports the following states:

 - CA53 CPUs:
        - CPU_SLEEP:       CPU power off state
        - CLUSTER_SLEEP_0: Cluster power off state

 - CA73 CPUs:
        - CPU_NAP:         CPU retention state
        - CPU_SLEEP:       CPU power off state
        - CLUSTER_SLEEP_1: Cluster power off state

This patch adds the idle states description for the Hi3660 to the device
tree.

Cc: Kevin Wang <jean.wangtao@linaro.org>
Signed-off-by: Leo Yan <leo.yan@linaro.org>
Acked-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Signed-off-by: Wei Xu <xuwei5@hisilicon.com>
arch/arm64/boot/dts/hisilicon/hi3660.dtsi

index c6a1961e8d55ecb9bdb07e8696fe9a755c8d21e8..8921310e4c55f6955f4b4a4d3e55711fbad23c61 100644 (file)
@@ -58,6 +58,7 @@
                        device_type = "cpu";
                        reg = <0x0 0x0>;
                        enable-method = "psci";
+                       cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP_0>;
                };
 
                cpu1: cpu@1 {
@@ -65,6 +66,7 @@
                        device_type = "cpu";
                        reg = <0x0 0x1>;
                        enable-method = "psci";
+                       cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP_0>;
                };
 
                cpu2: cpu@2 {
@@ -72,6 +74,7 @@
                        device_type = "cpu";
                        reg = <0x0 0x2>;
                        enable-method = "psci";
+                       cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP_0>;
                };
 
                cpu3: cpu@3 {
@@ -79,6 +82,7 @@
                        device_type = "cpu";
                        reg = <0x0 0x3>;
                        enable-method = "psci";
+                       cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP_0>;
                };
 
                cpu4: cpu@100 {
                        device_type = "cpu";
                        reg = <0x0 0x100>;
                        enable-method = "psci";
+                       cpu-idle-states = <
+                                       &CPU_NAP
+                                       &CPU_SLEEP
+                                       &CLUSTER_SLEEP_1
+                       >;
                };
 
                cpu5: cpu@101 {
                        device_type = "cpu";
                        reg = <0x0 0x101>;
                        enable-method = "psci";
+                       cpu-idle-states = <
+                                       &CPU_NAP
+                                       &CPU_SLEEP
+                                       &CLUSTER_SLEEP_1
+                       >;
                };
 
                cpu6: cpu@102 {
                        device_type = "cpu";
                        reg = <0x0 0x102>;
                        enable-method = "psci";
+                       cpu-idle-states = <
+                                       &CPU_NAP
+                                       &CPU_SLEEP
+                                       &CLUSTER_SLEEP_1
+                       >;
                };
 
                cpu7: cpu@103 {
                        device_type = "cpu";
                        reg = <0x0 0x103>;
                        enable-method = "psci";
+                       cpu-idle-states = <
+                                       &CPU_NAP
+                                       &CPU_SLEEP
+                                       &CLUSTER_SLEEP_1
+                       >;
+               };
+
+               idle-states {
+                       entry-method = "psci";
+
+                       CPU_NAP: cpu-nap {
+                               compatible = "arm,idle-state";
+                               arm,psci-suspend-param = <0x0000001>;
+                               entry-latency-us = <7>;
+                               exit-latency-us = <2>;
+                               min-residency-us = <15>;
+                       };
+
+                       CPU_SLEEP: cpu-sleep {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x0010000>;
+                               entry-latency-us = <40>;
+                               exit-latency-us = <70>;
+                               min-residency-us = <3000>;
+                       };
+
+                       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 = <5000>;
+                               min-residency-us = <20000>;
+                       };
+
+                       CLUSTER_SLEEP_1: cluster-sleep-1 {
+                               compatible = "arm,idle-state";
+                               local-timer-stop;
+                               arm,psci-suspend-param = <0x1010000>;
+                               entry-latency-us = <1000>;
+                               exit-latency-us = <5000>;
+                               min-residency-us = <20000>;
+                       };
                };
        };