[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v2 16/62] x86/link: Relocate program headers
From: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> When the xen binary is loaded by libelf (in the future) we rely on the elf loader to load the binary accordingly. Specify the load address so that the resulting binary can make p_vaddr and p_paddr have different values. Signed-off-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> Signed-off-by: Wei Liu <wei.liu2@xxxxxxxxxx> --- v2: Clarify commit message. Haven't tested grub1 boot. --- xen/arch/x86/xen.lds.S | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/xen/arch/x86/xen.lds.S b/xen/arch/x86/xen.lds.S index 6164ad094f..400d8a56c4 100644 --- a/xen/arch/x86/xen.lds.S +++ b/xen/arch/x86/xen.lds.S @@ -13,6 +13,7 @@ #undef __XEN_VIRT_START #define __XEN_VIRT_START __image_base__ #define SECTION_ALIGN MB(2) +#define DECL_SECTION(x) x : ENTRY(efi_start) @@ -20,8 +21,9 @@ ENTRY(efi_start) #define FORMAT "elf64-x86-64" #define SECTION_ALIGN PAGE_SIZE +#define DECL_SECTION(x) x : AT(ADDR(x) - __XEN_VIRT_START) -ENTRY(start) +ENTRY(start_pa) #endif /* EFI */ @@ -56,9 +58,11 @@ SECTIONS __2M_text_start = .; /* Start of 2M superpages, mapped RX. */ #endif + start_pa = ABSOLUTE(start - __XEN_VIRT_START); + . = __XEN_VIRT_START + XEN_IMG_OFFSET; _start = .; - .text : { + DECL_SECTION(.text) { _stext = .; /* Text and read-only data */ *(.text) *(.text.cold) @@ -73,7 +77,7 @@ SECTIONS __2M_text_end = .; __2M_rodata_start = .; /* Start of 2M superpages, mapped RO. */ - .rodata : { + DECL_SECTION(.rodata) { _srodata = .; /* Bug frames table */ __start_bug_frames = .; @@ -132,13 +136,13 @@ SECTIONS * compiler may want to inject other things in the .note which we don't care * about - hence this unique name. */ - .note.gnu.build-id : { + DECL_SECTION(.note.gnu.build-id) { __note_gnu_build_id_start = .; *(.note.gnu.build-id) __note_gnu_build_id_end = .; } :note :text #elif defined(BUILD_ID_EFI) - .buildid : { + DECL_SECTION(.buildid) { __note_gnu_build_id_start = .; *(.buildid) __note_gnu_build_id_end = .; @@ -153,7 +157,7 @@ SECTIONS __2M_init_start = .; /* Start of 2M superpages, mapped RWX (boot only). */ . = ALIGN(PAGE_SIZE); /* Init code and data */ __init_begin = .; - .init : { + DECL_SECTION(.init) { _sinittext = .; *(.init.text) /* @@ -215,7 +219,7 @@ SECTIONS __2M_rwdata_start = .; /* Start of 2M superpages, mapped RW. */ . = ALIGN(SMP_CACHE_BYTES); - .data.read_mostly : { + DECL_SECTION(.data.read_mostly) { *(.data.read_mostly) . = ALIGN(8); __start_schedulers_array = .; @@ -223,7 +227,7 @@ SECTIONS __end_schedulers_array = .; } :text - .data : { /* Data */ + DECL_SECTION(.data) { *(.data.page_aligned) *(.data) *(.data.rel) @@ -231,7 +235,7 @@ SECTIONS CONSTRUCTORS } :text - .bss : { /* BSS */ + DECL_SECTION(.bss) { __bss_start = .; *(.bss.stack_aligned) *(.bss.page_aligned*) -- 2.11.0 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |