mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 02:32:11 +00:00
LoopIdiom: Use utility functions.
The only difference between deleteIfDeadInstruction and RecursivelyDeleteTriviallyDeadInstructions is that the former also manually invalidates SCEV. That's unnecessary because SCEV automatically gets informed when an instruction is deleted via a ValueHandle. NFC. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@228508 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
128482cfc4
commit
fd3cd51a3a
@ -237,44 +237,13 @@ Pass *llvm::createLoopIdiomPass() { return new LoopIdiomRecognize(); }
|
|||||||
/// and zero out all the operands of this instruction. If any of them become
|
/// and zero out all the operands of this instruction. If any of them become
|
||||||
/// dead, delete them and the computation tree that feeds them.
|
/// dead, delete them and the computation tree that feeds them.
|
||||||
///
|
///
|
||||||
static void deleteDeadInstruction(Instruction *I, ScalarEvolution &SE,
|
static void deleteDeadInstruction(Instruction *I,
|
||||||
const TargetLibraryInfo *TLI) {
|
const TargetLibraryInfo *TLI) {
|
||||||
SmallVector<Instruction*, 32> NowDeadInsts;
|
SmallVector<Value *, 16> Operands(I->value_op_begin(), I->value_op_end());
|
||||||
|
I->replaceAllUsesWith(UndefValue::get(I->getType()));
|
||||||
NowDeadInsts.push_back(I);
|
I->eraseFromParent();
|
||||||
|
for (Value *Op : Operands)
|
||||||
// Before we touch this instruction, remove it from SE!
|
RecursivelyDeleteTriviallyDeadInstructions(Op, TLI);
|
||||||
do {
|
|
||||||
Instruction *DeadInst = NowDeadInsts.pop_back_val();
|
|
||||||
|
|
||||||
// This instruction is dead, zap it, in stages. Start by removing it from
|
|
||||||
// SCEV.
|
|
||||||
SE.forgetValue(DeadInst);
|
|
||||||
|
|
||||||
for (unsigned op = 0, e = DeadInst->getNumOperands(); op != e; ++op) {
|
|
||||||
Value *Op = DeadInst->getOperand(op);
|
|
||||||
DeadInst->setOperand(op, nullptr);
|
|
||||||
|
|
||||||
// If this operand just became dead, add it to the NowDeadInsts list.
|
|
||||||
if (!Op->use_empty()) continue;
|
|
||||||
|
|
||||||
if (Instruction *OpI = dyn_cast<Instruction>(Op))
|
|
||||||
if (isInstructionTriviallyDead(OpI, TLI))
|
|
||||||
NowDeadInsts.push_back(OpI);
|
|
||||||
}
|
|
||||||
|
|
||||||
DeadInst->eraseFromParent();
|
|
||||||
|
|
||||||
} while (!NowDeadInsts.empty());
|
|
||||||
}
|
|
||||||
|
|
||||||
/// deleteIfDeadInstruction - If the specified value is a dead instruction,
|
|
||||||
/// delete it and any recursively used instructions.
|
|
||||||
static void deleteIfDeadInstruction(Value *V, ScalarEvolution &SE,
|
|
||||||
const TargetLibraryInfo *TLI) {
|
|
||||||
if (Instruction *I = dyn_cast<Instruction>(V))
|
|
||||||
if (isInstructionTriviallyDead(I, TLI))
|
|
||||||
deleteDeadInstruction(I, SE, TLI);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
@ -290,7 +259,7 @@ static void deleteIfDeadInstruction(Value *V, ScalarEvolution &SE,
|
|||||||
// the concern of breaking data dependence.
|
// the concern of breaking data dependence.
|
||||||
bool LIRUtil::isAlmostEmpty(BasicBlock *BB) {
|
bool LIRUtil::isAlmostEmpty(BasicBlock *BB) {
|
||||||
if (BranchInst *Br = getBranch(BB)) {
|
if (BranchInst *Br = getBranch(BB)) {
|
||||||
return Br->isUnconditional() && BB->size() == 1;
|
return Br->isUnconditional() && Br == BB->begin();
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -547,7 +516,7 @@ void NclPopcountRecognize::transform(Instruction *CntInst,
|
|||||||
cast<ICmpInst>(Builder.CreateICmp(PreCond->getPredicate(), Opnd0, Opnd1));
|
cast<ICmpInst>(Builder.CreateICmp(PreCond->getPredicate(), Opnd0, Opnd1));
|
||||||
PreCond->replaceAllUsesWith(NewPreCond);
|
PreCond->replaceAllUsesWith(NewPreCond);
|
||||||
|
|
||||||
deleteDeadInstruction(PreCond, *SE, TLI);
|
RecursivelyDeleteTriviallyDeadInstructions(PreCond, TLI);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Step 3: Note that the population count is exactly the trip count of the
|
// Step 3: Note that the population count is exactly the trip count of the
|
||||||
@ -597,15 +566,7 @@ void NclPopcountRecognize::transform(Instruction *CntInst,
|
|||||||
// Step 4: All the references to the original population counter outside
|
// Step 4: All the references to the original population counter outside
|
||||||
// the loop are replaced with the NewCount -- the value returned from
|
// the loop are replaced with the NewCount -- the value returned from
|
||||||
// __builtin_ctpop().
|
// __builtin_ctpop().
|
||||||
{
|
CntInst->replaceUsesOutsideBlock(NewCount, Body);
|
||||||
SmallVector<Value *, 4> CntUses;
|
|
||||||
for (User *U : CntInst->users())
|
|
||||||
if (cast<Instruction>(U)->getParent() != Body)
|
|
||||||
CntUses.push_back(U);
|
|
||||||
for (unsigned Idx = 0; Idx < CntUses.size(); Idx++) {
|
|
||||||
(cast<Instruction>(CntUses[Idx]))->replaceUsesOfWith(CntInst, NewCount);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// step 5: Forget the "non-computable" trip-count SCEV associated with the
|
// step 5: Forget the "non-computable" trip-count SCEV associated with the
|
||||||
// loop. The loop would otherwise not be deleted even if it becomes empty.
|
// loop. The loop would otherwise not be deleted even if it becomes empty.
|
||||||
@ -1002,7 +963,7 @@ processLoopStridedStore(Value *DestPtr, unsigned StoreSize,
|
|||||||
StoreSize, getAnalysis<AliasAnalysis>(), TheStore)) {
|
StoreSize, getAnalysis<AliasAnalysis>(), TheStore)) {
|
||||||
Expander.clear();
|
Expander.clear();
|
||||||
// If we generated new code for the base pointer, clean up.
|
// If we generated new code for the base pointer, clean up.
|
||||||
deleteIfDeadInstruction(BasePtr, *SE, TLI);
|
RecursivelyDeleteTriviallyDeadInstructions(BasePtr, TLI);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1058,7 +1019,7 @@ processLoopStridedStore(Value *DestPtr, unsigned StoreSize,
|
|||||||
|
|
||||||
// Okay, the memset has been formed. Zap the original store and anything that
|
// Okay, the memset has been formed. Zap the original store and anything that
|
||||||
// feeds into it.
|
// feeds into it.
|
||||||
deleteDeadInstruction(TheStore, *SE, TLI);
|
deleteDeadInstruction(TheStore, TLI);
|
||||||
++NumMemSet;
|
++NumMemSet;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1099,7 +1060,7 @@ processLoopStoreOfLoopLoad(StoreInst *SI, unsigned StoreSize,
|
|||||||
getAnalysis<AliasAnalysis>(), SI)) {
|
getAnalysis<AliasAnalysis>(), SI)) {
|
||||||
Expander.clear();
|
Expander.clear();
|
||||||
// If we generated new code for the base pointer, clean up.
|
// If we generated new code for the base pointer, clean up.
|
||||||
deleteIfDeadInstruction(StoreBasePtr, *SE, TLI);
|
RecursivelyDeleteTriviallyDeadInstructions(StoreBasePtr, TLI);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1114,8 +1075,8 @@ processLoopStoreOfLoopLoad(StoreInst *SI, unsigned StoreSize,
|
|||||||
StoreSize, getAnalysis<AliasAnalysis>(), SI)) {
|
StoreSize, getAnalysis<AliasAnalysis>(), SI)) {
|
||||||
Expander.clear();
|
Expander.clear();
|
||||||
// If we generated new code for the base pointer, clean up.
|
// If we generated new code for the base pointer, clean up.
|
||||||
deleteIfDeadInstruction(LoadBasePtr, *SE, TLI);
|
RecursivelyDeleteTriviallyDeadInstructions(LoadBasePtr, TLI);
|
||||||
deleteIfDeadInstruction(StoreBasePtr, *SE, TLI);
|
RecursivelyDeleteTriviallyDeadInstructions(StoreBasePtr, TLI);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1148,7 +1109,7 @@ processLoopStoreOfLoopLoad(StoreInst *SI, unsigned StoreSize,
|
|||||||
|
|
||||||
// Okay, the memset has been formed. Zap the original store and anything that
|
// Okay, the memset has been formed. Zap the original store and anything that
|
||||||
// feeds into it.
|
// feeds into it.
|
||||||
deleteDeadInstruction(SI, *SE, TLI);
|
deleteDeadInstruction(SI, TLI);
|
||||||
++NumMemCpy;
|
++NumMemCpy;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user