public class org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp extends org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp implements org.graalvm.compiler.lir.StandardOp$ImplicitNullCheck
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp
super_class: org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp
{
public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp> TYPE;
descriptor: Lorg/graalvm/compiler/lir/LIRInstructionClass;
flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
Signature: Lorg/graalvm/compiler/lir/LIRInstructionClass<Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;>;
private final org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize size;
descriptor: Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
protected jdk.vm.ci.meta.AllocatableValue x;
descriptor: Ljdk/vm/ci/meta/AllocatableValue;
flags: (0x0004) ACC_PROTECTED
RuntimeVisibleAnnotations:
org.graalvm.compiler.lir.LIRInstruction$Use(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})
protected jdk.vm.ci.meta.Value y;
descriptor: Ljdk/vm/ci/meta/Value;
flags: (0x0004) ACC_PROTECTED
RuntimeVisibleAnnotations:
org.graalvm.compiler.lir.LIRInstruction$Use(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;, org.graalvm.compiler.lir.LIRInstruction$OperandFlag.STACK:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;, org.graalvm.compiler.lir.LIRInstruction$OperandFlag.COMPOSITE:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})
protected org.graalvm.compiler.lir.LIRFrameState state;
descriptor: Lorg/graalvm/compiler/lir/LIRFrameState;
flags: (0x0004) ACC_PROTECTED
RuntimeVisibleAnnotations:
org.graalvm.compiler.lir.LIRInstruction$State()
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/lir/amd64/AMD64ControlFlow;
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.lir.amd64.AMD64ControlFlow$CmpBranchOp.$assertionsDisabled:Z
3: ldc Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;
invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
putstatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.Value, org.graalvm.compiler.lir.LIRFrameState, org.graalvm.compiler.core.common.calc.Condition, org.graalvm.compiler.lir.LabelRef, org.graalvm.compiler.lir.LabelRef, double);
descriptor: (Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/lir/LIRFrameState;Lorg/graalvm/compiler/core/common/calc/Condition;Lorg/graalvm/compiler/lir/LabelRef;Lorg/graalvm/compiler/lir/LabelRef;D)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=10, args_size=9
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: aload 0
getstatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
aload 5
invokestatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow.intCond:(Lorg/graalvm/compiler/core/common/calc/Condition;)Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 6
aload 7
dload 8
invokespecial org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/lir/LabelRef;Lorg/graalvm/compiler/lir/LabelRef;D)V
1: aload 0
aload 1
putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
2: aload 0
aload 2
putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
3: aload 0
aload 3
putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
4: aload 0
aload 4
putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
5: return
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;
0 6 1 size Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
0 6 2 x Ljdk/vm/ci/meta/AllocatableValue;
0 6 3 y Ljdk/vm/ci/meta/Value;
0 6 4 state Lorg/graalvm/compiler/lir/LIRFrameState;
0 6 5 cond Lorg/graalvm/compiler/core/common/calc/Condition;
0 6 6 trueDestination Lorg/graalvm/compiler/lir/LabelRef;
0 6 7 falseDestination Lorg/graalvm/compiler/lir/LabelRef;
0 6 8 trueDestinationProbability D
MethodParameters:
Name Flags
size
x
y
state
cond
trueDestination
falseDestination
trueDestinationProbability
public void emitCode(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.amd64.AMD64MacroAssembler);
descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.isRegister:(Ljdk/vm/ci/meta/Value;)Z
ifeq 15
1: getstatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.$assertionsDisabled:Z
ifne 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
ifnull 2
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
2: StackMap locals:
StackMap stack:
aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 5
3: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;Z)V
4: goto 14
StackMap locals:
StackMap stack:
5: aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 8
6: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;Z)V
7: goto 14
StackMap locals:
StackMap stack:
8: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestinationProbability:D
ldc 0.5
dcmpg
ifge 12
9: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;Z)V
10: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
11: goto 14
12: StackMap locals:
StackMap stack:
aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;Z)V
13: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
14: StackMap locals:
StackMap stack:
return
15: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
ifnonnull 16
aconst_null
goto 17
StackMap locals:
StackMap stack:
16: aload 0
aload 1
invokedynamic accept(Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;)Ljava/util/function/IntConsumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(I)V
org/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp.lambda$0(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;I)V (7)
(I)V
StackMap locals:
StackMap stack: java.util.function.IntConsumer
17: astore 3
start local 3 18: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokestatic jdk.vm.ci.code.ValueUtil.isStackSlot:(Ljdk/vm/ci/meta/Value;)Z
ifeq 32
19: aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 22
20: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.asAddress:(Ljdk/vm/ci/meta/Value;)Lorg/graalvm/compiler/asm/AbstractAddress;
checkcast org.graalvm.compiler.asm.amd64.AMD64Address
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
21: goto 45
StackMap locals: java.util.function.IntConsumer
StackMap stack:
22: aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 25
23: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.asAddress:(Ljdk/vm/ci/meta/Value;)Lorg/graalvm/compiler/asm/AbstractAddress;
checkcast org.graalvm.compiler.asm.amd64.AMD64Address
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
24: goto 45
StackMap locals:
StackMap stack:
25: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestinationProbability:D
ldc 0.5
dcmpg
ifge 29
26: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.asAddress:(Ljdk/vm/ci/meta/Value;)Lorg/graalvm/compiler/asm/AbstractAddress;
checkcast org.graalvm.compiler.asm.amd64.AMD64Address
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
27: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
28: goto 45
29: StackMap locals:
StackMap stack:
aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.asAddress:(Ljdk/vm/ci/meta/Value;)Lorg/graalvm/compiler/asm/AbstractAddress;
checkcast org.graalvm.compiler.asm.amd64.AMD64Address
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
30: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
31: goto 45
32: StackMap locals:
StackMap stack:
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
checkcast org.graalvm.compiler.lir.amd64.AMD64AddressValue
astore 4
start local 4 33: aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 36
34: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 4
invokevirtual org.graalvm.compiler.lir.amd64.AMD64AddressValue.toAddress:()Lorg/graalvm/compiler/asm/amd64/AMD64Address;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
35: goto 45
StackMap locals: org.graalvm.compiler.lir.amd64.AMD64AddressValue
StackMap stack:
36: aload 1
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
ifeq 39
37: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 4
invokevirtual org.graalvm.compiler.lir.amd64.AMD64AddressValue.toAddress:()Lorg/graalvm/compiler/asm/amd64/AMD64Address;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
38: goto 45
StackMap locals:
StackMap stack:
39: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestinationProbability:D
ldc 0.5
dcmpg
ifge 43
40: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 4
invokevirtual org.graalvm.compiler.lir.amd64.AMD64AddressValue.toAddress:()Lorg/graalvm/compiler/asm/amd64/AMD64Address;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
41: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
42: goto 45
43: StackMap locals:
StackMap stack:
aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
aload 4
invokevirtual org.graalvm.compiler.lir.amd64.AMD64AddressValue.toAddress:()Lorg/graalvm/compiler/asm/amd64/AMD64Address;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
iconst_0
aload 3
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;ZLjava/util/function/IntConsumer;)V
44: aload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
invokevirtual org.graalvm.compiler.asm.amd64.AMD64MacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
end local 4 45: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 46 0 this Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;
0 46 1 crb Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
0 46 2 masm Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;
18 46 3 applyBeforeFusedPair Ljava/util/function/IntConsumer;
33 45 4 yAddress Lorg/graalvm/compiler/lir/amd64/AMD64AddressValue;
MethodParameters:
Name Flags
crb
masm
public boolean makeNullCheckFor(jdk.vm.ci.meta.Value, org.graalvm.compiler.lir.LIRFrameState, int);
descriptor: (Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/lir/LIRFrameState;I)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
ifnonnull 3
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
instanceof org.graalvm.compiler.lir.amd64.AMD64AddressValue
ifeq 3
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.y:Ljdk/vm/ci/meta/Value;
checkcast org.graalvm.compiler.lir.amd64.AMD64AddressValue
aload 1
iload 3
invokevirtual org.graalvm.compiler.lir.amd64.AMD64AddressValue.isValidImplicitNullCheckFor:(Ljdk/vm/ci/meta/Value;I)Z
ifeq 3
1: aload 0
aload 2
putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
2: iconst_1
ireturn
3: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;
0 4 1 value Ljdk/vm/ci/meta/Value;
0 4 2 nullCheckState Lorg/graalvm/compiler/lir/LIRFrameState;
0 4 3 implicitNullCheckLimit I
MethodParameters:
Name Flags
value
nullCheckState
implicitNullCheckLimit
private void lambda$0(org.graalvm.compiler.lir.asm.CompilationResultBuilder, int);
descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;I)V
flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 2 0: aload 1
iload 2
aload 0
getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp.state:Lorg/graalvm/compiler/lir/LIRFrameState;
invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.recordImplicitException:(ILorg/graalvm/compiler/lir/LIRFrameState;)V
return
end local 2 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpBranchOp;
0 1 2 pos I
}
SourceFile: "AMD64ControlFlow.java"
NestHost: org.graalvm.compiler.lir.amd64.AMD64ControlFlow
InnerClasses:
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
public final ConditionFlag = org.graalvm.compiler.asm.amd64.AMD64Assembler$ConditionFlag of org.graalvm.compiler.asm.amd64.AMD64Assembler
public OperandSize = org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize of org.graalvm.compiler.asm.amd64.AMD64BaseAssembler
public final OperandFlag = org.graalvm.compiler.lir.LIRInstruction$OperandFlag of org.graalvm.compiler.lir.LIRInstruction
public abstract State = org.graalvm.compiler.lir.LIRInstruction$State of org.graalvm.compiler.lir.LIRInstruction
public abstract Use = org.graalvm.compiler.lir.LIRInstruction$Use of org.graalvm.compiler.lir.LIRInstruction
public abstract ImplicitNullCheck = org.graalvm.compiler.lir.StandardOp$ImplicitNullCheck of org.graalvm.compiler.lir.StandardOp
public BranchOp = org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp of org.graalvm.compiler.lir.amd64.AMD64ControlFlow
public CmpBranchOp = org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpBranchOp of org.graalvm.compiler.lir.amd64.AMD64ControlFlow