Home | History | Annotate | Download | only in ldscripts
      1 /* Script for -pie -z combreloc -z now -z relro: position independent executable, combine & sort relocs */
      2 /* Copyright (C) 2014 Free Software Foundation, Inc.
      3    Copying and distribution of this script, with or without modification,
      4    are permitted in any medium without royalty provided the copyright
      5    notice and this notice are preserved.  */
      6 OUTPUT_FORMAT("elf64-bigaarch64", "elf64-bigaarch64",
      7 	      "elf64-littleaarch64")
      8 OUTPUT_ARCH(aarch64)
      9 ENTRY(_start)
     10 SECTIONS
     11 {
     12   /* Read-only sections, merged into text segment: */
     13   PROVIDE (__executable_start = 0); . = 0 + SIZEOF_HEADERS;
     14   .interp         : { *(.interp) }
     15   .note.gnu.build-id : { *(.note.gnu.build-id) }
     16   .hash           : { *(.hash) }
     17   .gnu.hash       : { *(.gnu.hash) }
     18   .dynsym         : { *(.dynsym) }
     19   .dynstr         : { *(.dynstr) }
     20   .gnu.version    : { *(.gnu.version) }
     21   .gnu.version_d  : { *(.gnu.version_d) }
     22   .gnu.version_r  : { *(.gnu.version_r) }
     23   .rela.dyn       :
     24     {
     25       *(.rela.init)
     26       *(.rela.text .rela.text.* .rela.gnu.linkonce.t.*)
     27       *(.rela.fini)
     28       *(.rela.rodata .rela.rodata.* .rela.gnu.linkonce.r.*)
     29       *(.rela.data .rela.data.* .rela.gnu.linkonce.d.*)
     30       *(.rela.tdata .rela.tdata.* .rela.gnu.linkonce.td.*)
     31       *(.rela.tbss .rela.tbss.* .rela.gnu.linkonce.tb.*)
     32       *(.rela.ctors)
     33       *(.rela.dtors)
     34       *(.rela.got)
     35       *(.rela.bss .rela.bss.* .rela.gnu.linkonce.b.*)
     36       *(.rela.ifunc)
     37     }
     38   .rela.plt       :
     39     {
     40       *(.rela.plt)
     41       PROVIDE_HIDDEN (__rela_iplt_start = .);
     42       *(.rela.iplt)
     43       PROVIDE_HIDDEN (__rela_iplt_end = .);
     44     }
     45   .init           :
     46   {
     47     KEEP (*(SORT_NONE(.init)))
     48   } =0
     49   .plt            : ALIGN(16) { *(.plt) *(.iplt) }
     50   .text           :
     51   {
     52     *(.text.unlikely .text.*_unlikely .text.unlikely.*)
     53     *(.text.exit .text.exit.*)
     54     *(.text.startup .text.startup.*)
     55     *(.text.hot .text.hot.*)
     56     *(.text .stub .text.* .gnu.linkonce.t.*)
     57     /* .gnu.warning sections are handled specially by elf32.em.  */
     58     *(.gnu.warning)
     59   } =0
     60   .fini           :
     61   {
     62     KEEP (*(SORT_NONE(.fini)))
     63   } =0
     64   PROVIDE (__etext = .);
     65   PROVIDE (_etext = .);
     66   PROVIDE (etext = .);
     67   .rodata         : { *(.rodata .rodata.* .gnu.linkonce.r.*) }
     68   .rodata1        : { *(.rodata1) }
     69   .eh_frame_hdr : { *(.eh_frame_hdr) }
     70   .eh_frame       : ONLY_IF_RO { KEEP (*(.eh_frame)) }
     71   .gcc_except_table   : ONLY_IF_RO { *(.gcc_except_table
     72   .gcc_except_table.*) }
     73   /* These sections are generated by the Sun/Oracle C++ compiler.  */
     74   .exception_ranges   : ONLY_IF_RO { *(.exception_ranges
     75   .exception_ranges*) }
     76   /* Adjust the address for the data segment.  For 32 bits we want to align
     77   at exactly a page boundary to make life easier for apriori. */
     78   . = ALIGN (CONSTANT (MAXPAGESIZE)) - ((CONSTANT (MAXPAGESIZE) - .) & (CONSTANT (MAXPAGESIZE) - 1)); . = DATA_SEGMENT_ALIGN (CONSTANT (MAXPAGESIZE), CONSTANT (COMMONPAGESIZE));
     79   /* Exception handling  */
     80   .eh_frame       : ONLY_IF_RW { KEEP (*(.eh_frame)) }
     81   .gcc_except_table   : ONLY_IF_RW { *(.gcc_except_table .gcc_except_table.*) }
     82   .exception_ranges   : ONLY_IF_RW { *(.exception_ranges .exception_ranges*) }
     83   /* Thread Local Storage sections  */
     84   .tdata	  : { *(.tdata .tdata.* .gnu.linkonce.td.*) }
     85   .tbss		  : { *(.tbss .tbss.* .gnu.linkonce.tb.*) *(.tcommon) }
     86   /* Ensure the __preinit_array_start label is properly aligned.  We
     87      could instead move the label definition inside the section, but
     88      the linker would then create the section even if it turns out to
     89      be empty, which isn't pretty.  */
     90   . = ALIGN(64 / 8);
     91   PROVIDE_HIDDEN (__preinit_array_start = .);
     92   .preinit_array     :
     93   {
     94     KEEP (*(.preinit_array))
     95   }
     96   PROVIDE_HIDDEN (__preinit_array_end = .);
     97   PROVIDE_HIDDEN (__init_array_start = .);
     98   .init_array     :
     99   {
    100     KEEP (*crtbegin*.o(.init_array))
    101     KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*)))
    102     KEEP (*(.init_array EXCLUDE_FILE (*crtbegin.o *crtbegin*.o *crtend.o *crtend*.o ) .ctors))
    103   }
    104   PROVIDE_HIDDEN (__init_array_end = .);
    105   PROVIDE_HIDDEN (__fini_array_start = .);
    106   .fini_array     :
    107   {
    108     KEEP (*crtbegin*.o(.fini_array))
    109     KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*)))
    110     KEEP (*(.fini_array EXCLUDE_FILE (*crtbegin.o *crtbegin*.o *crtend.o *crtend*.o ) .dtors))
    111   }
    112   PROVIDE_HIDDEN (__fini_array_end = .);
    113   .ctors          :
    114   {
    115     /* gcc uses crtbegin.o to find the start of
    116        the constructors, so we make sure it is
    117        first.  Because this is a wildcard, it
    118        doesn't matter if the user does not
    119        actually link against crtbegin.o; the
    120        linker won't look for a file to match a
    121        wildcard.  The wildcard also means that it
    122        doesn't matter which directory crtbegin.o
    123        is in.  */
    124     KEEP (*crtbegin.o(.ctors))
    125     KEEP (*crtbegin*.o(.ctors))
    126     /* We don't want to include the .ctor section from
    127        the crtend.o file until after the sorted ctors.
    128        The .ctor section from the crtend file contains the
    129        end of ctors marker and it must be last */
    130     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o ) .ctors))
    131     KEEP (*(SORT(.ctors.*)))
    132     KEEP (*(.ctors))
    133   }
    134   .dtors          :
    135   {
    136     KEEP (*crtbegin.o(.dtors))
    137     KEEP (*crtbegin*.o(.dtors))
    138     KEEP (*(EXCLUDE_FILE (*crtend.o *crtend*.o ) .dtors))
    139     KEEP (*(SORT(.dtors.*)))
    140     KEEP (*(.dtors))
    141   }
    142   .jcr            : { KEEP (*(.jcr)) }
    143   .data.rel.ro : { *(.data.rel.ro.local* .gnu.linkonce.d.rel.ro.local.*) *(.data.rel.ro .data.rel.ro.* .gnu.linkonce.d.rel.ro.*) }
    144   .dynamic        : { *(.dynamic) }
    145   .got            : { *(.got.plt) *(.igot.plt) *(.got) *(.igot) }
    146   . = DATA_SEGMENT_RELRO_END (0, .);
    147   .data           :
    148   {
    149     PROVIDE (__data_start = .);
    150     *(.data .data.* .gnu.linkonce.d.*)
    151     SORT(CONSTRUCTORS)
    152   }
    153   .data1          : { *(.data1) }
    154   _edata = .; PROVIDE (edata = .);
    155   __bss_start = .;
    156   __bss_start__ = .;
    157   .bss            :
    158   {
    159    *(.dynbss)
    160    *(.bss .bss.* .gnu.linkonce.b.*)
    161    *(COMMON)
    162    /* Align here to ensure that the .bss section occupies space up to
    163       _end.  Align after .bss to ensure correct alignment even if the
    164       .bss section disappears because there are no input sections.  */
    165    . = ALIGN(64 / 8);
    166   }
    167   _bss_end__ = . ; __bss_end__ = . ;
    168   . = ALIGN(64 / 8);
    169   . = SEGMENT_START("ldata-segment", .);
    170   . = ALIGN(64 / 8);
    171   __end__ = . ;
    172   _end = .;
    173   _bss_end__ = . ; __bss_end__ = . ; __end__ = . ;
    174   PROVIDE (end = .);
    175   . = DATA_SEGMENT_END (.);
    176   /* Stabs debugging sections.  */
    177   .stab          0 : { *(.stab) }
    178   .stabstr       0 : { *(.stabstr) }
    179   .stab.excl     0 : { *(.stab.excl) }
    180   .stab.exclstr  0 : { *(.stab.exclstr) }
    181   .stab.index    0 : { *(.stab.index) }
    182   .stab.indexstr 0 : { *(.stab.indexstr) }
    183   .comment       0 : { *(.comment) }
    184   /* DWARF debug sections.
    185      Symbols in the DWARF debugging sections are relative to the beginning
    186      of the section so we begin them at 0.  */
    187   /* DWARF 1 */
    188   .debug          0 : { *(.debug) }
    189   .line           0 : { *(.line) }
    190   /* GNU DWARF 1 extensions */
    191   .debug_srcinfo  0 : { *(.debug_srcinfo) }
    192   .debug_sfnames  0 : { *(.debug_sfnames) }
    193   /* DWARF 1.1 and DWARF 2 */
    194   .debug_aranges  0 : { *(.debug_aranges) }
    195   .debug_pubnames 0 : { *(.debug_pubnames) }
    196   /* DWARF 2 */
    197   .debug_info     0 : { *(.debug_info .gnu.linkonce.wi.*) }
    198   .debug_abbrev   0 : { *(.debug_abbrev) }
    199   .debug_line     0 : { *(.debug_line .debug_line.* .debug_line_end ) }
    200   .debug_frame    0 : { *(.debug_frame) }
    201   .debug_str      0 : { *(.debug_str) }
    202   .debug_loc      0 : { *(.debug_loc) }
    203   .debug_macinfo  0 : { *(.debug_macinfo) }
    204   /* SGI/MIPS DWARF 2 extensions */
    205   .debug_weaknames 0 : { *(.debug_weaknames) }
    206   .debug_funcnames 0 : { *(.debug_funcnames) }
    207   .debug_typenames 0 : { *(.debug_typenames) }
    208   .debug_varnames  0 : { *(.debug_varnames) }
    209   /* DWARF 3 */
    210   .debug_pubtypes 0 : { *(.debug_pubtypes) }
    211   .debug_ranges   0 : { *(.debug_ranges) }
    212   /* DWARF Extension.  */
    213   .debug_macro    0 : { *(.debug_macro) }
    214   .ARM.attributes 0 : { KEEP (*(.ARM.attributes)) KEEP (*(.gnu.attributes)) }
    215   .note.gnu.arm.ident 0 : { KEEP (*(.note.gnu.arm.ident)) }
    216   /DISCARD/ : { *(.note.GNU-stack) *(.gnu_debuglink) *(.gnu.lto_*) *(.mdebug.*) }
    217 }
    218