|  | ; Testcase generated from the following code: | 
|  | ; extern __thread int i; | 
|  | ; void f(); | 
|  | ; int g(void) { | 
|  | ;   if (i) { | 
|  | ;     i = 0; | 
|  | ;     f(); | 
|  | ;   } | 
|  | ;   return i; | 
|  | ; } | 
|  | ; We want to make sure that TLS variables are not accessed before | 
|  | ; the stack frame is set up. | 
|  |  | 
|  | ; RUN: llc < %s -relocation-model=pic | FileCheck %s | 
|  |  | 
|  | target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" | 
|  | target triple = "x86_64-unknown-freebsd11.0" | 
|  |  | 
|  | @i = external thread_local global i32, align 4 | 
|  |  | 
|  | define i32 @g() #0 { | 
|  | entry: | 
|  | %tmp = load i32, i32* @i, align 4 | 
|  | %tobool = icmp eq i32 %tmp, 0 | 
|  | br i1 %tobool, label %if.end, label %if.then | 
|  |  | 
|  | if.then:                                          ; preds = %entry | 
|  | store i32 0, i32* @i, align 4 | 
|  | tail call void (...) @f() #2 | 
|  | %.pre = load i32, i32* @i, align 4 | 
|  | br label %if.end | 
|  |  | 
|  | if.end:                                           ; preds = %if.then, %entry | 
|  | %tmp1 = phi i32 [ 0, %entry ], [ %.pre, %if.then ] | 
|  | ret i32 %tmp1 | 
|  | } | 
|  |  | 
|  | ; CHECK: g:                                      # @g | 
|  | ; CHECK-NEXT:         .cfi_startproc | 
|  | ; CHECK-NEXT: # %bb.0:                                 # %entry | 
|  | ; CHECK-NEXT:         pushq   %rbp | 
|  | ; CHECK-NEXT:         .cfi_def_cfa_offset 16 | 
|  | ; CHECK-NEXT:         .cfi_offset %rbp, -16 | 
|  | ; CHECK-NEXT:         movq    %rsp, %rbp | 
|  | ; CHECK-NEXT:         .cfi_def_cfa_register %rbp | 
|  | ; CHECK-NEXT:         pushq   %rbx | 
|  | ; CHECK-NEXT:         pushq   %rax | 
|  | ; CHECK-NEXT:         .cfi_offset %rbx, -24 | 
|  | ; CHECK-NEXT:         data16 | 
|  | ; CHECK-NEXT:         leaq    i@TLSGD(%rip), %rdi | 
|  |  | 
|  | declare void @f(...) #1 | 
|  |  | 
|  | attributes #0 = { nounwind uwtable "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } | 
|  | attributes #1 = { "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+fxsr,+mmx,+sse,+sse2" "unsafe-fp-math"="false" "use-soft-float"="false" } | 
|  | attributes #2 = { nounwind } |