1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i686-pc-win32 -mattr=+sse2 | FileCheck %s --check-prefix=CHECK --check-prefix=SSE2 2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i686-pc-win32 -mattr=+sse2,+avx | FileCheck %s --check-prefix=CHECK --check-prefix=AVX 3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i686-pc-win32 -mattr=+sse2,+avx,+avx512f | FileCheck %s --check-prefix=CHECK --check-prefix=AVX512 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker; While we don't support varargs with fastcall, we do support forwarding. 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker@asdf = internal constant [4 x i8] c"asdf" 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Workerdeclare void @puts(i8*) 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Workerdefine i32 @call_fast_thunk() { 12*9880d681SAndroid Build Coastguard Worker %r = call x86_fastcallcc i32 (...) @fast_thunk(i32 inreg 1, i32 inreg 2, i32 3) 13*9880d681SAndroid Build Coastguard Worker ret i32 %r 14*9880d681SAndroid Build Coastguard Worker} 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Workerdefine x86_fastcallcc i32 @fast_thunk(...) { 17*9880d681SAndroid Build Coastguard Worker call void @puts(i8* getelementptr ([4 x i8], [4 x i8]* @asdf, i32 0, i32 0)) 18*9880d681SAndroid Build Coastguard Worker %r = musttail call x86_fastcallcc i32 (...) bitcast (i32 (i32, i32, i32)* @fast_target to i32 (...)*) (...) 19*9880d681SAndroid Build Coastguard Worker ret i32 %r 20*9880d681SAndroid Build Coastguard Worker} 21*9880d681SAndroid Build Coastguard Worker 22*9880d681SAndroid Build Coastguard Worker; Check that we spill and fill around the call to puts. 23*9880d681SAndroid Build Coastguard Worker 24*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @fast_thunk@0: 25*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl %ecx, {{.*}} 26*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl %edx, {{.*}} 27*9880d681SAndroid Build Coastguard Worker; CHECK: calll _puts 28*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl {{.*}}, %ecx 29*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl {{.*}}, %edx 30*9880d681SAndroid Build Coastguard Worker; CHECK: jmp @fast_target@12 31*9880d681SAndroid Build Coastguard Worker 32*9880d681SAndroid Build Coastguard Workerdefine x86_fastcallcc i32 @fast_target(i32 inreg %a, i32 inreg %b, i32 %c) { 33*9880d681SAndroid Build Coastguard Worker %a0 = add i32 %a, %b 34*9880d681SAndroid Build Coastguard Worker %a1 = add i32 %a0, %c 35*9880d681SAndroid Build Coastguard Worker ret i32 %a1 36*9880d681SAndroid Build Coastguard Worker} 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker; Repeat the test for vectorcall, which has XMM registers. 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Workerdefine i32 @call_vector_thunk() { 41*9880d681SAndroid Build Coastguard Worker %r = call x86_vectorcallcc i32 (...) @vector_thunk(i32 inreg 1, i32 inreg 2, i32 3) 42*9880d681SAndroid Build Coastguard Worker ret i32 %r 43*9880d681SAndroid Build Coastguard Worker} 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Workerdefine x86_vectorcallcc i32 @vector_thunk(...) { 46*9880d681SAndroid Build Coastguard Worker call void @puts(i8* getelementptr ([4 x i8], [4 x i8]* @asdf, i32 0, i32 0)) 47*9880d681SAndroid Build Coastguard Worker %r = musttail call x86_vectorcallcc i32 (...) bitcast (i32 (i32, i32, i32)* @vector_target to i32 (...)*) (...) 48*9880d681SAndroid Build Coastguard Worker ret i32 %r 49*9880d681SAndroid Build Coastguard Worker} 50*9880d681SAndroid Build Coastguard Worker 51*9880d681SAndroid Build Coastguard Worker; Check that we spill and fill SSE registers around the call to puts. 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: vector_thunk@@0: 54*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl %ecx, {{.*}} 55*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl %edx, {{.*}} 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm0, {{.*}} 58*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm1, {{.*}} 59*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm2, {{.*}} 60*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm3, {{.*}} 61*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm4, {{.*}} 62*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups %xmm5, {{.*}} 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm0, {{.*}} 65*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm1, {{.*}} 66*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm2, {{.*}} 67*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm3, {{.*}} 68*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm4, {{.*}} 69*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups %ymm5, {{.*}} 70*9880d681SAndroid Build Coastguard Worker 71*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm0, {{.*}} 72*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm1, {{.*}} 73*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm2, {{.*}} 74*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm3, {{.*}} 75*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm4, {{.*}} 76*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups %zmm5, {{.*}} 77*9880d681SAndroid Build Coastguard Worker 78*9880d681SAndroid Build Coastguard Worker; CHECK: calll _puts 79*9880d681SAndroid Build Coastguard Worker 80*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm0 81*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm1 82*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm2 83*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm3 84*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm4 85*9880d681SAndroid Build Coastguard Worker; SSE2-DAG: movups {{.*}}, %xmm5 86*9880d681SAndroid Build Coastguard Worker 87*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm0 88*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm1 89*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm2 90*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm3 91*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm4 92*9880d681SAndroid Build Coastguard Worker; AVX-DAG: vmovups {{.*}}, %ymm5 93*9880d681SAndroid Build Coastguard Worker 94*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm0 95*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm1 96*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm2 97*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm3 98*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm4 99*9880d681SAndroid Build Coastguard Worker; AVX512-DAG: vmovups {{.*}}, %zmm5 100*9880d681SAndroid Build Coastguard Worker 101*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl {{.*}}, %ecx 102*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: movl {{.*}}, %edx 103*9880d681SAndroid Build Coastguard Worker; CHECK: jmp vector_target@@12 104*9880d681SAndroid Build Coastguard Worker 105*9880d681SAndroid Build Coastguard Workerdefine x86_vectorcallcc i32 @vector_target(i32 inreg %a, i32 inreg %b, i32 %c) { 106*9880d681SAndroid Build Coastguard Worker %a0 = add i32 %a, %b 107*9880d681SAndroid Build Coastguard Worker %a1 = add i32 %a0, %c 108*9880d681SAndroid Build Coastguard Worker ret i32 %a1 109*9880d681SAndroid Build Coastguard Worker} 110