1ARCH="aarch64:ilp32"
2MACHINE=
3NOP=0x1f2003d5
4
5SCRIPT_NAME=elf
6ELFSIZE=32
7OUTPUT_FORMAT="elf32-littleaarch64"
8BIG_OUTPUT_FORMAT="elf32-bigaarch64"
9LITTLE_OUTPUT_FORMAT="elf32-littleaarch64"
10NO_REL_RELOCS=yes
11
12TEMPLATE_NAME=elf
13EXTRA_EM_FILE=aarch64elf
14
15GENERATE_SHLIB_SCRIPT=yes
16GENERATE_PIE_SCRIPT=yes
17
18MAXPAGESIZE="CONSTANT (MAXPAGESIZE)"
19
20ENTRY=_start
21EMBEDDED=yes
22SEPARATE_GOTPLT=12
23IREL_IN_PLT=
24TEXT_START_ADDR=0x00400000
25
26DATA_START_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__data_start = .${CREATE_SHLIB+)};"
27
28# AArch64 does not support .s* sections.
29NO_SMALL_DATA=yes
30
31OTHER_BSS_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__bss_start__ = .${CREATE_SHLIB+)};"
32OTHER_BSS_END_SYMBOLS="${CREATE_SHLIB+PROVIDE (}_bss_end__ = .${CREATE_SHLIB+)}; ${CREATE_SHLIB+PROVIDE (}__bss_end__ = .${CREATE_SHLIB+)};"
33OTHER_END_SYMBOLS="${CREATE_SHLIB+PROVIDE (}__end__ = .${CREATE_SHLIB+)};"
34
35OTHER_SECTIONS='.note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }'
36ATTRS_SECTIONS='.ARM.attributes 0 : { KEEP (*(.ARM.attributes)) KEEP (*(.gnu.attributes)) }'
37
38# This sets the stack to the top of the simulator memory (2^19 bytes).
39STACK_ADDR=0x80000
40