summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-11-13 01:43:00 +0000
committerChris Lattner <sabre@nondot.org>2003-11-13 01:43:00 +0000
commit04946381b920ee8f7f8d3c4de8b8359d5457a7ed (patch)
treea87940d3a74203df9f0ac8e7c302048f96149cd2 /llvm/lib
parentb5be72ff30fd83f1b78c575c9fe4e4902f290c0e (diff)
downloadbcm5719-llvm-04946381b920ee8f7f8d3c4de8b8359d5457a7ed.tar.gz
bcm5719-llvm-04946381b920ee8f7f8d3c4de8b8359d5457a7ed.zip
Add an initial version of the CompleteBUDataStructures class, which is currently
identical to the BU pass, but has an accurate call graph llvm-svn: 9956
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Analysis/DataStructure/CompleteBottomUp.cpp75
1 files changed, 75 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/DataStructure/CompleteBottomUp.cpp b/llvm/lib/Analysis/DataStructure/CompleteBottomUp.cpp
new file mode 100644
index 00000000000..751d5b0ff2b
--- /dev/null
+++ b/llvm/lib/Analysis/DataStructure/CompleteBottomUp.cpp
@@ -0,0 +1,75 @@
+//===- CompleteBottomUp.cpp - Complete Bottom-Up Data Structure Graphs ----===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file was developed by the LLVM research group and is distributed under
+// the University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This is the exact same as the bottom-up graphs, but we use take a completed
+// call graph and inline all indirect callees into their callers graphs, making
+// the result more useful for things like pool allocation.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/Analysis/DataStructure.h"
+#include "llvm/Module.h"
+#include "llvm/Analysis/DSGraph.h"
+using namespace llvm;
+
+namespace {
+ RegisterAnalysis<CompleteBUDataStructures>
+ X("cbudatastructure", "'Complete' Bottom-up Data Structure Analysis");
+}
+
+using namespace DS;
+
+// run - Calculate the bottom up data structure graphs for each function in the
+// program.
+//
+bool CompleteBUDataStructures::run(Module &M) {
+ BUDataStructures &BU = getAnalysis<BUDataStructures>();
+ GlobalsGraph = new DSGraph(BU.getGlobalsGraph());
+ GlobalsGraph->setPrintAuxCalls();
+
+ // Our call graph is the same as the BU data structures call graph
+ ActualCallees = BU.getActualCallees();
+
+#if 1 // REMOVE ME EVENTUALLY
+ // FIXME: TEMPORARY (remove once finalization of indirect call sites in the
+ // globals graph has been implemented in the BU pass)
+ TDDataStructures &TD = getAnalysis<TDDataStructures>();
+
+ // The call graph extractable from the TD pass is _much more complete_ and
+ // trustable than that generated by the BU pass so far. Until this is fixed,
+ // we hack it like this:
+ for (Module::iterator MI = M.begin(), ME = M.end(); MI != ME; ++MI) {
+ if (MI->isExternal()) continue;
+ const std::vector<DSCallSite> &CSs = TD.getDSGraph(*MI).getFunctionCalls();
+
+ for (unsigned CSi = 0, e = CSs.size(); CSi != e; ++CSi) {
+ if (CSs[CSi].isIndirectCall()) {
+ Instruction *TheCall = CSs[CSi].getCallSite().getInstruction();
+
+ const std::vector<GlobalValue*> &Callees =
+ CSs[CSi].getCalleeNode()->getGlobals();
+ for (unsigned i = 0, e = Callees.size(); i != e; ++i)
+ if (Function *F = dyn_cast<Function>(Callees[i]))
+ ActualCallees.insert(std::make_pair(TheCall, F));
+ }
+ }
+ }
+#endif
+
+ // Start by copying all of the BU data structures graphs over, verbatim.
+ for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I)
+ if (!I->isExternal()) {
+ DSInfo[I] = new DSGraph(BU.getDSGraph(*I));
+ DSInfo[I]->setGlobalsGraph(GlobalsGraph);
+ DSInfo[I]->setPrintAuxCalls();
+ }
+
+
+ return false;
+}
OpenPOWER on IntegriCloud