diff options
author | Chris Lattner <sabre@nondot.org> | 2002-04-01 00:13:56 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-04-01 00:13:56 +0000 |
commit | f30185fdfbb61bd63999b819bb117a8f9776296a (patch) | |
tree | b22da271eb1f9ce14ef9546258565a58c7a01699 /lib/Analysis/DataStructure/EliminateNodes.cpp | |
parent | bab4a90cb9a987176a4f378f50412de086182195 (diff) |
Allow merging of identical call nodes. Make the shadow node pointed to
by the call node noncritical before the call is destroyed.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2082 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/DataStructure/EliminateNodes.cpp')
-rw-r--r-- | lib/Analysis/DataStructure/EliminateNodes.cpp | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/lib/Analysis/DataStructure/EliminateNodes.cpp b/lib/Analysis/DataStructure/EliminateNodes.cpp index 7dd5b3317b..767f7fe006 100644 --- a/lib/Analysis/DataStructure/EliminateNodes.cpp +++ b/lib/Analysis/DataStructure/EliminateNodes.cpp @@ -53,6 +53,23 @@ static void DestroyFirstNodeOfPair(DSNode *N1, DSNode *N2) { assert(RanOnce && "Node on user set but cannot find the use!"); } + // If we are about to eliminate a call node that returns a pointer, make the + // shadow node it points to not be critical anymore! + // + if (isa<CallDSNode>(N1) && N1->getNumLinks()) { + assert(N1->getNumLinks() == 1 && "Call node can only return one pointer!"); + PointerValSet &PVS = N1->getLink(0); + + for (unsigned i = 0, e = PVS.size(); i != e; ++i) + if (ShadowDSNode *Shad = dyn_cast<ShadowDSNode>(PVS[i].Node)) + if (Shad->isCriticalNode()) { + Shad->resetCriticalMark(); // Only unmark _ONE_ node.. + break; + } + + } + + N1->removeAllIncomingEdges(); delete N1; } @@ -170,10 +187,7 @@ bool FunctionDSGraph::UnlinkUndistinguishableNodes() { return removeIndistinguishableNodes(AllocNodes) | removeIndistinguishableNodes(ShadowNodes) | - //FIXME: We cannot naively remove call nodes here because if there is a - // shadow node that is the result of the call, we have to make sure to - // merge the shadow node as well!!! - // removeIndistinguishableNodePairs(CallNodes) | + removeIndistinguishableNodePairs(CallNodes) | removeIndistinguishableNodePairs(GlobalNodes); } |