Commit d16b8209 authored by Dave Jones's avatar Dave Jones

[CPUFREQ] speedstep-centrino: don't loop on transient MSR

From: "Pallipadi, Venkatesh" <venkatesh.pallipadi@intel.com>

The transient MSR values are for very short duration and so I feel reading
out the last set frequency is better than looping until reading something
expected.
Signed-off-by: default avatarDominik Brodowski <linux@brodo.de>
Signed-off-by: default avatarVenkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Signed-off-by: default avatarDave Jones <davej@redhat.com>
parent 4e1e90fa
...@@ -332,25 +332,12 @@ static unsigned int get_cur_freq(unsigned int cpu) ...@@ -332,25 +332,12 @@ static unsigned int get_cur_freq(unsigned int cpu)
/* /*
* On some CPUs, we can see transient MSR values (which are * On some CPUs, we can see transient MSR values (which are
* not present in _PSS), while CPU is doing some automatic * not present in _PSS), while CPU is doing some automatic
* P-state transition (like TM2). Allow CPU to stabilize at * P-state transition (like TM2). Get the last freq set
* some freq and retry. * in PERF_CTL.
* If we continue to see transients for long time, just return
* the lowest possible frequency as best guess.
*/ */
int retries = 0; rdmsr(MSR_IA32_PERF_CTL, l, h);
#define MAX_EXTRACT_CLOCK_RETRIES 5
while (clock_freq == 0 && retries < MAX_EXTRACT_CLOCK_RETRIES) {
udelay(100);
retries++;
rdmsr(MSR_IA32_PERF_STATUS, l, h);
clock_freq = extract_clock(l, cpu, 0);
}
if (clock_freq == 0) {
rdmsr(MSR_IA32_PERF_STATUS, l, h);
clock_freq = extract_clock(l, cpu, 1); clock_freq = extract_clock(l, cpu, 1);
} }
}
set_cpus_allowed(current, saved_mask); set_cpus_allowed(current, saved_mask);
return clock_freq; return clock_freq;
......
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