mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
xen/acpi: Workaround broken BIOSes exporting non-existing C-states.
We did a similar check for the P-states but did not do it for the C-states. What we want to do is ignore cases where the DSDT has definition for sixteen CPUs, but the machine only has eight CPUs and we get: xen-acpi-processor: (CX): Hypervisor error (-22) for ACPI CPU14 Reported-by: Tobias Geiger <tobias.geiger@vido.info> Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
This commit is contained in:
parent
cf405ae612
commit
b930fe5e1f
1 changed files with 4 additions and 1 deletions
|
@ -128,7 +128,10 @@ static int push_cxx_to_hypervisor(struct acpi_processor *_pr)
|
||||||
pr_debug(" C%d: %s %d uS\n",
|
pr_debug(" C%d: %s %d uS\n",
|
||||||
cx->type, cx->desc, (u32)cx->latency);
|
cx->type, cx->desc, (u32)cx->latency);
|
||||||
}
|
}
|
||||||
} else
|
} else if (ret != -EINVAL)
|
||||||
|
/* EINVAL means the ACPI ID is incorrect - meaning the ACPI
|
||||||
|
* table is referencing a non-existing CPU - which can happen
|
||||||
|
* with broken ACPI tables. */
|
||||||
pr_err(DRV_NAME "(CX): Hypervisor error (%d) for ACPI CPU%u\n",
|
pr_err(DRV_NAME "(CX): Hypervisor error (%d) for ACPI CPU%u\n",
|
||||||
ret, _pr->acpi_id);
|
ret, _pr->acpi_id);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue