summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Grosser <tobias@grosser.es>2015-10-15 18:26:06 +0000
committerTobias Grosser <tobias@grosser.es>2015-10-15 18:26:06 +0000
commitb860289dbded3bb6d853426a49631a9cc22d0c24 (patch)
treeaecd196fea25c9bfeda183a37ee7cff49f9aecf2
parent2cdd5e47109e428ffd769a9b03b80956a0c32216 (diff)
downloadbcm5719-llvm-b860289dbded3bb6d853426a49631a9cc22d0c24.tar.gz
bcm5719-llvm-b860289dbded3bb6d853426a49631a9cc22d0c24.zip
Add ScopInfo test case for r250411
llvm-svn: 250439
-rw-r--r--polly/test/ScopInfo/intra-non-affine-stmt-phi-node.ll54
1 files changed, 54 insertions, 0 deletions
diff --git a/polly/test/ScopInfo/intra-non-affine-stmt-phi-node.ll b/polly/test/ScopInfo/intra-non-affine-stmt-phi-node.ll
new file mode 100644
index 00000000000..8a27811748a
--- /dev/null
+++ b/polly/test/ScopInfo/intra-non-affine-stmt-phi-node.ll
@@ -0,0 +1,54 @@
+; RUN: opt %loadPolly -polly-scops -analyze \
+; RUN: -S < %s | FileCheck %s
+
+
+; CHECK: Statements {
+; CHECK-NEXT: Stmt_loop__TO__backedge
+; CHECK-NEXT: Domain :=
+; CHECK-NEXT: { Stmt_loop__TO__backedge[i0] : i0 <= 100 and i0 >= 0 };
+; CHECK-NEXT: Schedule :=
+; CHECK-NEXT: { Stmt_loop__TO__backedge[i0] -> [i0, 0] };
+; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 1]
+; CHECK-NEXT: { Stmt_loop__TO__backedge[i0] -> MemRef_merge__phi[] };
+; CHECK-NEXT: MayWriteAccess := [Reduction Type: NONE] [Scalar: 1]
+; CHECK-NEXT: { Stmt_loop__TO__backedge[i0] -> MemRef_merge__phi[] };
+; CHECK-NEXT: MayWriteAccess := [Reduction Type: NONE] [Scalar: 1]
+; CHECK-NEXT: { Stmt_loop__TO__backedge[i0] -> MemRef_merge__phi[] };
+; CHECK-NEXT: Stmt_backedge
+; CHECK-NEXT: Domain :=
+; CHECK-NEXT: { Stmt_backedge[i0] : i0 <= 100 and i0 >= 0 };
+; CHECK-NEXT: Schedule :=
+; CHECK-NEXT: { Stmt_backedge[i0] -> [i0, 1] };
+; CHECK-NEXT: ReadAccess := [Reduction Type: NONE] [Scalar: 1]
+; CHECK-NEXT: { Stmt_backedge[i0] -> MemRef_merge__phi[] };
+; CHECK-NEXT: MustWriteAccess := [Reduction Type: NONE] [Scalar: 0]
+; CHECK-NEXT: { Stmt_backedge[i0] -> MemRef_A[0] };
+; CHECK-NEXT: }
+
+define void @foo(float* %A, i1 %cond0, i1 %cond1) {
+entry:
+ br label %loop
+
+loop:
+ %indvar = phi i64 [0, %entry], [%indvar.next, %backedge]
+ %val0 = fadd float 1.0, 2.0
+ %val1 = fadd float 1.0, 2.0
+ br i1 %cond0, label %branch1, label %backedge
+
+branch1:
+ %val2 = fadd float 1.0, 2.0
+ br i1 %cond1, label %branch2, label %backedge
+
+branch2:
+ br label %backedge
+
+backedge:
+ %merge = phi float [%val0, %loop], [%val1, %branch1], [%val2, %branch2]
+ %indvar.next = add i64 %indvar, 1
+ store float %merge, float* %A
+ %cmp = icmp sle i64 %indvar.next, 100
+ br i1 %cmp, label %loop, label %exit
+
+exit:
+ ret void
+}
OpenPOWER on IntegriCloud