diff options
author | Chris Lattner <sabre@nondot.org> | 2010-04-20 00:47:34 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-04-20 00:47:34 +0000 |
commit | 8a39ed75ec57c7fabde318c0d45fac014ac287f4 (patch) | |
tree | 33eb1a7cfaa92feef321e2a1defdf65ecd81dc80 /lib/Analysis/IPA/CallGraph.cpp | |
parent | 4471136e4db67f5b6cf064cb3b0a7668f15bfe6c (diff) |
make CallGraphNode dtor abort if a node is deleted when there are still
references to it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101847 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/IPA/CallGraph.cpp')
-rw-r--r-- | lib/Analysis/IPA/CallGraph.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/lib/Analysis/IPA/CallGraph.cpp b/lib/Analysis/IPA/CallGraph.cpp index 8c43aa1488..c59c31c22a 100644 --- a/lib/Analysis/IPA/CallGraph.cpp +++ b/lib/Analysis/IPA/CallGraph.cpp @@ -158,6 +158,7 @@ private: // destroy - Release memory for the call graph virtual void destroy() { /// CallsExternalNode is not in the function map, delete it explicitly. + CallsExternalNode->allReferencesDropped(); delete CallsExternalNode; CallsExternalNode = 0; CallGraph::destroy(); @@ -181,6 +182,14 @@ void CallGraph::initialize(Module &M) { void CallGraph::destroy() { if (FunctionMap.empty()) return; + // Reset all node's use counts to zero before deleting them to prevent an + // assertion from firing. +#ifndef NDEBUG + for (FunctionMapTy::iterator I = FunctionMap.begin(), E = FunctionMap.end(); + I != E; ++I) + I->second->allReferencesDropped(); +#endif + for (FunctionMapTy::iterator I = FunctionMap.begin(), E = FunctionMap.end(); I != E; ++I) delete I->second; |