mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-04 05:31:06 +00:00
Add the explanatory comment from r122680's commit message to the code itself.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122689 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
19feb4ca8a
commit
2a8c22aa68
@ -195,6 +195,16 @@ void Calculate(DominatorTreeBase<typename GraphTraits<NodeT>::NodeType>& DT,
|
|||||||
// 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 != F.size());
|
||||||
|
|
||||||
|
// When naively implemented, the Lengauer-Tarjan algorithm requires a separate
|
||||||
|
// bucket for each vertex. However, this is unnecessary, because each vertex
|
||||||
|
// is only placed into a single bucket (that of its semidominator), and each
|
||||||
|
// vertex's bucket is processed before it is added to any bucket itself.
|
||||||
|
//
|
||||||
|
// Instead of using a bucket per vertex, we use a single array Buckets that
|
||||||
|
// has two purposes. Before the vertex V with preorder number i is processed,
|
||||||
|
// Buckets[i] stores the index of the first element in V's bucket. After V's
|
||||||
|
// bucket is processed, Buckets[i] stores the index of the next element in the
|
||||||
|
// bucket containing V, if any.
|
||||||
std::vector<unsigned> Buckets;
|
std::vector<unsigned> Buckets;
|
||||||
Buckets.resize(N + 1);
|
Buckets.resize(N + 1);
|
||||||
for (unsigned i = 1; i <= N; ++i)
|
for (unsigned i = 1; i <= N; ++i)
|
||||||
|
Loading…
Reference in New Issue
Block a user