Index: tests_lit/reader_tests/call.ll |
diff --git a/tests_lit/reader_tests/call.ll b/tests_lit/reader_tests/call.ll |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f70c44ad631b6612c9de802f67090942bd9c4d74 |
--- /dev/null |
+++ b/tests_lit/reader_tests/call.ll |
@@ -0,0 +1,112 @@ |
+; Test handling of call instructions. |
+ |
+; RUN: llvm-as < %s | pnacl-freeze -allow-local-symbol-tables \ |
+; RUN: | %llvm2ice -notranslate -verbose=inst -build-on-read \ |
+; RUN: -allow-pnacl-reader-error-recovery \ |
+; RUN: -allow-local-symbol-tables \ |
+; RUN: | FileCheck %s |
+ |
+define i32 @fib(i32 %n) { |
Jim Stichnoth
2014/09/18 21:41:54
Just so I don't have to pore through all these tes
Karl
2014/09/18 22:01:50
Almost. I removed duplicate calls to an intrinsic
jvoung (off chromium)
2014/09/18 23:43:53
Hmm I'm not sure you need to have calls to all the
Karl
2014/09/19 20:29:51
I can't test a bad type signature, because llvm-as
|
+entry: |
+ %cmp = icmp slt i32 %n, 2 |
+ br i1 %cmp, label %return, label %if.end |
+ |
+if.end: ; preds = %entry |
+ %sub = add i32 %n, -1 |
+ %call = tail call i32 @fib(i32 %sub) |
+ %sub1 = add i32 %n, -2 |
+ %call2 = tail call i32 @fib(i32 %sub1) |
+ %add = add i32 %call2, %call |
+ ret i32 %add |
+ |
+return: ; preds = %entry |
+ ret i32 %n |
+} |
+ |
+; CHECK: define i32 @fib(i32 %n) { |
+; CHECK-NEXT: entry: |
+; CHECK-NEXT: %cmp = icmp slt i32 %n, 2 |
+; CHECK-NEXT: br i1 %cmp, label %return, label %if.end |
+; CHECK-NEXT: if.end: |
+; CHECK-NEXT: %sub = add i32 %n, -1 |
+; CHECK-NEXT: %call = call i32 @fib(i32 %sub) |
+; CHECK-NEXT: %sub1 = add i32 %n, -2 |
+; CHECK-NEXT: %call2 = call i32 @fib(i32 %sub1) |
+; CHECK-NEXT: %add = add i32 %call2, %call |
+; CHECK-NEXT: ret i32 %add |
+; CHECK-NEXT: return: |
+; CHECK-NEXT: ret i32 %n |
+; CHECK-NEXT: } |
+ |
+define i32 @fact(i32 %n) { |
+entry: |
+ %cmp = icmp slt i32 %n, 2 |
+ br i1 %cmp, label %return, label %if.end |
+ |
+if.end: ; preds = %entry |
+ %sub = add i32 %n, -1 |
+ %call = tail call i32 @fact(i32 %sub) |
+ %mul = mul i32 %call, %n |
+ ret i32 %mul |
+ |
+return: ; preds = %entry |
+ ret i32 %n |
+} |
+ |
+; CHECK-NEXT: define i32 @fact(i32 %n) { |
+; CHECK-NEXT: entry: |
+; CHECK-NEXT: %cmp = icmp slt i32 %n, 2 |
+; CHECK-NEXT: br i1 %cmp, label %return, label %if.end |
+; CHECK-NEXT: if.end: |
+; CHECK-NEXT: %sub = add i32 %n, -1 |
+; CHECK-NEXT: %call = call i32 @fact(i32 %sub) |
+; CHECK-NEXT: %mul = mul i32 %call, %n |
+; CHECK-NEXT: ret i32 %mul |
+; CHECK-NEXT: return: |
+; CHECK-NEXT: ret i32 %n |
+; CHECK-NEXT: } |
+ |
+define i32 @redirect(i32 %n) { |
+entry: |
+ %call = tail call i32 @redirect_target(i32 %n) |
+ ret i32 %call |
+} |
+ |
+; CHECK-NEXT: define i32 @redirect(i32 %n) { |
+; CHECK-NEXT: entry: |
+; CHECK-NEXT: %call = call i32 @redirect_target(i32 %n) |
+; CHECK-NEXT: ret i32 %call |
+; CHECK-NEXT: } |
+ |
+declare i32 @redirect_target(i32) |
+ |
+define void @call_void(i32 %n) { |
+entry: |
+ %cmp2 = icmp sgt i32 %n, 0 |
+ br i1 %cmp2, label %if.then, label %if.end |
+ |
+if.then: ; preds = %entry, %if.then |
+ %n.tr3 = phi i32 [ %call.i, %if.then ], [ %n, %entry ] |
+ %sub = add i32 %n.tr3, -1 |
+ %call.i = tail call i32 @redirect_target(i32 %sub) |
+ %cmp = icmp sgt i32 %call.i, 0 |
+ br i1 %cmp, label %if.then, label %if.end |
+ |
+if.end: ; preds = %if.then, %entry |
+ ret void |
+} |
+ |
+; CHECK-NEXT: define void @call_void(i32 %n) { |
+; CHECK-NEXT: entry: |
+; CHECK-NEXT: %cmp2 = icmp sgt i32 %n, 0 |
+; CHECK-NEXT: br i1 %cmp2, label %if.then, label %if.end |
+; CHECK-NEXT: if.then: |
+; CHECK-NEXT: %n.tr3 = phi i32 [ %call.i, %if.then ], [ %n, %entry ] |
+; CHECK-NEXT: %sub = add i32 %n.tr3, -1 |
+; CHECK-NEXT: %call.i = call i32 @redirect_target(i32 %sub) |
+; CHECK-NEXT: %cmp = icmp sgt i32 %call.i, 0 |
+; CHECK-NEXT: br i1 %cmp, label %if.then, label %if.end |
+; CHECK-NEXT: if.end: |
+; CHECK-NEXT: ret void |
+; CHECK-NEXT: } |
+ |