debug intrinsics do not go in the callgraph, this fixes a couple

clang regtest failures.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80724 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2009-09-01 21:37:50 +00:00
parent 44a18370e0
commit 8bff7c960c

View File

@ -22,6 +22,7 @@
#include "llvm/PassManagers.h" #include "llvm/PassManagers.h"
#include "llvm/Function.h" #include "llvm/Function.h"
#include "llvm/Support/Debug.h" #include "llvm/Support/Debug.h"
#include "llvm/IntrinsicInst.h"
#include "llvm/Support/raw_ostream.h" #include "llvm/Support/raw_ostream.h"
using namespace llvm; using namespace llvm;
@ -192,7 +193,7 @@ void CGPassManager::RefreshCallGraph(std::vector<CallGraphNode*> &CurSCC,
for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB)
for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ++I) { for (BasicBlock::iterator I = BB->begin(), E = BB->end(); I != E; ++I) {
CallSite CS = CallSite::get(I); CallSite CS = CallSite::get(I);
if (!CS.getInstruction()) continue; if (!CS.getInstruction() || isa<DbgInfoIntrinsic>(I)) continue;
// If this call site already existed in the callgraph, just verify it // If this call site already existed in the callgraph, just verify it
// matches up to expectations and remove it from CallSites. // matches up to expectations and remove it from CallSites.