From: Chris Lattner Date: Thu, 3 Oct 2002 21:55:28 +0000 (+0000) Subject: Prune function nodes that are no longer referenced due to inlining X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=a00397e1eeaaffc21d01af612480476fe95b20a5;p=oota-llvm.git Prune function nodes that are no longer referenced due to inlining git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@4036 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/DataStructure/BottomUpClosure.cpp b/lib/Analysis/DataStructure/BottomUpClosure.cpp index 11ee6065d19..475f6878d58 100644 --- a/lib/Analysis/DataStructure/BottomUpClosure.cpp +++ b/lib/Analysis/DataStructure/BottomUpClosure.cpp @@ -253,6 +253,7 @@ DSGraph &BUDataStructures::calculateGraph(Function &F) { Graph->maskIncompleteMarkers(); Graph->markIncompleteNodes(); + Graph->removeTriviallyDeadNodes(false); Graph->removeDeadNodes(/*KeepAllGlobals*/ true, /*KeepCalls*/ true); DEBUG(std::cerr << " [BU] Done inlining: " << F.getName() << " [" diff --git a/lib/Analysis/DataStructure/DataStructure.cpp b/lib/Analysis/DataStructure/DataStructure.cpp index f50c8ea6cfb..0c4362b3756 100644 --- a/lib/Analysis/DataStructure/DataStructure.cpp +++ b/lib/Analysis/DataStructure/DataStructure.cpp @@ -578,7 +578,7 @@ bool DSGraph::isNodeDead(DSNode *N) { N->getSize() == 0 && N->getReferrers().size() == N->getGlobals().size()) { - // Remove the globals from the valuemap, so that the referrer count will go + // Remove the globals from the ValueMap, so that the referrer count will go // down to zero. removeRefsToGlobal(N, ValueMap); assert(N->getReferrers().empty() && "Referrers should all be gone now!"); @@ -608,7 +608,7 @@ static void removeIdenticalCalls(vector > &Calls, // void DSGraph::removeTriviallyDeadNodes(bool KeepAllGlobals) { for (unsigned i = 0; i != Nodes.size(); ++i) - if (! KeepAllGlobals || ! (Nodes[i]->NodeType & DSNode::GlobalNode)) + if (!KeepAllGlobals || !(Nodes[i]->NodeType & DSNode::GlobalNode)) if (isNodeDead(Nodes[i])) { // This node is dead! delete Nodes[i]; // Free memory... Nodes.erase(Nodes.begin()+i--); // Remove from node list...