1 /* Script for --shared -z combreloc: shared library, combine & sort relocs */ 2 OUTPUT_FORMAT("elf32-i386", "elf32-i386", 3 "elf32-i386") 4 OUTPUT_ARCH(i386) 5 ENTRY(_start) 6 SEARCH_DIR("/usr/local/google/home/dmitriyz/toolchain/i686-unknown-linux-gnu/lib"); SEARCH_DIR("/usr/local/google/home/dmitriyz/toolchain/lib"); SEARCH_DIR("/usr/local/lib"); SEARCH_DIR("/lib"); SEARCH_DIR("/usr/lib"); 7 SECTIONS 8 { 9 /* Read-only sections, merged into text segment: */ 10 . = 0 + SIZEOF_HEADERS; 11 .hash : { *(.hash) } 12 .dynsym : { *(.dynsym) } 13 .dynstr : { *(.dynstr) } 14 .gnu.version : { *(.gnu.version) } 15 .gnu.version_d : { *(.gnu.version_d) } 16 .gnu.version_r : { *(.gnu.version_r) } 17 .rel.dyn : 18 { 19 *(.rel.init) 20 *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*) 21 *(.rel.fini) 22 *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*) 23 *(.rel.data.rel.ro* .rel.gnu.linkonce.d.rel.ro.*) 24 *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*) 25 *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*) 26 *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*) 27 *(.rel.ctors) 28 *(.rel.dtors) 29 *(.rel.got) 30 *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*) 31 } 32 .rela.dyn : 33 { 34 *(.rela.init) 35 *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*) 36 *(.rela.fini) 37 *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) 38 *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*) 39 *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*) 40 *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*) 41 *(.rela.ctors) 42 *(.rela.dtors) 43 *(.rela.got) 44 *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*) 45 } 46 .rel.plt : { *(.rel.plt) } 47 .rela.plt : { *(.rela.plt) } 48 .init : 49 { 50 KEEP (*(.init)) 51 } =0x90909090 52 .plt : { *(.plt) } 53 .text : 54 { 55 *(.text .stub .text.* .gnu.linkonce.t.*) 56 KEEP (*(.text.*personality*)) 57 /* .gnu.warning sections are handled specially by elf32.em. */ 58 *(.gnu.warning) 59 } =0x90909090 60 .fini : 61 { 62 KEEP (*(.fini)) 63 } =0x90909090 64 PROVIDE (__etext = .); 65 PROVIDE (_etext = .); 66 PROVIDE (etext = .); 67 .rodata : { *(.rodata .rodata.* .gnu.linkonce.r.*) } 68 .rodata1 : { *(.rodata1) } 69 .eh_frame_hdr : { *(.eh_frame_hdr) } 70 .eh_frame : ONLY_IF_RO { KEEP (*(.eh_frame)) } 71 .gcc_except_table : ONLY_IF_RO { *(.gcc_except_table .gcc_except_table.*) } 72 /* Adjust the address for the data segment. We want to adjust up to 73 the same address within the page on the next page up. */ 74 . = ALIGN (0x1000) - ((0x1000 - .) & (0x1000 - 1)); . = DATA_SEGMENT_ALIGN (0x1000, 0x1000); 75 /* Exception handling */ 76 .eh_frame : ONLY_IF_RW { KEEP (*(.eh_frame)) } 77 .gcc_except_table : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) } 78 /* Thread Local Storage sections */ 79 .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) } 80 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) } 81 .preinit_array : 82 { 83 KEEP (*(.preinit_array)) 84 } 85 .init_array : 86 { 87 KEEP (*(SORT(.init_array.*))) 88 KEEP (*(.init_array)) 89 } 90 .fini_array : 91 { 92 KEEP (*(.fini_array)) 93 KEEP (*(SORT(.fini_array.*))) 94 } 95 .ctors : 96 { 97 /* gcc uses crtbegin.o to find the start of 98 the constructors, so we make sure it is 99 first. Because this is a wildcard, it 100 doesn't matter if the user does not 101 actually link against crtbegin.o; the 102 linker won't look for a file to match a 103 wildcard. The wildcard also means that it 104 doesn't matter which directory crtbegin.o 105 is in. */ 106 KEEP (*crtbegin*.o(.ctors)) 107 /* We don't want to include the .ctor section from 108 the crtend.o file until after the sorted ctors. 109 The .ctor section from the crtend file contains the 110 end of ctors marker and it must be last */ 111 KEEP (*(EXCLUDE_FILE (*crtend*.o ) .ctors)) 112 KEEP (*(SORT(.ctors.*))) 113 KEEP (*(.ctors)) 114 } 115 .dtors : 116 { 117 KEEP (*crtbegin*.o(.dtors)) 118 KEEP (*(EXCLUDE_FILE (*crtend*.o ) .dtors)) 119 KEEP (*(SORT(.dtors.*))) 120 KEEP (*(.dtors)) 121 } 122 .jcr : { KEEP (*(.jcr)) } 123 .data.rel.ro : { *(.data.rel.ro.local* .gnu.linkonce.d.rel.ro.local.*) *(.data.rel.ro* .gnu.linkonce.d.rel.ro.*) } 124 .dynamic : { *(.dynamic) } 125 .got : { *(.got) } 126 . = DATA_SEGMENT_RELRO_END (12, .); 127 .got.plt : { *(.got.plt) } 128 .data : 129 { 130 *(.data .data.* .gnu.linkonce.d.*) 131 KEEP (*(.gnu.linkonce.d.*personality*)) 132 SORT(CONSTRUCTORS) 133 } 134 .data1 : { *(.data1) } 135 _edata = .; PROVIDE (edata = .); 136 __bss_start = .; 137 .bss : 138 { 139 *(.dynbss) 140 *(.bss .bss.* .gnu.linkonce.b.*) 141 *(COMMON) 142 /* Align here to ensure that the .bss section occupies space up to 143 _end. Align after .bss to ensure correct alignment even if the 144 .bss section disappears because there are no input sections. 145 FIXME: Why do we need it? When there is no .bss section, we don't 146 pad the .data section. */ 147 . = ALIGN(. != 0 ? 32 / 8 : 1); 148 } 149 . = ALIGN(32 / 8); 150 . = ALIGN(32 / 8); 151 _end = .; PROVIDE (end = .); 152 . = DATA_SEGMENT_END (.); 153 /* Stabs debugging sections. */ 154 .stab 0 : { *(.stab) } 155 .stabstr 0 : { *(.stabstr) } 156 .stab.excl 0 : { *(.stab.excl) } 157 .stab.exclstr 0 : { *(.stab.exclstr) } 158 .stab.index 0 : { *(.stab.index) } 159 .stab.indexstr 0 : { *(.stab.indexstr) } 160 .comment 0 : { *(.comment) } 161 /* DWARF debug sections. 162 Symbols in the DWARF debugging sections are relative to the beginning 163 of the section so we begin them at 0. */ 164 /* DWARF 1 */ 165 .debug 0 : { *(.debug) } 166 .line 0 : { *(.line) } 167 /* GNU DWARF 1 extensions */ 168 .debug_srcinfo 0 : { *(.debug_srcinfo) } 169 .debug_sfnames 0 : { *(.debug_sfnames) } 170 /* DWARF 1.1 and DWARF 2 */ 171 .debug_aranges 0 : { *(.debug_aranges) } 172 .debug_pubnames 0 : { *(.debug_pubnames) } 173 /* DWARF 2 */ 174 .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) } 175 .debug_abbrev 0 : { *(.debug_abbrev) } 176 .debug_line 0 : { *(.debug_line) } 177 .debug_frame 0 : { *(.debug_frame) } 178 .debug_str 0 : { *(.debug_str) } 179 .debug_loc 0 : { *(.debug_loc) } 180 .debug_macinfo 0 : { *(.debug_macinfo) } 181 /* SGI/MIPS DWARF 2 extensions */ 182 .debug_weaknames 0 : { *(.debug_weaknames) } 183 .debug_funcnames 0 : { *(.debug_funcnames) } 184 .debug_typenames 0 : { *(.debug_typenames) } 185 .debug_varnames 0 : { *(.debug_varnames) } 186 /DISCARD/ : { *(.note.GNU-stack) } 187 } 188