mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-22 14:05:03 +00:00
Use Duncan's patch to delete the instructions in reverse order (minus the landingpad and terminator).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@139090 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
66d1836380
commit
a268468d50
@ -1574,15 +1574,19 @@ bool InstCombiner::DoOneIteration(Function &F, unsigned Iteration) {
|
||||
for (Function::iterator BB = F.begin(), E = F.end(); BB != E; ++BB) {
|
||||
if (Visited.count(BB)) continue;
|
||||
|
||||
// Delete the instructions.
|
||||
for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ) {
|
||||
Instruction *Inst = &*I++;
|
||||
if (isa<TerminatorInst>(Inst))
|
||||
break;
|
||||
// Delete the instructions backwards, as it has a reduced likelihood of
|
||||
// having to update as many def-use and use-def chains.
|
||||
Instruction *EndInst = BB->getTerminator(); // Last not to be deleted.
|
||||
while (EndInst != BB->begin()) {
|
||||
// Delete the next to last instruction.
|
||||
BasicBlock::iterator I = EndInst;
|
||||
Instruction *Inst = --I;
|
||||
if (!Inst->use_empty())
|
||||
Inst->replaceAllUsesWith(UndefValue::get(Inst->getType()));
|
||||
if (isa<LandingPadInst>(Inst))
|
||||
if (isa<LandingPadInst>(Inst)) {
|
||||
EndInst = Inst;
|
||||
continue;
|
||||
}
|
||||
if (!isa<DbgInfoIntrinsic>(Inst)) {
|
||||
++NumDeadInst;
|
||||
MadeIRChange = true;
|
||||
|
@ -1686,15 +1686,19 @@ static void DeleteInstructionInBlock(BasicBlock *BB) {
|
||||
if (isa<TerminatorInst>(BB->begin()))
|
||||
return;
|
||||
|
||||
// Delete the instructions.
|
||||
for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ) {
|
||||
Instruction *Inst = &*I++;
|
||||
if (isa<TerminatorInst>(Inst))
|
||||
break;
|
||||
// Delete the instructions backwards, as it has a reduced likelihood of having
|
||||
// to update as many def-use and use-def chains.
|
||||
Instruction *EndInst = BB->getTerminator(); // Last not to be deleted.
|
||||
while (EndInst != BB->begin()) {
|
||||
// Delete the next to last instruction.
|
||||
BasicBlock::iterator I = EndInst;
|
||||
Instruction *Inst = --I;
|
||||
if (!Inst->use_empty())
|
||||
Inst->replaceAllUsesWith(UndefValue::get(Inst->getType()));
|
||||
if (isa<LandingPadInst>(Inst))
|
||||
if (isa<LandingPadInst>(Inst)) {
|
||||
EndInst = Inst;
|
||||
continue;
|
||||
}
|
||||
BB->getInstList().erase(Inst);
|
||||
++NumInstRemoved;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user