arm64: dts: juno: Add cpu dynamic-power-coefficient information
authorDietmar Eggemann <dietmar.eggemann@arm.com>
Mon, 28 Jan 2019 16:55:21 +0000 (16:55 +0000)
committerSudeep Holla <sudeep.holla@arm.com>
Tue, 29 Jan 2019 15:31:37 +0000 (15:31 +0000)
A CPUfreq driver, like the scpi driver used on Juno boards, which
provide the Energy Model with power cost information via the PM_OPP
of_dev_pm_opp_get_cpu_power() function, do need the
dynamic-power-coefficient (C) in the device tree.

Method used to obtain the C value:

C is computed by measuring energy (E) consumption of a frequency domain
(FD) over a 10s runtime (t) sysbench workload running at each Operating
Performance Point (OPP) affine to 1 or 2 CPUs of that FD while the other
CPUs of the system are hotplugged out.

By definition all CPUs of a FD have the the same micro-architecture. An
OPP is characterized by a certain frequency (f) and voltage (V) value.
The corresponding power values (P) are calculated by dividing the delta
of the E values between the runs with 2 and 1 CPUs by t.

With n data tuples (P, f, V), n equal to number of OPPs for this
frequency domain, we can solve C by:

P = Pstat + Pdyn

P = Pstat + CV²f

Cx = (Px - P1)/(Vx²fx - V1²f1) with x = {2, ..., n}

The C value is the arithmetic mean out of {C2, ..., Cn}.

Since DVFS is broken on Juno r1, no dynamic-power-coefficient
information has been added to its dts file.

Signed-off-by: Dietmar Eggemann <dietmar.eggemann@arm.com>
Signed-off-by: Quentin Perret <quentin.perret@arm.com>
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
arch/arm64/boot/dts/arm/juno-r2.dts
arch/arm64/boot/dts/arm/juno.dts

index ab77adb..66f0ec7 100644 (file)
@@ -99,6 +99,7 @@
                        clocks = <&scpi_dvfs 0>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <1024>;
+                       dynamic-power-coefficient = <450>;
                };
 
                A72_1: cpu@1 {
                        clocks = <&scpi_dvfs 0>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <1024>;
+                       dynamic-power-coefficient = <450>;
                };
 
                A53_0: cpu@100 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <485>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_1: cpu@101 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <485>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_2: cpu@102 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <485>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_3: cpu@103 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <485>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A72_L2: l2-cache0 {
index 08d4ba1..9890afd 100644 (file)
@@ -98,6 +98,7 @@
                        clocks = <&scpi_dvfs 0>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <1024>;
+                       dynamic-power-coefficient = <530>;
                };
 
                A57_1: cpu@1 {
                        clocks = <&scpi_dvfs 0>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <1024>;
+                       dynamic-power-coefficient = <530>;
                };
 
                A53_0: cpu@100 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <578>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_1: cpu@101 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <578>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_2: cpu@102 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <578>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A53_3: cpu@103 {
                        clocks = <&scpi_dvfs 1>;
                        cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>;
                        capacity-dmips-mhz = <578>;
+                       dynamic-power-coefficient = <140>;
                };
 
                A57_L2: l2-cache0 {