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

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

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

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

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

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

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

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

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

  private final int r;
    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 1586
            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$VexShiftOp.$assertionsDisabled:Z
         3: .line 1588
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSRLW"
            iconst_1
            iconst_1
            iconst_0
            sipush 209
            bipush 113
            iconst_2
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSRLW:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         4: .line 1589
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSRLD"
            iconst_1
            iconst_1
            iconst_0
            sipush 210
            bipush 114
            iconst_2
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSRLD:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         5: .line 1590
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSRLQ"
            iconst_1
            iconst_1
            iconst_0
            sipush 211
            bipush 115
            iconst_2
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSRLQ:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         6: .line 1591
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSRAW"
            iconst_1
            iconst_1
            iconst_0
            sipush 225
            bipush 113
            iconst_4
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSRAW:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         7: .line 1592
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSRAD"
            iconst_1
            iconst_1
            iconst_0
            sipush 226
            bipush 114
            iconst_4
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSRAD:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         8: .line 1593
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSLLW"
            iconst_1
            iconst_1
            iconst_0
            sipush 241
            bipush 113
            bipush 6
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSLLW:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
         9: .line 1594
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSLLD"
            iconst_1
            iconst_1
            iconst_0
            sipush 242
            bipush 114
            bipush 6
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSLLD:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
        10: .line 1595
            new org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp
            dup
            ldc "VPSLLQ"
            iconst_1
            iconst_1
            iconst_0
            sipush 243
            bipush 115
            bipush 6
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.<init>:(Ljava/lang/String;IIIIII)V
            putstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.VPSLLQ:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(java.lang.String, int, int, int, int, int, int);
    descriptor: (Ljava/lang/String;IIIIII)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=8, args_size=8
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp 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 immOp
        start local 7 // int r
         0: .line 1602
            aload 0 /* this */
            aload 1 /* opcode */
            iload 2 /* pp */
            iload 3 /* mmmmm */
            iload 4 /* w */
            iload 5 /* op */
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VEXOpAssertion.AVX1_2:Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;
            invokespecial org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRVMOp.<init>:(Ljava/lang/String;IIIILorg/graalvm/compiler/asm/amd64/AMD64Assembler$VEXOpAssertion;)V
         1: .line 1603
            aload 0 /* this */
            iload 6 /* immOp */
            putfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.immOp:I
         2: .line 1604
            aload 0 /* this */
            iload 7 /* r */
            putfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.r:I
         3: .line 1605
            return
        end local 7 // int r
        end local 6 // int immOp
        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$VexShiftOp this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
            0    4     1  opcode  Ljava/lang/String;
            0    4     2      pp  I
            0    4     3   mmmmm  I
            0    4     4       w  I
            0    4     5      op  I
            0    4     6   immOp  I
            0    4     7       r  I
    MethodParameters:
        Name  Flags
      opcode  
      pp      
      mmmmm   
      w       
      op      
      immOp   
      r       

  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, int);
    descriptor: (Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=6, args_size=6
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp 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
        start local 5 // int imm8
         0: .line 1609
            getstatic org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.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 */
            aconst_null
            aload 3 /* dst */
            aload 4 /* src */
            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 1610
      StackMap locals:
      StackMap stack:
            aload 1 /* asm */
            aconst_null
            aload 3 /* dst */
            aload 4 /* src */
            aload 2 /* size */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.pp:I
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.mmmmm:I
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.w:I
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.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
         2: .line 1611
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.immOp:I
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitByte:(I)V
         3: .line 1612
            aload 1 /* asm */
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp.r:I
            aload 4 /* src */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitModRM:(ILjdk/vm/ci/code/Register;)V
         4: .line 1613
            aload 1 /* asm */
            iload 5 /* imm8 */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64Assembler.emitByte:(I)V
         5: .line 1614
            return
        end local 5 // int imm8
        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$VexShiftOp this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler$VexShiftOp;
            0    6     1   asm  Lorg/graalvm/compiler/asm/amd64/AMD64Assembler;
            0    6     2  size  Lorg/graalvm/compiler/asm/amd64/AVXKind$AVXSize;
            0    6     3   dst  Ljdk/vm/ci/code/Register;
            0    6     4   src  Ljdk/vm/ci/code/Register;
            0    6     5  imm8  I
    MethodParameters:
      Name  Flags
      asm   
      size  
      dst   
      src   
      imm8  
}
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 abstract VexRRIOp = org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRRIOp of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public VexRVMOp = org.graalvm.compiler.asm.amd64.AMD64Assembler$VexRVMOp of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public final VexShiftOp = org.graalvm.compiler.asm.amd64.AMD64Assembler$VexShiftOp of org.graalvm.compiler.asm.amd64.AMD64Assembler
  public final AVXSize = org.graalvm.compiler.asm.amd64.AVXKind$AVXSize of org.graalvm.compiler.asm.amd64.AVXKind