diff options
author | Yinghai Lu <yinghai@kernel.org> | 2009-03-12 19:04:42 -0400 |
---|---|---|
committer | H. Peter Anvin <hpa@zytor.com> | 2009-03-14 20:23:47 -0400 |
commit | 7543c1de84ed93c6769c9f20dced08a522af8912 (patch) | |
tree | dbeab0ab071b86c80b4d7c2701c7b767616772a6 /arch/x86 | |
parent | 6de6cb442e76bbaf2e685150be8ddac0f237a59c (diff) |
x86-32: compute initial mapping size more accurately
Impact: simplification
We only need to map the kernel in head_32.S, not the whole of
lowmem. We use 512MB as a reasonable (but arbitrary) limit on
the maximum size of the kernel image.
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Jeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/include/asm/page_32_types.h | 5 | ||||
-rw-r--r-- | arch/x86/kernel/head_32.S | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/arch/x86/include/asm/page_32_types.h b/arch/x86/include/asm/page_32_types.h index f1e4a79a6e4..0f915ae649a 100644 --- a/arch/x86/include/asm/page_32_types.h +++ b/arch/x86/include/asm/page_32_types.h | |||
@@ -39,6 +39,11 @@ | |||
39 | #define __VIRTUAL_MASK_SHIFT 32 | 39 | #define __VIRTUAL_MASK_SHIFT 32 |
40 | #endif /* CONFIG_X86_PAE */ | 40 | #endif /* CONFIG_X86_PAE */ |
41 | 41 | ||
42 | /* | ||
43 | * Kernel image size is limited to 512 MB (see in arch/x86/kernel/head_32.S) | ||
44 | */ | ||
45 | #define KERNEL_IMAGE_SIZE (512 * 1024 * 1024) | ||
46 | |||
42 | #ifndef __ASSEMBLY__ | 47 | #ifndef __ASSEMBLY__ |
43 | 48 | ||
44 | /* | 49 | /* |
diff --git a/arch/x86/kernel/head_32.S b/arch/x86/kernel/head_32.S index db6652710e9..3ce5456dfbe 100644 --- a/arch/x86/kernel/head_32.S +++ b/arch/x86/kernel/head_32.S | |||
@@ -54,7 +54,7 @@ | |||
54 | * | 54 | * |
55 | * This should be a multiple of a page. | 55 | * This should be a multiple of a page. |
56 | */ | 56 | */ |
57 | LOW_PAGES = 1<<(32-PAGE_SHIFT_asm) | 57 | LOW_PAGES = (KERNEL_IMAGE_SIZE + PAGE_SIZE_asm - 1)>>PAGE_SHIFT |
58 | 58 | ||
59 | /* | 59 | /* |
60 | * To preserve the DMA pool in PAGEALLOC kernels, we'll allocate | 60 | * To preserve the DMA pool in PAGEALLOC kernels, we'll allocate |