The patch titled i386: Convert more absolute symbols to section relative has been added to the -mm tree. Its filename is i386-convert-more-absolute-symbols-to-section-relative.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: i386: Convert more absolute symbols to section relative From: Vivek Goyal <vgoyal@xxxxxxxxxx> o Convert more absolute symbols to section relative to keep the theme in vmlinux.lds.S file and to avoid problem if kernel is relocated. o Also put a message so that in future people can be aware of it and avoid introducing absolute symbols. Signed-off-by: Vivek Goyal <vgoyal@xxxxxxxxxx> Cc: Andi Kleen <ak@xxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/i386/kernel/vmlinux.lds.S | 14 ++++++++++---- 1 files changed, 10 insertions(+), 4 deletions(-) diff -puN arch/i386/kernel/vmlinux.lds.S~i386-convert-more-absolute-symbols-to-section-relative arch/i386/kernel/vmlinux.lds.S --- a/arch/i386/kernel/vmlinux.lds.S~i386-convert-more-absolute-symbols-to-section-relative +++ a/arch/i386/kernel/vmlinux.lds.S @@ -2,6 +2,12 @@ * Written by Martin Mares <mj@xxxxxxxxxxxxxxxxxxxxxxxx>; */ +/* Don't define absolute symbols until and unless you know that symbol + * value is should remain constant even if kernel image is relocated + * at run time. Absolute symbols are not relocated. If symbol value should + * change if kernel is relocated, make the symbol section relative and + * put it inside the section definition. + */ #define LOAD_OFFSET __PAGE_OFFSET #include <asm-generic/vmlinux.lds.h> @@ -61,11 +67,11 @@ SECTIONS CONSTRUCTORS } :data - __start_paravirtprobe = .; .paravirtprobe : AT(ADDR(.paravirtprobe) - LOAD_OFFSET) { + __start_paravirtprobe = .; *(.paravirtprobe) + __stop_paravirtprobe = .; } - __stop_paravirtprobe = .; . = ALIGN(4096); .data_nosave : AT(ADDR(.data_nosave) - LOAD_OFFSET) { @@ -161,11 +167,11 @@ SECTIONS *(.altinstr_replacement) } . = ALIGN(4); - __start_parainstructions = .; .parainstructions : AT(ADDR(.parainstructions) - LOAD_OFFSET) { + __start_parainstructions = .; *(.parainstructions) + __stop_parainstructions = .; } - __stop_parainstructions = .; /* .exit.text is discard at runtime, not link time, to deal with references from .altinstructions and .eh_frame */ .exit.text : AT(ADDR(.exit.text) - LOAD_OFFSET) { *(.exit.text) } _ Patches currently in -mm which might be from vgoyal@xxxxxxxxxx are x86_64-mm-i386-reloc-data-4k-aligned.patch fix-x86_64-mm-i386-reloc-cleanup-align.patch fix-x86_64-mm-i386-reloc-kallsyms.patch i386-mark-config_relocatable-experimental.patch i386-extend-bzimage-protocol-for-relocatable-protected-mode-kernel.patch i386-convert-more-absolute-symbols-to-section-relative.patch clockevents-core-check-for-clock-event-device-handler-being-non-null-before-calling-it.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html