1#include <asm/vdso.h> 2 3/* 4 * Linker script for vDSO. This is an ELF shared object prelinked to 5 * its virtual address, and with only one read-only segment. 6 * This script controls its layout. 7 */ 8 9#if defined(BUILD_VDSO64) 10# define SHDR_SIZE 64 11#elif defined(BUILD_VDSO32) || defined(BUILD_VDSOX32) 12# define SHDR_SIZE 40 13#else 14# error unknown VDSO target 15#endif 16 17#define NUM_FAKE_SHDRS 13 18 19SECTIONS 20{ 21 /* 22 * User/kernel shared data is before the vDSO. This may be a little 23 * uglier than putting it after the vDSO, but it avoids issues with 24 * non-allocatable things that dangle past the end of the PT_LOAD 25 * segment. 26 */ 27 28 vvar_start = . - 3 * PAGE_SIZE; 29 vvar_page = vvar_start; 30 31 /* Place all vvars at the offsets in asm/vvar.h. */ 32#define EMIT_VVAR(name, offset) vvar_ ## name = vvar_page + offset; 33#define __VVAR_KERNEL_LDS 34#include <asm/vvar.h> 35#undef __VVAR_KERNEL_LDS 36#undef EMIT_VVAR 37 38 pvclock_page = vvar_start + PAGE_SIZE; 39 hvclock_page = vvar_start + 2 * PAGE_SIZE; 40 41 . = SIZEOF_HEADERS; 42 43 .hash : { *(.hash) } :text 44 .gnu.hash : { *(.gnu.hash) } 45 .dynsym : { *(.dynsym) } 46 .dynstr : { *(.dynstr) } 47 .gnu.version : { *(.gnu.version) } 48 .gnu.version_d : { *(.gnu.version_d) } 49 .gnu.version_r : { *(.gnu.version_r) } 50 51 .dynamic : { *(.dynamic) } :text :dynamic 52 53 .rodata : { 54 *(.rodata*) 55 *(.data*) 56 *(.sdata*) 57 *(.got.plt) *(.got) 58 *(.gnu.linkonce.d.*) 59 *(.bss*) 60 *(.dynbss*) 61 *(.gnu.linkonce.b.*) 62 63 /* 64 * Ideally this would live in a C file, but that won't 65 * work cleanly for x32 until we start building the x32 66 * C code using an x32 toolchain. 67 */ 68 VDSO_FAKE_SECTION_TABLE_START = .; 69 . = . + NUM_FAKE_SHDRS * SHDR_SIZE; 70 VDSO_FAKE_SECTION_TABLE_END = .; 71 } :text 72 73 .fake_shstrtab : { *(.fake_shstrtab) } :text 74 75 76 .note : { *(.note.*) } :text :note 77 78 .eh_frame_hdr : { *(.eh_frame_hdr) } :text :eh_frame_hdr 79 .eh_frame : { KEEP (*(.eh_frame)) } :text 80 81 82 /* 83 * Text is well-separated from actual data: there's plenty of 84 * stuff that isn't used at runtime in between. 85 */ 86 87 .text : { *(.text*) } :text =0x90909090, 88 89 /* 90 * At the end so that eu-elflint stays happy when vdso2c strips 91 * these. A better implementation would avoid allocating space 92 * for these. 93 */ 94 .altinstructions : { *(.altinstructions) } :text 95 .altinstr_replacement : { *(.altinstr_replacement) } :text 96 97 /DISCARD/ : { 98 *(.discard) 99 *(.discard.*) 100 *(__bug_table) 101 } 102} 103 104/* 105 * Very old versions of ld do not recognize this name token; use the constant. 106 */ 107#define PT_GNU_EH_FRAME 0x6474e550 108 109/* 110 * We must supply the ELF program headers explicitly to get just one 111 * PT_LOAD segment, and set the flags explicitly to make segments read-only. 112 */ 113PHDRS 114{ 115 text PT_LOAD FLAGS(5) FILEHDR PHDRS; /* PF_R|PF_X */ 116 dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ 117 note PT_NOTE FLAGS(4); /* PF_R */ 118 eh_frame_hdr PT_GNU_EH_FRAME; 119} 120