17509ff7cSJens Wiklander/* SPDX-License-Identifier: BSD-2-Clause */ 27509ff7cSJens Wiklander/* 37509ff7cSJens Wiklander * Copyright (c) 2014, STMicroelectronics International N.V. 47509ff7cSJens Wiklander * Copyright (c) 2016-2019, Linaro Limited 57509ff7cSJens Wiklander */ 67509ff7cSJens Wiklander 77509ff7cSJens Wiklander#ifdef ARM32 87509ff7cSJens WiklanderOUTPUT_FORMAT("elf32-littlearm") 97509ff7cSJens WiklanderOUTPUT_ARCH(arm) 107509ff7cSJens Wiklander#endif 117509ff7cSJens Wiklander#ifdef ARM64 127509ff7cSJens WiklanderOUTPUT_FORMAT("elf64-littleaarch64") 137509ff7cSJens WiklanderOUTPUT_ARCH(aarch64) 147509ff7cSJens Wiklander#endif 15*8fab4371Sliushiwei#ifdef RV64 16*8fab4371SliushiweiOUTPUT_ARCH(riscv) 17*8fab4371Sliushiwei#endif 187509ff7cSJens Wiklander 197509ff7cSJens WiklanderENTRY(_ldelf_start) 207509ff7cSJens WiklanderSECTIONS { 217509ff7cSJens Wiklander .text : { 227509ff7cSJens Wiklander __text_start = .; 2301ffca57SJens Wiklander *(.text._ldelf_start) 2401ffca57SJens Wiklander *(.text .text.*) 257509ff7cSJens Wiklander *(.stub) 267509ff7cSJens Wiklander *(.glue_7) 277509ff7cSJens Wiklander *(.glue_7t) 287509ff7cSJens Wiklander *(.gnu.linkonce.t.*) 297509ff7cSJens Wiklander /* Workaround for an erratum in ARM's VFP11 coprocessor */ 307509ff7cSJens Wiklander *(.vfp11_veneer) 317509ff7cSJens Wiklander __text_end = .; 327509ff7cSJens Wiklander } 337a6682fcSRuchika Gupta .note.gnu.property : { *(.note.gnu.property) } 347509ff7cSJens Wiklander .plt : { *(.plt) } 357509ff7cSJens Wiklander 367509ff7cSJens Wiklander .eh_frame : { *(.eh_frame) } 377509ff7cSJens Wiklander .rodata : { 387509ff7cSJens Wiklander *(.gnu.linkonce.r.*) 397509ff7cSJens Wiklander *(.rodata .rodata.*) 407509ff7cSJens Wiklander } 417509ff7cSJens Wiklander /* .ARM.exidx is sorted, so has to go in its own output section. */ 427509ff7cSJens Wiklander .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } 437509ff7cSJens Wiklander .ARM.extab : { *(.ARM.extab*) } 447509ff7cSJens Wiklander .ctors : { *(.ctors) } 457509ff7cSJens Wiklander .dtors : { *(.dtors) } 467509ff7cSJens Wiklander .dynsym : { *(.dynsym) } 477509ff7cSJens Wiklander .dynstr : { *(.dynstr) } 487509ff7cSJens Wiklander .hash : { *(.hash) } 497509ff7cSJens Wiklander 50cfc0f074SJerome Forissier /* 51cfc0f074SJerome Forissier * Relocation sections may be aligned on 4 or 8 bytes. With ALIGN(8) 52cfc0f074SJerome Forissier * we avoid any padding between __reloc_begin and the first relocation. 53cfc0f074SJerome Forissier */ 54cfc0f074SJerome Forissier . = ALIGN(8); 557509ff7cSJens Wiklander __reloc_begin = .; 567509ff7cSJens Wiklander .rel.got : { *(.rel.got) } 577509ff7cSJens Wiklander .rela.got : { *(.rela.got) } 587509ff7cSJens Wiklander .rel.text : { *(.rel.text) *(.rel.gnu.linkonce.t*) } 597509ff7cSJens Wiklander .rela.text : { *(.rela.text) *(.rela.gnu.linkonce.t*) } 607509ff7cSJens Wiklander .rel.data : { *(.rel.data) *(.rel.gnu.linkonce.d*) } 617509ff7cSJens Wiklander .rela.data : { *(.rela.data) *(.rela.gnu.linkonce.d*) } 627509ff7cSJens Wiklander .rel.rodata : { *(.rel.rodata) *(.rel.gnu.linkonce.r*) } 637509ff7cSJens Wiklander .rela.rodata : { *(.rela.rodata) *(.rela.gnu.linkonce.r*) } 647509ff7cSJens Wiklander .rel.dyn : { *(.rel.dyn) } 657509ff7cSJens Wiklander .rela.dyn : { *(.rela.dyn) } 667509ff7cSJens Wiklander .rel.ctors : { *(.rel.ctors) } 677509ff7cSJens Wiklander .rela.ctors : { *(.rela.ctors) } 687509ff7cSJens Wiklander .rel.dtors : { *(.rel.dtors) } 697509ff7cSJens Wiklander .rela.dtors : { *(.rela.dtors) } 707509ff7cSJens Wiklander .rel.init : { *(.rel.init) } 717509ff7cSJens Wiklander .rela.init : { *(.rela.init) } 727509ff7cSJens Wiklander .rel.fini : { *(.rel.fini) } 737509ff7cSJens Wiklander .rela.fini : { *(.rela.fini) } 747509ff7cSJens Wiklander .rel.bss : { *(.rel.bss) } 757509ff7cSJens Wiklander .rela.bss : { *(.rela.bss) } 767509ff7cSJens Wiklander .rel.plt : { *(.rel.plt) } 777509ff7cSJens Wiklander .rela.plt : { *(.rela.plt) } 787509ff7cSJens Wiklander __reloc_end = .; 797509ff7cSJens Wiklander 80054c7904SJerome Forissier /* Page align to allow dropping execute bit for RW data */ 81054c7904SJerome Forissier . = ALIGN(4096); 82054c7904SJerome Forissier 837509ff7cSJens Wiklander .dynamic : { *(.dynamic) } 84054c7904SJerome Forissier .got : { *(.got.plt) *(.got) } 857509ff7cSJens Wiklander 867509ff7cSJens Wiklander .data : { *(.data .data.* .gnu.linkonce.d.*) } 877509ff7cSJens Wiklander .bss : { *(.bss .bss.* .gnu.linkonce.b.* COMMON) } 887509ff7cSJens Wiklander 897509ff7cSJens Wiklander /DISCARD/ : { *(.interp) } 907509ff7cSJens Wiklander} 91