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

  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

  protected jdk.vm.ci.meta.Value result;
    descriptor: Ljdk/vm/ci/meta/Value;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Def(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  protected jdk.vm.ci.meta.Value x;
    descriptor: Ljdk/vm/ci/meta/Value;
    flags: (0x0004) ACC_PROTECTED
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Alive(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$Alive(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 222
            ldc Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$SPARCIMulccOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
         1: .line 223
            bipush 10
            invokestatic org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate.create:(I)Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            putstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.SIZE:Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(jdk.vm.ci.meta.Value, jdk.vm.ci.meta.Value, jdk.vm.ci.meta.Value);
    descriptor: (Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/Value;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp this
        start local 1 // jdk.vm.ci.meta.Value result
        start local 2 // jdk.vm.ci.meta.Value x
        start local 3 // jdk.vm.ci.meta.Value y
         0: .line 229
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.SIZE:Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            invokespecial org.graalvm.compiler.lir.sparc.SPARCLIRInstruction.<init>:(Lorg/graalvm/compiler/lir/LIRInstructionClass;Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;)V
         1: .line 230
            aload 0 /* this */
            aload 1 /* result */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.result:Ljdk/vm/ci/meta/Value;
         2: .line 231
            aload 0 /* this */
            aload 2 /* x */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.x:Ljdk/vm/ci/meta/Value;
         3: .line 232
            aload 0 /* this */
            aload 3 /* y */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.y:Ljdk/vm/ci/meta/Value;
         4: .line 233
            return
        end local 3 // jdk.vm.ci.meta.Value y
        end local 2 // jdk.vm.ci.meta.Value x
        end local 1 // jdk.vm.ci.meta.Value result
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$SPARCIMulccOp;
            0    5     1  result  Ljdk/vm/ci/meta/Value;
            0    5     2       x  Ljdk/vm/ci/meta/Value;
            0    5     3       y  Ljdk/vm/ci/meta/Value;
    MethodParameters:
        Name  Flags
      result  
      x       
      y       

  protected 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: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=11, args_size=3
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 237
            aconst_null
            astore 3
            aconst_null
            astore 4
         1: aload 2 /* masm */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.getScratchRegister:()Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler$ScratchRegister;
            astore 5 /* tmpScratch */
        start local 5 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister tmpScratch
         2: .line 238
            aload 5 /* tmpScratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.getRegister:()Ljdk/vm/ci/code/Register;
            astore 6 /* tmp */
        start local 6 // jdk.vm.ci.code.Register tmp
         3: .line 239
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.result:Ljdk/vm/ci/meta/Value;
            getstatic jdk.vm.ci.sparc.SPARCKind.WORD:Ljdk/vm/ci/sparc/SPARCKind;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/PlatformKind;)Ljdk/vm/ci/code/Register;
            astore 7 /* resultRegister */
        start local 7 // jdk.vm.ci.code.Register resultRegister
         4: .line 240
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.x:Ljdk/vm/ci/meta/Value;
            getstatic jdk.vm.ci.sparc.SPARCKind.WORD:Ljdk/vm/ci/sparc/SPARCKind;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/PlatformKind;)Ljdk/vm/ci/code/Register;
            astore 8 /* xRegister */
        start local 8 // jdk.vm.ci.code.Register xRegister
         5: .line 241
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp.y:Ljdk/vm/ci/meta/Value;
            getstatic jdk.vm.ci.sparc.SPARCKind.WORD:Ljdk/vm/ci/sparc/SPARCKind;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;Ljdk/vm/ci/meta/PlatformKind;)Ljdk/vm/ci/code/Register;
            astore 9 /* yRegister */
        start local 9 // jdk.vm.ci.code.Register yRegister
         6: .line 242
            aload 2 /* masm */
            aload 8 /* xRegister */
            iconst_0
            aload 8 /* xRegister */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sra:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
         7: .line 243
            aload 2 /* masm */
            aload 9 /* yRegister */
            iconst_0
            aload 9 /* yRegister */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sra:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
         8: .line 244
            aload 2 /* masm */
            aload 8 /* xRegister */
            aload 9 /* yRegister */
            aload 7 /* resultRegister */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.mulx:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
         9: .line 245
            new org.graalvm.compiler.asm.Label
            dup
            invokespecial org.graalvm.compiler.asm.Label.<init>:()V
            astore 10 /* noOverflow */
        start local 10 // org.graalvm.compiler.asm.Label noOverflow
        10: .line 246
            aload 2 /* masm */
            aload 7 /* resultRegister */
            iconst_0
            aload 6 /* tmp */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sra:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
        11: .line 247
            aload 2 /* masm */
            aload 6 /* tmp */
            aload 7 /* resultRegister */
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler$ConditionFlag.Equal:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler$CC.Xcc:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$CC;
            aload 10 /* noOverflow */
            getstatic org.graalvm.compiler.asm.sparc.SPARCAssembler$BranchPredict.PREDICT_TAKEN:Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$BranchPredict;
            aconst_null
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.compareBranch:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$ConditionFlag;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$CC;Lorg/graalvm/compiler/asm/Label;Lorg/graalvm/compiler/asm/sparc/SPARCAssembler$BranchPredict;Ljava/lang/Runnable;)V
        12: .line 248
            aload 2 /* masm */
            getstatic jdk.vm.ci.sparc.SPARC.g0:Ljdk/vm/ci/code/Register;
            iconst_2
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.wrccr:(Ljdk/vm/ci/code/Register;I)V
        13: .line 249
            aload 2 /* masm */
            aload 10 /* noOverflow */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.bind:(Lorg/graalvm/compiler/asm/Label;)V
        end local 10 // org.graalvm.compiler.asm.Label noOverflow
        end local 9 // jdk.vm.ci.code.Register yRegister
        end local 8 // jdk.vm.ci.code.Register xRegister
        end local 7 // jdk.vm.ci.code.Register resultRegister
        end local 6 // jdk.vm.ci.code.Register tmp
        14: .line 250
            aload 5 /* tmpScratch */
            ifnull 20
            aload 5 /* tmpScratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.close:()V
            goto 20
      StackMap locals: org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp org.graalvm.compiler.lir.asm.CompilationResultBuilder org.graalvm.compiler.asm.sparc.SPARCMacroAssembler java.lang.Throwable java.lang.Throwable org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister
      StackMap stack: java.lang.Throwable
        15: astore 3
            aload 5 /* tmpScratch */
            ifnull 16
            aload 5 /* tmpScratch */
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister.close:()V
        end local 5 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister tmpScratch
      StackMap locals:
      StackMap stack:
        16: aload 3
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        17: astore 4
            aload 3
            ifnonnull 18
            aload 4
            astore 3
            goto 19
      StackMap locals:
      StackMap stack:
        18: aload 3
            aload 4
            if_acmpeq 19
            aload 3
            aload 4
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        19: aload 3
            athrow
        20: .line 251
      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.SPARCArithmetic$SPARCIMulccOp this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   21     0            this  Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$SPARCIMulccOp;
            0   21     1             crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   21     2            masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
            2   16     5      tmpScratch  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler$ScratchRegister;
            3   14     6             tmp  Ljdk/vm/ci/code/Register;
            4   14     7  resultRegister  Ljdk/vm/ci/code/Register;
            5   14     8       xRegister  Ljdk/vm/ci/code/Register;
            6   14     9       yRegister  Ljdk/vm/ci/code/Register;
           10   14    10      noOverflow  Lorg/graalvm/compiler/asm/Label;
      Exception table:
        from    to  target  type
           2    14      15  any
           1    17      17  any
    MethodParameters:
      Name  Flags
      crb   
      masm  
}
SourceFile: "SPARCArithmetic.java"
NestHost: org.graalvm.compiler.lir.sparc.SPARCArithmetic
InnerClasses:
  public final BranchPredict = org.graalvm.compiler.asm.sparc.SPARCAssembler$BranchPredict of org.graalvm.compiler.asm.sparc.SPARCAssembler
  public final CC = org.graalvm.compiler.asm.sparc.SPARCAssembler$CC 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 ScratchRegister = org.graalvm.compiler.asm.sparc.SPARCMacroAssembler$ScratchRegister of org.graalvm.compiler.asm.sparc.SPARCMacroAssembler
  public abstract Alive = org.graalvm.compiler.lir.LIRInstruction$Alive of org.graalvm.compiler.lir.LIRInstruction
  public abstract Def = org.graalvm.compiler.lir.LIRInstruction$Def of org.graalvm.compiler.lir.LIRInstruction
  public final OperandFlag = org.graalvm.compiler.lir.LIRInstruction$OperandFlag of org.graalvm.compiler.lir.LIRInstruction
  public final SPARCIMulccOp = org.graalvm.compiler.lir.sparc.SPARCArithmetic$SPARCIMulccOp of org.graalvm.compiler.lir.sparc.SPARCArithmetic
  public SizeEstimate = org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate of org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin