summaryrefslogtreecommitdiff
path: root/lib/Analysis/DataStructure/CompleteBottomUp.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-03-13 20:15:06 +0000
committerChris Lattner <sabre@nondot.org>2005-03-13 20:15:06 +0000
commita66e353cf90e59df8da938560db6dc31caf9b423 (patch)
tree23d0500f7161b37f34626bec85df70bc75674d5f /lib/Analysis/DataStructure/CompleteBottomUp.cpp
parentadfd5f14b426aa68f3d5b4c8c9b6145ae36af11d (diff)
After finishing BU analysis, move all global variables from the globals
graph into main and mark them complete. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20583 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/DataStructure/CompleteBottomUp.cpp')
-rw-r--r--lib/Analysis/DataStructure/CompleteBottomUp.cpp29
1 files changed, 26 insertions, 3 deletions
diff --git a/lib/Analysis/DataStructure/CompleteBottomUp.cpp b/lib/Analysis/DataStructure/CompleteBottomUp.cpp
index 1c9e3299d02..77a5f32fa59 100644
--- a/lib/Analysis/DataStructure/CompleteBottomUp.cpp
+++ b/lib/Analysis/DataStructure/CompleteBottomUp.cpp
@@ -76,9 +76,10 @@ bool CompleteBUDataStructures::runOnModule(Module &M) {
hash_map<DSGraph*, unsigned> ValMap;
unsigned NextID = 1;
- if (Function *Main = M.getMainFunction()) {
- if (!Main->isExternal())
- calculateSCCGraphs(getOrCreateGraph(*Main), Stack, NextID, ValMap);
+ Function *MainFunc = M.getMainFunction();
+ if (MainFunc) {
+ if (!MainFunc->isExternal())
+ calculateSCCGraphs(getOrCreateGraph(*MainFunc), Stack, NextID, ValMap);
} else {
std::cerr << "CBU-DSA: No 'main' function found!\n";
}
@@ -88,6 +89,28 @@ bool CompleteBUDataStructures::runOnModule(Module &M) {
calculateSCCGraphs(getOrCreateGraph(*I), Stack, NextID, ValMap);
GlobalsGraph->removeTriviallyDeadNodes();
+
+
+ // Merge the globals variables (not the calls) from the globals graph back
+ // into the main function's graph so that the main function contains all of
+ // the information about global pools and GV usage in the program.
+ if (MainFunc) {
+ DSGraph &MainGraph = getOrCreateGraph(*MainFunc);
+ const DSGraph &GG = *MainGraph.getGlobalsGraph();
+ ReachabilityCloner RC(MainGraph, GG,
+ DSGraph::DontCloneCallNodes |
+ DSGraph::DontCloneAuxCallNodes);
+
+ // Clone the global nodes into this graph.
+ for (DSScalarMap::global_iterator I = GG.getScalarMap().global_begin(),
+ E = GG.getScalarMap().global_end(); I != E; ++I)
+ if (isa<GlobalVariable>(*I))
+ RC.getClonedNH(GG.getNodeForValue(*I));
+
+ MainGraph.markIncompleteNodes(DSGraph::MarkFormalArgs |
+ DSGraph::IgnoreGlobals);
+ }
+
return false;
}