xref: /netbsd-src/external/gpl3/binutils.old/dist/ld/emulparams/armelf.sh (revision e992f068c547fd6e84b3f104dc2340adcc955732)
1MACHINE=
2SCRIPT_NAME=elf
3OUTPUT_FORMAT="elf32-littlearm"
4BIG_OUTPUT_FORMAT="elf32-bigarm"
5LITTLE_OUTPUT_FORMAT="elf32-littlearm"
6TEXT_START_ADDR=0x8000
7TEMPLATE_NAME=elf
8EXTRA_EM_FILE=armelf
9OTHER_TEXT_SECTIONS='*(.glue_7t) *(.glue_7) *(.vfp11_veneer) *(.v4_bx)'
10OTHER_BSS_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__bss_start__ = .${CREATE_SHLIB+)};"
11OTHER_BSS_END_SYMBOLS="${CREATE_SHLIB+PROVIDE (}_bss_end__ = .${CREATE_SHLIB+)}; ${CREATE_SHLIB+PROVIDE (}__bss_end__ = .${CREATE_SHLIB+)};"
12OTHER_END_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__end__ = .${CREATE_SHLIB+)};"
13OTHER_SECTIONS='.note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }'
14ATTRS_SECTIONS='.ARM.attributes 0 : { KEEP (*(.ARM.attributes)) KEEP (*(.gnu.attributes)) }'
15OTHER_READONLY_SECTIONS="
16  .ARM.extab ${RELOCATING-0} : { *(.ARM.extab${RELOCATING+* .gnu.linkonce.armextab.*}) }
17  .ARM.exidx ${RELOCATING-0} :
18    {
19      ${RELOCATING+PROVIDE_HIDDEN (__exidx_start = .);}
20      *(.ARM.exidx${RELOCATING+* .gnu.linkonce.armexidx.*})
21      ${RELOCATING+PROVIDE_HIDDEN (__exidx_end = .);}
22    }"
23
24DATA_START_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__data_start = .${CREATE_SHLIB+)};"
25
26GENERATE_SHLIB_SCRIPT=yes
27GENERATE_PIE_SCRIPT=yes
28
29ARCH=arm
30MACHINE=
31MAXPAGESIZE="CONSTANT (MAXPAGESIZE)"
32ENTRY=_start
33EMBEDDED=yes
34
35# This sets the stack to the top of the simulator memory (2^19 bytes).
36STACK_ADDR=0x80000
37
38# ARM does not support .s* sections.
39NO_SMALL_DATA=yes
40
41# ARM supports the .noinit and .persistent sections.
42HAVE_NOINIT=yes
43HAVE_PERSISTENT=yes
44