mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-12 23:40:54 +00:00
6c3ce45003
Calls involved in thread-local variable lookup save more registers than normal calls. rdar://problem/23073171 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@252837 91177308-0d34-0410-b5e6-96231b3b80d8
29 lines
879 B
LLVM
29 lines
879 B
LLVM
; RUN: llc < %s -mtriple x86_64-apple-darwin | FileCheck %s
|
|
|
|
@a = thread_local global i32 4, align 4
|
|
|
|
define i32 @f2(i32 %p1, i32 %p2, i32 %p3, i32 %p4, i32 %p5) {
|
|
entry:
|
|
; Parameters are in %edi, %esi, %edx, %ecx, %r8d, there is no need to save
|
|
; these parameters except the one in %edi, before making the TLS call.
|
|
; %edi is used to pass parameter to the TLS call.
|
|
; CHECK-NOT: movl %r8d
|
|
; CHECK-NOT: movl %ecx
|
|
; CHECK-NOT: movl %edx
|
|
; CHECK-NOT: movl %esi
|
|
; CHECK: movq {{.*}}TLVP{{.*}}, %rdi
|
|
; CHECK-NEXT: callq
|
|
; CHECK-NEXT: movl (%rax),
|
|
; CHECK-NOT: movl {{.*}}, %esi
|
|
; CHECK-NOT: movl {{.*}}, %edx
|
|
; CHECK-NOT: movl {{.*}}, %ecx
|
|
; CHECK-NOT: movl {{.*}}, %r8d
|
|
; CHECK: callq
|
|
%0 = load i32, i32* @a, align 4
|
|
%call = tail call i32 @f3(i32 %p1, i32 %p2, i32 %p3, i32 %p4, i32 %p5)
|
|
%add = add nsw i32 %call, %0
|
|
ret i32 %add
|
|
}
|
|
|
|
declare i32 @f3(i32, i32, i32, i32, i32)
|