public abstract class org.graalvm.compiler.phases.BasePhase<C> implements org.graalvm.compiler.phases.contract.PhaseSizeContract
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: org.graalvm.compiler.phases.BasePhase
super_class: java.lang.Object
{
private final org.graalvm.compiler.debug.DebugTimer timer;
descriptor: Lorg/graalvm/compiler/debug/DebugTimer;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.graalvm.compiler.debug.DebugCounter executionCount;
descriptor: Lorg/graalvm/compiler/debug/DebugCounter;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.graalvm.compiler.debug.DebugCounter inputNodesCount;
descriptor: Lorg/graalvm/compiler/debug/DebugCounter;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.graalvm.compiler.debug.DebugMemUseTracker memUseTracker;
descriptor: Lorg/graalvm/compiler/debug/DebugMemUseTracker;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private static final java.lang.ClassValue<org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics> statisticsClassValue;
descriptor: Ljava/lang/ClassValue;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/lang/ClassValue<Lorg/graalvm/compiler/phases/BasePhase$BasePhaseStatistics;>;
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=2, locals=0, args_size=0
0: ldc Lorg/graalvm/compiler/phases/BasePhase;
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.BasePhase.$assertionsDisabled:Z
3: new org.graalvm.compiler.phases.BasePhase$1
dup
invokespecial org.graalvm.compiler.phases.BasePhase$1.<init>:()V
putstatic org.graalvm.compiler.phases.BasePhase.statisticsClassValue:Ljava/lang/ClassValue;
4: return
LocalVariableTable:
Start End Slot Name Signature
protected void <init>();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: getstatic org.graalvm.compiler.phases.BasePhase.statisticsClassValue:Ljava/lang/ClassValue;
aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.ClassValue.get:(Ljava/lang/Class;)Ljava/lang/Object;
checkcast org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics
astore 1
start local 1 2: aload 0
aload 1
getfield org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics.timer:Lorg/graalvm/compiler/debug/DebugTimer;
putfield org.graalvm.compiler.phases.BasePhase.timer:Lorg/graalvm/compiler/debug/DebugTimer;
3: aload 0
aload 1
getfield org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics.executionCount:Lorg/graalvm/compiler/debug/DebugCounter;
putfield org.graalvm.compiler.phases.BasePhase.executionCount:Lorg/graalvm/compiler/debug/DebugCounter;
4: aload 0
aload 1
getfield org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics.memUseTracker:Lorg/graalvm/compiler/debug/DebugMemUseTracker;
putfield org.graalvm.compiler.phases.BasePhase.memUseTracker:Lorg/graalvm/compiler/debug/DebugMemUseTracker;
5: aload 0
aload 1
getfield org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics.inputNodesCount:Lorg/graalvm/compiler/debug/DebugCounter;
putfield org.graalvm.compiler.phases.BasePhase.inputNodesCount:Lorg/graalvm/compiler/debug/DebugCounter;
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/graalvm/compiler/phases/BasePhase<TC;>;
2 7 1 statistics Lorg/graalvm/compiler/phases/BasePhase$BasePhaseStatistics;
public final void apply(org.graalvm.compiler.nodes.StructuredGraph, );
descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
aload 2
iconst_1
invokevirtual org.graalvm.compiler.phases.BasePhase.apply:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;Z)V
1: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/graalvm/compiler/phases/BasePhase<TC;>;
0 2 1 graph Lorg/graalvm/compiler/nodes/StructuredGraph;
0 2 2 context TC;
Signature: (Lorg/graalvm/compiler/nodes/StructuredGraph;TC;)V
MethodParameters:
Name Flags
graph final
context final
protected final void apply(org.graalvm.compiler.nodes.StructuredGraph, C, );
descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;Z)V
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
Code:
stack=5, locals=12, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aconst_null
astore 4
aconst_null
astore 5
1: aload 0
getfield org.graalvm.compiler.phases.BasePhase.timer:Lorg/graalvm/compiler/debug/DebugTimer;
invokeinterface org.graalvm.compiler.debug.DebugTimer.start:()Lorg/graalvm/compiler/debug/DebugCloseable;
astore 6
start local 6 2: aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
aload 0
invokestatic org.graalvm.compiler.debug.Debug.scope:(Ljava/lang/Object;Ljava/lang/Object;)Lorg/graalvm/compiler/debug/Debug$Scope;
astore 7
start local 7 3: aload 0
getfield org.graalvm.compiler.phases.BasePhase.memUseTracker:Lorg/graalvm/compiler/debug/DebugMemUseTracker;
invokeinterface org.graalvm.compiler.debug.DebugMemUseTracker.start:()Lorg/graalvm/compiler/debug/DebugCloseable;
astore 8
start local 8 4: iconst_0
istore 9
start local 9 5: aconst_null
astore 10
start local 10 6: getstatic org.graalvm.compiler.phases.BasePhase$PhaseOptions.VerifyGraalPhasesSize:Lorg/graalvm/compiler/options/OptionValue;
invokevirtual org.graalvm.compiler.options.OptionValue.getValue:()Ljava/lang/Object;
checkcast java.lang.Boolean
invokevirtual java.lang.Boolean.booleanValue:()Z
ifeq 10
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.checkContract:()Z
ifeq 10
7: aload 2
instanceof org.graalvm.compiler.phases.tiers.PhaseContext
ifeq 10
8: aload 1
aload 2
checkcast org.graalvm.compiler.phases.tiers.PhaseContext
invokevirtual org.graalvm.compiler.phases.tiers.PhaseContext.getNodeCostProvider:()Lorg/graalvm/compiler/nodes/spi/NodeCostProvider;
invokestatic org.graalvm.compiler.phases.contract.NodeCostUtil.computeGraphSize:(Lorg/graalvm/compiler/nodes/StructuredGraph;Lorg/graalvm/compiler/nodes/spi/NodeCostProvider;)I
istore 9
9: aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getMark:()Lorg/graalvm/compiler/graph/Graph$Mark;
astore 10
10: StackMap locals: org.graalvm.compiler.phases.BasePhase org.graalvm.compiler.nodes.StructuredGraph java.lang.Object int java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.debug.Debug$Scope org.graalvm.compiler.debug.DebugCloseable int org.graalvm.compiler.graph.Graph$Mark
StackMap stack:
iload 3
ifeq 12
iconst_3
invokestatic org.graalvm.compiler.debug.Debug.isDumpEnabled:(I)Z
ifeq 12
11: iconst_3
aload 1
ldc "Before phase %s"
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.getName:()Ljava/lang/CharSequence;
invokestatic org.graalvm.compiler.debug.Debug.dump:(ILjava/lang/Object;Ljava/lang/String;Ljava/lang/Object;)V
12: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.phases.BasePhase.inputNodesCount:Lorg/graalvm/compiler/debug/DebugCounter;
aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodeCount:()I
i2l
invokeinterface org.graalvm.compiler.debug.DebugCounter.add:(J)V
13: aload 0
aload 1
aload 2
invokevirtual org.graalvm.compiler.phases.BasePhase.run:(Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
14: aload 0
getfield org.graalvm.compiler.phases.BasePhase.executionCount:Lorg/graalvm/compiler/debug/DebugCounter;
invokeinterface org.graalvm.compiler.debug.DebugCounter.increment:()V
15: getstatic org.graalvm.compiler.phases.BasePhase$PhaseOptions.VerifyGraalPhasesSize:Lorg/graalvm/compiler/options/OptionValue;
invokevirtual org.graalvm.compiler.options.OptionValue.getValue:()Ljava/lang/Object;
checkcast java.lang.Boolean
invokevirtual java.lang.Boolean.booleanValue:()Z
ifeq 20
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.checkContract:()Z
ifeq 20
16: aload 2
instanceof org.graalvm.compiler.phases.tiers.PhaseContext
ifeq 20
17: aload 10
invokevirtual org.graalvm.compiler.graph.Graph$Mark.isCurrent:()Z
ifne 20
18: aload 1
aload 2
checkcast org.graalvm.compiler.phases.tiers.PhaseContext
invokevirtual org.graalvm.compiler.phases.tiers.PhaseContext.getNodeCostProvider:()Lorg/graalvm/compiler/nodes/spi/NodeCostProvider;
invokestatic org.graalvm.compiler.phases.contract.NodeCostUtil.computeGraphSize:(Lorg/graalvm/compiler/nodes/StructuredGraph;Lorg/graalvm/compiler/nodes/spi/NodeCostProvider;)I
istore 11
start local 11 19: aload 1
iload 9
iload 11
aload 0
invokestatic org.graalvm.compiler.phases.contract.NodeCostUtil.phaseFulfillsSizeContract:(Lorg/graalvm/compiler/nodes/StructuredGraph;IILorg/graalvm/compiler/phases/contract/PhaseSizeContract;)V
end local 11 20: StackMap locals:
StackMap stack:
iload 3
ifeq 22
iconst_1
invokestatic org.graalvm.compiler.debug.Debug.isDumpEnabled:(I)Z
ifeq 22
21: iconst_1
aload 1
ldc "%s"
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.getName:()Ljava/lang/CharSequence;
invokestatic org.graalvm.compiler.debug.Debug.dump:(ILjava/lang/Object;Ljava/lang/String;Ljava/lang/Object;)V
22: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.debug.Fingerprint.ENABLED:Z
ifeq 27
23: aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
ifnonnull 24
aload 1
getfield org.graalvm.compiler.nodes.StructuredGraph.name:Ljava/lang/String;
goto 25
StackMap locals:
StackMap stack:
24: aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.method:()Ljdk/vm/ci/meta/ResolvedJavaMethod;
ldc "%H.%n(%p)"
invokeinterface jdk.vm.ci.meta.ResolvedJavaMethod.format:(Ljava/lang/String;)Ljava/lang/String;
StackMap locals:
StackMap stack: java.lang.String
25: astore 11
start local 11 26: ldc "After phase %s nodes in %s are %s"
iconst_3
anewarray java.lang.Object
dup
iconst_0
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.getName:()Ljava/lang/CharSequence;
aastore
dup
iconst_1
aload 11
aastore
dup
iconst_2
aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodes:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.snapshot:()Ljava/util/List;
aastore
invokestatic org.graalvm.compiler.debug.Fingerprint.submit:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 11 27: StackMap locals:
StackMap stack:
invokestatic org.graalvm.compiler.debug.Debug.isVerifyEnabled:()Z
ifeq 29
28: aload 1
ldc "%s"
aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.getName:()Ljava/lang/CharSequence;
invokestatic org.graalvm.compiler.debug.Debug.verify:(Ljava/lang/Object;Ljava/lang/String;Ljava/lang/Object;)V
29: StackMap locals:
StackMap stack:
getstatic org.graalvm.compiler.phases.BasePhase.$assertionsDisabled:Z
ifne 30
aload 1
invokevirtual org.graalvm.compiler.nodes.StructuredGraph.verify:()Z
ifne 30
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
end local 10 end local 9 30: StackMap locals:
StackMap stack:
aload 8
ifnull 33
aload 8
invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
goto 33
StackMap locals:
StackMap stack: java.lang.Throwable
31: astore 4
aload 8
ifnull 32
aload 8
invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
end local 8 StackMap locals:
StackMap stack:
32: aload 4
athrow
StackMap locals:
StackMap stack:
33: aload 7
ifnull 38
aload 7
invokeinterface org.graalvm.compiler.debug.Debug$Scope.close:()V
goto 38
StackMap locals:
StackMap stack: java.lang.Throwable
34: astore 5
aload 4
ifnonnull 35
aload 5
astore 4
goto 36
StackMap locals:
StackMap stack:
35: aload 4
aload 5
if_acmpeq 36
aload 4
aload 5
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
36: aload 7
ifnull 37
aload 7
invokeinterface org.graalvm.compiler.debug.Debug$Scope.close:()V
end local 7 StackMap locals:
StackMap stack:
37: aload 4
athrow
StackMap locals:
StackMap stack:
38: aload 6
ifnull 48
aload 6
invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
goto 48
StackMap locals:
StackMap stack: java.lang.Throwable
39: astore 5
aload 4
ifnonnull 40
aload 5
astore 4
goto 41
StackMap locals:
StackMap stack:
40: aload 4
aload 5
if_acmpeq 41
aload 4
aload 5
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
41: aload 6
ifnull 42
aload 6
invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
end local 6 StackMap locals:
StackMap stack:
42: aload 4
athrow
StackMap locals:
StackMap stack: java.lang.Throwable
43: astore 5
aload 4
ifnonnull 44
aload 5
astore 4
goto 45
StackMap locals:
StackMap stack:
44: aload 4
aload 5
if_acmpeq 45
aload 4
aload 5
invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
StackMap locals:
StackMap stack:
45: aload 4
athrow
StackMap locals: org.graalvm.compiler.phases.BasePhase org.graalvm.compiler.nodes.StructuredGraph java.lang.Object int
StackMap stack: java.lang.Throwable
46: astore 4
start local 4 47: aload 4
invokestatic org.graalvm.compiler.debug.Debug.handle:(Ljava/lang/Throwable;)Ljava/lang/RuntimeException;
athrow
end local 4 48: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 49 0 this Lorg/graalvm/compiler/phases/BasePhase<TC;>;
0 49 1 graph Lorg/graalvm/compiler/nodes/StructuredGraph;
0 49 2 context TC;
0 49 3 dumpGraph Z
2 42 6 a Lorg/graalvm/compiler/debug/DebugCloseable;
3 37 7 s Lorg/graalvm/compiler/debug/Debug$Scope;
4 32 8 c Lorg/graalvm/compiler/debug/DebugCloseable;
5 30 9 sizeBefore I
6 30 10 before Lorg/graalvm/compiler/graph/Graph$Mark;
19 20 11 sizeAfter I
26 27 11 graphDesc Ljava/lang/String;
47 48 4 t Ljava/lang/Throwable;
Exception table:
from to target type
4 30 31 any
3 33 34 any
2 38 39 any
1 43 43 any
0 46 46 Class java.lang.Throwable
Signature: (Lorg/graalvm/compiler/nodes/StructuredGraph;TC;Z)V
MethodParameters:
Name Flags
graph final
context final
dumpGraph final
protected java.lang.CharSequence getName();
descriptor: ()Ljava/lang/CharSequence;
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
astore 1
start local 1 1: aload 1
aload 1
ldc "."
invokevirtual java.lang.String.lastIndexOf:(Ljava/lang/String;)I
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
astore 2
start local 2 2: aload 2
bipush 36
invokevirtual java.lang.String.indexOf:(I)I
istore 3
start local 3 3: iload 3
ifle 5
4: aload 2
iconst_0
iload 3
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 2
5: StackMap locals: java.lang.String java.lang.String int
StackMap stack:
aload 2
ldc "Phase"
invokevirtual java.lang.String.endsWith:(Ljava/lang/String;)Z
ifeq 7
6: aload 2
iconst_0
aload 2
invokevirtual java.lang.String.length:()I
ldc "Phase"
invokevirtual java.lang.String.length:()I
isub
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 2
7: StackMap locals:
StackMap stack:
aload 2
areturn
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/BasePhase<TC;>;
1 8 1 className Ljava/lang/String;
2 8 2 s Ljava/lang/String;
3 8 3 innerClassPos I
protected abstract void run(org.graalvm.compiler.nodes.StructuredGraph, );
descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;Ljava/lang/Object;)V
flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
Signature: (Lorg/graalvm/compiler/nodes/StructuredGraph;TC;)V
MethodParameters:
Name Flags
graph
context
public java.lang.String contractorName();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual org.graalvm.compiler.phases.BasePhase.getName:()Ljava/lang/CharSequence;
checkcast java.lang.String
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/graalvm/compiler/phases/BasePhase<TC;>;
public float codeSizeIncrease();
descriptor: ()F
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc 1.25
freturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/graalvm/compiler/phases/BasePhase<TC;>;
}
Signature: <C:Ljava/lang/Object;>Ljava/lang/Object;Lorg/graalvm/compiler/phases/contract/PhaseSizeContract;
SourceFile: "BasePhase.java"
NestMembers:
org.graalvm.compiler.phases.BasePhase$1 org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics org.graalvm.compiler.phases.BasePhase$NamePatternHolder org.graalvm.compiler.phases.BasePhase$PhaseOptions
InnerClasses:
public abstract Scope = org.graalvm.compiler.debug.Debug$Scope of org.graalvm.compiler.debug.Debug
public Mark = org.graalvm.compiler.graph.Graph$Mark of org.graalvm.compiler.graph.Graph
org.graalvm.compiler.phases.BasePhase$1
private BasePhaseStatistics = org.graalvm.compiler.phases.BasePhase$BasePhaseStatistics of org.graalvm.compiler.phases.BasePhase
NamePatternHolder = org.graalvm.compiler.phases.BasePhase$NamePatternHolder of org.graalvm.compiler.phases.BasePhase
public PhaseOptions = org.graalvm.compiler.phases.BasePhase$PhaseOptions of org.graalvm.compiler.phases.BasePhase