[PATCH 34/35] x86: Use walk_system_ream_range() instead of referring e820.map directly for tboot

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Yinghai Lu
Date: Thursday, May 13, 2010 - 5:19 pm

So we can make e820 to be __initdata

Signed-off-by: Yinghai Lu <yinghai@kernel.org>
---
 arch/x86/kernel/tboot.c |   22 +++++++++-------------
 1 files changed, 9 insertions(+), 13 deletions(-)

diff --git a/arch/x86/kernel/tboot.c b/arch/x86/kernel/tboot.c
index c2f1b26..20b9531 100644
--- a/arch/x86/kernel/tboot.c
+++ b/arch/x86/kernel/tboot.c
@@ -171,34 +171,30 @@ static void tboot_create_trampoline(void)
 
 #ifdef CONFIG_ACPI_SLEEP
 
-static void add_mac_region(phys_addr_t start, unsigned long size)
+static int
+add_mac_region(unsigned long start_pfn, unsigned long nr_pages, void  *arg)
 {
+	u64 start = start_pfn;
+	u64 size = nr_pages;
 	struct tboot_mac_region *mr;
-	phys_addr_t end = start + size;
 
 	if (tboot->num_mac_regions >= MAX_TB_MAC_REGIONS)
 		panic("tboot: Too many MAC regions\n");
 
 	if (start && size) {
 		mr = &tboot->mac_regions[tboot->num_mac_regions++];
-		mr->start = round_down(start, PAGE_SIZE);
-		mr->size  = round_up(end, PAGE_SIZE) - mr->start;
+		mr->start = start << PAGE_SHIFT;
+		mr->size  = (u32) (size << PAGE_SHIFT);
 	}
+
+	return 0;
 }
 
 static int tboot_setup_sleep(void)
 {
-	int i;
-
 	tboot->num_mac_regions = 0;
 
-	for (i = 0; i < e820.nr_map; i++) {
-		if ((e820.map[i].type != E820_RAM)
-		 && (e820.map[i].type != E820_RESERVED_KERN))
-			continue;
-
-		add_mac_region(e820.map[i].addr, e820.map[i].size);
-	}
+	walk_system_ram_range(0, max_pfn, NULL, add_mac_region);
 
 	tboot->acpi_sinfo.kernel_s3_resume_vector = acpi_wakeup_address;
 
-- 
1.6.4.2

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH -v16 00/35] Use lmb with x86, Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 04/35] lmb: Add lmb_find_area(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 07/35] x86, lmb: Add lmb_to_bootmem(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 11/35] lmb: Add find_memory_core_early(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 12/35] x86, lmb: Add lmb_find_area_node(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 13/35] x86, lmb: Add lmb_free_memory_size(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 14/35] x86, lmb: Add lmb_memory_size(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 18/35] x86: Use lmb to replace early_res, Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 20/35] x86: Remove not used early_res code, Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 28/35] x86: Add sanitize_e820_map(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 29/35] x86: Change e820_saved to __initdata, Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 30/35] x86: Align e820 ram range to page, Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 32/35] x86: Add get_centaur_ram_top(), Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 34/35] x86: Use walk_system_ream_range() instead of ..., Yinghai Lu, (Thu May 13, 5:19 pm)
[PATCH 35/35] x86: make e820 to be __initdata, Yinghai Lu, (Thu May 13, 5:19 pm)
Re: [PATCH 04/35] lmb: Add lmb_find_area(), Benjamin Herrenschmidt, (Thu May 13, 7:16 pm)
Re: [PATCH 08/35] x86,lmb: Add lmb_reserve_area/lmb_free_area, Benjamin Herrenschmidt, (Thu May 13, 7:26 pm)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Benjamin Herrenschmidt, (Thu May 13, 7:29 pm)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Benjamin Herrenschmidt, (Thu May 13, 7:30 pm)
Re: [PATCH 13/35] x86, lmb: Add lmb_free_memory_size(), Benjamin Herrenschmidt, (Thu May 13, 7:31 pm)
Re: [PATCH 14/35] x86, lmb: Add lmb_memory_size(), Benjamin Herrenschmidt, (Thu May 13, 7:31 pm)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Thu May 13, 7:32 pm)
Re: [PATCH 17/35] x86, lmb: Add x86 version of __lmb_find_ ..., Benjamin Herrenschmidt, (Thu May 13, 7:34 pm)
Re: [PATCH 24/35] lmb: Move __alloc_memory_core_early() to ..., Benjamin Herrenschmidt, (Thu May 13, 7:36 pm)
Re: [PATCH 04/35] lmb: Add lmb_find_area(), Yinghai, (Thu May 13, 11:25 pm)
Re: [PATCH 04/35] lmb: Add lmb_find_area(), Benjamin Herrenschmidt, (Fri May 14, 1:12 am)
Re: [PATCH 08/35] x86,lmb: Add lmb_reserve_area/lmb_free_area, Benjamin Herrenschmidt, (Fri May 14, 1:15 am)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Benjamin Herrenschmidt, (Fri May 14, 1:16 am)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Benjamin Herrenschmidt, (Fri May 14, 1:19 am)
Re: [PATCH 13/35] x86, lmb: Add lmb_free_memory_size(), Benjamin Herrenschmidt, (Fri May 14, 1:21 am)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Fri May 14, 1:30 am)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), David Miller, (Fri May 14, 1:30 am)
Re: [PATCH 17/35] x86, lmb: Add x86 version of __lmb_find_ ..., Benjamin Herrenschmidt, (Fri May 14, 1:31 am)
Re: [PATCH 04/35] lmb: Add lmb_find_area(), Yinghai Lu, (Fri May 14, 9:28 am)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Yinghai Lu, (Fri May 14, 9:44 am)
Re: [PATCH 13/35] x86, lmb: Add lmb_free_memory_size(), Benjamin Herrenschmidt, (Fri May 14, 3:20 pm)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Fri May 14, 3:30 pm)
Re: [PATCH 11/35] lmb: Add find_memory_core_early(), Benjamin Herrenschmidt, (Fri May 14, 3:34 pm)
lmb type features., Yinghai, (Fri May 14, 4:51 pm)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Sun May 16, 5:39 pm)
Re: lmb type features., Benjamin Herrenschmidt, (Sun May 16, 5:46 pm)
Re: lmb type features., Yinghai, (Sun May 16, 11:06 pm)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Mon May 17, 12:24 am)
Re: [PATCH 15/35] x86, lmb: Add lmb_reserve_area_overlap_ok(), Benjamin Herrenschmidt, (Mon May 17, 3:01 pm)