[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] x86: Fix an S3 bug caused by x_firmware_waking_vector
# HG changeset patch # User Keir Fraser <keir.fraser@xxxxxxxxxx> # Date 1210840680 -3600 # Node ID 29dc52031954896a407a97cba167c197f8e1c0ed # Parent 9044705960cb30cec385bdca7305bcf7db096721 x86: Fix an S3 bug caused by x_firmware_waking_vector According to ACPI spec., x_firmware_waking_vector in FACS is for waking up in protected mode and firmware_waking_vector is for in real mode. Xen once use x_firmware_waking_vector which can make S3 failed on some platform. This patch fixed the bug by using non-x one. Signed-off-by: Huacai Chen <huacai.chen@xxxxxxxxx> --- xen/arch/x86/acpi/boot.c | 14 +++----------- 1 files changed, 3 insertions(+), 11 deletions(-) diff -r 9044705960cb -r 29dc52031954 xen/arch/x86/acpi/boot.c --- a/xen/arch/x86/acpi/boot.c Thu May 15 09:36:38 2008 +0100 +++ b/xen/arch/x86/acpi/boot.c Thu May 15 09:38:00 2008 +0100 @@ -441,17 +441,9 @@ acpi_fadt_parse_sleep_info(struct acpi_t "FACS is shorter than ACPI spec allow: 0x%x", facs->length); - if ((rsdp->revision < 2) || (facs->length < 32)) { - acpi_sinfo.wakeup_vector = facs_pa + - offsetof(struct acpi_table_facs, - firmware_waking_vector); - acpi_sinfo.vector_width = 32; - } else { - acpi_sinfo.wakeup_vector = facs_pa + - offsetof(struct acpi_table_facs, - xfirmware_waking_vector); - acpi_sinfo.vector_width = 64; - } + acpi_sinfo.wakeup_vector = facs_pa + + offsetof(struct acpi_table_facs, firmware_waking_vector); + acpi_sinfo.vector_width = 32; printk(KERN_INFO PREFIX " wakeup_vec[%"PRIx64"], vec_size[%x]\n", _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |