Summary: Currently when --no-rosegment is specified or a linker script with SECTIONS command is used, .rodata (A) .text (AX) are assigned the same rank and .rodata may be placed after .text . This increases the gap between .text and .bss and can cause pc-relative relocation overflow (e.g. gcc crtbegin.o crtbegin.S have R_X86_64_PC32 relocation from .text to .bss). This patch makes SingleRoRx affect only segment layout, not section layout. As a consequence, .rodata will be placed before .text regardless of SingleRoRx. Reviewers: espindola, ruiu, grimar, echristo, javed.absar Subscribers: emaste, arichardson, llvm-commits Differential Revision: https://reviews.llvm.org/D48405 llvm-svn: 335627
34 lines
1004 B
ArmAsm
34 lines
1004 B
ArmAsm
# REQUIRES: x86
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
|
|
|
|
# RUN: echo "SECTIONS { .text : { *(.text.bar) *(.text.foo) } }" > %t.script
|
|
# RUN: ld.lld -o %t --script %t.script %t.o
|
|
# RUN: llvm-objdump -s %t | FileCheck %s
|
|
|
|
# RUN: echo "SECTIONS { .text : { *(.text.foo) *(.text.bar) } }" > %t.script
|
|
# RUN: ld.lld -o %t --script %t.script %t.o
|
|
# RUN: llvm-objdump -s %t | FileCheck --check-prefix=INV %s
|
|
|
|
|
|
# CHECK: Contents of section .rodata:
|
|
# CHECK-NEXT: 02000000 00000000 01000000 00000000
|
|
# CHECK: Contents of section .text:
|
|
# CHECK-NEXT: 02000000 00000000 01000000 00000000
|
|
|
|
# INV: Contents of section .rodata:
|
|
# INV-NEXT: 01000000 00000000 02000000 00000000
|
|
# INV: Contents of section .text:
|
|
# INV-NEXT: 01000000 00000000 02000000 00000000
|
|
|
|
.global _start
|
|
_start:
|
|
|
|
.section .text.bar,"a",@progbits
|
|
.quad 2
|
|
.section .text.foo,"a",@progbits
|
|
.quad 1
|
|
.section .rodata.foo,"ao",@progbits,.text.foo
|
|
.quad 1
|
|
.section .rodata.bar,"ao",@progbits,.text.bar
|
|
.quad 2
|