aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2008-02-21 07:45:16 -0500
committerIngo Molnar <mingo@elte.hu>2008-04-17 11:40:45 -0400
commitb4e0409a36f4533770a12095bde2a574a08a319e (patch)
treeb160009adc4a6fb836dcd277da668c6a174c273f /arch
parent223ac2f42d49dd0324ca02ea15897ead1a2f5133 (diff)
x86: check vmlinux limits, 64-bit
these build-time and link-time checks would have prevented the vmlinux size regression. Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/kernel/head64.c13
-rw-r--r--arch/x86/kernel/vmlinux_64.lds.S6
-rw-r--r--arch/x86/mm/fault.c4
3 files changed, 19 insertions, 4 deletions
diff --git a/arch/x86/kernel/head64.c b/arch/x86/kernel/head64.c
index ad2440832de0..38f32e798a99 100644
--- a/arch/x86/kernel/head64.c
+++ b/arch/x86/kernel/head64.c
@@ -82,6 +82,19 @@ void __init x86_64_start_kernel(char * real_mode_data)
82{ 82{
83 int i; 83 int i;
84 84
85 /*
86 * Build-time sanity checks on the kernel image and module
87 * area mappings. (these are purely build-time and produce no code)
88 */
89 BUILD_BUG_ON(MODULES_VADDR < KERNEL_IMAGE_START);
90 BUILD_BUG_ON(MODULES_VADDR-KERNEL_IMAGE_START < KERNEL_IMAGE_SIZE);
91 BUILD_BUG_ON(MODULES_LEN + KERNEL_IMAGE_SIZE > 2*PUD_SIZE);
92 BUILD_BUG_ON((KERNEL_IMAGE_START & ~PMD_MASK) != 0);
93 BUILD_BUG_ON((MODULES_VADDR & ~PMD_MASK) != 0);
94 BUILD_BUG_ON(!(MODULES_VADDR > __START_KERNEL));
95 BUILD_BUG_ON(!(((MODULES_END - 1) & PGDIR_MASK) ==
96 (__START_KERNEL & PGDIR_MASK)));
97
85 /* clear bss before set_intr_gate with early_idt_handler */ 98 /* clear bss before set_intr_gate with early_idt_handler */
86 clear_bss(); 99 clear_bss();
87 100
diff --git a/arch/x86/kernel/vmlinux_64.lds.S b/arch/x86/kernel/vmlinux_64.lds.S
index fab132299735..4c369451007b 100644
--- a/arch/x86/kernel/vmlinux_64.lds.S
+++ b/arch/x86/kernel/vmlinux_64.lds.S
@@ -247,3 +247,9 @@ SECTIONS
247 247
248 DWARF_DEBUG 248 DWARF_DEBUG
249} 249}
250
251/*
252 * Build-time check on the image size:
253 */
254ASSERT((_end - _text <= KERNEL_IMAGE_SIZE),
255 "kernel image bigger than KERNEL_IMAGE_SIZE")
diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c
index ec08d8389850..81fcbeec3892 100644
--- a/arch/x86/mm/fault.c
+++ b/arch/x86/mm/fault.c
@@ -976,9 +976,5 @@ void vmalloc_sync_all(void)
976 if (address == start) 976 if (address == start)
977 start = address + PGDIR_SIZE; 977 start = address + PGDIR_SIZE;
978 } 978 }
979 /* Check that there is no need to do the same for the modules area. */
980 BUILD_BUG_ON(!(MODULES_VADDR > __START_KERNEL));
981 BUILD_BUG_ON(!(((MODULES_END - 1) & PGDIR_MASK) ==
982 (__START_KERNEL & PGDIR_MASK)));
983#endif 979#endif
984} 980}