diff options
author | Bernhard Walle <bwalle@suse.de> | 2008-06-08 09:46:31 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-08 04:35:13 -0400 |
commit | 12448e3ef3ae7fca7a7ad205084f45a67dcc4356 (patch) | |
tree | 13454a47ea26ba7e7ca65de286e836e50569234e | |
parent | 8b2ef1d7285740953a2c4ef7faf15fdfc5e2f358 (diff) |
x86: use reserve_bootmem_generic() to reserve crashkernel memory on x86_64
This patch uses reserve_bootmem_generic() instead of reserve_bootmem()
to reserve the crashkernel memory on x86_64. That's necessary for NUMA
machines, see 00212fef814612245ed0261cbac8426d0c9a31a5:
[PATCH] Fix kdump Crash Kernel boot memory reservation for NUMA machines
This patch will fix a boot memory reservation bug that trashes memory on
the ES7000 when loading the kdump crash kernel.
The code in arch/x86_64/kernel/setup.c to reserve boot memory for the crash
kernel uses the non-numa aware "reserve_bootmem" function instead of the
NUMA aware "reserve_bootmem_generic". I checked to make sure that no other
function was using "reserve_bootmem" and found none, except the ones that
had NUMA ifdef'ed out.
I have tested this patch only on an ES7000 with NUMA on and off (numa=off)
in a single (non-NUMA) and multi-cell (NUMA) configurations.
Signed-off-by: Amul Shah <amul.shah@unisys.com>
Looks-good-to: Vivek Goyal <vgoyal@in.ibm.com>
Cc: Andi Kleen <ak@muc.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
The switch-back to reserve_bootmem() was accidentally introduced in
5c3391f9f749023a49c64d607da4fb49263690eb when adding the BOOTMEM_EXCLUSIVE
parameter.
Signed-off-by: Bernhard Walle <bwalle@suse.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/kernel/setup_64.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/kernel/setup_64.c b/arch/x86/kernel/setup_64.c index 26d60cc0e370..ec65696ca2cd 100644 --- a/arch/x86/kernel/setup_64.c +++ b/arch/x86/kernel/setup_64.c | |||
@@ -244,7 +244,7 @@ static void __init reserve_crashkernel(void) | |||
244 | return; | 244 | return; |
245 | } | 245 | } |
246 | 246 | ||
247 | if (reserve_bootmem(crash_base, crash_size, | 247 | if (reserve_bootmem_generic(crash_base, crash_size, |
248 | BOOTMEM_EXCLUSIVE) < 0) { | 248 | BOOTMEM_EXCLUSIVE) < 0) { |
249 | printk(KERN_INFO "crashkernel reservation failed - " | 249 | printk(KERN_INFO "crashkernel reservation failed - " |
250 | "memory is in use\n"); | 250 | "memory is in use\n"); |