diff options
author | Sam Ravnborg <sam@ravnborg.org> | 2009-04-29 03:47:28 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-04-29 04:20:34 -0400 |
commit | 9d16e78318f174fd4b07916a93e41749d5199267 (patch) | |
tree | ca6c0cdbd651aeef4df3b0d6c2b9c05c0e8cbebd /arch/x86/kernel/vmlinux.lds.S | |
parent | bf6a57418d5445c98047edbec022c9e54d1526e6 (diff) |
x86, vmlinux.lds: unify percpu
32 bit:
- move __init_end outside the .bss output section
It really did not belong in there
[ Impact: 64-bit: cleanup, 32-bit: refactor linker script ]
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Cc: Tim Abbott <tabbott@MIT.EDU>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
LKML-Reference: <1240991249-27117-12-git-send-email-sam@ravnborg.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/vmlinux.lds.S')
-rw-r--r-- | arch/x86/kernel/vmlinux.lds.S | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/arch/x86/kernel/vmlinux.lds.S b/arch/x86/kernel/vmlinux.lds.S index 1ab62a5fa1a5..1ea2b8571e1a 100644 --- a/arch/x86/kernel/vmlinux.lds.S +++ b/arch/x86/kernel/vmlinux.lds.S | |||
@@ -330,6 +330,36 @@ SECTIONS | |||
330 | } | 330 | } |
331 | #endif | 331 | #endif |
332 | 332 | ||
333 | #if defined(CONFIG_X86_64) && defined(CONFIG_SMP) | ||
334 | /* | ||
335 | * percpu offsets are zero-based on SMP. PERCPU_VADDR() changes the | ||
336 | * output PHDR, so the next output section - __data_nosave - should | ||
337 | * start another section data.init2. Also, pda should be at the head of | ||
338 | * percpu area. Preallocate it and define the percpu offset symbol | ||
339 | * so that it can be accessed as a percpu variable. | ||
340 | */ | ||
341 | . = ALIGN(PAGE_SIZE); | ||
342 | PERCPU_VADDR(0, :percpu) | ||
343 | #else | ||
344 | PERCPU(PAGE_SIZE) | ||
345 | #endif | ||
346 | |||
347 | . = ALIGN(PAGE_SIZE); | ||
348 | /* freed after init ends here */ | ||
349 | __init_end = .; | ||
350 | |||
351 | #ifdef CONFIG_X86_64 | ||
352 | .data_nosave : AT(ADDR(.data_nosave) - LOAD_OFFSET) { | ||
353 | . = ALIGN(PAGE_SIZE); | ||
354 | __nosave_begin = .; | ||
355 | *(.data.nosave) | ||
356 | . = ALIGN(PAGE_SIZE); | ||
357 | __nosave_end = .; | ||
358 | } :data.init2 | ||
359 | /* use another section data.init2, see PERCPU_VADDR() above */ | ||
360 | #endif | ||
361 | |||
362 | |||
333 | #ifdef CONFIG_X86_32 | 363 | #ifdef CONFIG_X86_32 |
334 | # include "vmlinux_32.lds.S" | 364 | # include "vmlinux_32.lds.S" |
335 | #else | 365 | #else |