[llvm] r249575 - [IndVars] Preserve LCSSA in `eliminateIdentitySCEV`
Sanjoy Das via llvm-commits
llvm-commits at lists.llvm.org
Wed Oct 7 10:38:31 PDT 2015
Author: sanjoy
Date: Wed Oct 7 12:38:31 2015
New Revision: 249575
URL: http://llvm.org/viewvc/llvm-project?rev=249575&view=rev
Log:
[IndVars] Preserve LCSSA in `eliminateIdentitySCEV`
Summary:
After r249211, SCEV can see through some LCSSA phis. Add a
`replacementPreservesLCSSAForm` check before replacing uses of these phi
nodes with a simplified use of the induction variable to avoid breaking
LCSSA.
Fixes 25047.
Depends on D13460.
Reviewers: atrick, hfinkel
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D13461
Added:
llvm/trunk/test/Transforms/IndVarSimplify/pr25047.ll
Modified:
llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp
Modified: llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp?rev=249575&r1=249574&r2=249575&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp (original)
+++ llvm/trunk/lib/Transforms/Utils/SimplifyIndVar.cpp Wed Oct 7 12:38:31 2015
@@ -333,6 +333,9 @@ bool SimplifyIndvar::eliminateIdentitySC
if (!DT || !DT->dominates(IVOperand, UseInst))
return false;
+ if (!LI->replacementPreservesLCSSAForm(UseInst, IVOperand))
+ return false;
+
DEBUG(dbgs() << "INDVARS: Eliminated identity: " << *UseInst << '\n');
UseInst->replaceAllUsesWith(IVOperand);
Added: llvm/trunk/test/Transforms/IndVarSimplify/pr25047.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/IndVarSimplify/pr25047.ll?rev=249575&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/IndVarSimplify/pr25047.ll (added)
+++ llvm/trunk/test/Transforms/IndVarSimplify/pr25047.ll Wed Oct 7 12:38:31 2015
@@ -0,0 +1,49 @@
+; RUN: opt -indvars -S < %s | FileCheck %s
+
+target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-apple-macosx10.11.0"
+
+define void @fn1(i1 %c0, i1 %c1) {
+; CHECK-LABEL: @fn1(
+entry:
+ br i1 %c0, label %for.end.34, label %for.cond.1thread-pre-split
+
+for.cond.loopexit: ; preds = %for.end.29, %for.end.7
+ %f.lcssa = phi i32 [ %f.1, %for.end.29 ], [ %f.1, %for.end.7 ]
+ br i1 %c1, label %for.end.34, label %for.cond.1thread-pre-split
+
+for.cond.1thread-pre-split: ; preds = %for.cond.loopexit, %entry
+ %f.047 = phi i32 [ %f.lcssa, %for.cond.loopexit ], [ 0, %entry ]
+ br label %for.cond.1
+
+for.cond.1: ; preds = %for.cond.1, %for.cond.1thread-pre-split
+ br i1 %c1, label %for.cond.4, label %for.cond.1
+
+for.cond.4: ; preds = %for.end.29, %for.cond.1
+ %f.1 = phi i32 [ 0, %for.end.29 ], [ %f.047, %for.cond.1 ]
+ br label %for.cond.5
+
+for.cond.5: ; preds = %for.cond.5, %for.cond.4
+ %h.0 = phi i32 [ 0, %for.cond.4 ], [ %inc, %for.cond.5 ]
+ %cmp = icmp slt i32 %h.0, 1
+ %inc = add nsw i32 %h.0, 1
+ br i1 %cmp, label %for.cond.5, label %for.end.7
+
+for.end.7: ; preds = %for.cond.5
+ %g.lcssa = phi i32 [ %h.0, %for.cond.5 ]
+ %tobool10 = icmp eq i32 %g.lcssa, 0
+ br i1 %tobool10, label %for.end.8, label %for.cond.loopexit
+
+for.end.8: ; preds = %for.end.7
+ br i1 %c1, label %for.cond.19, label %for.end.29
+
+for.cond.19: ; preds = %for.cond.19, %for.end.8
+ br label %for.cond.19
+
+for.end.29: ; preds = %for.end.8
+ %tobool30 = icmp eq i32 %f.1, 0
+ br i1 %tobool30, label %for.cond.4, label %for.cond.loopexit
+
+for.end.34: ; preds = %for.cond.loopexit, %entry
+ ret void
+}
More information about the llvm-commits
mailing list