diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2014-04-26 09:45:55 +0000 | 
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2014-04-26 09:45:55 +0000 | 
| commit | 90821c2a93668510bd1703ca9879e9f2e49e5cca (patch) | |
| tree | f32615115035ee0f034a804e1c28f41c9744138a /llvm/lib/Analysis | |
| parent | 5e2d70b9a3ac93069115a0e30749750ae1764c6c (diff) | |
| download | bcm5719-llvm-90821c2a93668510bd1703ca9879e9f2e49e5cca.tar.gz bcm5719-llvm-90821c2a93668510bd1703ca9879e9f2e49e5cca.zip | |
[LCG] Rather than removing nodes from the SCC entry set when we process
them, just skip over any DFS-numbered nodes when finding the next root
of a DFS. This allows the entry set to just be a vector as we populate
it from a uniqued source. It also removes the possibility for a linear
scan of the entry set to actually do the removal which can make things
go quadratic if we get unlucky.
llvm-svn: 207312
Diffstat (limited to 'llvm/lib/Analysis')
| -rw-r--r-- | llvm/lib/Analysis/LazyCallGraph.cpp | 13 | 
1 files changed, 7 insertions, 6 deletions
| diff --git a/llvm/lib/Analysis/LazyCallGraph.cpp b/llvm/lib/Analysis/LazyCallGraph.cpp index 50accb3a753..196003430a4 100644 --- a/llvm/lib/Analysis/LazyCallGraph.cpp +++ b/llvm/lib/Analysis/LazyCallGraph.cpp @@ -100,9 +100,9 @@ LazyCallGraph::LazyCallGraph(Module &M) : NextDFSNumber(0) {    for (auto &Entry : EntryNodes)      if (Function *F = Entry.dyn_cast<Function *>()) -      SCCEntryNodes.insert(F); +      SCCEntryNodes.push_back(F);      else -      SCCEntryNodes.insert(&Entry.get<Node *>()->getFunction()); +      SCCEntryNodes.push_back(&Entry.get<Node *>()->getFunction());  }  LazyCallGraph::LazyCallGraph(LazyCallGraph &&G) @@ -437,10 +437,12 @@ LazyCallGraph::SCC *LazyCallGraph::getNextSCCInPostOrder() {      DFSStack.pop_back();    } else {      // If we've handled all candidate entry nodes to the SCC forest, we're done. -    if (SCCEntryNodes.empty()) -      return nullptr; +    do { +      if (SCCEntryNodes.empty()) +        return nullptr; -    N = &get(*SCCEntryNodes.pop_back_val()); +      N = &get(*SCCEntryNodes.pop_back_val()); +    } while (N->DFSNumber != 0);      I = N->begin();      N->LowLink = N->DFSNumber = 1;      NextDFSNumber = 2; @@ -463,7 +465,6 @@ LazyCallGraph::SCC *LazyCallGraph::getNextSCCInPostOrder() {          assert(!SCCMap.count(&ChildN) &&                 "Found a node with 0 DFS number but already in an SCC!");          ChildN.LowLink = ChildN.DFSNumber = NextDFSNumber++; -        SCCEntryNodes.remove(&ChildN.getFunction());          N = &ChildN;          I = ChildN.begin();          E = ChildN.end(); | 

