llvm-mirror/test/MC/PowerPC/ppc64-tls-relocs-01.s
Zaara Syeda 891074f69a [PowerPC] Set isAsmParserOnly=1 for X-form TLS loads/stores
The X-form TLS load/store instructions added for optimizing the initial-exec
sequence in https://reviews.llvm.org/rL327635 fail to assemble. llvm-mc fails
with the error: invalid operand for instruction. This patch adds these
instructions into a block with isAsmParserOnly, similar to how ADD8TLS_ is
currently handled.

Differential Revision: https://reviews.llvm.org/D47382

llvm-svn: 333374
2018-05-28 15:27:58 +00:00

42 lines
1.4 KiB
ArmAsm

# RUN: llvm-mc -triple=powerpc64-unknown-linux-gnu -filetype=obj %s | \
# RUN: llvm-readobj -r | FileCheck %s
.text
addis 3, 13, t@tprel@ha
addi 3, 3, t@tprel@l
addis 3, 2, t@got@tprel@ha
ld 3, t@got@tprel@l(3)
lwzx 4, 3, t@tls
lhzx 4, 3, t@tls
lbzx 4, 3, t@tls
ldx 4, 3, t@tls
stbx 4, 3, t@tls
sthx 4, 3, t@tls
stwx 4, 3, t@tls
stdx 4, 3, t@tls
.type t,@object
.section .tbss,"awT",@nobits
.globl t
.align 2
t:
.long 0
.size t, 4
# Check for a pair of R_PPC64_TPREL16_HA / R_PPC64_TPREL16_LO relocs
# against the thread-local symbol 't'.
# CHECK: Relocations [
# CHECK: Section ({{[0-9]+}}) .rela.text {
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TPREL16_HA t
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TPREL16_LO t
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_GOT_TPREL16_HA t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_GOT_TPREL16_LO_DS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: 0x{{[0-9,A-F]+}} R_PPC64_TLS t 0x0
# CHECK-NEXT: }