[PATCH] D82108: [IndVarSimplify] Don't replace IV user with unsafe loop-invariant (PR45360)
Roman Lebedev via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jun 18 11:27:08 PDT 2020
lebedev.ri updated this revision to Diff 271783.
lebedev.ri marked an inline comment as done.
lebedev.ri edited the summary of this revision.
lebedev.ri added a comment.
Actually, i guess we only need `isSafeToExpand()`, not whole `isSafeToExpandAt()`.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D82108/new/
https://reviews.llvm.org/D82108
Files:
llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
llvm/test/Transforms/IndVarSimplify/X86/pr45360.ll
Index: llvm/test/Transforms/IndVarSimplify/X86/pr45360.ll
===================================================================
--- llvm/test/Transforms/IndVarSimplify/X86/pr45360.ll
+++ llvm/test/Transforms/IndVarSimplify/X86/pr45360.ll
@@ -26,7 +26,6 @@
; CHECK: bb19:
; CHECK-NEXT: [[I8_LCSSA9:%.*]] = phi i32 [ [[D_PROMOTED8]], [[BB:%.*]] ], [ [[I8:%.*]], [[BB27:%.*]] ]
; CHECK-NEXT: [[I8]] = and i32 [[I8_LCSSA9]], [[I6]]
-; CHECK-NEXT: [[TMP0:%.*]] = urem i32 [[I24]], [[I8]]
; CHECK-NEXT: [[I21:%.*]] = icmp eq i32 [[I8]], 0
; CHECK-NEXT: br i1 [[I21]], label [[BB27_THREAD:%.*]], label [[BB27]]
; CHECK: bb27.thread:
@@ -35,8 +34,9 @@
; CHECK-NEXT: store i32 0, i32* @c, align 4
; CHECK-NEXT: br label [[BB32:%.*]]
; CHECK: bb27:
-; CHECK-NEXT: store i32 [[TMP0]], i32* @e, align 4
-; CHECK-NEXT: [[I30:%.*]] = icmp eq i32 [[TMP0]], 0
+; CHECK-NEXT: [[I26:%.*]] = urem i32 [[I24]], [[I8]]
+; CHECK-NEXT: store i32 [[I26]], i32* @e, align 4
+; CHECK-NEXT: [[I30:%.*]] = icmp eq i32 [[I26]], 0
; CHECK-NEXT: br i1 [[I30]], label [[BB32_LOOPEXIT:%.*]], label [[BB19]]
; CHECK: bb32.loopexit:
; CHECK-NEXT: store i32 -1, i32* @f, align 4
Index: llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
===================================================================
--- llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
+++ llvm/lib/Transforms/Utils/SimplifyIndVar.cpp
@@ -672,6 +672,12 @@
if (Rewriter.isHighCostExpansion(S, L, SCEVCheapExpansionBudget, TTI, I))
return false;
+ if (!isSafeToExpand(S, *SE)) {
+ LLVM_DEBUG(dbgs() << "INDVARS: Can not replace IV user: " << *I
+ << " with loop invariant: " << *S << '\n');
+ return false;
+ }
+
auto *IP = GetLoopInvariantInsertPosition(L, I);
auto *Invariant = Rewriter.expandCodeFor(S, I->getType(), IP);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D82108.271783.patch
Type: text/x-patch
Size: 1872 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200618/55569eab/attachment.bin>
More information about the llvm-commits
mailing list