mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-17 21:35:07 +00:00
Change the Dominators recalculate() function to only rely on GraphTraits
This is a patch by Guoping Long! As part of utilizing LLVM Dominator computation in Clang, made two changes to LLVM dominators tree implementation: - (1) Change the recalculate() template function to only rely on GraphTraits. - (2) Add a size() method to GraphTraits template class to query the number of nodes in the graph. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145837 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fef3f9aed3
commit
e15402f92b
@ -43,9 +43,12 @@ struct GraphTraits {
|
|||||||
// typedef ...iterator nodes_iterator;
|
// typedef ...iterator nodes_iterator;
|
||||||
// static nodes_iterator nodes_begin(GraphType *G)
|
// static nodes_iterator nodes_begin(GraphType *G)
|
||||||
// static nodes_iterator nodes_end (GraphType *G)
|
// static nodes_iterator nodes_end (GraphType *G)
|
||||||
//
|
|
||||||
// nodes_iterator/begin/end - Allow iteration over all nodes in the graph
|
// nodes_iterator/begin/end - Allow iteration over all nodes in the graph
|
||||||
|
|
||||||
|
// static unsigned size (GraphType *G)
|
||||||
|
// Return total number of nodes in the graph
|
||||||
|
//
|
||||||
|
|
||||||
|
|
||||||
// If anyone tries to use this class without having an appropriate
|
// If anyone tries to use this class without having an appropriate
|
||||||
// specialization, make an error. If you get this error, it's because you
|
// specialization, make an error. If you get this error, it's because you
|
||||||
|
@ -171,7 +171,7 @@ void Calculate(DominatorTreeBase<typename GraphTraits<NodeT>::NodeType>& DT,
|
|||||||
|
|
||||||
// it might be that some blocks did not get a DFS number (e.g., blocks of
|
// it might be that some blocks did not get a DFS number (e.g., blocks of
|
||||||
// infinite loops). In these cases an artificial exit node is required.
|
// infinite loops). In these cases an artificial exit node is required.
|
||||||
MultipleRoots |= (DT.isPostDominator() && N != F.size());
|
MultipleRoots |= (DT.isPostDominator() && N != GraphTraits<FuncT*>::size(&F));
|
||||||
|
|
||||||
// When naively implemented, the Lengauer-Tarjan algorithm requires a separate
|
// When naively implemented, the Lengauer-Tarjan algorithm requires a separate
|
||||||
// bucket for each vertex. However, this is unnecessary, because each vertex
|
// bucket for each vertex. However, this is unnecessary, because each vertex
|
||||||
|
@ -653,21 +653,24 @@ public:
|
|||||||
/// recalculate - compute a dominator tree for the given function
|
/// recalculate - compute a dominator tree for the given function
|
||||||
template<class FT>
|
template<class FT>
|
||||||
void recalculate(FT& F) {
|
void recalculate(FT& F) {
|
||||||
|
typedef GraphTraits<FT*> TraitsTy;
|
||||||
reset();
|
reset();
|
||||||
this->Vertex.push_back(0);
|
this->Vertex.push_back(0);
|
||||||
|
|
||||||
if (!this->IsPostDominators) {
|
if (!this->IsPostDominators) {
|
||||||
// Initialize root
|
// Initialize root
|
||||||
this->Roots.push_back(&F.front());
|
NodeT *entry = TraitsTy::getEntryNode(&F);
|
||||||
this->IDoms[&F.front()] = 0;
|
this->Roots.push_back(entry);
|
||||||
this->DomTreeNodes[&F.front()] = 0;
|
this->IDoms[entry] = 0;
|
||||||
|
this->DomTreeNodes[entry] = 0;
|
||||||
|
|
||||||
Calculate<FT, NodeT*>(*this, F);
|
Calculate<FT, NodeT*>(*this, F);
|
||||||
} else {
|
} else {
|
||||||
// Initialize the roots list
|
// Initialize the roots list
|
||||||
for (typename FT::iterator I = F.begin(), E = F.end(); I != E; ++I) {
|
for (typename TraitsTy::nodes_iterator I = TraitsTy::nodes_begin(&F),
|
||||||
if (std::distance(GraphTraits<FT*>::child_begin(I),
|
E = TraitsTy::nodes_end(&F); I != E; ++I) {
|
||||||
GraphTraits<FT*>::child_end(I)) == 0)
|
if (std::distance(TraitsTy::child_begin(I),
|
||||||
|
TraitsTy::child_end(I)) == 0)
|
||||||
addRoot(I);
|
addRoot(I);
|
||||||
|
|
||||||
// Prepopulate maps so that we don't get iterator invalidation issues later.
|
// Prepopulate maps so that we don't get iterator invalidation issues later.
|
||||||
|
@ -437,6 +437,7 @@ template <> struct GraphTraits<MachineFunction*> :
|
|||||||
typedef MachineFunction::iterator nodes_iterator;
|
typedef MachineFunction::iterator nodes_iterator;
|
||||||
static nodes_iterator nodes_begin(MachineFunction *F) { return F->begin(); }
|
static nodes_iterator nodes_begin(MachineFunction *F) { return F->begin(); }
|
||||||
static nodes_iterator nodes_end (MachineFunction *F) { return F->end(); }
|
static nodes_iterator nodes_end (MachineFunction *F) { return F->end(); }
|
||||||
|
static unsigned size (MachineFunction *F) { return F->size(); }
|
||||||
};
|
};
|
||||||
template <> struct GraphTraits<const MachineFunction*> :
|
template <> struct GraphTraits<const MachineFunction*> :
|
||||||
public GraphTraits<const MachineBasicBlock*> {
|
public GraphTraits<const MachineBasicBlock*> {
|
||||||
@ -452,6 +453,9 @@ template <> struct GraphTraits<const MachineFunction*> :
|
|||||||
static nodes_iterator nodes_end (const MachineFunction *F) {
|
static nodes_iterator nodes_end (const MachineFunction *F) {
|
||||||
return F->end();
|
return F->end();
|
||||||
}
|
}
|
||||||
|
static unsigned size (const MachineFunction *F) {
|
||||||
|
return F->size();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -314,6 +314,7 @@ template <> struct GraphTraits<Function*> : public GraphTraits<BasicBlock*> {
|
|||||||
typedef Function::iterator nodes_iterator;
|
typedef Function::iterator nodes_iterator;
|
||||||
static nodes_iterator nodes_begin(Function *F) { return F->begin(); }
|
static nodes_iterator nodes_begin(Function *F) { return F->begin(); }
|
||||||
static nodes_iterator nodes_end (Function *F) { return F->end(); }
|
static nodes_iterator nodes_end (Function *F) { return F->end(); }
|
||||||
|
static unsigned size (Function *F) { return F->size(); }
|
||||||
};
|
};
|
||||||
template <> struct GraphTraits<const Function*> :
|
template <> struct GraphTraits<const Function*> :
|
||||||
public GraphTraits<const BasicBlock*> {
|
public GraphTraits<const BasicBlock*> {
|
||||||
@ -323,6 +324,7 @@ template <> struct GraphTraits<const Function*> :
|
|||||||
typedef Function::const_iterator nodes_iterator;
|
typedef Function::const_iterator nodes_iterator;
|
||||||
static nodes_iterator nodes_begin(const Function *F) { return F->begin(); }
|
static nodes_iterator nodes_begin(const Function *F) { return F->begin(); }
|
||||||
static nodes_iterator nodes_end (const Function *F) { return F->end(); }
|
static nodes_iterator nodes_end (const Function *F) { return F->end(); }
|
||||||
|
static unsigned size (const Function *F) { return F->size(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user