llvm-toolchain-9/lld/test/ELF/i386-tls-le-align.s

30 lines
623 B
ArmAsm

# REQUIRES: x86
# RUN: llvm-mc -filetype=obj -triple=i386 %s -o %t.o
# RUN: ld.lld %t.o -o %t
# RUN: llvm-objdump -d --no-show-raw-insn --print-imm-hex %t | FileCheck %s
# -alignTo(p_memsz, p_align) = -alignTo(4, 64) = -64
# CHECK: movl %gs:0xffffffc0, %eax
movl %gs:a@NTPOFF, %eax
# CHECK-NEXT: subl $0x40, %edx
subl $a@tpoff, %edx
# GD to LE relaxation.
# CHECK-NEXT: movl %gs:0x0, %eax
# CHECK-NEXT: subl $0x40, %eax
leal a@tlsgd(,%ebx,1), %eax
call ___tls_get_addr@plt
ret
.globl ___tls_get_addr
.type ___tls_get_addr,@function
___tls_get_addr:
.section .tbss,"awT"
.align 64
a:
.long 0
.size a, 4