Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Transforms / IROutliner / outlining-swifttailcc.ll
blob48cc128ad68de84d68c0267ef3d20b8fc439f233
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --include-generated-funcs
2 ; RUN: opt -S -passes=verify,iroutliner -ir-outlining-no-cost < %s | FileCheck %s
4 ; Check that we do not outline musttail calls when swifttailcc is present.
6 declare swifttailcc void @musttail()
8 define swifttailcc void @f1() {
9   %a = alloca i32, align 4
10   store i32 2, ptr %a, align 4
11   musttail call swifttailcc void @musttail()
12   ret void
15 define swifttailcc void @f2() {
16   %a = alloca i32, align 4
17   store i32 2, ptr %a, align 4
18   musttail call swifttailcc void @musttail()
19   ret void
21 ; CHECK-LABEL: @f1(
22 ; CHECK-NEXT:    [[A:%.*]] = alloca i32, align 4
23 ; CHECK-NEXT:    store i32 2, ptr [[A]], align 4
24 ; CHECK-NEXT:    musttail call swifttailcc void @musttail()
25 ; CHECK-NEXT:    ret void
28 ; CHECK-LABEL: @f2(
29 ; CHECK-NEXT:    [[A:%.*]] = alloca i32, align 4
30 ; CHECK-NEXT:    store i32 2, ptr [[A]], align 4
31 ; CHECK-NEXT:    musttail call swifttailcc void @musttail()
32 ; CHECK-NEXT:    ret void