Old: PT_LOAD(.data | PT_GNU_RELRO(.data.rel.ro .bss.rel.ro) | .bss) New: PT_LOAD(PT_GNU_RELRO(.data.rel.ro .bss.rel.ro) | .data .bss) The placement of | indicates page alignment caused by PT_GNU_RELRO. The new layout has simpler rules and saves space for many cases. Old size: roundup(.data) + roundup(.data.rel.ro) New size: roundup(.data.rel.ro + .bss.rel.ro) + .data Other advantages: * At runtime the 3 memory mappings decrease to 2. * start(PT_TLS) = start(PT_GNU_RELRO) = start(RW PT_LOAD). This simplifies binary manipulation tools. GNU strip before 2.31 discards PT_GNU_RELRO if its address is not equal to the start of its associated PT_LOAD. This has been fixed by https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=f2731e0c374e5323ce4cdae2bcc7b7fe22da1a6f But with this change, we will be compatible with GNU strip before 2.31 * Before, .got.plt (non-relro by default) was placed before .got (relro by default), which made it impossible to have _GLOBAL_OFFSET_TABLE_ (start of .got.plt on x86-64) equal to the end of .got (R_GOT*_FROM_END) (https://bugs.llvm.org/show_bug.cgi?id=36555). With the new ordering, we can improve on this regard if we'd like to. Reviewers: ruiu, espindola, pcc Subscribers: emaste, arichardson, llvm-commits, joerg, jdoerfert Differential Revision: https://reviews.llvm.org/D56828 llvm-svn: 356117
59 lines
1.3 KiB
ArmAsm
59 lines
1.3 KiB
ArmAsm
# REQUIRES: x86
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
|
|
# RUN: ld.lld %t -o %tout
|
|
# RUN: llvm-objdump --section-headers %tout | FileCheck %s
|
|
|
|
.global _start
|
|
.text
|
|
_start:
|
|
|
|
.section .text.a,"ax"
|
|
.byte 0
|
|
.section .text.,"ax"
|
|
.byte 0
|
|
.section .rodata.a,"a"
|
|
.byte 0
|
|
.section .rodata,"a"
|
|
.byte 0
|
|
.section .data.a,"aw"
|
|
.byte 0
|
|
.section .data,"aw"
|
|
.byte 0
|
|
.section .bss.a,"aw",@nobits
|
|
.byte 0
|
|
.section .bss,"aw",@nobits
|
|
.byte 0
|
|
.section .foo.a,"aw"
|
|
.byte 0
|
|
.section .foo,"aw"
|
|
.byte 0
|
|
.section .data.rel.ro,"aw",%progbits
|
|
.byte 0
|
|
.section .data.rel.ro.a,"aw",%progbits
|
|
.byte 0
|
|
.section .data.rel.ro.local,"aw",%progbits
|
|
.byte 0
|
|
.section .data.rel.ro.local.a,"aw",%progbits
|
|
.byte 0
|
|
.section .tbss.foo,"aGwT",@nobits,foo,comdat
|
|
.byte 0
|
|
.section .gcc_except_table.foo,"aG",@progbits,foo,comdat
|
|
.byte 0
|
|
.section .tdata.foo,"aGwT",@progbits,foo,comdat
|
|
.byte 0
|
|
|
|
// CHECK: 1 .rodata 00000002
|
|
// CHECK: 2 .gcc_except_table 00000001
|
|
// CHECK: 3 .text 00000002
|
|
// CHECK: 4 .tdata 00000001
|
|
// CHECK: 5 .tbss 00000001
|
|
// CHECK: 6 .data.rel.ro 00000004
|
|
// CHECK: 7 .data 00000002
|
|
// CHECK: 8 .foo.a 00000001
|
|
// CHECK: 9 .foo 00000001
|
|
// CHECK: 10 .bss 00000002
|
|
// CHECK: 11 .comment 00000008
|
|
// CHECK: 12 .symtab 00000030
|
|
// CHECK: 13 .shstrtab 00000075
|
|
// CHECK: 14 .strtab 00000008
|