Expose the low level DCE mechanism to external users

Refactor code to support it

llvm-svn: 1083
This commit is contained in:
Chris Lattner 2001-11-01 07:00:27 +00:00
parent 63ac2b335a
commit 7567f6c15f
1 changed files with 20 additions and 10 deletions

View File

@ -34,20 +34,30 @@
#include "llvm/Assembly/Writer.h"
#include <algorithm>
static bool RemoveUnusedDefs(BasicBlock::InstListType &Vals) {
// dceInstruction - Inspect the instruction at *BBI and figure out if it's
// [trivially] dead. If so, remove the instruction and update the iterator
// to point to the instruction that immediately succeeded the original
// instruction.
//
bool opt::DeadCodeElimination::dceInstruction(BasicBlock::InstListType &BBIL,
BasicBlock::iterator &BBI) {
// Look for un"used" definitions...
if ((*BBI)->use_empty() && !(*BBI)->hasSideEffects() &&
!isa<TerminatorInst>(*BBI)) {
delete BBIL.remove(BBI); // Bye bye
return true;
}
return false;
}
static inline bool RemoveUnusedDefs(BasicBlock::InstListType &Vals) {
bool Changed = false;
for (BasicBlock::InstListType::iterator DI = Vals.begin();
DI != Vals.end()-1; ) {
// Look for un"used" definitions...
if ((*DI)->use_empty() && !(*DI)->hasSideEffects()) {
// Bye bye
//cerr << "Removing: " << *DI;
delete Vals.remove(DI);
DI != Vals.end(); )
if (opt::DeadCodeElimination::dceInstruction(Vals, DI))
Changed = true;
} else {
else
++DI;
}
}
return Changed;
}