From e6c0b5dba4b43f90fd489a1a7819b8d9d827bb06 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 4 Feb 2003 00:03:37 +0000 Subject: [PATCH] Fix steensgaard to work on a lot more cases... git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5488 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Analysis/DataStructure/Steensgaard.cpp | 23 +++++++++------------- 1 file changed, 9 insertions(+), 14 deletions(-) diff --git a/lib/Analysis/DataStructure/Steensgaard.cpp b/lib/Analysis/DataStructure/Steensgaard.cpp index 24765228001..c42ff73ac23 100644 --- a/lib/Analysis/DataStructure/Steensgaard.cpp +++ b/lib/Analysis/DataStructure/Steensgaard.cpp @@ -21,6 +21,7 @@ namespace { namespace { class Steens : public Pass, public AliasAnalysis { DSGraph *ResultGraph; + DSGraph *GlobalsGraph; // FIXME: Eliminate globals graph stuff from DNE public: Steens() : ResultGraph(0) {} ~Steens() { assert(ResultGraph == 0 && "releaseMemory not called?"); } @@ -85,8 +86,7 @@ namespace { /// with the specified call site descriptor. This function links the arguments /// and the return value for the call site context-insensitively. /// -void Steens::ResolveFunctionCall(Function *F, - const DSCallSite &Call, +void Steens::ResolveFunctionCall(Function *F, const DSCallSite &Call, DSNodeHandle &RetVal) { assert(ResultGraph != 0 && "Result graph not allocated!"); hash_map &ValMap = ResultGraph->getScalarMap(); @@ -100,7 +100,7 @@ void Steens::ResolveFunctionCall(Function *F, for (Function::aiterator AI = F->abegin(), AE = F->aend(); AI != AE; ++AI) { hash_map::iterator I = ValMap.find(AI); if (I != ValMap.end()) // If its a pointer argument... - I->second.addEdgeTo(Call.getPtrArg(PtrArgIdx++)); + I->second.mergeWith(Call.getPtrArg(PtrArgIdx++)); } assert(PtrArgIdx == Call.getNumPtrArgs() && "Argument resolution mismatch!"); @@ -116,7 +116,8 @@ bool Steens::run(Module &M) { // Create a new, empty, graph... ResultGraph = new DSGraph(); - + GlobalsGraph = new DSGraph(); + ResultGraph->setGlobalsGraph(GlobalsGraph); // RetValMap - Keep track of the return values for all functions that return // valid pointers. // @@ -143,16 +144,9 @@ bool Steens::run(Module &M) { // Incorporate the inlined Function's ScalarMap into the global // ScalarMap... hash_map &GVM = ResultGraph->getScalarMap(); - - while (!ValMap.empty()) { // Loop over value map, moving entries over... - const std::pair &DSN = *ValMap.begin(); - hash_map::iterator I = GVM.find(DSN.first); - if (I == GVM.end()) - GVM[DSN.first] = DSN.second; - else - I->second.mergeWith(DSN.second); - ValMap.erase(ValMap.begin()); - } + for (hash_map::iterator I = ValMap.begin(), + E = ValMap.end(); I != E; ++I) + GVM[I->first].mergeWith(I->second); } // FIXME: Must recalculate and use the Incomplete markers!! @@ -199,6 +193,7 @@ bool Steens::run(Module &M) { ResultGraph->markIncompleteNodes(DSGraph::IgnoreFormalArgs); // Remove any nodes that are dead after all of the merging we have done... + // FIXME: We should be able to disable the globals graph for steens! ResultGraph->removeDeadNodes(DSGraph::KeepUnreachableGlobals); DEBUG(print(std::cerr, &M));