[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.10] x86/link: Relocate program headers
commit f575701f3c7a6c6afde7c289058d9d3110a617d1 Author: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> AuthorDate: Wed Nov 22 11:09:41 2017 +0000 Commit: Roger Pau Monne <roger.pau@xxxxxxxxxx> CommitDate: Thu Jan 11 17:51:18 2018 +0000 x86/link: Relocate program headers 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*) -- generated by git-patchbot for /home/xen/git/xen.git#stable-4.10 _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |