intel/sandybridge: Use common ACPI S3 recovery
Fix regression, S3 resume not working on sandy/ivy after commit
9d6f365
ACPI S3: Remove HIGH_MEMORY_SAVE where possible
There is some 20ms delay with ACPI S3 wakeup time due to MTRR setup
being done after the backup copy. Moving to RELOCATABLE_RAMSTAGE fixes
this delay by removing need of this backup entirely.
Change-Id: Ib72ff914f5dfef8611f5f6cf9687495779013b02
Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com>
Reviewed-on: https://review.coreboot.org/15248
Tested-by: build bot (Jenkins)
Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
5ecc41b0c9
commit
9b9915284f
3 changed files with 2 additions and 37 deletions
|
@ -17,8 +17,6 @@
|
||||||
#include <cpu/x86/mtrr.h>
|
#include <cpu/x86/mtrr.h>
|
||||||
#include <cpu/x86/cache.h>
|
#include <cpu/x86/cache.h>
|
||||||
#include <cpu/x86/post_code.h>
|
#include <cpu/x86/post_code.h>
|
||||||
#include <arch/acpi.h>
|
|
||||||
#include "northbridge/intel/sandybridge/sandybridge.h"
|
|
||||||
|
|
||||||
/* The full cache-as-ram size includes the cache-as-ram portion from coreboot
|
/* The full cache-as-ram size includes the cache-as-ram portion from coreboot
|
||||||
* and the space used by the reference code. These 2 values combined should
|
* and the space used by the reference code. These 2 values combined should
|
||||||
|
@ -284,27 +282,6 @@ before_romstage:
|
||||||
|
|
||||||
post_code(0x3c)
|
post_code(0x3c)
|
||||||
|
|
||||||
#if CONFIG_HAVE_ACPI_RESUME
|
|
||||||
movl CBMEM_BOOT_MODE, %eax
|
|
||||||
cmpl $0x2, %eax // Resume?
|
|
||||||
jne __acpi_resume_backup_done
|
|
||||||
|
|
||||||
/* copy 1MB - 64K to high tables ram_base to prevent memory corruption
|
|
||||||
* through stage 2. We could keep stuff like stack and heap in high
|
|
||||||
* tables memory completely, but that's a wonderful clean up task for
|
|
||||||
* another day.
|
|
||||||
*/
|
|
||||||
cld
|
|
||||||
movl $CONFIG_RAMBASE, %esi
|
|
||||||
movl CBMEM_RESUME_BACKUP, %edi
|
|
||||||
movl $HIGH_MEMORY_SAVE >> 2, %ecx
|
|
||||||
rep movsl
|
|
||||||
|
|
||||||
__acpi_resume_backup_done:
|
|
||||||
#endif
|
|
||||||
|
|
||||||
post_code(0x3d)
|
|
||||||
|
|
||||||
__main:
|
__main:
|
||||||
post_code(POST_PREPARE_RAMSTAGE)
|
post_code(POST_PREPARE_RAMSTAGE)
|
||||||
cld /* Clear direction flag. */
|
cld /* Clear direction flag. */
|
||||||
|
|
|
@ -233,15 +233,9 @@ void northbridge_romstage_finalize(int s3resume)
|
||||||
* this is not a resume. In that case we just create the cbmem toc.
|
* this is not a resume. In that case we just create the cbmem toc.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
*(u32 *)CBMEM_BOOT_MODE = 0;
|
|
||||||
*(u32 *)CBMEM_RESUME_BACKUP = 0;
|
|
||||||
|
|
||||||
if (s3resume) {
|
if (s3resume) {
|
||||||
void *resume_backup_memory = cbmem_find(CBMEM_ID_RESUME);
|
acpi_prepare_for_resume();
|
||||||
if (resume_backup_memory) {
|
|
||||||
*(u32 *)CBMEM_BOOT_MODE = 2;
|
|
||||||
*(u32 *)CBMEM_RESUME_BACKUP = (u32)resume_backup_memory;
|
|
||||||
}
|
|
||||||
/* Magic for S3 resume */
|
/* Magic for S3 resume */
|
||||||
pci_write_config32(PCI_DEV(0, 0x00, 0), SKPAD, 0xcafed00d);
|
pci_write_config32(PCI_DEV(0, 0x00, 0), SKPAD, 0xcafed00d);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -196,12 +196,6 @@
|
||||||
|
|
||||||
#define DMIDRCCFG 0xeb4 /* 32bit */
|
#define DMIDRCCFG 0xeb4 /* 32bit */
|
||||||
|
|
||||||
/* Delegation of resume backup memory so we don't have to
|
|
||||||
* (slowly) handle backing up OS memory in romstage.c
|
|
||||||
*/
|
|
||||||
#define CBMEM_BOOT_MODE 0x610
|
|
||||||
#define CBMEM_RESUME_BACKUP 0x614
|
|
||||||
|
|
||||||
#ifndef __ASSEMBLER__
|
#ifndef __ASSEMBLER__
|
||||||
static inline void barrier(void) { asm("" ::: "memory"); }
|
static inline void barrier(void) { asm("" ::: "memory"); }
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue