diff options
author | Lan Tianyu <tianyu.lan@intel.com> | 2013-08-12 22:07:28 -0400 |
---|---|---|
committer | Zhang Rui <rui.zhang@intel.com> | 2013-08-15 03:25:08 -0400 |
commit | 044d5c26da262fa433dacbe1c6962459050d6b06 (patch) | |
tree | 44fbdb1f385b088f94bdb92f263fa35d30cd9896 /drivers/thermal/cpu_cooling.c | |
parent | 584d88b2cd3b60507e708d2452651e4d3caa1b81 (diff) |
Thermal/cpu_cooling: Return directly for the cpu out of allowed_cpus in the cpufreq_thermal_notifier()
cpufreq_thermal_notifier() is to change the cpu's cpufreq in the allowed_cpus mask
when associated thermal-cpufreq cdev's cooling state is changed. It's a cpufreq policy
notifier handler and it will be triggered even if those cpus out of allowed_cpus has
changed freq policy.
cpufreq_thermal_notifier() checks the policy->cpu. If it belongs to allowed_cpus,
change max_freq(default to 0) to the desire cpufreq value and pass 0 and max_freq
to cpufreq_verify_within_limits() as cpufreq scope. But if not, do nothing and
max_freq will remain 0. This will cause the cpufreq scope to become 0~0. This
is not right. This patch is to return directly after finding cpu not belonging
to allowed_cpus.
Signed-off-by: Lan Tianyu <tianyu.lan@intel.com>
Signed-off-by: Zhang Rui <rui.zhang@intel.com>
Diffstat (limited to 'drivers/thermal/cpu_cooling.c')
-rw-r--r-- | drivers/thermal/cpu_cooling.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/thermal/cpu_cooling.c b/drivers/thermal/cpu_cooling.c index 82e15dbb3ac7..5b3744e7a95b 100644 --- a/drivers/thermal/cpu_cooling.c +++ b/drivers/thermal/cpu_cooling.c | |||
@@ -322,6 +322,8 @@ static int cpufreq_thermal_notifier(struct notifier_block *nb, | |||
322 | 322 | ||
323 | if (cpumask_test_cpu(policy->cpu, ¬ify_device->allowed_cpus)) | 323 | if (cpumask_test_cpu(policy->cpu, ¬ify_device->allowed_cpus)) |
324 | max_freq = notify_device->cpufreq_val; | 324 | max_freq = notify_device->cpufreq_val; |
325 | else | ||
326 | return 0; | ||
325 | 327 | ||
326 | /* Never exceed user_policy.max */ | 328 | /* Never exceed user_policy.max */ |
327 | if (max_freq > policy->user_policy.max) | 329 | if (max_freq > policy->user_policy.max) |