public final class org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp extends org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRMOp
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp
  super_class: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRMOp
{
  public static final org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp BLSI;
    descriptor: Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp BLSMSK;
    descriptor: Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  public static final org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp BLSR;
    descriptor: Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private final int ext;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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=9, locals=0, args_size=0
         0: .line 1553
            ldc Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;
            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.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.$assertionsDisabled:Z
         3: .line 1555
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp
            dup
            ldc "BLSI"
            iconst_0
            iconst_2
            iconst_0
            sipush 243
            iconst_3
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.BMI1:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.<init>:(Ljava/lang/String;IIIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.BLSI:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
         4: .line 1556
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp
            dup
            ldc "BLSMSK"
            iconst_0
            iconst_2
            iconst_0
            sipush 243
            iconst_2
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.BMI1:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.<init>:(Ljava/lang/String;IIIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.BLSMSK:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
         5: .line 1557
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp
            dup
            ldc "BLSR"
            iconst_0
            iconst_2
            iconst_0
            sipush 243
            iconst_1
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.BMI1:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.<init>:(Ljava/lang/String;IIIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.BLSR:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(java.lang.String, int, int, int, int, int, org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion);
    descriptor: (Ljava/lang/String;IIIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=8, args_size=8
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
        start local 1 // java.lang.String opcode
        start local 2 // int pp
        start local 3 // int mmmmm
        start local 4 // int w
        start local 5 // int op
        start local 6 // int ext
        start local 7 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion assertion
         0: .line 1562
            aload 0 /* this */
            aload 1 /* opcode */
            iload 2 /* pp */
            iload 3 /* mmmmm */
            iload 4 /* w */
            iload 5 /* op */
            aload 7 /* assertion */
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRMOp.<init>:(Ljava/lang/String;IIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
         1: .line 1563
            aload 0 /* this */
            iload 6 /* ext */
            putfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.ext:I
         2: .line 1564
            return
        end local 7 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion assertion
        end local 6 // int ext
        end local 5 // int op
        end local 4 // int w
        end local 3 // int mmmmm
        end local 2 // int pp
        end local 1 // java.lang.String opcode
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
            0    3     1     opcode  Ljava/lang/String;
            0    3     2         pp  I
            0    3     3      mmmmm  I
            0    3     4          w  I
            0    3     5         op  I
            0    3     6        ext  I
            0    3     7  assertion  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
    MethodParameters:
           Name  Flags
      opcode     
      pp         
      mmmmm      
      w          
      op         
      ext        
      assertion  

  public void emit(org.graalvm.compiler.asm.amd64.AMD64Assembler, org.graalvm.compiler.asm.amd64.AVXKind$AVXSize, jdk.vm.ci.code.Register, jdk.vm.ci.code.Register);
    descriptor: (Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
        start local 1 // org.graalvm.compiler.asm.amd64.AMD64Assembler asm
        start local 2 // org.graalvm.compiler.asm.amd64.AVXKind$AVXSize size
        start local 3 // jdk.vm.ci.code.Register dst
        start local 4 // jdk.vm.ci.code.Register src
         0: .line 1568
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.assertion:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            aload 1 /* asm */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler.target:Ljdk/vm/ci/code/TargetDescription;
            getfield jdk.vm.ci.code.TargetDescription.arch:Ljdk/vm/ci/code/Architecture;
            checkcast jdk.vm.ci.amd64.AMD64
            aload 2 /* size */
            aload 3 /* dst */
            aconst_null
            aconst_null
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.check:(Ljdk/vm/ci/amd64/AMD64;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1569
      StackMap locals:
      StackMap stack:
            aload 1 /* asm */
            getstatic jdk.vm.ci.amd64.AMD64.cpuRegisters:[Ljdk/vm/ci/code/Register;
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.ext:I
            aaload
            aload 3 /* dst */
            aload 4 /* src */
            aload 2 /* size */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.pp:I
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.mmmmm:I
            aload 2 /* size */
            getstatic org.graalvm.compiler.asm.amd64.AVXKind$AVXSize.DWORD:Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;
            if_acmpne 2
            iconst_0
            goto 3
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp org.graalvm.compiler.asm.amd64.AMD64Assembler org.graalvm.compiler.asm.amd64.AVXKind$AVXSize jdk.vm.ci.code.Register jdk.vm.ci.code.Register
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64Assembler jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AVXKind$AVXSize int int
         2: iconst_1
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp org.graalvm.compiler.asm.amd64.AMD64Assembler org.graalvm.compiler.asm.amd64.AVXKind$AVXSize jdk.vm.ci.code.Register jdk.vm.ci.code.Register
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64Assembler jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AVXKind$AVXSize int int int
         3: aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.wEvex:I
            iconst_0
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.vexPrefix:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;IIIIZ)Z
            pop
         4: .line 1570
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.op:I
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitByte:(I)V
         5: .line 1571
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.ext:I
            aload 4 /* src */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitModRM:(ILjdk/vm/ci/code/Register;)V
         6: .line 1572
            return
        end local 4 // jdk.vm.ci.code.Register src
        end local 3 // jdk.vm.ci.code.Register dst
        end local 2 // org.graalvm.compiler.asm.amd64.AVXKind$AVXSize size
        end local 1 // org.graalvm.compiler.asm.amd64.AMD64Assembler asm
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
            0    7     1   asm  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;
            0    7     2  size  Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;
            0    7     3   dst  Ljdk/vm/ci/code/Register;
            0    7     4   src  Ljdk/vm/ci/code/Register;
    MethodParameters:
      Name  Flags
      asm   
      size  
      dst   
      src   

  public void emit(org.graalvm.compiler.asm.amd64.AMD64Assembler, org.graalvm.compiler.asm.amd64.AVXKind$AVXSize, jdk.vm.ci.code.Register, org.graalvm.compiler.asm.amd64.AMD64Address);
    descriptor: (Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=5, args_size=5
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
        start local 1 // org.graalvm.compiler.asm.amd64.AMD64Assembler asm
        start local 2 // org.graalvm.compiler.asm.amd64.AVXKind$AVXSize size
        start local 3 // jdk.vm.ci.code.Register dst
        start local 4 // org.graalvm.compiler.asm.amd64.AMD64Address src
         0: .line 1576
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.assertion:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            aload 1 /* asm */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler.target:Ljdk/vm/ci/code/TargetDescription;
            getfield jdk.vm.ci.code.TargetDescription.arch:Ljdk/vm/ci/code/Architecture;
            checkcast jdk.vm.ci.amd64.AMD64
            aload 2 /* size */
            aload 3 /* dst */
            aconst_null
            aconst_null
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.check:(Ljdk/vm/ci/amd64/AMD64;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1577
      StackMap locals:
      StackMap stack:
            aload 1 /* asm */
            getstatic jdk.vm.ci.amd64.AMD64.cpuRegisters:[Ljdk/vm/ci/code/Register;
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.ext:I
            aaload
            aload 3 /* dst */
            aload 4 /* src */
            aload 2 /* size */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.pp:I
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.mmmmm:I
            aload 2 /* size */
            getstatic org.graalvm.compiler.asm.amd64.AVXKind$AVXSize.DWORD:Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;
            if_acmpne 2
            iconst_0
            goto 3
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp org.graalvm.compiler.asm.amd64.AMD64Assembler org.graalvm.compiler.asm.amd64.AVXKind$AVXSize jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64Assembler jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address org.graalvm.compiler.asm.amd64.AVXKind$AVXSize int int
         2: iconst_1
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp org.graalvm.compiler.asm.amd64.AMD64Assembler org.graalvm.compiler.asm.amd64.AVXKind$AVXSize jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64Assembler jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address org.graalvm.compiler.asm.amd64.AVXKind$AVXSize int int int
         3: aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.wEvex:I
            iconst_0
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.vexPrefix:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;IIIIZ)Z
            pop
         4: .line 1578
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.op:I
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitByte:(I)V
         5: .line 1579
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp.ext:I
            aload 4 /* src */
            iconst_0
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitOperandHelper:(ILorg/graalvm/compiler/asm/amd64/AMD64Address;I)V
         6: .line 1580
            return
        end local 4 // org.graalvm.compiler.asm.amd64.AMD64Address src
        end local 3 // jdk.vm.ci.code.Register dst
        end local 2 // org.graalvm.compiler.asm.amd64.AVXKind$AVXSize size
        end local 1 // org.graalvm.compiler.asm.amd64.AMD64Assembler asm
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexGeneralPurposeRMOp;
            0    7     1   asm  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;
            0    7     2  size  Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;
            0    7     3   dst  Ljdk/vm/ci/code/Register;
            0    7     4   src  Lorg/graalvm/compiler/asm/amd64/AMD64Address;
    MethodParameters:
      Name  Flags
      asm   
      size  
      dst   
      src   
}
SourceFile: "AMD64Assembler.java"
NestHost: org.graalvm.compiler.asm.amd64.AMD64Assembler
InnerClasses:
  private final VEXOpAssertion = org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public final VexGeneralPurposeRMOp = org.graalvm.compiler.asm.amd64.AMD64Assembler$VexGeneralPurposeRMOp of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public VexRMOp = org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRMOp of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public final AVXSize = org.graalvm.compiler.asm.amd64.AVXKind$AVXSize of org.graalvm.compiler.asm.amd64.AVXKind