[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / sibcall-win64.ll
blobb9d5a4813e09a71a5d79c3e582d2284adb4e930c
1 ; RUN: llc < %s -mtriple=x86_64-pc-linux | FileCheck %s
3 declare win64cc void @win64_callee(i32)
4 declare win64cc void (i32)* @win64_indirect()
5 declare win64cc void @win64_other(i32)
6 declare void @sysv_callee(i32)
7 declare void (i32)* @sysv_indirect()
8 declare void @sysv_other(i32)
10 define void @sysv_caller(i32 %p1) {
11 entry:
12   tail call win64cc void @win64_callee(i32 %p1)
13   ret void
16 ; CHECK-LABEL: sysv_caller:
17 ; CHECK: subq $40, %rsp
18 ; CHECK: callq win64_callee
19 ; CHECK: addq $40, %rsp
20 ; CHECK: retq
22 define win64cc void @win64_caller(i32 %p1) {
23 entry:
24   tail call void @sysv_callee(i32 %p1)
25   ret void
28 ; CHECK-LABEL: win64_caller:
29 ; CHECK: callq sysv_callee
30 ; CHECK: retq
32 define void @sysv_matched(i32 %p1) {
33   tail call void @sysv_callee(i32 %p1)
34   ret void
37 ; CHECK-LABEL: sysv_matched:
38 ; CHECK: jmp sysv_callee # TAILCALL
40 define win64cc void @win64_matched(i32 %p1) {
41   tail call win64cc void @win64_callee(i32 %p1)
42   ret void
45 ; CHECK-LABEL: win64_matched:
46 ; CHECK: jmp win64_callee # TAILCALL
48 define win64cc void @win64_indirect_caller(i32 %p1) {
49   %1 = call win64cc void (i32)* @win64_indirect()
50   call win64cc void @win64_other(i32 0)
51   tail call win64cc void %1(i32 %p1)
52   ret void
55 ; CHECK-LABEL: win64_indirect_caller:
56 ; CHECK: jmpq *%{{rax|rcx|rdx|r8|r9|r11}} # TAILCALL
58 define void @sysv_indirect_caller(i32 %p1) {
59   %1 = call void (i32)* @sysv_indirect()
60   call void @sysv_other(i32 0)
61   tail call void %1(i32 %p1)
62   ret void
65 ; CHECK-LABEL: sysv_indirect_caller:
66 ; CHECK: jmpq *%{{rax|rcx|rdx|rsi|rdi|r8|r9|r11}} # TAILCALL