1ARCH=aarch64 2MACHINE= 3NOP=0x1f2003d5 4 5SCRIPT_NAME=elf 6ELFSIZE=64 7OUTPUT_FORMAT="elf64-littleaarch64" 8BIG_OUTPUT_FORMAT="elf64-bigaarch64" 9LITTLE_OUTPUT_FORMAT="elf64-littleaarch64" 10NO_REL_RELOCS=yes 11 12TEMPLATE_NAME=elf 13EXTRA_EM_FILE=nto 14 15GENERATE_SHLIB_SCRIPT=yes 16GENERATE_PIE_SCRIPT=yes 17 18MAXPAGESIZE="CONSTANT (MAXPAGESIZE)" 19COMMONPAGESIZE="CONSTANT (COMMONPAGESIZE)" 20SEPARATE_GOTPLT="SIZEOF (.got.plt) >= 24 ? 24 : 0" 21IREL_IN_PLT= 22 23TEXT_START_ADDR=0x400000 24 25TEXT_START_SYMBOLS='PROVIDE (_btext = .);' 26DATA_START_SYMBOLS='PROVIDE (__data_start = .);'; 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# Ensure each PLT entry is aligned to a cache line. 38PLT=".plt ${RELOCATING-0} : ALIGN(16) { *(.plt)${RELOCATING+${IREL_IN_PLT+ *(.iplt)}} }" 39 40 41ELF_INTERPRETER_NAME=\"/usr/lib/ldqnx-64.so.2\" 42