public class org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp extends org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp
  super_class: org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp
{
  public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp> 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$CmpDataBranchOp;>;

  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;})

  private final jdk.vm.ci.meta.Constant y;
    descriptor: Ljdk/vm/ci/meta/Constant;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 523
            ldc Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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.Constant, 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/Constant;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=9, args_size=8
        start local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
        start local 1 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize size
        start local 2 // jdk.vm.ci.meta.AllocatableValue x
        start local 3 // jdk.vm.ci.meta.Constant y
        start local 4 // org.graalvm.compiler.core.common.calc.Condition cond
        start local 5 // org.graalvm.compiler.lir.LabelRef trueDestination
        start local 6 // org.graalvm.compiler.lir.LabelRef falseDestination
        start local 7 // double trueDestinationProbability
         0: .line 531
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            aload 4 /* cond */
            invokestatic org.graalvm.compiler.lir.amd64.AMD64ControlFlow.intCond:(Lorg/graalvm/compiler/core/common/calc/Condition;)Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
            aload 5 /* trueDestination */
            aload 6 /* falseDestination */
            dload 7 /* trueDestinationProbability */
            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: .line 532
            aload 0 /* this */
            aload 1 /* size */
            putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
         2: .line 534
            aload 0 /* this */
            aload 2 /* x */
            putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
         3: .line 535
            aload 0 /* this */
            aload 3 /* y */
            putfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.y:Ljdk/vm/ci/meta/Constant;
         4: .line 536
            return
        end local 7 // double trueDestinationProbability
        end local 6 // org.graalvm.compiler.lir.LabelRef falseDestination
        end local 5 // org.graalvm.compiler.lir.LabelRef trueDestination
        end local 4 // org.graalvm.compiler.core.common.calc.Condition cond
        end local 3 // jdk.vm.ci.meta.Constant y
        end local 2 // jdk.vm.ci.meta.AllocatableValue x
        end local 1 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize size
        end local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
      LocalVariableTable:
        Start  End  Slot                        Name  Signature
            0    5     0                        this  Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp;
            0    5     1                        size  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            0    5     2                           x  Ljdk/vm/ci/meta/AllocatableValue;
            0    5     3                           y  Ljdk/vm/ci/meta/Constant;
            0    5     4                        cond  Lorg/graalvm/compiler/core/common/calc/Condition;
            0    5     5             trueDestination  Lorg/graalvm/compiler/lir/LabelRef;
            0    5     6            falseDestination  Lorg/graalvm/compiler/lir/LabelRef;
            0    5     7  trueDestinationProbability  D
    MethodParameters:
                            Name  Flags
      size                        
      x                           
      y                           
      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=6, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.amd64.AMD64MacroAssembler masm
         0: .line 540
            aload 0 /* this */
            aload 1 /* crb */
            invokedynamic get(Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp;Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;)Ljava/util/function/Supplier;
              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:
                  ()Ljava/lang/Object;
                  org/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp.lambda$0(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;)Lorg/graalvm/compiler/asm/amd64/AMD64Address; (7)
                  ()Lorg/graalvm/compiler/asm/amd64/AMD64Address;
            astore 3 /* applyBeforeConsumer */
        start local 3 // java.util.function.Supplier applyBeforeConsumer
         1: .line 541
            aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifeq 4
         2: .line 542
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 3 /* applyBeforeConsumer */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljava/util/function/Supplier;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;)V
         3: .line 543
            goto 13
      StackMap locals: java.util.function.Supplier
      StackMap stack:
         4: aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifeq 7
         5: .line 544
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 3 /* applyBeforeConsumer */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljava/util/function/Supplier;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;)V
         6: .line 545
            goto 13
      StackMap locals:
      StackMap stack:
         7: aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.trueDestinationProbability:D
            ldc 0.5
            dcmpg
            ifge 11
         8: .line 546
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 3 /* applyBeforeConsumer */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljava/util/function/Supplier;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;)V
         9: .line 547
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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
        10: .line 548
            goto 13
        11: .line 549
      StackMap locals:
      StackMap stack:
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            aload 3 /* applyBeforeConsumer */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.condition:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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.cmpAndJcc:(Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;Ljdk/vm/ci/code/Register;Ljava/util/function/Supplier;Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$ConditionFlag;Lorg/graalvm/compiler/asm/Label;)V
        12: .line 550
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.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
        13: .line 552
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.util.function.Supplier applyBeforeConsumer
        end local 2 // org.graalvm.compiler.asm.amd64.AMD64MacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   14     0                 this  Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp;
            0   14     1                  crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   14     2                 masm  Lorg/graalvm/compiler/asm/amd64/AMD64MacroAssembler;
            1   14     3  applyBeforeConsumer  Ljava/util/function/Supplier<Lorg/graalvm/compiler/asm/amd64/AMD64Address;>;
    MethodParameters:
      Name  Flags
      crb   
      masm  

  private org.graalvm.compiler.asm.amd64.AMD64Address lambda$0(org.graalvm.compiler.lir.asm.CompilationResultBuilder);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;)Lorg/graalvm/compiler/asm/amd64/AMD64Address;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
         0: .line 540
            aload 1
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.y:Ljdk/vm/ci/meta/Constant;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp.size:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$OperandSize;
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$OperandSize.getBytes:()I
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.recordDataReferenceInCode:(Ljdk/vm/ci/meta/Constant;I)Lorg/graalvm/compiler/asm/AbstractAddress;
            checkcast org.graalvm.compiler.asm.amd64.AMD64Address
            areturn
        end local 0 // org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/lir/amd64/AMD64ControlFlow$CmpDataBranchOp;
}
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 Use = org.graalvm.compiler.lir.LIRInstruction$Use of org.graalvm.compiler.lir.LIRInstruction
  public BranchOp = org.graalvm.compiler.lir.amd64.AMD64ControlFlow$BranchOp of org.graalvm.compiler.lir.amd64.AMD64ControlFlow
  public CmpDataBranchOp = org.graalvm.compiler.lir.amd64.AMD64ControlFlow$CmpDataBranchOp of org.graalvm.compiler.lir.amd64.AMD64ControlFlow