|
@@ -119,29 +119,32 @@ void acpi_restore_state_mem(void)
|
|
|
|
|
|
|
|
|
/**
|
|
|
- * acpi_reserve_bootmem - do _very_ early ACPI initialisation
|
|
|
+ * acpi_reserve_wakeup_memory - do _very_ early ACPI initialisation
|
|
|
*
|
|
|
* We allocate a page from the first 1MB of memory for the wakeup
|
|
|
* routine for when we come back from a sleep state. The
|
|
|
* runtime allocator allows specification of <16MB pages, but not
|
|
|
* <1MB pages.
|
|
|
*/
|
|
|
-void __init acpi_reserve_bootmem(void)
|
|
|
+void __init acpi_reserve_wakeup_memory(void)
|
|
|
{
|
|
|
+ unsigned long mem;
|
|
|
+
|
|
|
if ((&wakeup_code_end - &wakeup_code_start) > WAKEUP_SIZE) {
|
|
|
printk(KERN_ERR
|
|
|
"ACPI: Wakeup code way too big, S3 disabled.\n");
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
- acpi_realmode = (unsigned long)alloc_bootmem_low(WAKEUP_SIZE);
|
|
|
+ mem = find_e820_area(0, 1<<20, WAKEUP_SIZE, PAGE_SIZE);
|
|
|
|
|
|
- if (!acpi_realmode) {
|
|
|
+ if (mem == -1L) {
|
|
|
printk(KERN_ERR "ACPI: Cannot allocate lowmem, S3 disabled.\n");
|
|
|
return;
|
|
|
}
|
|
|
-
|
|
|
- acpi_wakeup_address = virt_to_phys((void *)acpi_realmode);
|
|
|
+ acpi_realmode = (unsigned long) phys_to_virt(mem);
|
|
|
+ acpi_wakeup_address = mem;
|
|
|
+ reserve_early(mem, mem + WAKEUP_SIZE, "ACPI WAKEUP");
|
|
|
}
|
|
|
|
|
|
|