]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commitdiff
thermal: cpu_cooling: store cpufreq policy
authorViresh Kumar <viresh.kumar@linaro.org>
Tue, 25 Apr 2017 10:27:16 +0000 (15:57 +0530)
committerEduardo Valentin <edubezval@gmail.com>
Sun, 28 May 2017 00:32:33 +0000 (17:32 -0700)
The cpufreq policy can be used by the cpu_cooling driver, lets store it
in the cpufreq_cooling_device structure.

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: Lukasz Luba <lukasz.luba@arm.com>
Tested-by: Lukasz Luba <lukasz.luba@arm.com>
Signed-off-by: Eduardo Valentin <edubezval@gmail.com>
drivers/thermal/cpu_cooling.c

index 55ff45c1e917a953849d46060aacfe393ea2f786..7dddc7443f5d0ea0079d0f4b25858d4143207ef7 100644 (file)
@@ -67,6 +67,7 @@ struct power_table {
  *     registered.
  * @cdev: thermal_cooling_device pointer to keep track of the
  *     registered cooling device.
+ * @policy: cpufreq policy.
  * @cpufreq_state: integer value representing the current state of cpufreq
  *     cooling devices.
  * @clipped_freq: integer value representing the absolute value of the clipped
@@ -91,6 +92,7 @@ struct power_table {
 struct cpufreq_cooling_device {
        int id;
        struct thermal_cooling_device *cdev;
+       struct cpufreq_policy *policy;
        unsigned int cpufreq_state;
        unsigned int clipped_freq;
        unsigned int max_level;
@@ -760,6 +762,7 @@ __cpufreq_cooling_register(struct device_node *np,
        if (!cpufreq_cdev)
                return ERR_PTR(-ENOMEM);
 
+       cpufreq_cdev->policy = policy;
        num_cpus = cpumask_weight(policy->related_cpus);
        cpufreq_cdev->time_in_idle = kcalloc(num_cpus,
                                            sizeof(*cpufreq_cdev->time_in_idle),