forked from OSchip/llvm-project
40 lines
1.0 KiB
ArmAsm
40 lines
1.0 KiB
ArmAsm
# REQUIRES: x86
|
|
|
|
## Alignment of the copy relocated symbol is respected, even when .bss includes
|
|
## other sections (COMMON).
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux \
|
|
# RUN: %p/Inputs/relocation-copy-align-common.s -o %t2.o
|
|
# RUN: ld.lld -shared %t2.o -soname=so -o %t.so
|
|
# RUN: ld.lld %t.o %t.so -o %t3
|
|
# RUN: llvm-readobj -S -r %t3 | FileCheck %s
|
|
|
|
# CHECK: Section {
|
|
# CHECK: Index:
|
|
# CHECK: Name: .bss
|
|
# CHECK-NEXT: Type: SHT_NOBITS
|
|
# CHECK-NEXT: Flags [
|
|
# CHECK-NEXT: SHF_ALLOC
|
|
# CHECK-NEXT: SHF_WRITE
|
|
# CHECK-NEXT: ]
|
|
# CHECK-NEXT: Address: 0x203360
|
|
# CHECK-NEXT: Offset: 0x360
|
|
# CHECK-NEXT: Size: 64
|
|
# CHECK-NEXT: Link: 0
|
|
# CHECK-NEXT: Info: 0
|
|
# CHECK-NEXT: AddressAlignment: 32
|
|
# CHECK-NEXT: EntrySize: 0
|
|
# CHECK-NEXT: }
|
|
|
|
# CHECK: Relocations [
|
|
# CHECK-NEXT: Section {{.*}} .rela.dyn {
|
|
# CHECK-NEXT: 0x203380 R_X86_64_COPY foo 0x0
|
|
# CHECK-NEXT: }
|
|
# CHECK-NEXT: ]
|
|
|
|
.global _start
|
|
_start:
|
|
.comm sym1,4,4
|
|
movl $5, foo
|