[LLVM][IR] Use splat syntax when printing ConstantExpr based splats. (#116856)
[llvm-project.git] / llvm / test / Transforms / ExpandVariadics / indirect-calls.ll
blobb661f7f3e495f08ebc9c8a66d3827d750b1411a9
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -mtriple=wasm32-unknown-unknown -S --passes=expand-variadics --expand-variadics-override=optimize < %s | FileCheck %s -check-prefixes=OPT
3 ; RUN: opt -mtriple=wasm32-unknown-unknown -S --passes=expand-variadics --expand-variadics-override=lowering < %s | FileCheck %s -check-prefixes=ABI
4 ; REQUIRES: webassembly-registered-target
6 declare void @vararg(...)
7 @vararg_ptr = hidden global ptr @vararg, align 4
9 %struct.libcS = type { i8, i16, i32, i32, float, double }
11 define hidden void @fptr_single_i32(i32 noundef %x) {
12 ; OPT-LABEL: @fptr_single_i32(
13 ; OPT-NEXT:  entry:
14 ; OPT-NEXT:    [[TMP0:%.*]] = load volatile ptr, ptr @vararg_ptr, align 4
15 ; OPT-NEXT:    tail call void (...) [[TMP0]](i32 noundef [[X:%.*]])
16 ; OPT-NEXT:    ret void
18 ; ABI-LABEL: @fptr_single_i32(
19 ; ABI-NEXT:  entry:
20 ; ABI-NEXT:    [[VARARG_BUFFER:%.*]] = alloca [[FPTR_SINGLE_I32_VARARG:%.*]], align 16
21 ; ABI-NEXT:    [[TMP0:%.*]] = load volatile ptr, ptr @vararg_ptr, align 4
22 ; ABI-NEXT:    call void @llvm.lifetime.start.p0(i64 4, ptr [[VARARG_BUFFER]])
23 ; ABI-NEXT:    [[TMP1:%.*]] = getelementptr inbounds nuw [[FPTR_SINGLE_I32_VARARG]], ptr [[VARARG_BUFFER]], i32 0, i32 0
24 ; ABI-NEXT:    store i32 [[X:%.*]], ptr [[TMP1]], align 4
25 ; ABI-NEXT:    call void [[TMP0]](ptr [[VARARG_BUFFER]])
26 ; ABI-NEXT:    call void @llvm.lifetime.end.p0(i64 4, ptr [[VARARG_BUFFER]])
27 ; ABI-NEXT:    ret void
29 entry:
30   %0 = load volatile ptr, ptr @vararg_ptr, align 4
31   tail call void (...) %0(i32 noundef %x)
32   ret void
35 define hidden void @fptr_libcS(ptr noundef byval(%struct.libcS) align 8 %x) {
36 ; OPT-LABEL: @fptr_libcS(
37 ; OPT-NEXT:  entry:
38 ; OPT-NEXT:    [[TMP0:%.*]] = load volatile ptr, ptr @vararg_ptr, align 4
39 ; OPT-NEXT:    tail call void (...) [[TMP0]](ptr noundef nonnull byval([[STRUCT_LIBCS:%.*]]) align 8 [[X:%.*]])
40 ; OPT-NEXT:    ret void
42 ; ABI-LABEL: @fptr_libcS(
43 ; ABI-NEXT:  entry:
44 ; ABI-NEXT:    [[INDIRECTALLOCA:%.*]] = alloca [[STRUCT_LIBCS:%.*]], align 8
45 ; ABI-NEXT:    [[VARARG_BUFFER:%.*]] = alloca [[FPTR_LIBCS_VARARG:%.*]], align 16
46 ; ABI-NEXT:    [[TMP0:%.*]] = load volatile ptr, ptr @vararg_ptr, align 4
47 ; ABI-NEXT:    call void @llvm.memcpy.p0.p0.i64(ptr [[INDIRECTALLOCA]], ptr [[X:%.*]], i64 24, i1 false)
48 ; ABI-NEXT:    call void @llvm.lifetime.start.p0(i64 4, ptr [[VARARG_BUFFER]])
49 ; ABI-NEXT:    [[TMP1:%.*]] = getelementptr inbounds nuw [[FPTR_LIBCS_VARARG]], ptr [[VARARG_BUFFER]], i32 0, i32 0
50 ; ABI-NEXT:    store ptr [[INDIRECTALLOCA]], ptr [[TMP1]], align 4
51 ; ABI-NEXT:    call void [[TMP0]](ptr [[VARARG_BUFFER]])
52 ; ABI-NEXT:    call void @llvm.lifetime.end.p0(i64 4, ptr [[VARARG_BUFFER]])
53 ; ABI-NEXT:    ret void
55 entry:
56   %0 = load volatile ptr, ptr @vararg_ptr, align 4
57   tail call void (...) %0(ptr noundef nonnull byval(%struct.libcS) align 8 %x)
58   ret void