diff options
author | Tobias Grosser <tobias@grosser.es> | 2015-10-15 18:26:06 +0000 |
---|---|---|
committer | Tobias Grosser <tobias@grosser.es> | 2015-10-15 18:26:06 +0000 |
commit | b860289dbded3bb6d853426a49631a9cc22d0c24 (patch) | |
tree | aecd196fea25c9bfeda183a37ee7cff49f9aecf2 | |
parent | 2cdd5e47109e428ffd769a9b03b80956a0c32216 (diff) | |
download | bcm5719-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.ll | 54 |
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 +} |