public final class org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp 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$MulHighOp
  super_class: org.graalvm.compiler.lir.sparc.SPARCLIRInstruction
{
  public static final org.graalvm.compiler.lir.LIRInstructionClass<org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp> 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$MulHighOp;>;

  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

  private final org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh opcode;
    descriptor: Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.Opcode()

  public jdk.vm.ci.meta.AllocatableValue result;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0001) ACC_PUBLIC
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Def(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  public jdk.vm.ci.meta.AllocatableValue x;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0001) ACC_PUBLIC
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Alive(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  public jdk.vm.ci.meta.AllocatableValue y;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0001) ACC_PUBLIC
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Alive(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  public jdk.vm.ci.meta.AllocatableValue scratch;
    descriptor: Ljdk/vm/ci/meta/AllocatableValue;
    flags: (0x0001) ACC_PUBLIC
    RuntimeVisibleAnnotations: 
      org.graalvm.compiler.lir.LIRInstruction$Temp(value = {org.graalvm.compiler.lir.LIRInstruction$OperandFlag.REG:Lorg/graalvm/compiler/lir/LIRInstruction$OperandFlag;})

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  private static volatile int[] $SWITCH_TABLE$org$graalvm$compiler$lir$sparc$SPARCArithmetic$MulHighOp$MulHigh;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 301
            ldc Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic;
            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.SPARCArithmetic$MulHighOp.$assertionsDisabled:Z
         3: .line 302
            ldc Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp;
            invokestatic org.graalvm.compiler.lir.LIRInstructionClass.create:(Ljava/lang/Class;)Lorg/graalvm/compiler/lir/LIRInstructionClass;
            putstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
         4: .line 303
            iconst_4
            invokestatic org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate.create:(I)Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            putstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.SIZE:Lorg/graalvm/compiler/lir/sparc/SPARCLIRInstructionMixin$SizeEstimate;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue, jdk.vm.ci.meta.AllocatableValue);
    descriptor: (Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;Ljdk/vm/ci/meta/AllocatableValue;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=6
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp this
        start local 1 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh opcode
        start local 2 // jdk.vm.ci.meta.AllocatableValue x
        start local 3 // jdk.vm.ci.meta.AllocatableValue y
        start local 4 // jdk.vm.ci.meta.AllocatableValue result
        start local 5 // jdk.vm.ci.meta.AllocatableValue scratch
         0: .line 317
            aload 0 /* this */
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.TYPE:Lorg/graalvm/compiler/lir/LIRInstructionClass;
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.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 318
            aload 0 /* this */
            aload 1 /* opcode */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.opcode:Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
         2: .line 319
            aload 0 /* this */
            aload 2 /* x */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
         3: .line 320
            aload 0 /* this */
            aload 3 /* y */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
         4: .line 321
            aload 0 /* this */
            aload 5 /* scratch */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
         5: .line 322
            aload 0 /* this */
            aload 4 /* result */
            putfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
         6: .line 323
            return
        end local 5 // jdk.vm.ci.meta.AllocatableValue scratch
        end local 4 // jdk.vm.ci.meta.AllocatableValue result
        end local 3 // jdk.vm.ci.meta.AllocatableValue y
        end local 2 // jdk.vm.ci.meta.AllocatableValue x
        end local 1 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh opcode
        end local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp;
            0    7     1   opcode  Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
            0    7     2        x  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     3        y  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     4   result  Ljdk/vm/ci/meta/AllocatableValue;
            0    7     5  scratch  Ljdk/vm/ci/meta/AllocatableValue;
    MethodParameters:
         Name  Flags
      opcode   
      x        
      y        
      result   
      scratch  

  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=3, args_size=3
        start local 0 // org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp this
        start local 1 // org.graalvm.compiler.lir.asm.CompilationResultBuilder crb
        start local 2 // org.graalvm.compiler.asm.sparc.SPARCMacroAssembler masm
         0: .line 327
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.$assertionsDisabled:Z
            ifne 2
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.isRegister:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 1
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.isRegister:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 1
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.isRegister:(Ljdk/vm/ci/meta/Value;)Z
            ifeq 1
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.isRegister:(Ljdk/vm/ci/meta/Value;)Z
            ifne 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 328
      StackMap locals:
      StackMap stack:
            invokestatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.$SWITCH_TABLE$org$graalvm$compiler$lir$sparc$SPARCArithmetic$MulHighOp$MulHigh:()[I
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.opcode:Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.ordinal:()I
            iaload
            tableswitch { // 1 - 2
                    1: 3
                    2: 8
              default: 17
          }
         3: .line 330
      StackMap locals:
      StackMap stack:
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            iconst_0
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sra:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
         4: .line 331
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            iconst_0
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            invokestatic jdk.vm.ci.code.ValueUtil.asRegister:(Ljdk/vm/ci/meta/Value;)Ljdk/vm/ci/code/Register;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sra:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
         5: .line 332
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.mulx:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
         6: .line 333
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            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;
            bipush 32
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.srax:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
         7: .line 334
            goto 18
         8: .line 336
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.$assertionsDisabled:Z
            ifne 9
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual jdk.vm.ci.code.Register.equals:(Ljava/lang/Object;)Z
            ifeq 9
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         9: .line 337
      StackMap locals:
      StackMap stack:
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.umulxhi:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        10: .line 339
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            bipush 63
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.srlx:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
        11: .line 340
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.mulx:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        12: .line 341
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sub:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        13: .line 343
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.y:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            bipush 63
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.srlx:(Ljdk/vm/ci/code/Register;ILjdk/vm/ci/code/Register;)V
        14: .line 344
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.x:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.mulx:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        15: .line 345
            aload 2 /* masm */
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.scratch:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            aload 0 /* this */
            getfield org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.result:Ljdk/vm/ci/meta/AllocatableValue;
            getstatic jdk.vm.ci.sparc.SPARCKind.XWORD: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;
            invokevirtual org.graalvm.compiler.asm.sparc.SPARCMacroAssembler.sub:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
        16: .line 346
            goto 18
        17: .line 348
      StackMap locals:
      StackMap stack:
            invokestatic org.graalvm.compiler.debug.GraalError.shouldNotReachHere:()Ljava/lang/RuntimeException;
            athrow
        18: .line 350
      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$MulHighOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   19     0  this  Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp;
            0   19     1   crb  Lorg/graalvm/compiler/lir/asm/CompilationResultBuilder;
            0   19     2  masm  Lorg/graalvm/compiler/asm/sparc/SPARCMacroAssembler;
    MethodParameters:
      Name  Flags
      crb   
      masm  

  static int[] $SWITCH_TABLE$org$graalvm$compiler$lir$sparc$SPARCArithmetic$MulHighOp$MulHigh();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 301
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.$SWITCH_TABLE$org$graalvm$compiler$lir$sparc$SPARCArithmetic$MulHighOp$MulHigh:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.values:()[Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.IMUL:Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.LMUL:Lorg/graalvm/compiler/lir/sparc/SPARCArithmetic$MulHighOp$MulHigh;
            invokevirtual org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            dup
            putstatic org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp.$SWITCH_TABLE$org$graalvm$compiler$lir$sparc$SPARCArithmetic$MulHighOp$MulHigh:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
}
SourceFile: "SPARCArithmetic.java"
NestHost: org.graalvm.compiler.lir.sparc.SPARCArithmetic
InnerClasses:
  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 abstract Temp = org.graalvm.compiler.lir.LIRInstruction$Temp of org.graalvm.compiler.lir.LIRInstruction
  public final MulHighOp = org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp of org.graalvm.compiler.lir.sparc.SPARCArithmetic
  public final MulHigh = org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp$MulHigh of org.graalvm.compiler.lir.sparc.SPARCArithmetic$MulHighOp
  public SizeEstimate = org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin$SizeEstimate of org.graalvm.compiler.lir.sparc.SPARCLIRInstructionMixin