The patch titled mtrr: bSP: save and restore fixed-range MTRRs during suspend has been added to the -mm tree. Its filename is mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend.patch *** Remember to use Documentation/SubmitChecklist when testing your code *** See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: mtrr: bSP: save and restore fixed-range MTRRs during suspend From: Bernhard Kaindl <bk@xxxxxxx> Some BIOSes may modify fixed-range MTRRs in SMM, e.g. when they transition the system into ACPI mode, which is entered thru an SMI, triggered by Linux in acpi_enable(). SMIs which cause that Linux is interrupted and BIOS code is executed (which may change e.g. fixed-range MTRRs) in SMM may be raised by an embedded system controller which is often found in notebooks also at other occasions. If we would not update our copy of the fixed-range MTRRs before suspending to RAM or to disk, restore_processor_state() would set the fixed-range MTRRs of the BSP using old backup values which may be outdated and this could cause the system to fail later during resume. This patch ensures that our copy of the fixed-range MTRRs is updated when saving the boot processor state on suspend to disk and suspend to RAM. In combination with other patches this allows to fix s2ram and s2disk on the Acer Ferrari 1000 notebook and at least s2disk on the Acer Ferrari 5000 notebook. Signed-off-by: Bernhard Kaindl <bk@xxxxxxx> Cc: Dave Jones <davej@xxxxxxxxxxxxxxxxx> Cc: Andi Kleen <ak@xxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- arch/i386/power/cpu.c | 1 + arch/x86_64/kernel/suspend.c | 1 + 2 files changed, 2 insertions(+) diff -puN arch/i386/power/cpu.c~mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend arch/i386/power/cpu.c --- a/arch/i386/power/cpu.c~mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend +++ a/arch/i386/power/cpu.c @@ -21,6 +21,7 @@ unsigned long saved_context_eflags; void __save_processor_state(struct saved_context *ctxt) { + mtrr_save_fixed_ranges(NULL); kernel_fpu_begin(); /* diff -puN arch/x86_64/kernel/suspend.c~mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend arch/x86_64/kernel/suspend.c --- a/arch/x86_64/kernel/suspend.c~mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend +++ a/arch/x86_64/kernel/suspend.c @@ -48,6 +48,7 @@ void __save_processor_state(struct saved rdmsrl(MSR_FS_BASE, ctxt->fs_base); rdmsrl(MSR_GS_BASE, ctxt->gs_base); rdmsrl(MSR_KERNEL_GS_BASE, ctxt->gs_kernel_base); + mtrr_save_fixed_ranges(NULL); /* * control registers _ Patches currently in -mm which might be from bk@xxxxxxx are mtrr-implement-mtrr_save_fixed_ranges.patch mtrr-save-the-mtrrs-of-the-bsp-before-booting-an-ap.patch mtrr-bsp-save-and-restore-fixed-range-mtrrs-during-suspend.patch mtrr-enable-fixed-range-iorrs-to-sync-rdmem-and-wrmem.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html