diff options
-rw-r--r-- | llvm/lib/Transforms/Utils/LoopUnrollRuntime.cpp | 11 | ||||
-rw-r--r-- | llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-unroll.ll | 35 | ||||
-rw-r--r-- | llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-vect.ll (renamed from llvm/test/Analysis/ScalarEvolution/scev-expander-existing-value.ll) | 2 |
3 files changed, 43 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Utils/LoopUnrollRuntime.cpp b/llvm/lib/Transforms/Utils/LoopUnrollRuntime.cpp index 16197a9206e..5758a415f12 100644 --- a/llvm/lib/Transforms/Utils/LoopUnrollRuntime.cpp +++ b/llvm/lib/Transforms/Utils/LoopUnrollRuntime.cpp @@ -491,11 +491,6 @@ bool llvm::UnrollRuntimeLoopRemainder(Loop *L, unsigned Count, if (Log2_32(Count) > BEWidth) return false; - // If this loop is nested, then the loop unroller changes the code in the - // parent loop, so the Scalar Evolution pass needs to be run again. - if (Loop *ParentLoop = L->getParentLoop()) - SE->forgetLoop(ParentLoop); - BasicBlock *Latch = L->getLoopLatch(); // Loop structure is the following: @@ -685,6 +680,12 @@ bool llvm::UnrollRuntimeLoopRemainder(Loop *L, unsigned Count, ConnectProlog(L, BECount, Count, PrologExit, PreHeader, NewPreHeader, VMap, DT, LI, PreserveLCSSA); } + + // If this loop is nested, then the loop unroller changes the code in the + // parent loop, so the Scalar Evolution pass needs to be run again. + if (Loop *ParentLoop = L->getParentLoop()) + SE->forgetLoop(ParentLoop); + NumRuntimeUnrolled++; return true; } 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 +} + diff --git a/llvm/test/Analysis/ScalarEvolution/scev-expander-existing-value.ll b/llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-vect.ll index 0c1d6766869..a818b47523e 100644 --- a/llvm/test/Analysis/ScalarEvolution/scev-expander-existing-value.ll +++ b/llvm/test/Analysis/ScalarEvolution/scev-expander-reuse-vect.ll @@ -1,8 +1,10 @@ ; RUN: opt < %s -loop-vectorize -force-vector-width=4 -verify-scev-maps -S |FileCheck %s ; SCEV expansion uses existing value when the SCEV has no AddRec expr. +; CHECK-LABEL: @foo( ; CHECK: select ; CHECK-NOT: select +; CHECK: ret @a = common global [1000 x i16] zeroinitializer, align 16 |