public abstract class org.graalvm.compiler.phases.graph.PostOrderNodeIterator<T extends org.graalvm.compiler.phases.graph.MergeableState<T>>
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: org.graalvm.compiler.phases.graph.PostOrderNodeIterator
super_class: java.lang.Object
{
private final org.graalvm.compiler.graph.NodeBitMap visitedEnds;
descriptor: Lorg/graalvm/compiler/graph/NodeBitMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.Deque<org.graalvm.compiler.nodes.AbstractBeginNode> nodeQueue;
descriptor: Ljava/util/Deque;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/Deque<Lorg/graalvm/compiler/nodes/AbstractBeginNode;>;
private final org.graalvm.util.EconomicMap<org.graalvm.compiler.nodes.FixedNode, T> nodeStates;
descriptor: Lorg/graalvm/util/EconomicMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lorg/graalvm/util/EconomicMap<Lorg/graalvm/compiler/nodes/FixedNode;TT;>;
private final org.graalvm.compiler.nodes.FixedNode start;
descriptor: Lorg/graalvm/compiler/nodes/FixedNode;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
protected T state;
descriptor: Lorg/graalvm/compiler/phases/graph/MergeableState;
flags: (0x0004) ACC_PROTECTED
Signature: TT;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator;
invokevirtual java.lang.Class.desiredAssertionStatus:()Z
ifne 1
iconst_1
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: putstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.graalvm.compiler.nodes.FixedNode, );
descriptor: (Lorg/graalvm/compiler/nodes/FixedNode;Lorg/graalvm/compiler/phases/graph/MergeableState;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 1
invokevirtual org.graalvm.compiler.nodes.FixedNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
astore 3
start local 3 2: aload 0
aload 3
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.createNodeBitMap:()Lorg/graalvm/compiler/graph/NodeBitMap;
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
3: aload 0
new java.util.ArrayDeque
dup
invokespecial java.util.ArrayDeque.<init>:()V
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
4: aload 0
getstatic org.graalvm.util.Equivalence.IDENTITY:Lorg/graalvm/util/Equivalence;
invokestatic org.graalvm.util.EconomicMap.create:(Lorg/graalvm/util/Equivalence;)Lorg/graalvm/util/EconomicMap;
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
5: aload 0
aload 1
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.start:Lorg/graalvm/compiler/nodes/FixedNode;
6: aload 0
aload 2
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
7: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 8 1 start Lorg/graalvm/compiler/nodes/FixedNode;
0 8 2 initialState TT;
2 8 3 graph Lorg/graalvm/compiler/nodes/StructuredGraph;
Signature: (Lorg/graalvm/compiler/nodes/FixedNode;TT;)V
MethodParameters:
Name Flags
start
initialState
public void apply();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=1
start local 0 0: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.start:Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
start local 1 1: StackMap locals: org.graalvm.compiler.nodes.FixedNode
StackMap stack:
aload 1
instanceof org.graalvm.compiler.nodes.InvokeWithExceptionNode
ifeq 6
2: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.Invoke
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.invoke:(Lorg/graalvm/compiler/nodes/Invoke;)V
3: aload 0
aload 1
aconst_null
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.queueSuccessors:(Lorg/graalvm/compiler/nodes/FixedNode;Ljava/util/Set;)V
4: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nextQueuedNode:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
5: goto 43
StackMap locals:
StackMap stack:
6: aload 1
instanceof org.graalvm.compiler.nodes.LoopBeginNode
ifeq 13
7: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
aload 1
checkcast org.graalvm.compiler.nodes.LoopBeginNode
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.loopBegin:(Lorg/graalvm/compiler/nodes/LoopBeginNode;)V
8: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokeinterface org.graalvm.util.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
9: aload 0
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.clone:()Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
10: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.LoopBeginNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.loopBegin:(Lorg/graalvm/compiler/nodes/LoopBeginNode;)V
11: aload 1
checkcast org.graalvm.compiler.nodes.LoopBeginNode
invokevirtual org.graalvm.compiler.nodes.LoopBeginNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
12: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 43
aload 1
ifnonnull 43
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
13: StackMap locals:
StackMap stack:
aload 1
instanceof org.graalvm.compiler.nodes.LoopEndNode
ifeq 18
14: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.LoopEndNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.loopEnd:(Lorg/graalvm/compiler/nodes/LoopEndNode;)V
15: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.LoopEndNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.finishLoopEnds:(Lorg/graalvm/compiler/nodes/LoopEndNode;)V
16: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nextQueuedNode:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
17: goto 43
StackMap locals:
StackMap stack:
18: aload 1
instanceof org.graalvm.compiler.nodes.AbstractMergeNode
ifeq 22
19: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.AbstractMergeNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.merge:(Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
20: aload 1
checkcast org.graalvm.compiler.nodes.AbstractMergeNode
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
21: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 43
aload 1
ifnonnull 43
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
22: StackMap locals:
StackMap stack:
aload 1
instanceof org.graalvm.compiler.nodes.FixedWithNextNode
ifeq 28
23: aload 1
checkcast org.graalvm.compiler.nodes.FixedWithNextNode
invokevirtual org.graalvm.compiler.nodes.FixedWithNextNode.next:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 2
start local 2 24: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 25
aload 2
ifnonnull 25
new java.lang.AssertionError
dup
aload 1
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
25: StackMap locals: org.graalvm.compiler.nodes.FixedNode
StackMap stack:
aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
26: aload 2
astore 1
end local 2 27: goto 43
StackMap locals:
StackMap stack:
28: aload 1
instanceof org.graalvm.compiler.nodes.EndNode
ifeq 33
29: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.EndNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.end:(Lorg/graalvm/compiler/nodes/EndNode;)V
30: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.EndNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.queueMerge:(Lorg/graalvm/compiler/nodes/EndNode;)V
31: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nextQueuedNode:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
32: goto 43
StackMap locals:
StackMap stack:
33: aload 1
instanceof org.graalvm.compiler.nodes.ControlSinkNode
ifeq 37
34: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
35: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nextQueuedNode:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
36: goto 43
StackMap locals:
StackMap stack:
37: aload 1
instanceof org.graalvm.compiler.nodes.ControlSplitNode
ifeq 42
38: aload 0
aload 1
checkcast org.graalvm.compiler.nodes.ControlSplitNode
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.controlSplit:(Lorg/graalvm/compiler/nodes/ControlSplitNode;)Ljava/util/Set;
astore 2
start local 2 39: aload 0
aload 1
aload 2
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.queueSuccessors:(Lorg/graalvm/compiler/nodes/FixedNode;Ljava/util/Set;)V
40: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nextQueuedNode:()Lorg/graalvm/compiler/nodes/FixedNode;
astore 1
end local 2 41: goto 43
42: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 43
new java.lang.AssertionError
dup
aload 1
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
43: StackMap locals:
StackMap stack:
aload 1
ifnonnull 1
44: aload 0
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.finished:()V
45: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 46 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
1 46 1 current Lorg/graalvm/compiler/nodes/FixedNode;
24 27 2 next Lorg/graalvm/compiler/nodes/FixedNode;
39 41 2 successors Ljava/util/Set<Lorg/graalvm/compiler/graph/Node;>;
private void queueSuccessors(org.graalvm.compiler.nodes.FixedNode, java.util.Set<org.graalvm.compiler.graph.Node>);
descriptor: (Lorg/graalvm/compiler/nodes/FixedNode;Ljava/util/Set;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokeinterface org.graalvm.util.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
1: aload 2
ifnull 9
2: aload 2
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 7
StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.FixedNode java.util.Set top java.util.Iterator
StackMap stack:
3: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.graalvm.compiler.graph.Node
astore 3
start local 3 4: aload 3
ifnull 7
5: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 3
invokevirtual org.graalvm.compiler.graph.Node.predecessor:()Lorg/graalvm/compiler/graph/Node;
checkcast org.graalvm.compiler.nodes.FixedNode
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokeinterface org.graalvm.util.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
6: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
aload 3
checkcast org.graalvm.compiler.nodes.AbstractBeginNode
invokeinterface java.util.Deque.addFirst:(Ljava/lang/Object;)V
end local 3 7: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
8: goto 14
9: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.FixedNode java.util.Set
StackMap stack:
aload 1
invokevirtual org.graalvm.compiler.nodes.FixedNode.successors:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
astore 4
goto 13
StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.FixedNode java.util.Set top java.util.Iterator
StackMap stack:
10: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.graalvm.compiler.graph.Node
astore 3
start local 3 11: aload 3
ifnull 13
12: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
aload 3
checkcast org.graalvm.compiler.nodes.AbstractBeginNode
invokeinterface java.util.Deque.addFirst:(Ljava/lang/Object;)V
end local 3 13: StackMap locals:
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 10
14: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.FixedNode java.util.Set
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 15 1 x Lorg/graalvm/compiler/nodes/FixedNode;
0 15 2 successors Ljava/util/Set<Lorg/graalvm/compiler/graph/Node;>;
4 7 3 node Lorg/graalvm/compiler/graph/Node;
11 13 3 node Lorg/graalvm/compiler/graph/Node;
Signature: (Lorg/graalvm/compiler/nodes/FixedNode;Ljava/util/Set<Lorg/graalvm/compiler/graph/Node;>;)V
MethodParameters:
Name Flags
x
successors
private org.graalvm.compiler.nodes.FixedNode nextQueuedNode();
descriptor: ()Lorg/graalvm/compiler/nodes/FixedNode;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=7, args_size=1
start local 0 0: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
invokeinterface java.util.Deque.size:()I
istore 1
start local 1 1: goto 23
2: StackMap locals: int
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
invokeinterface java.util.Deque.removeFirst:()Ljava/lang/Object;
checkcast org.graalvm.compiler.nodes.AbstractBeginNode
astore 2
start local 2 3: aload 2
instanceof org.graalvm.compiler.nodes.AbstractMergeNode
ifeq 19
4: aload 2
checkcast org.graalvm.compiler.nodes.AbstractMergeNode
astore 3
start local 3 5: aload 0
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 3
iconst_0
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndAt:(I)Lorg/graalvm/compiler/nodes/EndNode;
invokeinterface org.graalvm.util.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.clone:()Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
6: new java.util.ArrayList
dup
aload 3
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
iconst_1
isub
invokespecial java.util.ArrayList.<init>:(I)V
astore 4
start local 4 7: iconst_1
istore 5
start local 5 8: goto 13
9: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator int org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode java.util.ArrayList int
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 3
iload 5
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndAt:(I)Lorg/graalvm/compiler/nodes/EndNode;
invokeinterface org.graalvm.util.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
astore 6
start local 6 10: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 11
aload 6
ifnonnull 11
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
11: StackMap locals: org.graalvm.compiler.phases.graph.MergeableState
StackMap stack:
aload 4
aload 6
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
end local 6 12: iinc 5 1
StackMap locals:
StackMap stack:
13: iload 5
aload 3
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
if_icmplt 9
end local 5 14: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
aload 3
aload 4
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.merge:(Lorg/graalvm/compiler/nodes/AbstractMergeNode;Ljava/util/List;)Z
istore 5
start local 5 15: iload 5
ifeq 17
16: aload 3
areturn
17: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator int org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractMergeNode java.util.ArrayList int
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
aload 3
invokeinterface java.util.Deque.addLast:(Ljava/lang/Object;)V
end local 5 end local 4 end local 3 18: goto 23
19: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 20
aload 2
invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
ifnonnull 20
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
20: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 2
invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.predecessor:()Lorg/graalvm/compiler/graph/Node;
checkcast org.graalvm.compiler.nodes.FixedNode
invokeinterface org.graalvm.util.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.clone:()Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
putfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
21: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
aload 2
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.afterSplit:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)V
22: aload 2
areturn
end local 2 23: StackMap locals:
StackMap stack:
iload 1
iinc 1 -1
ifgt 2
24: aconst_null
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 25 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
1 25 1 maxIterations I
3 23 2 node Lorg/graalvm/compiler/nodes/AbstractBeginNode;
5 18 3 merge Lorg/graalvm/compiler/nodes/AbstractMergeNode;
7 18 4 states Ljava/util/ArrayList<TT;>;
8 14 5 i I
10 12 6 other TT;
15 18 5 ready Z
private void finishLoopEnds(org.graalvm.compiler.nodes.LoopEndNode);
descriptor: (Lorg/graalvm/compiler/nodes/LoopEndNode;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=9, args_size=2
start local 0 start local 1 0: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 1
invokevirtual org.graalvm.compiler.graph.NodeBitMap.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
ifeq 1
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
1: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 2
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
invokeinterface org.graalvm.util.EconomicMap.containsKey:(Ljava/lang/Object;)Z
ifeq 2
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
2: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokeinterface org.graalvm.util.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
3: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 1
invokevirtual org.graalvm.compiler.graph.NodeBitMap.mark:(Lorg/graalvm/compiler/graph/Node;)V
4: aload 1
invokevirtual org.graalvm.compiler.nodes.LoopEndNode.loopBegin:()Lorg/graalvm/compiler/nodes/LoopBeginNode;
astore 2
start local 2 5: iconst_1
istore 3
start local 3 6: aload 2
invokevirtual org.graalvm.compiler.nodes.LoopBeginNode.loopEnds:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
astore 5
goto 11
StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.LoopEndNode org.graalvm.compiler.nodes.LoopBeginNode int top java.util.Iterator
StackMap stack:
7: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.graalvm.compiler.nodes.LoopEndNode
astore 4
start local 4 8: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 4
invokevirtual org.graalvm.compiler.graph.NodeBitMap.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
ifne 11
9: iconst_0
istore 3
10: goto 12
end local 4 11: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 7
12: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.LoopEndNode org.graalvm.compiler.nodes.LoopBeginNode int
StackMap stack:
iload 3
ifeq 22
13: new java.util.ArrayList
dup
aload 2
invokevirtual org.graalvm.compiler.nodes.LoopBeginNode.loopEnds:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.count:()I
invokespecial java.util.ArrayList.<init>:(I)V
astore 4
start local 4 14: aload 2
invokevirtual org.graalvm.compiler.nodes.LoopBeginNode.orderedLoopEnds:()[Lorg/graalvm/compiler/nodes/LoopEndNode;
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 18
StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.LoopEndNode org.graalvm.compiler.nodes.LoopBeginNode int java.util.ArrayList top int int org.graalvm.compiler.nodes.LoopEndNode[]
StackMap stack:
15: aload 8
iload 6
aaload
astore 5
start local 5 16: aload 4
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 5
invokeinterface org.graalvm.util.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
end local 5 17: iinc 6 1
StackMap locals:
StackMap stack:
18: iload 6
iload 7
if_icmplt 15
19: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 2
invokeinterface org.graalvm.util.EconomicMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.graph.MergeableState
astore 5
start local 5 20: aload 5
ifnull 22
21: aload 5
aload 2
aload 4
invokevirtual org.graalvm.compiler.phases.graph.MergeableState.loopEnds:(Lorg/graalvm/compiler/nodes/LoopBeginNode;Ljava/util/List;)V
end local 5 end local 4 22: StackMap locals: org.graalvm.compiler.phases.graph.PostOrderNodeIterator org.graalvm.compiler.nodes.LoopEndNode org.graalvm.compiler.nodes.LoopBeginNode int
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 23 1 end Lorg/graalvm/compiler/nodes/LoopEndNode;
5 23 2 begin Lorg/graalvm/compiler/nodes/LoopBeginNode;
6 23 3 endsVisited Z
8 11 4 le Lorg/graalvm/compiler/nodes/LoopEndNode;
14 22 4 states Ljava/util/ArrayList<TT;>;
16 17 5 le Lorg/graalvm/compiler/nodes/LoopEndNode;
20 22 5 loopBeginState TT;
MethodParameters:
Name Flags
end
private void queueMerge(org.graalvm.compiler.nodes.EndNode);
descriptor: (Lorg/graalvm/compiler/nodes/EndNode;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=5, args_size=2
start local 0 start local 1 0: getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 1
invokevirtual org.graalvm.compiler.graph.NodeBitMap.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
ifeq 1
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
1: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.phases.graph.PostOrderNodeIterator.$assertionsDisabled:Z
ifne 2
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
invokeinterface org.graalvm.util.EconomicMap.containsKey:(Ljava/lang/Object;)Z
ifeq 2
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
2: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeStates:Lorg/graalvm/util/EconomicMap;
aload 1
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.state:Lorg/graalvm/compiler/phases/graph/MergeableState;
invokeinterface org.graalvm.util.EconomicMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
3: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 1
invokevirtual org.graalvm.compiler.graph.NodeBitMap.mark:(Lorg/graalvm/compiler/graph/Node;)V
4: aload 1
invokevirtual org.graalvm.compiler.nodes.EndNode.merge:()Lorg/graalvm/compiler/nodes/AbstractMergeNode;
astore 2
start local 2 5: iconst_1
istore 3
start local 3 6: iconst_0
istore 4
start local 4 7: goto 12
8: StackMap locals: org.graalvm.compiler.nodes.AbstractMergeNode int int
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.visitedEnds:Lorg/graalvm/compiler/graph/NodeBitMap;
aload 2
iload 4
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndAt:(I)Lorg/graalvm/compiler/nodes/EndNode;
invokevirtual org.graalvm.compiler.graph.NodeBitMap.isMarked:(Lorg/graalvm/compiler/graph/Node;)Z
ifne 11
9: iconst_0
istore 3
10: goto 13
11: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
12: iload 4
aload 2
invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.forwardEndCount:()I
if_icmplt 8
end local 4 13: StackMap locals:
StackMap stack:
iload 3
ifeq 15
14: aload 0
getfield org.graalvm.compiler.phases.graph.PostOrderNodeIterator.nodeQueue:Ljava/util/Deque;
aload 2
invokeinterface java.util.Deque.add:(Ljava/lang/Object;)Z
pop
15: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 16 1 end Lorg/graalvm/compiler/nodes/EndNode;
5 16 2 merge Lorg/graalvm/compiler/nodes/AbstractMergeNode;
6 16 3 endsVisited Z
7 13 4 i I
MethodParameters:
Name Flags
end
protected abstract void node(org.graalvm.compiler.nodes.FixedNode);
descriptor: (Lorg/graalvm/compiler/nodes/FixedNode;)V
flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
MethodParameters:
Name Flags
node
protected void end(org.graalvm.compiler.nodes.EndNode);
descriptor: (Lorg/graalvm/compiler/nodes/EndNode;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 endNode Lorg/graalvm/compiler/nodes/EndNode;
MethodParameters:
Name Flags
endNode
protected void merge(org.graalvm.compiler.nodes.AbstractMergeNode);
descriptor: (Lorg/graalvm/compiler/nodes/AbstractMergeNode;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 merge Lorg/graalvm/compiler/nodes/AbstractMergeNode;
MethodParameters:
Name Flags
merge
protected void loopBegin(org.graalvm.compiler.nodes.LoopBeginNode);
descriptor: (Lorg/graalvm/compiler/nodes/LoopBeginNode;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 loopBegin Lorg/graalvm/compiler/nodes/LoopBeginNode;
MethodParameters:
Name Flags
loopBegin
protected void loopEnd(org.graalvm.compiler.nodes.LoopEndNode);
descriptor: (Lorg/graalvm/compiler/nodes/LoopEndNode;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 loopEnd Lorg/graalvm/compiler/nodes/LoopEndNode;
MethodParameters:
Name Flags
loopEnd
protected java.util.Set<org.graalvm.compiler.graph.Node> controlSplit(org.graalvm.compiler.nodes.ControlSplitNode);
descriptor: (Lorg/graalvm/compiler/nodes/ControlSplitNode;)Ljava/util/Set;
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: aconst_null
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 controlSplit Lorg/graalvm/compiler/nodes/ControlSplitNode;
Signature: (Lorg/graalvm/compiler/nodes/ControlSplitNode;)Ljava/util/Set<Lorg/graalvm/compiler/graph/Node;>;
MethodParameters:
Name Flags
controlSplit
protected void invoke(org.graalvm.compiler.nodes.Invoke);
descriptor: (Lorg/graalvm/compiler/nodes/Invoke;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokeinterface org.graalvm.compiler.nodes.Invoke.asNode:()Lorg/graalvm/compiler/nodes/FixedNode;
invokevirtual org.graalvm.compiler.phases.graph.PostOrderNodeIterator.node:(Lorg/graalvm/compiler/nodes/FixedNode;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
0 2 1 invoke Lorg/graalvm/compiler/nodes/Invoke;
MethodParameters:
Name Flags
invoke
protected void finished();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=0, locals=1, args_size=1
start local 0 0: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/graalvm/compiler/phases/graph/PostOrderNodeIterator<TT;>;
}
Signature: <T:Lorg/graalvm/compiler/phases/graph/MergeableState<TT;>;>Ljava/lang/Object;
SourceFile: "PostOrderNodeIterator.java"