mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-08 13:00:50 +00:00
Fix the "partial pool allocator" on em3d and others. The problem is that
DSNodes, unlike other GraphTraits nodes, can have null outgoing edges, and df_iterator doesn't take this into consideration. As a workaround, the successor iterator now handles null nodes and 'indicates' that null has no successors. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12025 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9148ad3099
commit
99df257910
@ -33,10 +33,14 @@ class DSNodeIterator : public forward_iterator<const DSNode, ptrdiff_t> {
|
||||
|
||||
DSNodeIterator(NodeTy *N) : Node(N), Offset(0) {} // begin iterator
|
||||
DSNodeIterator(NodeTy *N, bool) : Node(N) { // Create end iterator
|
||||
Offset = N->getNumLinks() << DS::PointerShift;
|
||||
if (Offset == 0 && Node->getForwardNode() &&
|
||||
Node->isDeadNode()) // Model Forward link
|
||||
Offset += DS::PointerSize;
|
||||
if (N != 0) {
|
||||
Offset = N->getNumLinks() << DS::PointerShift;
|
||||
if (Offset == 0 && Node->getForwardNode() &&
|
||||
Node->isDeadNode()) // Model Forward link
|
||||
Offset += DS::PointerSize;
|
||||
} else {
|
||||
Offset = 0;
|
||||
}
|
||||
}
|
||||
public:
|
||||
DSNodeIterator(const DSNodeHandle &NH)
|
||||
|
@ -33,10 +33,14 @@ class DSNodeIterator : public forward_iterator<const DSNode, ptrdiff_t> {
|
||||
|
||||
DSNodeIterator(NodeTy *N) : Node(N), Offset(0) {} // begin iterator
|
||||
DSNodeIterator(NodeTy *N, bool) : Node(N) { // Create end iterator
|
||||
Offset = N->getNumLinks() << DS::PointerShift;
|
||||
if (Offset == 0 && Node->getForwardNode() &&
|
||||
Node->isDeadNode()) // Model Forward link
|
||||
Offset += DS::PointerSize;
|
||||
if (N != 0) {
|
||||
Offset = N->getNumLinks() << DS::PointerShift;
|
||||
if (Offset == 0 && Node->getForwardNode() &&
|
||||
Node->isDeadNode()) // Model Forward link
|
||||
Offset += DS::PointerSize;
|
||||
} else {
|
||||
Offset = 0;
|
||||
}
|
||||
}
|
||||
public:
|
||||
DSNodeIterator(const DSNodeHandle &NH)
|
||||
|
Loading…
Reference in New Issue
Block a user