aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/mm
diff options
context:
space:
mode:
authorAndi Kleen <ak@suse.de>2008-01-30 07:33:17 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:33:17 -0500
commit751752789162fde69474edfa15935d0a77c0bc17 (patch)
tree43eef77784989bc25979da1cc128e31fc46b3cea /arch/x86/mm
parentedcd81199dbad5db11ae91b507cec1d46dd94a49 (diff)
x86: replace hard coded reservations in 64-bit early boot code with dynamic table
On x86-64 there are several memory allocations before bootmem. To avoid them stomping on each other they used to be all hard coded in bad_area(). Replace this with an array that is filled as needed. This cleans up the code considerably and allows to expand its use. Cc: peterz@infradead.org Signed-off-by: Andi Kleen <ak@suse.de> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'arch/x86/mm')
-rw-r--r--arch/x86/mm/init_64.c5
-rw-r--r--arch/x86/mm/numa_64.c1
2 files changed, 5 insertions, 1 deletions
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c
index 05f12c527b02..8198840c3dcb 100644
--- a/arch/x86/mm/init_64.c
+++ b/arch/x86/mm/init_64.c
@@ -176,7 +176,8 @@ __set_fixmap (enum fixed_addresses idx, unsigned long phys, pgprot_t prot)
176 set_pte_phys(address, phys, prot); 176 set_pte_phys(address, phys, prot);
177} 177}
178 178
179unsigned long __meminitdata table_start, table_end; 179static unsigned long __initdata table_start;
180static unsigned long __meminitdata table_end;
180 181
181static __meminit void *alloc_low_page(unsigned long *phys) 182static __meminit void *alloc_low_page(unsigned long *phys)
182{ 183{
@@ -387,6 +388,8 @@ void __init_refok init_memory_mapping(unsigned long start, unsigned long end)
387 if (!after_bootmem) 388 if (!after_bootmem)
388 mmu_cr4_features = read_cr4(); 389 mmu_cr4_features = read_cr4();
389 __flush_tlb_all(); 390 __flush_tlb_all();
391
392 reserve_early(table_start << PAGE_SHIFT, table_end << PAGE_SHIFT);
390} 393}
391 394
392#ifndef CONFIG_NUMA 395#ifndef CONFIG_NUMA
diff --git a/arch/x86/mm/numa_64.c b/arch/x86/mm/numa_64.c
index 37d429beba96..5d24dc1ec237 100644
--- a/arch/x86/mm/numa_64.c
+++ b/arch/x86/mm/numa_64.c
@@ -102,6 +102,7 @@ static int __init allocate_cachealigned_memnodemap(void)
102 } 102 }
103 pad_addr = (nodemap_addr + pad) & ~pad; 103 pad_addr = (nodemap_addr + pad) & ~pad;
104 memnodemap = phys_to_virt(pad_addr); 104 memnodemap = phys_to_virt(pad_addr);
105 reserve_early(nodemap_addr, nodemap_addr + nodemap_size);
105 106
106 printk(KERN_DEBUG "NUMA: Allocated memnodemap from %lx - %lx\n", 107 printk(KERN_DEBUG "NUMA: Allocated memnodemap from %lx - %lx\n",
107 nodemap_addr, nodemap_addr + nodemap_size); 108 nodemap_addr, nodemap_addr + nodemap_size);