Skip debug info when looking for existing EH calls at the

beginning of a block.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100230 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dale Johannesen 2010-04-02 21:49:27 +00:00
parent a144c3f34d
commit 7249ef0455
3 changed files with 19 additions and 2 deletions

View File

@ -131,6 +131,12 @@ public:
const Instruction* getFirstNonPHI() const { const Instruction* getFirstNonPHI() const {
return const_cast<BasicBlock*>(this)->getFirstNonPHI(); return const_cast<BasicBlock*>(this)->getFirstNonPHI();
} }
// Same as above, but also skip debug intrinsics.
Instruction* getFirstNonPHIOrDbg();
const Instruction* getFirstNonPHIOrDbg() const {
return const_cast<BasicBlock*>(this)->getFirstNonPHIOrDbg();
}
/// removeFromParent - This method unlinks 'this' from the containing /// removeFromParent - This method unlinks 'this' from the containing
/// function, but does not delete it. /// function, but does not delete it.

View File

@ -661,7 +661,7 @@ bool DwarfEHPrepare::PromoteStackTemporaries() {
/// the start of the basic block (unless there already is one, in which case /// the start of the basic block (unless there already is one, in which case
/// the existing call is returned). /// the existing call is returned).
Instruction *DwarfEHPrepare::CreateExceptionValueCall(BasicBlock *BB) { Instruction *DwarfEHPrepare::CreateExceptionValueCall(BasicBlock *BB) {
Instruction *Start = BB->getFirstNonPHI(); Instruction *Start = BB->getFirstNonPHIOrDbg();
// Is this a call to eh.exception? // Is this a call to eh.exception?
if (IntrinsicInst *CI = dyn_cast<IntrinsicInst>(Start)) if (IntrinsicInst *CI = dyn_cast<IntrinsicInst>(Start))
if (CI->getIntrinsicID() == Intrinsic::eh_exception) if (CI->getIntrinsicID() == Intrinsic::eh_exception)
@ -681,7 +681,7 @@ Instruction *DwarfEHPrepare::CreateExceptionValueCall(BasicBlock *BB) {
/// (creating it if necessary) at the start of the basic block (unless /// (creating it if necessary) at the start of the basic block (unless
/// there already is a load, in which case the existing load is returned). /// there already is a load, in which case the existing load is returned).
Instruction *DwarfEHPrepare::CreateValueLoad(BasicBlock *BB) { Instruction *DwarfEHPrepare::CreateValueLoad(BasicBlock *BB) {
Instruction *Start = BB->getFirstNonPHI(); Instruction *Start = BB->getFirstNonPHIOrDbg();
// Is this a load of the exception temporary? // Is this a load of the exception temporary?
if (ExceptionValueVar) if (ExceptionValueVar)
if (LoadInst* LI = dyn_cast<LoadInst>(Start)) if (LoadInst* LI = dyn_cast<LoadInst>(Start))

View File

@ -14,6 +14,7 @@
#include "llvm/BasicBlock.h" #include "llvm/BasicBlock.h"
#include "llvm/Constants.h" #include "llvm/Constants.h"
#include "llvm/Instructions.h" #include "llvm/Instructions.h"
#include "llvm/IntrinsicInst.h"
#include "llvm/LLVMContext.h" #include "llvm/LLVMContext.h"
#include "llvm/Type.h" #include "llvm/Type.h"
#include "llvm/ADT/STLExtras.h" #include "llvm/ADT/STLExtras.h"
@ -136,6 +137,16 @@ Instruction* BasicBlock::getFirstNonPHI() {
return &*i; return &*i;
} }
Instruction* BasicBlock::getFirstNonPHIOrDbg() {
BasicBlock::iterator i = begin();
// All valid basic blocks should have a terminator,
// which is not a PHINode. If we have an invalid basic
// block we'll get an assertion failure when dereferencing
// a past-the-end iterator.
while (isa<PHINode>(i) || isa<DbgInfoIntrinsic>(i)) ++i;
return &*i;
}
void BasicBlock::dropAllReferences() { void BasicBlock::dropAllReferences() {
for(iterator I = begin(), E = end(); I != E; ++I) for(iterator I = begin(), E = end(); I != E; ++I)
I->dropAllReferences(); I->dropAllReferences();