forked from OSchip/llvm-project
Simplify LoopStrengthReduce::DeleteTriviallyDeadInstructions by
making it use RecursivelyDeleteTriviallyDeadInstructions to do the heavy lifting. llvm-svn: 60195
This commit is contained in:
parent
a1bbdff933
commit
c077a2a535
|
@ -240,31 +240,30 @@ Value *LoopStrengthReduce::getCastedVersionOf(Instruction::CastOps opcode,
|
||||||
/// their operands subsequently dead.
|
/// their operands subsequently dead.
|
||||||
void LoopStrengthReduce::
|
void LoopStrengthReduce::
|
||||||
DeleteTriviallyDeadInstructions(SetVector<Instruction*> &Insts) {
|
DeleteTriviallyDeadInstructions(SetVector<Instruction*> &Insts) {
|
||||||
|
SmallVector<Instruction*, 16> DeadInsts;
|
||||||
|
|
||||||
while (!Insts.empty()) {
|
while (!Insts.empty()) {
|
||||||
Instruction *I = Insts.back();
|
Instruction *I = Insts.back();
|
||||||
Insts.pop_back();
|
Insts.pop_back();
|
||||||
|
|
||||||
|
// If I is dead, delete it and all the things that it recursively uses
|
||||||
|
// that become dead.
|
||||||
|
RecursivelyDeleteTriviallyDeadInstructions(I, &DeadInsts);
|
||||||
|
|
||||||
|
if (DeadInsts.empty()) continue;
|
||||||
|
Changed = true;
|
||||||
|
|
||||||
if (PHINode *PN = dyn_cast<PHINode>(I)) {
|
while (!DeadInsts.empty()) {
|
||||||
// If all incoming values to the Phi are the same, we can replace the Phi
|
Instruction *DeadInst = DeadInsts.back();
|
||||||
// with that value.
|
DeadInsts.pop_back();
|
||||||
if (Value *PNV = PN->hasConstantValue()) {
|
|
||||||
if (Instruction *U = dyn_cast<Instruction>(PNV))
|
// Make sure ScalarEvolutions knows this instruction is gone.
|
||||||
Insts.insert(U);
|
SE->deleteValueFromRecords(DeadInst);
|
||||||
SE->deleteValueFromRecords(PN);
|
|
||||||
PN->replaceAllUsesWith(PNV);
|
// Make sure that this instruction is removed from DeadInsts if it was
|
||||||
PN->eraseFromParent();
|
// recursively removed.
|
||||||
Changed = true;
|
if (DeadInst != I)
|
||||||
continue;
|
Insts.remove(DeadInst);
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isInstructionTriviallyDead(I)) {
|
|
||||||
for (User::op_iterator i = I->op_begin(), e = I->op_end(); i != e; ++i)
|
|
||||||
if (Instruction *U = dyn_cast<Instruction>(*i))
|
|
||||||
Insts.insert(U);
|
|
||||||
SE->deleteValueFromRecords(I);
|
|
||||||
I->eraseFromParent();
|
|
||||||
Changed = true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue