1#include <asm-generic/vmlinux.lds.h> 2 3OUTPUT_FORMAT(ELF_FORMAT) 4OUTPUT_ARCH(ELF_ARCH) 5ENTRY(_start) 6jiffies = jiffies_64; 7 8SECTIONS 9{ 10 /* This must contain the right address - not quite the default ELF one.*/ 11 PROVIDE (__executable_start = START); 12 /* Static binaries stick stuff here, like the sigreturn trampoline, 13 * invisibly to objdump. So, just make __binary_start equal to the very 14 * beginning of the executable, and if there are unmapped pages after this, 15 * they are forever unusable. 16 */ 17 __binary_start = START; 18 19 . = START + SIZEOF_HEADERS; 20 21#ifdef MODE_TT 22 .remap_data : { UNMAP_PATH (.data .bss) } 23 .remap : { UNMAP_PATH (.text) } 24 25 . = ALIGN(4096); /* Init code and data */ 26#endif 27 28 _text = .; 29 _stext = .; 30 __init_begin = .; 31 .init.text : { 32 _sinittext = .; 33 *(.init.text) 34 _einittext = .; 35 } 36 . = ALIGN(4096); 37 38 .text : 39 { 40 *(.text) 41 SCHED_TEXT 42 LOCK_TEXT 43 *(.fixup) 44 /* .gnu.warning sections are handled specially by elf32.em. */ 45 *(.gnu.warning) 46 *(.gnu.linkonce.t*) 47 48 . = ALIGN(4096); 49 __syscall_stub_start = .; 50 *(.__syscall_stub*) 51 __syscall_stub_end = .; 52 . = ALIGN(4096); 53 } 54 55 #include "asm/common.lds.S" 56 57 init.data : { *(init.data) } 58 .data : 59 { 60 . = ALIGN(KERNEL_STACK_SIZE); /* init_task */ 61 *(.data.init_task) 62 *(.data) 63 *(.gnu.linkonce.d*) 64 CONSTRUCTORS 65 } 66 .data1 : { *(.data1) } 67 .ctors : 68 { 69 *(.ctors) 70 } 71 .dtors : 72 { 73 *(.dtors) 74 } 75 76 .got : { *(.got.plt) *(.got) } 77 .dynamic : { *(.dynamic) } 78 .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) } 79 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) } 80 /* We want the small data sections together, so single-instruction offsets 81 can access them all, and initialized data all before uninitialized, so 82 we can shorten the on-disk segment size. */ 83 .sdata : { *(.sdata) } 84 _edata = .; 85 PROVIDE (edata = .); 86 . = ALIGN(0x1000); 87 .sbss : 88 { 89 __bss_start = .; 90 PROVIDE(_bss_start = .); 91 *(.sbss) 92 *(.scommon) 93 } 94 .bss : 95 { 96 *(.dynbss) 97 *(.bss) 98 *(COMMON) 99 } 100 _end = .; 101 PROVIDE (end = .); 102 103 STABS_DEBUG 104 105 DWARF_DEBUG 106} 107