Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Verifier / frameescape.ll
blob34d7612703ca68a1bcd1ba2a8a6ccc89fa642654
1 ; RUN: not llvm-as %s -o /dev/null 2>&1 | FileCheck %s
3 declare void @llvm.localescape(...)
4 declare ptr @llvm.localrecover(ptr, ptr, i32)
6 define internal void @f() {
7   %a = alloca i8
8   call void (...) @llvm.localescape(ptr %a)
9   call void (...) @llvm.localescape(ptr %a)
10   ret void
12 ; CHECK: multiple calls to llvm.localescape in one function
14 define internal void @g() {
15 entry:
16   %a = alloca i8
17   br label %not_entry
18 not_entry:
19   call void (...) @llvm.localescape(ptr %a)
20   ret void
22 ; CHECK: llvm.localescape used outside of entry block
24 define internal void @h() {
25   call ptr @llvm.localrecover(ptr null, ptr null, i32 0)
26   ret void
28 ; CHECK: llvm.localrecover first argument must be function defined in this module
30 @global = constant i8 0
32 declare void @declaration()
34 define internal void @i() {
35   call ptr @llvm.localrecover(ptr @global, ptr null, i32 0)
36   ret void
38 ; CHECK: llvm.localrecover first argument must be function defined in this module
40 define internal void @j() {
41   call ptr @llvm.localrecover(ptr @declaration, ptr null, i32 0)
42   ret void
44 ; CHECK: llvm.localrecover first argument must be function defined in this module
46 define internal void @k(i32 %n) {
47   call ptr @llvm.localrecover(ptr @f, ptr null, i32 %n)
48   ret void
51 ; CHECK: immarg operand has non-immediate parameter
52 ; CHECK-NEXT: i32 %n
53 ; CHECK-NEXT: %1 = call ptr @llvm.localrecover(ptr @f, ptr null, i32 %n)
55 define internal void @l(ptr %b) {
56   %a = alloca i8
57   call void (...) @llvm.localescape(ptr %a, ptr %b)
58   ret void
60 ; CHECK: llvm.localescape only accepts static allocas
62 define internal void @m() {
63   %a = alloca i8
64   call void (...) @llvm.localescape(ptr %a)
65   ret void
68 define internal void @n(ptr %fp) {
69   call ptr @llvm.localrecover(ptr @m, ptr %fp, i32 1)
70   ret void
72 ; CHECK: all indices passed to llvm.localrecover must be less than the number of arguments passed to llvm.localescape in the parent function