| ;; Test that we don't pad the x86-64 General Dynamic/Local Dynamic TLS code |
| ;; sequence. It uses prefixes to allow linker relaxation. We need to disable |
| ;; prefix or nop padding for it. For simplicity and consistency, disable for |
| ;; Local Dynamic and 32-bit as well. |
| ; RUN: llc -mtriple=i386 -relocation-model=pic -x86-branches-within-32B-boundaries < %s | FileCheck --check-prefixes=CHECK,32 %s |
| ; RUN: llc -mtriple=x86_64 -relocation-model=pic -x86-branches-within-32B-boundaries < %s | FileCheck --check-prefixes=CHECK,64 %s |
| |
| @gd = external thread_local global i32 |
| @ld = internal thread_local global i32 0 |
| |
| define i32 @tls_get_addr() { |
| ; CHECK-LABEL: tls_get_addr: |
| ; CHECK: #noautopadding |
| ; 32: leal gd@TLSGD(,%ebx), %eax |
| ; 32: calll ___tls_get_addr@PLT |
| ; 64: data16 |
| ; 64: leaq gd@TLSGD(%rip), %rdi |
| ; 64: callq __tls_get_addr@PLT |
| ; CHECK: #autopadding |
| ; CHECK: #noautopadding |
| ; 32: leal ld@TLSLDM(%ebx), %eax |
| ; 32: calll ___tls_get_addr@PLT |
| ; 64: leaq ld@TLSLD(%rip), %rdi |
| ; 64: callq __tls_get_addr@PLT |
| ; CHECK: #autopadding |
| %1 = load i32, ptr @gd |
| %2 = load i32, ptr @ld |
| %3 = add i32 %1, %2 |
| ret i32 %3 |
| } |