瀏覽代碼

cpufreq: CPPC: Correct desired_perf calculation

The desired_perf is an abstract performance number. Its value should
be in the range of [lowest perf, highest perf] of CPPC.
The correct calculation is
  desired_perf = freq * cppc_highest_perf / cppc_dmi_max_khz

And cppc_cpufreq_set_target() returns if desired_perf is exactly
the same with the old perf.

Signed-off-by: Hoan Tran <hotran@apm.com>
Reviewed-by: Prashanth Prakash <pprakash@codeaurora.org>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Hoan Tran 8 年之前
父節點
當前提交
c197d75803
共有 1 個文件被更改,包括 7 次插入1 次删除
  1. 7 1
      drivers/cpufreq/cppc_cpufreq.c

+ 7 - 1
drivers/cpufreq/cppc_cpufreq.c

@@ -80,11 +80,17 @@ static int cppc_cpufreq_set_target(struct cpufreq_policy *policy,
 {
 {
 	struct cpudata *cpu;
 	struct cpudata *cpu;
 	struct cpufreq_freqs freqs;
 	struct cpufreq_freqs freqs;
+	u32 desired_perf;
 	int ret = 0;
 	int ret = 0;
 
 
 	cpu = all_cpu_data[policy->cpu];
 	cpu = all_cpu_data[policy->cpu];
 
 
-	cpu->perf_ctrls.desired_perf = (u64)target_freq * policy->max / cppc_dmi_max_khz;
+	desired_perf = (u64)target_freq * cpu->perf_caps.highest_perf / cppc_dmi_max_khz;
+	/* Return if it is exactly the same perf */
+	if (desired_perf == cpu->perf_ctrls.desired_perf)
+		return ret;
+
+	cpu->perf_ctrls.desired_perf = desired_perf;
 	freqs.old = policy->cur;
 	freqs.old = policy->cur;
 	freqs.new = target_freq;
 	freqs.new = target_freq;