2 /* Copyright (C) 2014-2023 Free Software Foundation, Inc.
3 Copying and distribution of this script, with or without modification,
4 are permitted in any medium without royalty provided the copyright
5 notice and this notice are preserved. */
6 OUTPUT_FORMAT("elf32-iamcu", "elf32-iamcu",
10 SEARCH_DIR("/home/runner/work/tc-build/tc-build/install/x86_64-pc-linux-gnu/lib");
13 /* Read-only sections, merged into text segment: */
14 PROVIDE (__executable_start = SEGMENT_START("text-segment", 0x08048000)); . = SEGMENT_START("text-segment", 0x08048000) + SIZEOF_HEADERS;
15 .interp : { *(.interp) }
16 .note.gnu.build-id : { *(.note.gnu.build-id) }
18 .gnu.hash : { *(.gnu.hash) }
19 .dynsym : { *(.dynsym) }
20 .dynstr : { *(.dynstr) }
21 .gnu.version : { *(.gnu.version) }
22 .gnu.version_d : { *(.gnu.version_d) }
23 .gnu.version_r : { *(.gnu.version_r) }
24 .rel.init : { *(.rel.init) }
25 .rel.text : { *(.rel.text .rel.text.* .rel.gnu.linkonce.t.*) }
26 .rel.fini : { *(.rel.fini) }
27 .rel.rodata : { *(.rel.rodata .rel.rodata.* .rel.gnu.linkonce.r.*) }
28 .rel.data.rel.ro : { *(.rel.data.rel.ro .rel.data.rel.ro.* .rel.gnu.linkonce.d.rel.ro.*) }
29 .rel.data : { *(.rel.data .rel.data.* .rel.gnu.linkonce.d.*) }
30 .rel.tdata : { *(.rel.tdata .rel.tdata.* .rel.gnu.linkonce.td.*) }
31 .rel.tbss : { *(.rel.tbss .rel.tbss.* .rel.gnu.linkonce.tb.*) }
32 .rel.ctors : { *(.rel.ctors) }
33 .rel.dtors : { *(.rel.dtors) }
34 .rel.got : { *(.rel.got) }
35 .rel.bss : { *(.rel.bss .rel.bss.* .rel.gnu.linkonce.b.*) }
36 .rel.ifunc : { *(.rel.ifunc) }
40 PROVIDE_HIDDEN (__rel_iplt_start = .);
42 PROVIDE_HIDDEN (__rel_iplt_end = .);
46 KEEP (*(SORT_NONE(.init)))
48 .plt : { *(.plt) *(.iplt) }
49 .plt.got : { *(.plt.got) }
52 *(.text.unlikely .text.*_unlikely .text.unlikely.*)
53 *(.text.exit .text.exit.*)
54 *(.text.startup .text.startup.*)
55 *(.text.hot .text.hot.*)
56 *(SORT(.text.sorted.*))
57 *(.text .stub .text.* .gnu.linkonce.t.*)
58 /* .gnu.warning sections are handled specially by elf.em. */
63 KEEP (*(SORT_NONE(.fini)))
65 PROVIDE (__etext = .);
68 .rodata : { *(.rodata .rodata.* .gnu.linkonce.r.*) }
69 .rodata1 : { *(.rodata1) }
70 .eh_frame_hdr : { *(.eh_frame_hdr) *(.eh_frame_entry .eh_frame_entry.*) }
71 .eh_frame : ONLY_IF_RO { KEEP (*(.eh_frame)) *(.eh_frame.*) }
72 .sframe : ONLY_IF_RO { *(.sframe) *(.sframe.*) }
73 .gcc_except_table : ONLY_IF_RO { *(.gcc_except_table .gcc_except_table.*) }
74 .gnu_extab : ONLY_IF_RO { *(.gnu_extab*) }
75 /* These sections are generated by the Sun/Oracle C++ compiler. */
76 .exception_ranges : ONLY_IF_RO { *(.exception_ranges*) }
77 /* Adjust the address for the data segment. We want to adjust up to
78 the same address within the page on the next page up. */
79 . = DATA_SEGMENT_ALIGN (CONSTANT (MAXPAGESIZE), CONSTANT (COMMONPAGESIZE));
80 /* Exception handling */
81 .eh_frame : ONLY_IF_RW { KEEP (*(.eh_frame)) *(.eh_frame.*) }
82 .sframe : ONLY_IF_RW { *(.sframe) *(.sframe.*) }
83 .gnu_extab : ONLY_IF_RW { *(.gnu_extab) }
84 .gcc_except_table : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) }
85 .exception_ranges : ONLY_IF_RW { *(.exception_ranges*) }
86 /* Thread Local Storage sections */
89 PROVIDE_HIDDEN (__tdata_start = .);
90 *(.tdata .tdata.* .gnu.linkonce.td.*)
92 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
95 PROVIDE_HIDDEN (__preinit_array_start = .);
96 KEEP (*(.preinit_array))
97 PROVIDE_HIDDEN (__preinit_array_end = .);
101 PROVIDE_HIDDEN (__init_array_start = .);
102 KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*)))
103 KEEP (*(.init_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .ctors))
104 PROVIDE_HIDDEN (__init_array_end = .);
108 PROVIDE_HIDDEN (__fini_array_start = .);
109 KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*)))
110 KEEP (*(.fini_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .dtors))
111 PROVIDE_HIDDEN (__fini_array_end = .);
115 /* gcc uses crtbegin.o to find the start of
116 the constructors, so we make sure it is
117 first. Because this is a wildcard, it
118 doesn't matter if the user does not
119 actually link against crtbegin.o; the
120 linker won't look for a file to match a
121 wildcard. The wildcard also means that it
122 doesn't matter which directory crtbegin.o
124 KEEP (*crtbegin.o(.ctors))
125 KEEP (*crtbegin?.o(.ctors))
126 /* We don't want to include the .ctor section from
127 the crtend.o file until after the sorted ctors.
128 The .ctor section from the crtend file contains the
129 end of ctors marker and it must be last */
130 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .ctors))
131 KEEP (*(SORT(.ctors.*)))
136 KEEP (*crtbegin.o(.dtors))
137 KEEP (*crtbegin?.o(.dtors))
138 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .dtors))
139 KEEP (*(SORT(.dtors.*)))
142 .jcr : { KEEP (*(.jcr)) }
143 .data.rel.ro : { *(.data.rel.ro.local* .gnu.linkonce.d.rel.ro.local.*) *(.data.rel.ro .data.rel.ro.* .gnu.linkonce.d.rel.ro.*) }
144 .dynamic : { *(.dynamic) }
145 .got : { *(.got) *(.igot) }
146 . = DATA_SEGMENT_RELRO_END (SIZEOF (.got.plt) >= 12 ? 12 : 0, .);
147 .got.plt : { *(.got.plt) *(.igot.plt) }
150 *(.data .data.* .gnu.linkonce.d.*)
153 .data1 : { *(.data1) }
154 _edata = .; PROVIDE (edata = .);
160 *(.bss .bss.* .gnu.linkonce.b.*)
162 /* Align here to ensure that the .bss section occupies space up to
163 _end. Align after .bss to ensure correct alignment even if the
164 .bss section disappears because there are no input sections.
165 FIXME: Why do we need it? When there is no .bss section, we do not
166 pad the .data section. */
167 . = ALIGN(. != 0 ? 32 / 8 : 1);
170 . = SEGMENT_START("ldata-segment", .);
172 _end = .; PROVIDE (end = .);
173 . = DATA_SEGMENT_END (.);
174 /* Stabs debugging sections. */
175 .stab 0 : { *(.stab) }
176 .stabstr 0 : { *(.stabstr) }
177 .stab.excl 0 : { *(.stab.excl) }
178 .stab.exclstr 0 : { *(.stab.exclstr) }
179 .stab.index 0 : { *(.stab.index) }
180 .stab.indexstr 0 : { *(.stab.indexstr) }
181 .comment 0 : { *(.comment) }
182 .gnu.build.attributes : { *(.gnu.build.attributes .gnu.build.attributes.*) }
183 /* DWARF debug sections.
184 Symbols in the DWARF debugging sections are relative to the beginning
185 of the section so we begin them at 0. */
187 .debug 0 : { *(.debug) }
188 .line 0 : { *(.line) }
189 /* GNU DWARF 1 extensions. */
190 .debug_srcinfo 0 : { *(.debug_srcinfo) }
191 .debug_sfnames 0 : { *(.debug_sfnames) }
192 /* DWARF 1.1 and DWARF 2. */
193 .debug_aranges 0 : { *(.debug_aranges) }
194 .debug_pubnames 0 : { *(.debug_pubnames) }
196 .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
197 .debug_abbrev 0 : { *(.debug_abbrev) }
198 .debug_line 0 : { *(.debug_line .debug_line.* .debug_line_end) }
199 .debug_frame 0 : { *(.debug_frame) }
200 .debug_str 0 : { *(.debug_str) }
201 .debug_loc 0 : { *(.debug_loc) }
202 .debug_macinfo 0 : { *(.debug_macinfo) }
203 /* SGI/MIPS DWARF 2 extensions. */
204 .debug_weaknames 0 : { *(.debug_weaknames) }
205 .debug_funcnames 0 : { *(.debug_funcnames) }
206 .debug_typenames 0 : { *(.debug_typenames) }
207 .debug_varnames 0 : { *(.debug_varnames) }
209 .debug_pubtypes 0 : { *(.debug_pubtypes) }
210 .debug_ranges 0 : { *(.debug_ranges) }
212 .debug_addr 0 : { *(.debug_addr) }
213 .debug_line_str 0 : { *(.debug_line_str) }
214 .debug_loclists 0 : { *(.debug_loclists) }
215 .debug_macro 0 : { *(.debug_macro) }
216 .debug_names 0 : { *(.debug_names) }
217 .debug_rnglists 0 : { *(.debug_rnglists) }
218 .debug_str_offsets 0 : { *(.debug_str_offsets) }
219 .debug_sup 0 : { *(.debug_sup) }
220 .gnu.attributes 0 : { KEEP (*(.gnu.attributes)) }
221 /DISCARD/ : { *(.note.GNU-stack) *(.gnu_debuglink) *(.gnu.lto_*) }