diff --git a/lib/Transforms/Scalar/ADCE.cpp b/lib/Transforms/Scalar/ADCE.cpp index ffb57d0d6ae..0efdbf4b0f6 100644 --- a/lib/Transforms/Scalar/ADCE.cpp +++ b/lib/Transforms/Scalar/ADCE.cpp @@ -84,8 +84,8 @@ private: } inline void markTerminatorLive(const BasicBlock *BB) { - DEBUG(std::cerr << "Terminat Live: " << BB->getTerminator()); - markInstructionLive((Instruction*)BB->getTerminator()); + DEBUG(std::cerr << "Terminator Live: " << BB->getTerminator()); + markInstructionLive(const_cast(BB->getTerminator())); } }; @@ -176,7 +176,7 @@ bool ADCE::doADCE() { BBI != BBE; ++BBI) { BasicBlock *BB = *BBI; for (BasicBlock::iterator II = BB->begin(), EI = BB->end(); II != EI; ) { - if (II->mayWriteToMemory() || II->getOpcode() == Instruction::Ret) { + if (II->mayWriteToMemory() || isa(II) || isa(II)){ markInstructionLive(II); ++II; // Increment the inst iterator if the inst wasn't deleted } else if (isInstructionTriviallyDead(II)) {