| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| ; RUN: llc -mtriple=x86_64 -verify-machineinstrs -relocation-model=pic < %s | FileCheck %s |
| |
| ; Passing a pointer to thread-local storage to a function can be problematic |
| ; since computing such addresses requires a function call that is introduced |
| ; very late in instruction selection. We need to ensure that we don't introduce |
| ; nested call sequence markers if this function call happens in a call sequence. |
| |
| @TLS = internal thread_local global i64 zeroinitializer, align 8 |
| declare void @bar(ptr) |
| define internal void @foo() { |
| ; CHECK-LABEL: foo: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: pushq %rbx |
| ; CHECK-NEXT: .cfi_def_cfa_offset 16 |
| ; CHECK-NEXT: .cfi_offset %rbx, -16 |
| ; CHECK-NEXT: leaq TLS@TLSLD(%rip), %rdi |
| ; CHECK-NEXT: callq __tls_get_addr@PLT |
| ; CHECK-NEXT: leaq TLS@DTPOFF(%rax), %rbx |
| ; CHECK-NEXT: movq %rbx, %rdi |
| ; CHECK-NEXT: callq bar@PLT |
| ; CHECK-NEXT: movq %rbx, %rdi |
| ; CHECK-NEXT: callq bar@PLT |
| ; CHECK-NEXT: popq %rbx |
| ; CHECK-NEXT: .cfi_def_cfa_offset 8 |
| ; CHECK-NEXT: retq |
| call void @bar(ptr @TLS) |
| call void @bar(ptr @TLS) |
| ret void |
| } |