only look at successors of globals. This gets us down to "only" 22s in the
authorChris Lattner <sabre@nondot.org>
Thu, 24 Mar 2005 21:17:27 +0000 (21:17 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 24 Mar 2005 21:17:27 +0000 (21:17 +0000)
bu pass for 176.gcc

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20818 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/DataStructure/DataStructure.cpp

index 2b5dfd6eb73d16461697bb3eeb97098a4e5ee0b4..ae4d51b3435aac5b451c02b377fe2aee851501ce 100644 (file)
@@ -1448,10 +1448,15 @@ void DSGraph::mergeInGraph(const DSCallSite &CS,
 
   DSScalarMap GSM = Graph.getScalarMap();
   for (DSScalarMap::global_iterator GI = GSM.global_begin(),
-         E = GSM.global_end(); GI != E; ++GI)
-    if (PathExistsToClonedNode(Graph.getNodeForValue(*GI).getNode(), RC,
-                               NodesReachCopiedNodes))
-      GlobalsToCopy.push_back(*GI);
+         E = GSM.global_end(); GI != E; ++GI) {
+    DSNode *GlobalNode = Graph.getNodeForValue(*GI).getNode();
+    for (DSNode::edge_iterator EI = GlobalNode->edge_begin(),
+           EE = GlobalNode->edge_end(); EI != EE; ++EI)
+      if (PathExistsToClonedNode(EI->getNode(), RC, NodesReachCopiedNodes)) {
+        GlobalsToCopy.push_back(*GI);
+        break;
+      }
+  }
 
   // Copy aux calls that are needed.
   for (unsigned i = 0, e = AuxCallToCopy.size(); i != e; ++i)