Skip to content
Snippets Groups Projects
Commit cbad11e0 authored by Chris Lattner's avatar Chris Lattner
Browse files

don't put erase or query for non-allocainst pointers in an set of allocainsts*'s

llvm-svn: 43779
parent f76f2b0c
No related branches found
No related tags found
No related merge requests found
...@@ -271,7 +271,8 @@ bool DSE::handleEndBlock(BasicBlock& BB, ...@@ -271,7 +271,8 @@ bool DSE::handleEndBlock(BasicBlock& BB,
// See through pointer-to-pointer bitcasts // See through pointer-to-pointer bitcasts
TranslatePointerBitCasts(pointerOperand); TranslatePointerBitCasts(pointerOperand);
if (deadPointers.count(pointerOperand)){ if (isa<AllocaInst>(pointerOperand) &&
deadPointers.count(cast<AllocaInst>(pointerOperand))) {
// Remove it! // Remove it!
MD.removeInstruction(S); MD.removeInstruction(S);
...@@ -345,7 +346,8 @@ bool DSE::handleEndBlock(BasicBlock& BB, ...@@ -345,7 +346,8 @@ bool DSE::handleEndBlock(BasicBlock& BB,
for (std::vector<Instruction*>::iterator I = dead.begin(), E = dead.end(); for (std::vector<Instruction*>::iterator I = dead.begin(), E = dead.end();
I != E; ++I) I != E; ++I)
deadPointers.erase(*I); if (AllocaInst *AI = dyn_cast<AllocaInst>(*I))
deadPointers.erase(AI);
continue; continue;
} }
...@@ -427,7 +429,8 @@ bool DSE::RemoveUndeadPointers(Value* killPointer, ...@@ -427,7 +429,8 @@ bool DSE::RemoveUndeadPointers(Value* killPointer,
for (std::vector<Instruction*>::iterator I = undead.begin(), E = undead.end(); for (std::vector<Instruction*>::iterator I = undead.begin(), E = undead.end();
I != E; ++I) I != E; ++I)
deadPointers.erase(*I); if (AllocaInst *AI = dyn_cast<AllocaInst>(*I))
deadPointers.erase(AI);
return MadeChange; return MadeChange;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment