Commit d7a1944e authored by Gary Hade's avatar Gary Hade Committed by Dave Jones

[CPUFREQ] speedstep-centrino should ignore upper performance control bits

On some systems such as the IBM x3650 there are bits set in the
upper half of the control values provided by the _PSS object.
These bits are only relevant for cpufreq drivers that use IO ports
which are not currently supported by the speedstep-centrino driver.
The current MSR oriented code assumes that upper bits are not set
and thus fails to work correctly when they are.  e.g. the control
and status value equality check fails even though the ACPI spec
allows the inequality.
Signed-off-by: default avatarGary Hade <garyh@us.ibm.com>
Signed-off-by: default avatarDave Jones <davej@redhat.com>
parent 4e74663c
...@@ -463,6 +463,10 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy) ...@@ -463,6 +463,10 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
} }
for (i=0; i<p->state_count; i++) { for (i=0; i<p->state_count; i++) {
/* clear high bits (set by some BIOSes) that are non-relevant and
problematic for this driver's MSR only frequency transition code */
p->states[i].control &= 0xffff;
if (p->states[i].control != p->states[i].status) { if (p->states[i].control != p->states[i].status) {
dprintk("Different control (%llu) and status values (%llu)\n", dprintk("Different control (%llu) and status values (%llu)\n",
p->states[i].control, p->states[i].status); p->states[i].control, p->states[i].status);
......
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