OSDN Git Service

auto import from //depot/cupcake/@135843
[android-x86/prebuilt.git] / linux-x86 / toolchain / arm-eabi-4.3.1 / arm-eabi / lib / ldscripts / armelf.xu
1 /* Script for ld -Ur: link w/out relocation, do create constructors */
2 OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm",
3               "elf32-littlearm")
4 OUTPUT_ARCH(arm)
5 ENTRY(_start)
6  /* For some reason, the Solaris linker makes bad executables
7   if gld -r is used and the intermediate file has sections starting
8   at non-zero addresses.  Could be a Solaris ld bug, could be a GNU ld
9   bug.  But for now assigning the zero vmas works.  */
10 SECTIONS
11 {
12   /* Read-only sections, merged into text segment: */
13   .interp       0 : { *(.interp) }
14   .hash         0 : { *(.hash) }
15   .dynsym       0 : { *(.dynsym) }
16   .dynstr       0 : { *(.dynstr) }
17   .gnu.version  0 : { *(.gnu.version) }
18   .gnu.version_d 0: { *(.gnu.version_d) }
19   .gnu.version_r 0: { *(.gnu.version_r) }
20   .rel.init     0 : { *(.rel.init) }
21   .rela.init    0 : { *(.rela.init) }
22   .rel.text     0 : { *(.rel.text) }
23   .rela.text    0 : { *(.rela.text) }
24   .rel.fini     0 : { *(.rel.fini) }
25   .rela.fini    0 : { *(.rela.fini) }
26   .rel.rodata   0 : { *(.rel.rodata) }
27   .rela.rodata  0 : { *(.rela.rodata) }
28   .rel.data.rel.ro 0 : { *(.rel.data.rel.ro) }
29   .rela.data.rel.ro 0 : { *(.rela.data.rel.ro) }
30   .rel.data     0 : { *(.rel.data) }
31   .rela.data    0 : { *(.rela.data) }
32   .rel.tdata    0 : { *(.rel.tdata) }
33   .rela.tdata   0 : { *(.rela.tdata) }
34   .rel.tbss     0 : { *(.rel.tbss) }
35   .rela.tbss    0 : { *(.rela.tbss) }
36   .rel.ctors    0 : { *(.rel.ctors) }
37   .rela.ctors   0 : { *(.rela.ctors) }
38   .rel.dtors    0 : { *(.rel.dtors) }
39   .rela.dtors   0 : { *(.rela.dtors) }
40   .rel.got      0 : { *(.rel.got) }
41   .rela.got     0 : { *(.rela.got) }
42   .rel.bss      0 : { *(.rel.bss) }
43   .rela.bss     0 : { *(.rela.bss) }
44   .rel.plt      0 : { *(.rel.plt) }
45   .rela.plt     0 : { *(.rela.plt) }
46   .init         0 :
47   {
48     KEEP (*(.init))
49   } =0
50   .plt          0 : { *(.plt) }
51   .text         0 :
52   {
53     *(.text .stub)
54     KEEP (*(.text.*personality*))
55     /* .gnu.warning sections are handled specially by elf32.em.  */
56     *(.gnu.warning)
57   } =0
58   .fini         0 :
59   {
60     KEEP (*(.fini))
61   } =0
62   .rodata       0 : { *(.rodata) }
63   .rodata1      0 : { *(.rodata1) }
64   .ARM.extab 0 : { *(.ARM.extab) }
65   .ARM.exidx 0 : { *(.ARM.exidx) }
66   .eh_frame_hdr : { *(.eh_frame_hdr) }
67   .eh_frame     0 : ONLY_IF_RO { KEEP (*(.eh_frame)) }
68   .gcc_except_table 0 : ONLY_IF_RO { *(.gcc_except_table .gcc_except_table.*) }
69   /* Adjust the address for the data segment.  We want to adjust up to
70      the same address within the page on the next page up.  */
71   /* Exception handling  */
72   .eh_frame     0 : ONLY_IF_RW { KEEP (*(.eh_frame)) }
73   .gcc_except_table 0 : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) }
74   /* Thread Local Storage sections  */
75   .tdata        0 : { *(.tdata) }
76   .tbss         0 : { *(.tbss) }
77   .preinit_array   0 :
78   {
79     KEEP (*(.preinit_array))
80   }
81   .init_array   0 :
82   {
83      KEEP (*(SORT(.init_array.*)))
84      KEEP (*(.init_array))
85   }
86   .fini_array   0 :
87   {
88     KEEP (*(.fini_array))
89     KEEP (*(SORT(.fini_array.*)))
90   }
91   .jcr          0 : { KEEP (*(.jcr)) }
92   .dynamic      0 : { *(.dynamic) }
93   .got          0 : { *(.got.plt) *(.got) }
94   .data         0 :
95   {
96     *(.data)
97     KEEP (*(.gnu.linkonce.d.*personality*))
98     SORT(CONSTRUCTORS)
99   }
100   .data1        0 : { *(.data1) }
101   .bss          0 :
102   {
103    *(.dynbss)
104    *(.bss)
105    *(COMMON)
106    /* Align here to ensure that the .bss section occupies space up to
107       _end.  Align after .bss to ensure correct alignment even if the
108       .bss section disappears because there are no input sections.
109       FIXME: Why do we need it? When there is no .bss section, we don't
110       pad the .data section.  */
111   }
112   /* Stabs debugging sections.  */
113   .stab          0 : { *(.stab) }
114   .stabstr       0 : { *(.stabstr) }
115   .stab.excl     0 : { *(.stab.excl) }
116   .stab.exclstr  0 : { *(.stab.exclstr) }
117   .stab.index    0 : { *(.stab.index) }
118   .stab.indexstr 0 : { *(.stab.indexstr) }
119   .comment       0 : { *(.comment) }
120   /* DWARF debug sections.
121      Symbols in the DWARF debugging sections are relative to the beginning
122      of the section so we begin them at 0.  */
123   /* DWARF 1 */
124   .debug          0 : { *(.debug) }
125   .line           0 : { *(.line) }
126   /* GNU DWARF 1 extensions */
127   .debug_srcinfo  0 : { *(.debug_srcinfo) }
128   .debug_sfnames  0 : { *(.debug_sfnames) }
129   /* DWARF 1.1 and DWARF 2 */
130   .debug_aranges  0 : { *(.debug_aranges) }
131   .debug_pubnames 0 : { *(.debug_pubnames) }
132   /* DWARF 2 */
133   .debug_info     0 : { *(.debug_info .gnu.linkonce.wi.*) }
134   .debug_abbrev   0 : { *(.debug_abbrev) }
135   .debug_line     0 : { *(.debug_line) }
136   .debug_frame    0 : { *(.debug_frame) }
137   .debug_str      0 : { *(.debug_str) }
138   .debug_loc      0 : { *(.debug_loc) }
139   .debug_macinfo  0 : { *(.debug_macinfo) }
140   /* SGI/MIPS DWARF 2 extensions */
141   .debug_weaknames 0 : { *(.debug_weaknames) }
142   .debug_funcnames 0 : { *(.debug_funcnames) }
143   .debug_typenames 0 : { *(.debug_typenames) }
144   .debug_varnames  0 : { *(.debug_varnames) }
145     .stack        0 :
146   {
147     *(.stack)
148   }
149   .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
150   .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) }
151 }