diff options
| author | Max Kazantsev <max.kazantsev@azul.com> | 2018-09-18 04:57:18 +0000 |
|---|---|---|
| committer | Max Kazantsev <max.kazantsev@azul.com> | 2018-09-18 04:57:18 +0000 |
| commit | 0994abda3aa6ad490bb78f50e0be99952bdd2361 (patch) | |
| tree | 373c67ec0f9dd08cc75f3ba23c5a60a1ccd78dec | |
| parent | ebf46143eaf7fa3ad956baf8cc876cbe2c6ae306 (diff) | |
| download | bcm5719-llvm-0994abda3aa6ad490bb78f50e0be99952bdd2361.tar.gz bcm5719-llvm-0994abda3aa6ad490bb78f50e0be99952bdd2361.zip | |
[IndVars] Remove unreasonable checks in rewriteLoopExitValues
A piece of logic in rewriteLoopExitValues has a weird check on number of
users which allowed an unprofitable transform in case if an instruction has
more than 6 users.
Differential Revision: https://reviews.llvm.org/D51404
Reviewed By: etherzhhb
llvm-svn: 342444
| -rw-r--r-- | llvm/lib/Transforms/Scalar/IndVarSimplify.cpp | 16 | ||||
| -rw-r--r-- | llvm/test/Transforms/IndVarSimplify/dont-recompute.ll | 30 |
2 files changed, 35 insertions, 11 deletions
diff --git a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp index b536b534328..c35478e220b 100644 --- a/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp +++ b/llvm/lib/Transforms/Scalar/IndVarSimplify.cpp @@ -603,12 +603,9 @@ bool IndVarSimplify::rewriteLoopExitValues(Loop *L, SCEVExpander &Rewriter) { if (ExitValue->getSCEVType()>=scMulExpr) { bool HasHardInternalUses = false; bool HasSoftExternalUses = false; - unsigned NumUses = 0; - for (auto IB = Inst->user_begin(), IE = Inst->user_end(); - IB != IE && NumUses <= 6; ++IB) { - Instruction *UseInstr = cast<Instruction>(*IB); + for (auto *IB : Inst->users()) { + Instruction *UseInstr = cast<Instruction>(IB); unsigned Opc = UseInstr->getOpcode(); - NumUses++; if (L->contains(UseInstr)) { if (Opc == Instruction::Call) HasHardInternalUses = true; @@ -616,11 +613,8 @@ bool IndVarSimplify::rewriteLoopExitValues(Loop *L, SCEVExpander &Rewriter) { if (Opc == Instruction::PHI) { // Do not count the Phi as a use. LCSSA may have inserted // plenty of trivial ones. - NumUses--; - for (auto PB = UseInstr->user_begin(), - PE = UseInstr->user_end(); - PB != PE && NumUses <= 6; ++PB, ++NumUses) { - unsigned PhiOpc = cast<Instruction>(*PB)->getOpcode(); + for (auto *PB : UseInstr->users()) { + unsigned PhiOpc = cast<Instruction>(PB)->getOpcode(); if (PhiOpc != Instruction::Call && PhiOpc != Instruction::Ret) { HasSoftExternalUses = true; @@ -635,7 +629,7 @@ bool IndVarSimplify::rewriteLoopExitValues(Loop *L, SCEVExpander &Rewriter) { } } } - if (NumUses <= 6 && HasHardInternalUses && !HasSoftExternalUses) + if (HasHardInternalUses && !HasSoftExternalUses) continue; } diff --git a/llvm/test/Transforms/IndVarSimplify/dont-recompute.ll b/llvm/test/Transforms/IndVarSimplify/dont-recompute.ll index e5ced0f2e4b..713a55154ba 100644 --- a/llvm/test/Transforms/IndVarSimplify/dont-recompute.ll +++ b/llvm/test/Transforms/IndVarSimplify/dont-recompute.ll @@ -67,3 +67,33 @@ for.end: ; preds = %for.body ; CHECK-NEXT: ret i32 %add.lcssa ret i32 %add } + +; CHECK-LABEL: @test3( +define void @test3(i32 %m) nounwind uwtable { +entry: + br label %for.body + +for.body: ; preds = %for.body, %entry + %i.06 = phi i32 [ 0, %entry ], [ %inc, %for.body ] + %a.05 = phi i32 [ 0, %entry ], [ %add, %for.body ] + %add = add i32 %a.05, %m + mul i32 %add, 1 + mul i32 %add, 1 + mul i32 %add, 1 + mul i32 %add, 1 + mul i32 %add, 1 + mul i32 %add, 1 +; CHECK: tail call void @func(i32 %add) + tail call void @func(i32 %add) + %inc = add nsw i32 %i.06, 1 + %exitcond = icmp eq i32 %inc, 186 + br i1 %exitcond, label %for.end, label %for.body + +for.end: ; preds = %for.body +; CHECK: for.end: +; CHECK-NOT: mul i32 %m, 186 +; CHECK:%add.lcssa = phi i32 [ %add, %for.body ] +; CHECK-NEXT: tail call void @func(i32 %add.lcssa) + tail call void @func(i32 %add) + ret void +} |

