1*9a08862aSNagarathnam Muthusamy/* 2*9a08862aSNagarathnam Muthusamy * Linker script for vDSO. This is an ELF shared object prelinked to 3*9a08862aSNagarathnam Muthusamy * its virtual address, and with only one read-only segment. 4*9a08862aSNagarathnam Muthusamy * This script controls its layout. 5*9a08862aSNagarathnam Muthusamy */ 6*9a08862aSNagarathnam Muthusamy 7*9a08862aSNagarathnam Muthusamy#if defined(BUILD_VDSO64) 8*9a08862aSNagarathnam Muthusamy# define SHDR_SIZE 64 9*9a08862aSNagarathnam Muthusamy#elif defined(BUILD_VDSO32) 10*9a08862aSNagarathnam Muthusamy# define SHDR_SIZE 40 11*9a08862aSNagarathnam Muthusamy#else 12*9a08862aSNagarathnam Muthusamy# error unknown VDSO target 13*9a08862aSNagarathnam Muthusamy#endif 14*9a08862aSNagarathnam Muthusamy 15*9a08862aSNagarathnam Muthusamy#define NUM_FAKE_SHDRS 7 16*9a08862aSNagarathnam Muthusamy 17*9a08862aSNagarathnam MuthusamySECTIONS 18*9a08862aSNagarathnam Muthusamy{ 19*9a08862aSNagarathnam Muthusamy /* 20*9a08862aSNagarathnam Muthusamy * User/kernel shared data is before the vDSO. This may be a little 21*9a08862aSNagarathnam Muthusamy * uglier than putting it after the vDSO, but it avoids issues with 22*9a08862aSNagarathnam Muthusamy * non-allocatable things that dangle past the end of the PT_LOAD 23*9a08862aSNagarathnam Muthusamy * segment. Page size is 8192 for both 64-bit and 32-bit vdso binaries 24*9a08862aSNagarathnam Muthusamy */ 25*9a08862aSNagarathnam Muthusamy 26*9a08862aSNagarathnam Muthusamy vvar_start = . -8192; 27*9a08862aSNagarathnam Muthusamy vvar_data = vvar_start; 28*9a08862aSNagarathnam Muthusamy 29*9a08862aSNagarathnam Muthusamy . = SIZEOF_HEADERS; 30*9a08862aSNagarathnam Muthusamy 31*9a08862aSNagarathnam Muthusamy .hash : { *(.hash) } :text 32*9a08862aSNagarathnam Muthusamy .gnu.hash : { *(.gnu.hash) } 33*9a08862aSNagarathnam Muthusamy .dynsym : { *(.dynsym) } 34*9a08862aSNagarathnam Muthusamy .dynstr : { *(.dynstr) } 35*9a08862aSNagarathnam Muthusamy .gnu.version : { *(.gnu.version) } 36*9a08862aSNagarathnam Muthusamy .gnu.version_d : { *(.gnu.version_d) } 37*9a08862aSNagarathnam Muthusamy .gnu.version_r : { *(.gnu.version_r) } 38*9a08862aSNagarathnam Muthusamy 39*9a08862aSNagarathnam Muthusamy .dynamic : { *(.dynamic) } :text :dynamic 40*9a08862aSNagarathnam Muthusamy 41*9a08862aSNagarathnam Muthusamy .rodata : { 42*9a08862aSNagarathnam Muthusamy *(.rodata*) 43*9a08862aSNagarathnam Muthusamy *(.data*) 44*9a08862aSNagarathnam Muthusamy *(.sdata*) 45*9a08862aSNagarathnam Muthusamy *(.got.plt) *(.got) 46*9a08862aSNagarathnam Muthusamy *(.gnu.linkonce.d.*) 47*9a08862aSNagarathnam Muthusamy *(.bss*) 48*9a08862aSNagarathnam Muthusamy *(.dynbss*) 49*9a08862aSNagarathnam Muthusamy *(.gnu.linkonce.b.*) 50*9a08862aSNagarathnam Muthusamy 51*9a08862aSNagarathnam Muthusamy /* 52*9a08862aSNagarathnam Muthusamy * Ideally this would live in a C file: kept in here for 53*9a08862aSNagarathnam Muthusamy * compatibility with x86-64. 54*9a08862aSNagarathnam Muthusamy */ 55*9a08862aSNagarathnam Muthusamy VDSO_FAKE_SECTION_TABLE_START = .; 56*9a08862aSNagarathnam Muthusamy . = . + NUM_FAKE_SHDRS * SHDR_SIZE; 57*9a08862aSNagarathnam Muthusamy VDSO_FAKE_SECTION_TABLE_END = .; 58*9a08862aSNagarathnam Muthusamy } :text 59*9a08862aSNagarathnam Muthusamy 60*9a08862aSNagarathnam Muthusamy .fake_shstrtab : { *(.fake_shstrtab) } :text 61*9a08862aSNagarathnam Muthusamy 62*9a08862aSNagarathnam Muthusamy 63*9a08862aSNagarathnam Muthusamy .note : { *(.note.*) } :text :note 64*9a08862aSNagarathnam Muthusamy 65*9a08862aSNagarathnam Muthusamy .eh_frame_hdr : { *(.eh_frame_hdr) } :text :eh_frame_hdr 66*9a08862aSNagarathnam Muthusamy .eh_frame : { KEEP (*(.eh_frame)) } :text 67*9a08862aSNagarathnam Muthusamy 68*9a08862aSNagarathnam Muthusamy 69*9a08862aSNagarathnam Muthusamy /* 70*9a08862aSNagarathnam Muthusamy * Text is well-separated from actual data: there's plenty of 71*9a08862aSNagarathnam Muthusamy * stuff that isn't used at runtime in between. 72*9a08862aSNagarathnam Muthusamy */ 73*9a08862aSNagarathnam Muthusamy 74*9a08862aSNagarathnam Muthusamy .text : { *(.text*) } :text =0x90909090, 75*9a08862aSNagarathnam Muthusamy 76*9a08862aSNagarathnam Muthusamy /DISCARD/ : { 77*9a08862aSNagarathnam Muthusamy *(.discard) 78*9a08862aSNagarathnam Muthusamy *(.discard.*) 79*9a08862aSNagarathnam Muthusamy *(__bug_table) 80*9a08862aSNagarathnam Muthusamy } 81*9a08862aSNagarathnam Muthusamy} 82*9a08862aSNagarathnam Muthusamy 83*9a08862aSNagarathnam Muthusamy/* 84*9a08862aSNagarathnam Muthusamy * Very old versions of ld do not recognize this name token; use the constant. 85*9a08862aSNagarathnam Muthusamy */ 86*9a08862aSNagarathnam Muthusamy#define PT_GNU_EH_FRAME 0x6474e550 87*9a08862aSNagarathnam Muthusamy 88*9a08862aSNagarathnam Muthusamy/* 89*9a08862aSNagarathnam Muthusamy * We must supply the ELF program headers explicitly to get just one 90*9a08862aSNagarathnam Muthusamy * PT_LOAD segment, and set the flags explicitly to make segments read-only. 91*9a08862aSNagarathnam Muthusamy */ 92*9a08862aSNagarathnam MuthusamyPHDRS 93*9a08862aSNagarathnam Muthusamy{ 94*9a08862aSNagarathnam Muthusamy text PT_LOAD FLAGS(5) FILEHDR PHDRS; /* PF_R|PF_X */ 95*9a08862aSNagarathnam Muthusamy dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ 96*9a08862aSNagarathnam Muthusamy note PT_NOTE FLAGS(4); /* PF_R */ 97*9a08862aSNagarathnam Muthusamy eh_frame_hdr PT_GNU_EH_FRAME; 98*9a08862aSNagarathnam Muthusamy} 99