blob: 82ed81da497766d002a3e2a9861c775e1b259554 [file] [log] [blame]
Ben Cheng09ebc132013-10-18 00:02:49 -07001/* Script for ld --shared: link shared library */
2OUTPUT_FORMAT("elf64-bigaarch64", "elf64-bigaarch64",
3 "elf64-littleaarch64")
4OUTPUT_ARCH(aarch64)
5ENTRY(_start)
6SECTIONS
7{
8 /* Read-only sections, merged into text segment: */
9 . = 0 + SIZEOF_HEADERS;
10 .note.gnu.build-id : { *(.note.gnu.build-id) }
11 .hash : { *(.hash) }
12 .gnu.hash : { *(.gnu.hash) }
13 .dynsym : { *(.dynsym) }
14 .dynstr : { *(.dynstr) }
15 .gnu.version : { *(.gnu.version) }
16 .gnu.version_d : { *(.gnu.version_d) }
17 .gnu.version_r : { *(.gnu.version_r) }
18 .rela.init : { *(.rela.init) }
19 .rela.text : { *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*) }
20 .rela.fini : { *(.rela.fini) }
21 .rela.rodata : { *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*) }
22 .rela.data.rel.ro : { *(.rela.data.rel.ro .rela.data.rel.ro.* .rela.gnu.linkonce.d.rel.ro.*) }
23 .rela.data : { *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*) }
24 .rela.tdata : { *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*) }
25 .rela.tbss : { *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*) }
26 .rela.ctors : { *(.rela.ctors) }
27 .rela.dtors : { *(.rela.dtors) }
28 .rela.got : { *(.rela.got) }
29 .rela.bss : { *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*) }
30 .rela.ifunc : { *(.rela.ifunc) }
31 .rela.plt :
32 {
33 *(.rela.plt)
34 *(.rela.iplt)
35 }
36 .init :
37 {
38 KEEP (*(SORT_NONE(.init)))
39 } =0
40 .plt : ALIGN(16) { *(.plt) *(.iplt) }
41 .text :
42 {
43 *(.text.unlikely .text.*_unlikely)
44 *(.text.exit .text.exit.*)
45 *(.text.startup .text.startup.*)
46 *(.text.hot .text.hot.*)
47 *(.text .stub .text.* .gnu.linkonce.t.*)
48 /* .gnu.warning sections are handled specially by elf32.em. */
49 *(.gnu.warning)
50 } =0
51 .fini :
52 {
53 KEEP (*(SORT_NONE(.fini)))
54 } =0
55 PROVIDE (__etext = .);
56 PROVIDE (_etext = .);
57 PROVIDE (etext = .);
58 .rodata : { *(.rodata .rodata.* .gnu.linkonce.r.*) }
59 .rodata1 : { *(.rodata1) }
60 .eh_frame_hdr : { *(.eh_frame_hdr) }
61 .eh_frame : ONLY_IF_RO { KEEP (*(.eh_frame)) }
62 .gcc_except_table : ONLY_IF_RO { *(.gcc_except_table
63 .gcc_except_table.*) }
64 /* These sections are generated by the Sun/Oracle C++ compiler. */
65 .exception_ranges : ONLY_IF_RO { *(.exception_ranges
66 .exception_ranges*) }
67 /* Adjust the address for the data segment. We want to align at exactly
68 a page boundary to make life easier for apriori. */
69 . = ALIGN (CONSTANT (MAXPAGESIZE)); . = DATA_SEGMENT_ALIGN (CONSTANT (MAXPAGESIZE), CONSTANT (COMMONPAGESIZE));
70 /* Exception handling */
71 .eh_frame : ONLY_IF_RW { KEEP (*(.eh_frame)) }
72 .gcc_except_table : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) }
73 .exception_ranges : ONLY_IF_RW { *(.exception_ranges .exception_ranges*) }
74 /* Thread Local Storage sections */
75 .tdata : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
76 .tbss : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
77 /* Ensure the __preinit_array_start label is properly aligned. We
78 could instead move the label definition inside the section, but
79 the linker would then create the section even if it turns out to
80 be empty, which isn't pretty. */
81 . = ALIGN(32 / 8);
82 .preinit_array :
83 {
84 KEEP (*(.preinit_array))
85 }
86 .init_array :
87 {
88 KEEP (*crtbegin*.o(.init_array))
89 KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*)))
90 KEEP (*(.init_array))
91 KEEP (*(EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .ctors))
92 }
93 .fini_array :
94 {
95 KEEP (*crtbegin*.o(.fini_array))
96 KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*)))
97 KEEP (*(.fini_array))
98 KEEP (*(EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .dtors))
99 }
100 .ctors :
101 {
102 /* gcc uses crtbegin.o to find the start of
103 the constructors, so we make sure it is
104 first. Because this is a wildcard, it
105 doesn't matter if the user does not
106 actually link against crtbegin.o; the
107 linker won't look for a file to match a
108 wildcard. The wildcard also means that it
109 doesn't matter which directory crtbegin.o
110 is in. */
111 KEEP (*crtbegin.o(.ctors))
112 KEEP (*crtbegin*.o(.ctors))
113 /* We don't want to include the .ctor section from
114 the crtend.o file until after the sorted ctors.
115 The .ctor section from the crtend file contains the
116 end of ctors marker and it must be last */
117 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o ) .ctors))
118 KEEP (*(SORT(.ctors.*)))
119 KEEP (*(.ctors))
120 }
121 .dtors :
122 {
123 KEEP (*crtbegin.o(.dtors))
124 KEEP (*crtbegin*.o(.dtors))
125 KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o ) .dtors))
126 KEEP (*(SORT(.dtors.*)))
127 KEEP (*(.dtors))
128 }
129 .jcr : { KEEP (*(.jcr)) }
130 .data.rel.ro : { *(.data.rel.ro.local* .gnu.linkonce.d.rel.ro.local.*) *(.data.rel.ro .data.rel.ro.* .gnu.linkonce.d.rel.ro.*) }
131 .dynamic : { *(.dynamic) }
132 .got : { *(.got) *(.igot) }
133 . = DATA_SEGMENT_RELRO_END (24, .);
134 .got.plt : { *(.got.plt) *(.igot.plt) }
135 .data :
136 {
137 PROVIDE (__data_start = .);
138 *(.data .data.* .gnu.linkonce.d.*)
139 SORT(CONSTRUCTORS)
140 }
141 .data1 : { *(.data1) }
142 _edata = .; PROVIDE (edata = .);
143 . = .;
144 __bss_start = .;
145 __bss_start__ = .;
146 .bss :
147 {
148 *(.dynbss)
149 *(.bss .bss.* .gnu.linkonce.b.*)
150 *(COMMON)
151 /* Align here to ensure that the .bss section occupies space up to
152 _end. Align after .bss to ensure correct alignment even if the
153 .bss section disappears because there are no input sections. */
154 . = ALIGN(32 / 8);
155 }
156 _bss_end__ = . ; __bss_end__ = . ;
157 . = ALIGN(32 / 8);
158 . = ALIGN(32 / 8);
159 __end__ = . ;
160 _end = .;
161 _bss_end__ = . ; __bss_end__ = . ; __end__ = . ;
162 PROVIDE (end = .);
163 . = DATA_SEGMENT_END (.);
164 /* Stabs debugging sections. */
165 .stab 0 : { *(.stab) }
166 .stabstr 0 : { *(.stabstr) }
167 .stab.excl 0 : { *(.stab.excl) }
168 .stab.exclstr 0 : { *(.stab.exclstr) }
169 .stab.index 0 : { *(.stab.index) }
170 .stab.indexstr 0 : { *(.stab.indexstr) }
171 .comment 0 : { *(.comment) }
172 /* DWARF debug sections.
173 Symbols in the DWARF debugging sections are relative to the beginning
174 of the section so we begin them at 0. */
175 /* DWARF 1 */
176 .debug 0 : { *(.debug) }
177 .line 0 : { *(.line) }
178 /* GNU DWARF 1 extensions */
179 .debug_srcinfo 0 : { *(.debug_srcinfo) }
180 .debug_sfnames 0 : { *(.debug_sfnames) }
181 /* DWARF 1.1 and DWARF 2 */
182 .debug_aranges 0 : { *(.debug_aranges) }
183 .debug_pubnames 0 : { *(.debug_pubnames) }
184 /* DWARF 2 */
185 .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) }
186 .debug_abbrev 0 : { *(.debug_abbrev) }
187 .debug_line 0 : { *(.debug_line) }
188 .debug_frame 0 : { *(.debug_frame) }
189 .debug_str 0 : { *(.debug_str) }
190 .debug_loc 0 : { *(.debug_loc) }
191 .debug_macinfo 0 : { *(.debug_macinfo) }
192 /* SGI/MIPS DWARF 2 extensions */
193 .debug_weaknames 0 : { *(.debug_weaknames) }
194 .debug_funcnames 0 : { *(.debug_funcnames) }
195 .debug_typenames 0 : { *(.debug_typenames) }
196 .debug_varnames 0 : { *(.debug_varnames) }
197 /* DWARF 3 */
198 .debug_pubtypes 0 : { *(.debug_pubtypes) }
199 .debug_ranges 0 : { *(.debug_ranges) }
200 /* DWARF Extension. */
201 .debug_macro 0 : { *(.debug_macro) }
202 .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) KEEP (*(.gnu.attributes)) }
203 .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
204 /DISCARD/ : { *(.note.GNU-stack) *(.gnu_debuglink) *(.gnu.lto_*) *(.mdebug.*) }
205}