[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / Transforms / Inline / frameescape.ll
blob8566a7524c38d99f5029d452ea11f54e6779c005
1 ; RUN: opt -passes=inline -S < %s | FileCheck %s
2 ; RUN: opt -passes='cgscc(inline)' -S < %s | FileCheck %s
3 ; RUN: opt -passes='module-inline' -S < %s | FileCheck %s
5 ; PR23216: We can't inline functions using llvm.localescape.
7 declare void @llvm.localescape(...)
8 declare ptr @llvm.frameaddress(i32)
9 declare ptr @llvm.localrecover(ptr, ptr, i32)
11 define internal void @foo(ptr %fp) {
12   %a.i8 = call ptr @llvm.localrecover(ptr @bar, ptr %fp, i32 0)
13   store i32 42, ptr %a.i8
14   ret void
17 define internal i32 @bar() {
18 entry:
19   %a = alloca i32
20   call void (...) @llvm.localescape(ptr %a)
21   %fp = call ptr @llvm.frameaddress(i32 0)
22   tail call void @foo(ptr %fp)
23   %r = load i32, ptr %a
24   ret i32 %r
27 ; We even bail when someone marks it alwaysinline.
28 define internal i32 @bar_alwaysinline() alwaysinline {
29 entry:
30   %a = alloca i32
31   call void (...) @llvm.localescape(ptr %a)
32   tail call void @foo(ptr null)
33   ret i32 0
36 define i32 @bazz() {
37 entry:
38   %r = tail call i32 @bar()
39   %r1 = tail call i32 @bar_alwaysinline()
40   ret i32 %r
43 ; CHECK: define i32 @bazz()
44 ; CHECK: call i32 @bar()
45 ; CHECK: call i32 @bar_alwaysinline()