[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / CodeGen / X86 / win64_sibcall.ll
blob5a65d34a42665b5b5c02750ca40672b69b2d719c
1 ; RUN: llc < %s -mtriple=x86_64-pc-win32-coreclr | FileCheck %s -check-prefix=WIN_X64
2 ; RUN: llc < %s -mtriple=x86_64-pc-linux         | FileCheck %s -check-prefix=LINUX
4 %Object = type <{ [0 x i64*]* }>
6 define void @C1(%Object addrspace(1)* %param0) gc "coreclr" {
7 entry:
9 ; WIN_X64: # %bb.0:
10 ; WIN_X64:      pushq   %rax
11 ; LINUX:   # %bb.0:                                 # %entry
12 ; LINUX:        movq    $0, -8(%rsp)
14   %this = alloca %Object addrspace(1)*
15   store volatile %Object addrspace(1)* null, %Object addrspace(1)** %this
16   store volatile %Object addrspace(1)* %param0, %Object addrspace(1)** %this
17   br label %0
19 ; <label>:0                                       ; preds = %entry
20   %1 = load %Object addrspace(1)*, %Object addrspace(1)** %this, align 8
22 ; WIN_X64:      xorl    %r8d, %r8d
23 ; WIN_X64:      popq    %rax
24 ; WIN_X64:      jmp       C2                  # TAILCALL
25 ; LINUX:        xorl    %edx, %edx
26 ; LINUX:        jmp     C2                      # TAILCALL
28   tail call void @C2(%Object addrspace(1)* %1, i32 0, %Object addrspace(1)* null)
29   ret void
32 declare void @C2(%Object addrspace(1)*, i32, %Object addrspace(1)*)
34 ; Function Attrs: nounwind
35 declare void @llvm.localescape(...) #0
37 attributes #0 = { nounwind }