cpufreq: intel_pstate: Fix code ordering in intel_pstate_set_policy()
The limits->max_perf is rounded_up but immediately overwritten by
another assignment to limits->max_perf.
Move that operation to the correct location.
While here also added a pr_debug() call in ->set_policy to aid in
debugging.
Fixes: 785ee27881 (cpufreq: intel_pstate: Fix limits->max_perf rounding error)
Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
[ rjw : Subject & changelog ]
Cc: 4.4+ <stable@vger.kernel.org> # 4.4+
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
committed by
Rafael J. Wysocki
parent
b9af694802
commit
2c2c1af449
@@ -1460,6 +1460,9 @@ static int intel_pstate_set_policy(struct cpufreq_policy *policy)
|
|||||||
|
|
||||||
intel_pstate_clear_update_util_hook(policy->cpu);
|
intel_pstate_clear_update_util_hook(policy->cpu);
|
||||||
|
|
||||||
|
pr_debug("set_policy cpuinfo.max %u policy->max %u\n",
|
||||||
|
policy->cpuinfo.max_freq, policy->max);
|
||||||
|
|
||||||
cpu = all_cpu_data[0];
|
cpu = all_cpu_data[0];
|
||||||
if (cpu->pstate.max_pstate_physical > cpu->pstate.max_pstate &&
|
if (cpu->pstate.max_pstate_physical > cpu->pstate.max_pstate &&
|
||||||
policy->max < policy->cpuinfo.max_freq &&
|
policy->max < policy->cpuinfo.max_freq &&
|
||||||
@@ -1495,13 +1498,13 @@ static int intel_pstate_set_policy(struct cpufreq_policy *policy)
|
|||||||
limits->max_sysfs_pct);
|
limits->max_sysfs_pct);
|
||||||
limits->max_perf_pct = max(limits->min_policy_pct,
|
limits->max_perf_pct = max(limits->min_policy_pct,
|
||||||
limits->max_perf_pct);
|
limits->max_perf_pct);
|
||||||
limits->max_perf = round_up(limits->max_perf, FRAC_BITS);
|
|
||||||
|
|
||||||
/* Make sure min_perf_pct <= max_perf_pct */
|
/* Make sure min_perf_pct <= max_perf_pct */
|
||||||
limits->min_perf_pct = min(limits->max_perf_pct, limits->min_perf_pct);
|
limits->min_perf_pct = min(limits->max_perf_pct, limits->min_perf_pct);
|
||||||
|
|
||||||
limits->min_perf = div_fp(limits->min_perf_pct, 100);
|
limits->min_perf = div_fp(limits->min_perf_pct, 100);
|
||||||
limits->max_perf = div_fp(limits->max_perf_pct, 100);
|
limits->max_perf = div_fp(limits->max_perf_pct, 100);
|
||||||
|
limits->max_perf = round_up(limits->max_perf, FRAC_BITS);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
intel_pstate_set_update_util_hook(policy->cpu);
|
intel_pstate_set_update_util_hook(policy->cpu);
|
||||||
|
|||||||
Reference in New Issue
Block a user