diff options
author | Andi Kleen <ak@suse.de> | 2008-01-30 07:33:17 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:33:17 -0500 |
commit | 751752789162fde69474edfa15935d0a77c0bc17 (patch) | |
tree | 43eef77784989bc25979da1cc128e31fc46b3cea /arch/x86/mm | |
parent | edcd81199dbad5db11ae91b507cec1d46dd94a49 (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.c | 5 | ||||
-rw-r--r-- | arch/x86/mm/numa_64.c | 1 |
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 | ||
179 | unsigned long __meminitdata table_start, table_end; | 179 | static unsigned long __initdata table_start; |
180 | static unsigned long __meminitdata table_end; | ||
180 | 181 | ||
181 | static __meminit void *alloc_low_page(unsigned long *phys) | 182 | static __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); |