public final class org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp extends org.graalvm.compiler.lir.sparc.SPARCBlockEndOp implements org.graalvm.compiler.lir.sparc.SPARCDelayedControlTransfer
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp
  super_class: org.graalvm.compiler.lir.sparc.SPARCBlockEndOp
{
  public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp> 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/sparc/SPARCControlFlow$CompareBranchOp;>;

  public static final org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate SIZE;
    descriptor: Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  static final java.util.EnumSet<jdk.vm.ci.sparc.SPARCKind> SUPPORTED_KINDS;
    descriptor: Ljava/util/EnumSet;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/EnumSet<Ljdk/vm/ci/sparc/SPARCKind;>;

  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.CONST:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  private org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag conditionFlag;
    descriptor: Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
    flags: (0x0002) ACC_PRIVATE

  protected final org.graalvm.compiler.lir.LabelRef trueDestination;
    descriptor: Lorg/graalvm/compiler/lir/LabelRef;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected org.graalvm.compiler.asm.Assembler$LabelHint trueDestinationHint;
    descriptor: Lorg/graalvm/compiler/asm/Assembler$LabelHint;
    flags: (0x0004) ACC_PROTECTED

  protected final org.graalvm.compiler.lir.LabelRef falseDestination;
    descriptor: Lorg/graalvm/compiler/lir/LabelRef;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected org.graalvm.compiler.asm.Assembler$LabelHint falseDestinationHint;
    descriptor: Lorg/graalvm/compiler/asm/Assembler$LabelHint;
    flags: (0x0004) ACC_PROTECTED

  protected final jdk.vm.ci.sparc.SPARCKind kind;
    descriptor: Ljdk/vm/ci/sparc/SPARCKind;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final boolean unorderedIsTrue;
    descriptor: Z
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  private boolean emitted;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private int delaySlotPosition;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private double trueDestinationProbability;
    descriptor: D
    flags: (0x0002) ACC_PRIVATE

  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: .line 141
            ldc Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow;
            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.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
         3: .line 142
            ldc Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
         4: .line 143
            iconst_3
            invokestatic org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate.create:(I)Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            putstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.SIZE:Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
         5: .line 144
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD:Ljdk/vm/ci/sparc/SPARCKind;
            getstatic jdk.vm.ci.sparc.SPARCKind.WORD:Ljdk/vm/ci/sparc/SPARCKind;
            invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;Ljava/lang/Enum;)Ljava/util/EnumSet;
            putstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.SUPPORTED_KINDS:Ljava/util/EnumSet;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.Value, org.graalvm.compiler.core.common.calc.Condition, org.graalvm.compiler.lir.LabelRef, org.graalvm.compiler.lir.LabelRef, jdk.vm.ci.sparc.SPARCKind, boolean, double);
    descriptor: (Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/core/common/calc/Condition;Lorg/graalvm/compiler/lir/LabelRef;Lorg/graalvm/compiler/lir/LabelRef;Ljdk/vm/ci/sparc/SPARCKind;ZD)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=10, args_size=9
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // jdk.vm.ci.meta.AllocatableValue x
        start local 2 // jdk.vm.ci.meta.Value y
        start local 3 // org.graalvm.compiler.core.common.calc.Condition condition
        start local 4 // org.graalvm.compiler.lir.LabelRef trueDestination
        start local 5 // org.graalvm.compiler.lir.LabelRef falseDestination
        start local 6 // jdk.vm.ci.sparc.SPARCKind kind
        start local 7 // boolean unorderedIsTrue
        start local 8 // double trueDestinationProbability
         0: .line 161
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.SIZE:Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            invokespecial org.graalvm.compiler.lir.sparc.SPARCBlockEndOp.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;)V
         1: .line 155
            aload 0 /* this */
            iconst_0
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
         2: .line 156
            aload 0 /* this */
            iconst_m1
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.delaySlotPosition:I
         3: .line 162
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 4
            aload 1 /* x */
            invokevirtual jdk.vm.ci.meta.AllocatableValue.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            aload 2 /* y */
            invokevirtual jdk.vm.ci.meta.Value.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            if_acmpeq 4
            new java.lang.AssertionError
            dup
            ldc "PlatformKind of x must match PlatformKind of y. %s!=%s"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* x */
            invokevirtual jdk.vm.ci.meta.AllocatableValue.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            aastore
            dup
            iconst_1
            aload 2 /* y */
            invokevirtual jdk.vm.ci.meta.Value.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         4: .line 163
      StackMap locals: org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp jdk.vm.ci.meta.AllocatableValue jdk.vm.ci.meta.Value org.graalvm.compiler.core.common.calc.Condition org.graalvm.compiler.lir.LabelRef org.graalvm.compiler.lir.LabelRef jdk.vm.ci.sparc.SPARCKind int double
      StackMap stack:
            aload 0 /* this */
            aload 1 /* x */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
         5: .line 164
            aload 0 /* this */
            aload 2 /* y */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
         6: .line 165
            aload 0 /* this */
            aload 4 /* trueDestination */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
         7: .line 166
            aload 0 /* this */
            aload 5 /* falseDestination */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
         8: .line 167
            aload 0 /* this */
            aload 6 /* kind */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
         9: .line 168
            aload 0 /* this */
            iload 7 /* unorderedIsTrue */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.unorderedIsTrue:Z
        10: .line 169
            aload 0 /* this */
            dload 8 /* trueDestinationProbability */
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationProbability:D
        11: .line 170
            aload 0 /* this */
            aload 6 /* kind */
            invokevirtual jdk.vm.ci.sparc.SPARCKind.isInteger:()Z
            aload 3 /* condition */
            iload 7 /* unorderedIsTrue */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow.fromCondition:(ZLorg/graalvm/compiler/core/common/calc/Condition;Z)Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.conditionFlag:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
        12: .line 171
            return
        end local 8 // double trueDestinationProbability
        end local 7 // boolean unorderedIsTrue
        end local 6 // jdk.vm.ci.sparc.SPARCKind kind
        end local 5 // org.graalvm.compiler.lir.LabelRef falseDestination
        end local 4 // org.graalvm.compiler.lir.LabelRef trueDestination
        end local 3 // org.graalvm.compiler.core.common.calc.Condition condition
        end local 2 // jdk.vm.ci.meta.Value y
        end local 1 // jdk.vm.ci.meta.AllocatableValue x
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot                        Name  Signature
            0   13     0                        this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0   13     1                           x  Ljdk/vm/ci/meta/AllocatableValue;
            0   13     2                           y  Ljdk/vm/ci/meta/Value;
            0   13     3                   condition  Lorg/graalvm/compiler/core/common/calc/Condition;
            0   13     4             trueDestination  Lorg/graalvm/compiler/lir/LabelRef;
            0   13     5            falseDestination  Lorg/graalvm/compiler/lir/LabelRef;
            0   13     6                        kind  Ljdk/vm/ci/sparc/SPARCKind;
            0   13     7             unorderedIsTrue  Z
            0   13     8  trueDestinationProbability  D
    MethodParameters:
                            Name  Flags
      x                           
      y                           
      condition                   
      trueDestination             
      falseDestination            
      kind                        
      unorderedIsTrue             
      trueDestinationProbability  

  public void emitCode(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.sparc.SPARCMacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 175
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
            ifeq 2
         1: .line 176
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 2
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.position:()I
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.delaySlotPosition:I
            isub
            iconst_4
            if_icmpeq 2
            new java.lang.AssertionError
            dup
            ldc "Only one instruction can be stuffed into the delay slot"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 178
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
            ifne 10
         3: .line 179
            aload 0 /* this */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.requestHints:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)V
         4: .line 180
            aload 2 /* masm */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.getTargetPosition:(Lorg/graalvm/compiler/asm/Assembler;)I
            istore 3 /* targetPosition */
        start local 3 // int targetPosition
         5: .line 181
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            iload 3 /* targetPosition */
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.canUseShortBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;I)Z
            ifeq 7
         6: .line 182
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitShortCompareBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)Z
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
         7: .line 184
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
            ifne 10
         8: .line 185
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            iconst_1
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitLongCompareBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Z)Z
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
         9: .line 186
            aload 0 /* this */
            iconst_1
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
        end local 3 // int targetPosition
        10: .line 189
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 11
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
            ifne 11
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        11: .line 190
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0            this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0   12     1             crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   12     2            masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            5   10     3  targetPosition  I
    MethodParameters:
      Name  Flags
      crb   
      masm  

  private boolean emitLongCompareBranch(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.sparc.SPARCMacroAssembler, boolean);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Z)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        start local 3 // boolean withDelayedNop
         0: .line 193
            aload 2 /* masm */
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler$Op3s.Subcc:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$Op3s;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.sparc.SPARCOP3Op.emitOp3:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$Op3s;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;)V
         1: .line 194
            aload 1 /* crb */
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.conditionFlag:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            iload 3 /* withDelayedNop */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationProbability:D
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow.emitBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Ljdk/vm/ci/sparc/SPARCKind;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;Lorg/graalvm/compiler/lir/LabelRef;Lorg/graalvm/compiler/lir/LabelRef;ZD)Z
            ireturn
        end local 3 // boolean withDelayedNop
        end local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0    2     1             crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0    2     2            masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            0    2     3  withDelayedNop  Z
    MethodParameters:
                Name  Flags
      crb             
      masm            
      withDelayedNop  

  private static int getTargetPosition(org.graalvm.compiler.asm.Assembler);
    descriptor: (Lorg/graalvm/compiler/asm/Assembler;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.asm.Assembler asm
         0: .line 198
            aload 0 /* asm */
            invokevirtual org.graalvm.compiler.asm.Assembler.position:()I
            iconst_2
            aload 0 /* asm */
            getfield org.graalvm.compiler.asm.Assembler.target:Ljdk/vm/ci/code/TargetDescription;
            getfield jdk.vm.ci.code.TargetDescription.wordSize:I
            imul
            iadd
            ireturn
        end local 0 // org.graalvm.compiler.asm.Assembler asm
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0   asm  Lorg/graalvm/compiler/asm/Assembler;
    MethodParameters:
      Name  Flags
      asm   

  public void emitControlTransfer(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.sparc.SPARCMacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 203
            aload 0 /* this */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.requestHints:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)V
         1: .line 205
            aload 2 /* masm */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.getTargetPosition:(Lorg/graalvm/compiler/asm/Assembler;)I
            istore 3 /* targetPosition */
        start local 3 // int targetPosition
         2: .line 206
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            iload 3 /* targetPosition */
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.canUseShortBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;I)Z
            ifne 6
         3: .line 207
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* crb */
            aload 2 /* masm */
            iconst_0
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitLongCompareBranch:(Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Z)Z
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
         4: .line 208
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
            ifeq 6
         5: .line 209
            aload 0 /* this */
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.position:()I
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.delaySlotPosition:I
         6: .line 212
      StackMap locals: int
      StackMap stack:
            return
        end local 3 // int targetPosition
        end local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0            this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0    7     1             crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0    7     2            masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            2    7     3  targetPosition  I
    MethodParameters:
      Name  Flags
      crb   
      masm  

  private void requestHints(org.graalvm.compiler.asm.sparc.SPARCMacroAssembler);
    descriptor: (Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 215
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            ifnonnull 2
         1: .line 216
            aload 0 /* this */
            aload 1 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.requestLabelHint:(Lorg/graalvm/compiler/asm/Label;)Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
         2: .line 218
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            ifnonnull 4
         3: .line 219
            aload 0 /* this */
            aload 1 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.requestLabelHint:(Lorg/graalvm/compiler/asm/Label;)Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
         4: .line 221
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0    5     1  masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
    MethodParameters:
      Name  Flags
      masm  

  private boolean emitShortCompareBranch(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.sparc.SPARCMacroAssembler);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=10, args_size=3
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 254
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD:Ljdk/vm/ci/sparc/SPARCKind;
            if_acmpne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: istore 3 /* isLong */
        start local 3 // boolean isLong
         3: .line 255
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.conditionFlag:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            astore 4 /* actualConditionFlag */
        start local 4 // org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag actualConditionFlag
         4: .line 256
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            astore 5 /* actualTrueTarget */
        start local 5 // org.graalvm.compiler.asm.Label actualTrueTarget
         5: .line 257
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            astore 6 /* actualFalseTarget */
        start local 6 // org.graalvm.compiler.asm.Label actualFalseTarget
         6: .line 260
            aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifeq 13
         7: .line 261
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.conditionFlag:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            astore 4 /* actualConditionFlag */
         8: .line 262
            aload 5 /* actualTrueTarget */
            astore 7 /* tmpTarget */
        start local 7 // org.graalvm.compiler.asm.Label tmpTarget
         9: .line 263
            aload 6 /* actualFalseTarget */
            astore 5 /* actualTrueTarget */
        10: .line 264
            aload 7 /* tmpTarget */
            astore 6 /* actualFalseTarget */
        11: .line 265
            iconst_0
            istore 8 /* needJump */
        start local 8 // boolean needJump
        12: .line 266
            goto 22
        end local 8 // boolean needJump
        end local 7 // org.graalvm.compiler.asm.Label tmpTarget
        13: .line 267
      StackMap locals: org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp org.graalvm.compiler.lir.asm.CompilationResultBuilder org.graalvm.compiler.asm.sparc.SPARCMacroAssembler int org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag org.graalvm.compiler.asm.Label org.graalvm.compiler.asm.Label
      StackMap stack:
            aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifeq 14
            iconst_0
            goto 15
      StackMap locals:
      StackMap stack:
        14: iconst_1
      StackMap locals:
      StackMap stack: int
        15: istore 8 /* needJump */
        start local 8 // boolean needJump
        16: .line 268
            aload 2 /* masm */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.getTargetPosition:(Lorg/graalvm/compiler/asm/Assembler;)I
            istore 9 /* targetPosition */
        start local 9 // int targetPosition
        17: .line 269
            iload 8 /* needJump */
            ifeq 22
            aload 2 /* masm */
            iload 9 /* targetPosition */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            aload 5 /* actualTrueTarget */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow.isShortBranch:(Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;ILorg/graalvm/compiler/asm/Assembler$LabelHint;Lorg/graalvm/compiler/asm/Label;)Z
            ifne 22
        18: .line 273
            aload 4 /* actualConditionFlag */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag.negate:()Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            astore 4 /* actualConditionFlag */
        19: .line 274
            aload 5 /* actualTrueTarget */
            astore 7 /* tmpTarget */
        start local 7 // org.graalvm.compiler.asm.Label tmpTarget
        20: .line 275
            aload 6 /* actualFalseTarget */
            astore 5 /* actualTrueTarget */
        21: .line 276
            aload 7 /* tmpTarget */
            astore 6 /* actualFalseTarget */
        end local 9 // int targetPosition
        end local 7 // org.graalvm.compiler.asm.Label tmpTarget
        22: .line 279
      StackMap locals: org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp org.graalvm.compiler.lir.asm.CompilationResultBuilder org.graalvm.compiler.asm.sparc.SPARCMacroAssembler int org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag org.graalvm.compiler.asm.Label org.graalvm.compiler.asm.Label top int
      StackMap stack:
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            aload 5 /* actualTrueTarget */
            aload 4 /* actualConditionFlag */
            iload 3 /* isLong */
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitCBCond:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/asm/Label;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;Z)V
        23: .line 280
            iload 8 /* needJump */
            ifeq 26
        24: .line 281
            aload 2 /* masm */
            aload 6 /* actualFalseTarget */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.jmp:(Lorg/graalvm/compiler/asm/Label;)V
        25: .line 282
            aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.nop:()V
        26: .line 284
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 8 // boolean needJump
        end local 6 // org.graalvm.compiler.asm.Label actualFalseTarget
        end local 5 // org.graalvm.compiler.asm.Label actualTrueTarget
        end local 4 // org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag actualConditionFlag
        end local 3 // boolean isLong
        end local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   27     0                 this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0   27     1                  crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   27     2                 masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            3   27     3               isLong  Z
            4   27     4  actualConditionFlag  Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            5   27     5     actualTrueTarget  Lorg/graalvm/compiler/asm/Label;
            6   27     6    actualFalseTarget  Lorg/graalvm/compiler/asm/Label;
            9   13     7            tmpTarget  Lorg/graalvm/compiler/asm/Label;
           20   22     7            tmpTarget  Lorg/graalvm/compiler/asm/Label;
           12   13     8             needJump  Z
           16   27     8             needJump  Z
           17   22     9       targetPosition  I
    MethodParameters:
      Name  Flags
      crb   
      masm  

  private static void emitCBCond(org.graalvm.compiler.asm.sparc.SPARCMacroAssembler, jdk.vm.ci.meta.Value, jdk.vm.ci.meta.Value, org.graalvm.compiler.asm.Label, org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag, boolean);
    descriptor: (Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;Lorg/graalvm/compiler/asm/Label;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;Z)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=15, args_size=6
        start local 0 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
        start local 1 // jdk.vm.ci.meta.Value actualX
        start local 2 // jdk.vm.ci.meta.Value actualY
        start local 3 // org.graalvm.compiler.asm.Label actualTrueTarget
        start local 4 // org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag cFlag
        start local 5 // boolean isLong
         0: .line 288
            aload 1 /* actualX */
            invokevirtual jdk.vm.ci.meta.Value.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            astore 6 /* xKind */
        start local 6 // jdk.vm.ci.meta.PlatformKind xKind
         1: .line 289
            aload 1 /* actualX */
            aload 6 /* xKind */
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/PlatformKind;)Ljdk/vm/ci/code/Register;
            astore 7 /* rs1 */
        start local 7 // jdk.vm.ci.code.Register rs1
         2: .line 290
            aload 2 /* actualY */
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.isJavaConstant:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 21
         3: .line 291
            aload 2 /* actualY */
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.asJavaConstant:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/meta/JavaConstant;
            astore 8 /* c */
        start local 8 // jdk.vm.ci.meta.JavaConstant c
         4: .line 292
            aload 8 /* c */
            invokeinterface jdk.vm.ci.meta.JavaConstant.isNull:()Z
            ifeq 5
            lconst_0
            goto 6
      StackMap locals: jdk.vm.ci.meta.PlatformKind jdk.vm.ci.code.Register jdk.vm.ci.meta.JavaConstant
      StackMap stack:
         5: aload 8 /* c */
            invokeinterface jdk.vm.ci.meta.JavaConstant.asLong:()J
      StackMap locals:
      StackMap stack: long
         6: lstore 9 /* constantY */
        start local 9 // long constantY
         7: .line 293
            aconst_null
            astore 11
            aconst_null
            astore 12
         8: aload 0 /* masm */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.getScratchRegister:()Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler$ScratchRegister;
            astore 13 /* scratch */
        start local 13 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister scratch
         9: .line 294
            lload 9 /* constantY */
            invokestatic org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.isSimm5:(J)Z
            ifeq 12
        10: .line 295
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler.CBCOND:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$CBCond;
            aload 0 /* masm */
            aload 4 /* cFlag */
            iload 5 /* isLong */
            aload 7 /* rs1 */
            lload 9 /* constantY */
            l2i
            aload 3 /* actualTrueTarget */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler$CBCond.emit:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;ZLjdk/vm/ci/code/Register;ILorg/graalvm/compiler/asm/Label;)V
        11: .line 296
            goto 15
        12: .line 297
      StackMap locals: org.graalvm.compiler.asm.sparc.SPARCMacroAssembler jdk.vm.ci.meta.Value jdk.vm.ci.meta.Value org.graalvm.compiler.asm.Label org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag int jdk.vm.ci.meta.PlatformKind jdk.vm.ci.code.Register jdk.vm.ci.meta.JavaConstant long java.lang.Throwable java.lang.Throwable org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister
      StackMap stack:
            aload 13 /* scratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.getRegister:()Ljdk/vm/ci/code/Register;
            astore 14 /* rs2 */
        start local 14 // jdk.vm.ci.code.Register rs2
        13: .line 298
            aload 0 /* masm */
            lload 9 /* constantY */
            aload 14 /* rs2 */
            iconst_0
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.setx:(JLjdk/vm/ci/code/Register;Z)V
        14: .line 299
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler.CBCOND:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$CBCond;
            aload 0 /* masm */
            aload 4 /* cFlag */
            iload 5 /* isLong */
            aload 7 /* rs1 */
            aload 14 /* rs2 */
            aload 3 /* actualTrueTarget */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler$CBCond.emit:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;ZLjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/Label;)V
        end local 14 // jdk.vm.ci.code.Register rs2
        15: .line 301
      StackMap locals:
      StackMap stack:
            aload 13 /* scratch */
            ifnull 23
            aload 13 /* scratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.close:()V
            goto 23
      StackMap locals:
      StackMap stack: java.lang.Throwable
        16: astore 11
            aload 13 /* scratch */
            ifnull 17
            aload 13 /* scratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.close:()V
        end local 13 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister scratch
      StackMap locals:
      StackMap stack:
        17: aload 11
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        18: astore 12
            aload 11
            ifnonnull 19
            aload 12
            astore 11
            goto 20
      StackMap locals:
      StackMap stack:
        19: aload 11
            aload 12
            if_acmpeq 20
            aload 11
            aload 12
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        20: aload 11
            athrow
        end local 9 // long constantY
        end local 8 // jdk.vm.ci.meta.JavaConstant c
        21: .line 303
      StackMap locals: org.graalvm.compiler.asm.sparc.SPARCMacroAssembler jdk.vm.ci.meta.Value jdk.vm.ci.meta.Value org.graalvm.compiler.asm.Label org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag int jdk.vm.ci.meta.PlatformKind jdk.vm.ci.code.Register
      StackMap stack:
            aload 2 /* actualY */
            aload 6 /* xKind */
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/PlatformKind;)Ljdk/vm/ci/code/Register;
            astore 8 /* rs2 */
        start local 8 // jdk.vm.ci.code.Register rs2
        22: .line 304
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler.CBCOND:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$CBCond;
            aload 0 /* masm */
            aload 4 /* cFlag */
            iload 5 /* isLong */
            aload 7 /* rs1 */
            aload 8 /* rs2 */
            aload 3 /* actualTrueTarget */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler$CBCond.emit:(Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;ZLjdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/Label;)V
        end local 8 // jdk.vm.ci.code.Register rs2
        23: .line 306
      StackMap locals:
      StackMap stack:
            return
        end local 7 // jdk.vm.ci.code.Register rs1
        end local 6 // jdk.vm.ci.meta.PlatformKind xKind
        end local 5 // boolean isLong
        end local 4 // org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag cFlag
        end local 3 // org.graalvm.compiler.asm.Label actualTrueTarget
        end local 2 // jdk.vm.ci.meta.Value actualY
        end local 1 // jdk.vm.ci.meta.Value actualX
        end local 0 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   24     0              masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            0   24     1           actualX  Ljdk/vm/ci/meta/Value;
            0   24     2           actualY  Ljdk/vm/ci/meta/Value;
            0   24     3  actualTrueTarget  Lorg/graalvm/compiler/asm/Label;
            0   24     4             cFlag  Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            0   24     5            isLong  Z
            1   24     6             xKind  Ljdk/vm/ci/meta/PlatformKind;
            2   24     7               rs1  Ljdk/vm/ci/code/Register;
            4   21     8                 c  Ljdk/vm/ci/meta/JavaConstant;
            7   21     9         constantY  J
            9   17    13           scratch  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler$ScratchRegister;
           13   15    14               rs2  Ljdk/vm/ci/code/Register;
           22   23     8               rs2  Ljdk/vm/ci/code/Register;
      Exception table:
        from    to  target  type
           9    15      16  any
           8    18      18  any
    MethodParameters:
                  Name  Flags
      masm              
      actualX           
      actualY           
      actualTrueTarget  
      cFlag             
      isLong            

  private boolean canUseShortBranch(org.graalvm.compiler.lir.asm.CompilationResultBuilder, org.graalvm.compiler.asm.sparc.SPARCAssembler, int);
    descriptor: (Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;I)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCAssembler asm
        start local 3 // int position
         0: .line 309
            aload 2 /* asm */
            getstatic jdk.vm.ci.sparc.SPARC$CPUFeature.CBCOND:Ljdk/vm/ci/sparc/SPARC$CPUFeature;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCAssembler.hasFeature:(Ljdk/vm/ci/sparc/SPARC$CPUFeature;)Z
            ifne 2
         1: .line 310
            iconst_0
            ireturn
         2: .line 312
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokevirtual jdk.vm.ci.meta.AllocatableValue.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            checkcast jdk.vm.ci.sparc.SPARCKind
            invokevirtual jdk.vm.ci.sparc.SPARCKind.isInteger:()Z
            ifne 4
         3: .line 313
            iconst_0
            ireturn
         4: .line 318
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.isJavaConstant:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 6
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.asJavaConstant:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/meta/JavaConstant;
            invokestatic org.graalvm.compiler.asm.sparc.SPARCAssembler.isSimm5:(Ljdk/vm/ci/meta/JavaConstant;)Z
            ifne 6
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.asJavaConstant:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/meta/JavaConstant;
            invokestatic org.graalvm.compiler.asm.sparc.SPARCAssembler.isSimm13:(Ljdk/vm/ci/meta/JavaConstant;)Z
            ifeq 6
         5: .line 319
            iconst_0
            ireturn
         6: .line 321
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* hasShortJumpTarget */
        start local 4 // boolean hasShortJumpTarget
         7: .line 322
            aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifne 9
         8: .line 323
            iload 4 /* hasShortJumpTarget */
            aload 2 /* asm */
            iload 3 /* position */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.trueDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow.isShortBranch:(Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;ILorg/graalvm/compiler/asm/Assembler$LabelHint;Lorg/graalvm/compiler/asm/Label;)Z
            ior
            istore 4 /* hasShortJumpTarget */
         9: .line 325
      StackMap locals: int
      StackMap stack:
            aload 1 /* crb */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.asm.CompilationResultBuilder.isSuccessorEdge:(Lorg/graalvm/compiler/lir/LabelRef;)Z
            ifne 11
        10: .line 326
            iload 4 /* hasShortJumpTarget */
            aload 2 /* asm */
            iload 3 /* position */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestinationHint:Lorg/graalvm/compiler/asm/Assembler$LabelHint;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.falseDestination:Lorg/graalvm/compiler/lir/LabelRef;
            invokevirtual org.graalvm.compiler.lir.LabelRef.label:()Lorg/graalvm/compiler/asm/Label;
            invokestatic org.graalvm.compiler.lir.sparc.SPARCControlFlow.isShortBranch:(Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;ILorg/graalvm/compiler/asm/Assembler$LabelHint;Lorg/graalvm/compiler/asm/Label;)Z
            ior
            istore 4 /* hasShortJumpTarget */
        11: .line 328
      StackMap locals:
      StackMap stack:
            iload 4 /* hasShortJumpTarget */
            ireturn
        end local 4 // boolean hasShortJumpTarget
        end local 3 // int position
        end local 2 // org.graalvm.compiler.asm.sparc.SPARCAssembler asm
        end local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   12     0                this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
            0   12     1                 crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   12     2                 asm  Lorg/graalvm/compiler/asm/sparc/SPARCAssembler;
            0   12     3            position  I
            7   12     4  hasShortJumpTarget  Z
    MethodParameters:
          Name  Flags
      crb       
      asm       
      position  

  public void resetState();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
         0: .line 333
            aload 0 /* this */
            iconst_0
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.emitted:Z
         1: .line 334
            aload 0 /* this */
            iconst_m1
            putfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.delaySlotPosition:I
         2: .line 335
            return
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;

  public void verify();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
         0: .line 339
            aload 0 /* this */
            invokespecial org.graalvm.compiler.lir.sparc.SPARCBlockEndOp.verify:()V
         1: .line 340
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 2
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.SUPPORTED_KINDS:Ljava/util/EnumSet;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            invokevirtual java.util.EnumSet.contains:(Ljava/lang/Object;)Z
            ifne 2
            new java.lang.AssertionError
            dup
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 341
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 3
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.isConstantValue:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 3
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         3: .line 342
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.$assertionsDisabled:Z
            ifne 5
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokevirtual jdk.vm.ci.meta.AllocatableValue.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifeq 4
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokestatic org.graalvm.compiler.lir.LIRValueUtil.isConstantValue:(Ljdk/vm/ci/meta/Value;)Z
            ifne 5
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokevirtual jdk.vm.ci.meta.Value.getPlatformKind:()Ljdk/vm/ci/meta/PlatformKind;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.kind:Ljdk/vm/ci/sparc/SPARCKind;
            invokevirtual java.lang.Object.equals:(Ljava/lang/Object;)Z
            ifne 5
      StackMap locals:
      StackMap stack:
         4: new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp.y:Ljdk/vm/ci/meta/Value;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         5: .line 343
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/graalvm/compiler/lir/sparc/SPARCControlFlow$CompareBranchOp;
}
SourceFile: "SPARCControlFlow.java"
NestHost: org.graalvm.compiler.lir.sparc.SPARCControlFlow
InnerClasses:
  public final CPUFeature = jdk.vm.ci.sparc.SPARC$CPUFeature of jdk.vm.ci.sparc.SPARC
  public LabelHint = org.graalvm.compiler.asm.Assembler$LabelHint of org.graalvm.compiler.asm.Assembler
  public final CBCond = org.graalvm.compiler.asm.sparc.SPARCAssembler$CBCond of org.graalvm.compiler.asm.sparc.SPARCAssembler
  public final ConditionFlag = org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag of org.graalvm.compiler.asm.sparc.SPARCAssembler
  public final Op3s = org.graalvm.compiler.asm.sparc.SPARCAssembler$Op3s of org.graalvm.compiler.asm.sparc.SPARCAssembler
  public ScratchRegister = org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister of org.graalvm.compiler.asm.sparc.SPARCMacroAssembler
  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 final CompareBranchOp = org.graalvm.compiler.lir.sparc.SPARCControlFlow$CompareBranchOp of org.graalvm.compiler.lir.sparc.SPARCControlFlow
  public SizeEstimate = org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate of org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin