; RUN: llc -mattr=+egpr %s -mtriple=x86_64 --relocation-model=pic -enable-tlsdesc -filetype=obj -o %t.o ; RUN: llvm-objdump --no-print-imm-hex -dr %t.o | FileCheck %s --check-prefix=TLSDESC ; RUN: echo '.tbss; .globl b,c,d,e,f,g,h,i,j; b: .zero 4;c: .zero 4;d: .zero 4;e: .zero 4;f: .zero 4;g: .zero 4;h: .zero 4;i: .zero 4;j: .zero 4' | llvm-mc -filetype=obj -triple=x86_64 - -o %t1.o ; RUN: llc -mattr=+egpr %s -mtriple=x86_64 -filetype=obj -o %t.o -x86-enable-apx-for-relocation=true ; RUN: llvm-objdump --no-print-imm-hex -dr %t.o | FileCheck %s --check-prefix=GOTTPOFF_APXRELAX ; RUN: echo '.tbss; .globl b,c,d,e,f,g,h,i,j; b: .zero 4;c: .zero 4;d: .zero 4;e: .zero 4;f: .zero 4;g: .zero 4;h: .zero 4;i: .zero 4;j: .zero 4' | llvm-mc -filetype=obj -triple=x86_64 - -o %t1.o ; RUN: llc -mattr=+egpr %s -mtriple=x86_64 -filetype=obj -o %t.o ; RUN: llvm-objdump --no-print-imm-hex -dr %t.o | FileCheck %s --check-prefix=GOTTPOFF_NOAPXRELAX ; RUN: echo '.tbss; .globl b,c,d,e,f,g,h,i,j; b: .zero 4;c: .zero 4;d: .zero 4;e: .zero 4;f: .zero 4;g: .zero 4;h: .zero 4;i: .zero 4;j: .zero 4' | llvm-mc -filetype=obj -triple=x86_64 - -o %t1.o ; TLSDESC: d5 18 89 c0 movq %rax, %r16 ; TLSDESC-NEXT: 48 8d 05 00 00 00 00 leaq (%rip), %rax ; TLSDESC-NEXT: R_X86_64_GOTPC32_TLSDESC j-0x4 ; GOTTPOFF_APXRELAX: d5 48 8b 05 00 00 00 00 movq (%rip), %r16 ; GOTTPOFF_APXRELAX-NEXT: R_X86_64_CODE_4_GOTTPOFF j-0x4 ; GOTTPOFF_NOAPXRELAX: 48 8b 1d 00 00 00 00 movq (%rip), %rbx ; GOTTPOFF_NOAPXRELAX-NEXT: R_X86_64_GOTTPOFF j-0x4 @a = thread_local global i32 0, align 4 @b = external thread_local global i32, align 4 @c = external thread_local global i32, align 4 @d = external thread_local global i32, align 4 @e = external thread_local global i32, align 4 @f = external thread_local global i32, align 4 @g = external thread_local global i32, align 4 @h = external thread_local global i32, align 4 @i = external thread_local global i32, align 4 @j = external thread_local global i32, align 4 define i32 @f2() nounwind { %1 = tail call ptr @llvm.threadlocal.address.p0(ptr @a) %2 = tail call ptr @llvm.threadlocal.address.p0(ptr @b) %3 = tail call ptr @llvm.threadlocal.address.p0(ptr @c) %4 = tail call ptr @llvm.threadlocal.address.p0(ptr @d) %5 = tail call ptr @llvm.threadlocal.address.p0(ptr @e) %6 = tail call ptr @llvm.threadlocal.address.p0(ptr @f) %7 = tail call ptr @llvm.threadlocal.address.p0(ptr @g) %8 = tail call ptr @llvm.threadlocal.address.p0(ptr @h) %9 = tail call ptr @llvm.threadlocal.address.p0(ptr @i) %10 = tail call ptr @llvm.threadlocal.address.p0(ptr @j) %11 = load i32, ptr %1 %12 = load i32, ptr %2 %13 = load i32, ptr %3 %14 = load i32, ptr %4 %15 = load i32, ptr %5 %16 = load i32, ptr %6 %17 = load i32, ptr %7 %18 = load i32, ptr %8 %19 = load i32, ptr %9 %20 = load i32, ptr %10 %21 = add i32 %11, %12 %22 = add i32 %13, %14 %23 = add i32 %15, %16 %24 = add i32 %17, %18 %25 = add i32 %19, %20 %26 = add i32 %21, %22 %27 = add i32 %23, %24 %28 = add i32 %26, %27 %29 = add i32 %25, %28 ret i32 %29 }