diff options
| author | Wei Mi <wmi@google.com> | 2016-08-25 16:17:18 +0000 |
|---|---|---|
| committer | Wei Mi <wmi@google.com> | 2016-08-25 16:17:18 +0000 |
| commit | 59ca96636d8524eb8cf9a1b2b34b537ad6335f10 (patch) | |
| tree | cdb5b119a71a8b36228668f98492367645f6e712 /llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll | |
| parent | 341b1fea7c2be567754b9430f89564cb9655ec30 (diff) | |
| download | bcm5719-llvm-59ca96636d8524eb8cf9a1b2b34b537ad6335f10.tar.gz bcm5719-llvm-59ca96636d8524eb8cf9a1b2b34b537ad6335f10.zip | |
[UNROLL] Postpone ScalarEvolution::forgetLoop after TripCountSC is expanded
when unroll runtime iteration loop.
In llvm::UnrollRuntimeLoopRemainder, if the loop to be unrolled is the inner
loop inside a loop nest, the scalar evolution needs to be dropped for its
parent loop which is done by ScalarEvolution::forgetLoop. However, we can
postpone forgetLoop to the end of UnrollRuntimeLoopRemainder so TripCountSC
expansion can still reuse existing value.
Differential Revision: https://reviews.llvm.org/D23572
llvm-svn: 279748
Diffstat (limited to 'llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll')
| -rw-r--r-- | llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll b/llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll new file mode 100644 index 00000000000..e74b004c6f8 --- /dev/null +++ b/llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll @@ -0,0 +1,35 @@ +; RUN: opt < %s -loop-unroll -unroll-runtime -unroll-count=2 -verify-scev-maps -S | FileCheck %s + +; Check SCEV expansion uses existing value when unrolling an inner loop with runtime trip count in a loop nest. +; CHECK-LABEL: @foo( +; CHECK: select +; CHECK-NOT: select +; CHECK: ret + +define void @foo(i32 %xfL, i32 %scaleL) local_unnamed_addr { +entry: + br label %for.body + +for.body: ; preds = %for.body5, %for.body, %entry + %xfL.addr.033 = phi i32 [ %xfL, %entry ], [ %add, %for.body5 ] + %add = add nsw i32 %xfL.addr.033, %scaleL + %shr = ashr i32 %add, 16 + %cmp.i = icmp slt i32 0, %shr + %.sroa.speculated = select i1 %cmp.i, i32 0, i32 %shr + %cmp425 = icmp slt i32 0, %.sroa.speculated + br i1 %cmp425, label %for.body5.preheader, label %for.end + +for.body5.preheader: ; preds = %for.body + %tmp0 = sext i32 %.sroa.speculated to i64 + br label %for.body5 + +for.body5: ; preds = %for.body5, %for.body5.preheader + %indvars.iv = phi i64 [ 0, %for.body5.preheader ], [ %indvars.iv.next, %for.body5 ] + %indvars.iv.next = add nsw i64 %indvars.iv, 1 + %cmp4 = icmp slt i64 %indvars.iv.next, %tmp0 + br i1 %cmp4, label %for.body5, label %for.body + +for.end: + ret void +} + |

