diff options
author | Dave Young <dyoung@redhat.com> | 2012-03-28 17:42:47 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-28 20:14:36 -0400 |
commit | 09c71bfd8384278c42f56380365940508194cec0 (patch) | |
tree | 3d11eea3bf9c6b2cad6a36755d155f31a0e229fe /arch | |
parent | eaa3be6add6f327ab0a633e4fee8e6f2cc8c8a4c (diff) |
kdump x86: fix total mem size calculation for reservation
crashkernel reservation need know the total memory size. Current
get_total_mem simply use max_pfn - min_low_pfn. It is wrong because it
will including memory holes in the middle.
Especially for kvm guest with memory > 0xe0000000, there's below in qemu
code: qemu split memory as below:
if (ram_size >= 0xe0000000 ) {
above_4g_mem_size = ram_size - 0xe0000000;
below_4g_mem_size = 0xe0000000;
} else {
below_4g_mem_size = ram_size;
}
So for 4G mem guest, seabios will insert a 512M usable region beyond of
4G. Thus in above case max_pfn - min_low_pfn will be more than original
memsize.
Fixing this issue by using memblock_phys_mem_size() to get the total
memsize.
Signed-off-by: Dave Young <dyoung@redhat.com>
Reviewed-by: WANG Cong <xiyou.wangcong@gmail.com>
Reviewed-by: Simon Horman <horms@verge.net.au>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/x86/kernel/setup.c | 11 |
1 files changed, 1 insertions, 10 deletions
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index 88638883176a..ab77aae4ad9b 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c | |||
@@ -509,15 +509,6 @@ static void __init memblock_x86_reserve_range_setup_data(void) | |||
509 | 509 | ||
510 | #ifdef CONFIG_KEXEC | 510 | #ifdef CONFIG_KEXEC |
511 | 511 | ||
512 | static inline unsigned long long get_total_mem(void) | ||
513 | { | ||
514 | unsigned long long total; | ||
515 | |||
516 | total = max_pfn - min_low_pfn; | ||
517 | |||
518 | return total << PAGE_SHIFT; | ||
519 | } | ||
520 | |||
521 | /* | 512 | /* |
522 | * Keep the crash kernel below this limit. On 32 bits earlier kernels | 513 | * Keep the crash kernel below this limit. On 32 bits earlier kernels |
523 | * would limit the kernel to the low 512 MiB due to mapping restrictions. | 514 | * would limit the kernel to the low 512 MiB due to mapping restrictions. |
@@ -536,7 +527,7 @@ static void __init reserve_crashkernel(void) | |||
536 | unsigned long long crash_size, crash_base; | 527 | unsigned long long crash_size, crash_base; |
537 | int ret; | 528 | int ret; |
538 | 529 | ||
539 | total_mem = get_total_mem(); | 530 | total_mem = memblock_phys_mem_size(); |
540 | 531 | ||
541 | ret = parse_crashkernel(boot_command_line, total_mem, | 532 | ret = parse_crashkernel(boot_command_line, total_mem, |
542 | &crash_size, &crash_base); | 533 | &crash_size, &crash_base); |