Commit 619c144c authored by Vince Hsu's avatar Vince Hsu Committed by Rafael J. Wysocki

cpufreq: respect the min/max settings from user space

When the user space tries to set scaling_(max|min)_freq through
sysfs, the cpufreq_set_policy() asks other driver's opinions
for the max/min frequencies. Some device drivers, like Tegra
CPU EDP which is not upstreamed yet though, may constrain the
CPU maximum frequency dynamically because of board design.
So if the user space access happens and some driver is capping
the cpu frequency at the same time, the user_policy->(max|min)
is overridden by the capped value, and that's not expected by
the user space. And if the user space is not invoked again,
the CPU will always be capped by the user_policy->(max|min)
even no drivers limit the CPU frequency any more.

This patch preserves the user specified min/max settings, so that
every time the cpufreq policy is updated, the new max/min can
be re-evaluated correctly based on the user's expection and
the present device drivers' status.
Signed-off-by: default avatarVince Hsu <vinceh@nvidia.com>
Acked-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 8197bb1b
...@@ -535,7 +535,7 @@ static int cpufreq_set_policy(struct cpufreq_policy *policy, ...@@ -535,7 +535,7 @@ static int cpufreq_set_policy(struct cpufreq_policy *policy,
static ssize_t store_##file_name \ static ssize_t store_##file_name \
(struct cpufreq_policy *policy, const char *buf, size_t count) \ (struct cpufreq_policy *policy, const char *buf, size_t count) \
{ \ { \
int ret; \ int ret, temp; \
struct cpufreq_policy new_policy; \ struct cpufreq_policy new_policy; \
\ \
ret = cpufreq_get_policy(&new_policy, policy->cpu); \ ret = cpufreq_get_policy(&new_policy, policy->cpu); \
...@@ -546,8 +546,10 @@ static ssize_t store_##file_name \ ...@@ -546,8 +546,10 @@ static ssize_t store_##file_name \
if (ret != 1) \ if (ret != 1) \
return -EINVAL; \ return -EINVAL; \
\ \
temp = new_policy.object; \
ret = cpufreq_set_policy(policy, &new_policy); \ ret = cpufreq_set_policy(policy, &new_policy); \
policy->user_policy.object = policy->object; \ if (!ret) \
policy->user_policy.object = temp; \
\ \
return ret ? ret : count; \ return ret ? ret : count; \
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment