class org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl implements org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$SIMDEncoder
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl
  super_class: java.lang.Object
{
  final org.graalvm.compiler.asm.amd64.AMD64BaseAssembler this$0;
    descriptor: Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  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=1, locals=0, args_size=0
         0: .line 811
            ldc Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;
            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.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(org.graalvm.compiler.asm.amd64.AMD64BaseAssembler);
    descriptor: (Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
         0: .line 811
            aload 0 /* this */
            aload 1
            putfield org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.this$0:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$VEXEncoderImpl;
    MethodParameters:
        Name  Flags
      this$0  final

  private int sizePrefixToPP(int);
    descriptor: (I)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
        start local 1 // int sizePrefix
         0: .line 814
            iload 1 /* sizePrefix */
            lookupswitch { // 3
                  102: 1
                  242: 2
                  243: 3
              default: 4
          }
         1: .line 816
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
         2: .line 818
      StackMap locals:
      StackMap stack:
            iconst_3
            ireturn
         3: .line 820
      StackMap locals:
      StackMap stack:
            iconst_2
            ireturn
         4: .line 822
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // int sizePrefix
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$VEXEncoderImpl;
            0    5     1  sizePrefix  I
    MethodParameters:
            Name  Flags
      sizePrefix  

  private int opcodeEscapePrefixToMMMMM(int);
    descriptor: (I)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
        start local 1 // int opcodeEscapePrefix
         0: .line 827
            iload 1 /* opcodeEscapePrefix */
            lookupswitch { // 3
                   15: 1
                14351: 2
                14863: 3
              default: 4
          }
         1: .line 829
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
         2: .line 831
      StackMap locals:
      StackMap stack:
            iconst_2
            ireturn
         3: .line 833
      StackMap locals:
      StackMap stack:
            iconst_3
            ireturn
         4: .line 835
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // int opcodeEscapePrefix
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    5     0                this  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$VEXEncoderImpl;
            0    5     1  opcodeEscapePrefix  I
    MethodParameters:
                    Name  Flags
      opcodeEscapePrefix  

  public void simdPrefix(jdk.vm.ci.code.Register, jdk.vm.ci.code.Register, org.graalvm.compiler.asm.amd64.AMD64Address, int, int, boolean);
    descriptor: (Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;IIZ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=7
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
        start local 1 // jdk.vm.ci.code.Register reg
        start local 2 // jdk.vm.ci.code.Register nds
        start local 3 // org.graalvm.compiler.asm.amd64.AMD64Address rm
        start local 4 // int sizePrefix
        start local 5 // int opcodeEscapePrefix
        start local 6 // boolean isRexW
         0: .line 841
            getstatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            ifne 1
            aload 1 /* reg */
            getfield jdk.vm.ci.code.Register.encoding:I
            bipush 16
            if_icmplt 1
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "encoding out of range: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* reg */
            getfield jdk.vm.ci.code.Register.encoding:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 842
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            ifne 2
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            bipush 16
            if_icmplt 2
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "encoding out of range: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 843
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.this$0:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;
            iconst_0
            aload 0 /* this */
            iload 4 /* sizePrefix */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.sizePrefixToPP:(I)I
            aload 0 /* this */
            iload 5 /* opcodeEscapePrefix */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.opcodeEscapePrefixToMMMMM:(I)I
            iload 6 /* isRexW */
            ifeq 3
            iconst_1
            goto 4
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int
         3: iconst_0
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int
         4: aload 1 /* reg */
            aload 3 /* rm */
            invokestatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler.getRXB:(Ljdk/vm/ci/code/Register;Lorg/graalvm/compiler/asm/amd64/AMD64Address;)I
            aload 2 /* nds */
            invokevirtual jdk.vm.ci.code.Register.isValid:()Z
            ifeq 5
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            goto 6
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int int
         5: iconst_0
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register org.graalvm.compiler.asm.amd64.AMD64Address int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int int int
         6: iconst_1
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler.emitVEX:(IIIIIIZ)V
         7: .line 844
            return
        end local 6 // boolean isRexW
        end local 5 // int opcodeEscapePrefix
        end local 4 // int sizePrefix
        end local 3 // org.graalvm.compiler.asm.amd64.AMD64Address rm
        end local 2 // jdk.vm.ci.code.Register nds
        end local 1 // jdk.vm.ci.code.Register reg
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    8     0                this  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$VEXEncoderImpl;
            0    8     1                 reg  Ljdk/vm/ci/code/Register;
            0    8     2                 nds  Ljdk/vm/ci/code/Register;
            0    8     3                  rm  Lorg/graalvm/compiler/asm/amd64/AMD64Address;
            0    8     4          sizePrefix  I
            0    8     5  opcodeEscapePrefix  I
            0    8     6              isRexW  Z
    MethodParameters:
                    Name  Flags
      reg                 
      nds                 
      rm                  
      sizePrefix          
      opcodeEscapePrefix  
      isRexW              

  public void simdPrefix(jdk.vm.ci.code.Register, jdk.vm.ci.code.Register, jdk.vm.ci.code.Register, int, int, boolean);
    descriptor: (Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;IIZ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=7
        start local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
        start local 1 // jdk.vm.ci.code.Register dst
        start local 2 // jdk.vm.ci.code.Register nds
        start local 3 // jdk.vm.ci.code.Register src
        start local 4 // int sizePrefix
        start local 5 // int opcodeEscapePrefix
        start local 6 // boolean isRexW
         0: .line 848
            getstatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            ifne 1
            aload 1 /* dst */
            getfield jdk.vm.ci.code.Register.encoding:I
            bipush 16
            if_icmplt 1
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "encoding out of range: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* dst */
            getfield jdk.vm.ci.code.Register.encoding:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 849
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            ifne 2
            aload 3 /* src */
            getfield jdk.vm.ci.code.Register.encoding:I
            bipush 16
            if_icmplt 2
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "encoding out of range: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* src */
            getfield jdk.vm.ci.code.Register.encoding:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 850
      StackMap locals:
      StackMap stack:
            getstatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.$assertionsDisabled:Z
            ifne 3
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            bipush 16
            if_icmplt 3
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "encoding out of range: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         3: .line 851
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.this$0:Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler;
            iconst_0
            aload 0 /* this */
            iload 4 /* sizePrefix */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.sizePrefixToPP:(I)I
            aload 0 /* this */
            iload 5 /* opcodeEscapePrefix */
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl.opcodeEscapePrefixToMMMMM:(I)I
            iload 6 /* isRexW */
            ifeq 4
            iconst_1
            goto 5
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int
         4: iconst_0
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int
         5: aload 1 /* dst */
            aload 3 /* src */
            invokestatic org.graalvm.compiler.asm.amd64.AMD64BaseAssembler.getRXB:(Ljdk/vm/ci/code/Register;Ljdk/vm/ci/code/Register;)I
            aload 2 /* nds */
            invokevirtual jdk.vm.ci.code.Register.isValid:()Z
            ifeq 6
            aload 2 /* nds */
            getfield jdk.vm.ci.code.Register.encoding:I
            goto 7
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int int
         6: iconst_0
      StackMap locals: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl jdk.vm.ci.code.Register jdk.vm.ci.code.Register jdk.vm.ci.code.Register int int int
      StackMap stack: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler int int int int int int
         7: iconst_1
            invokevirtual org.graalvm.compiler.asm.amd64.AMD64BaseAssembler.emitVEX:(IIIIIIZ)V
         8: .line 852
            return
        end local 6 // boolean isRexW
        end local 5 // int opcodeEscapePrefix
        end local 4 // int sizePrefix
        end local 3 // jdk.vm.ci.code.Register src
        end local 2 // jdk.vm.ci.code.Register nds
        end local 1 // jdk.vm.ci.code.Register dst
        end local 0 // org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    9     0                this  Lorg/graalvm/compiler/asm/amd64/AMD64BaseAssembler$VEXEncoderImpl;
            0    9     1                 dst  Ljdk/vm/ci/code/Register;
            0    9     2                 nds  Ljdk/vm/ci/code/Register;
            0    9     3                 src  Ljdk/vm/ci/code/Register;
            0    9     4          sizePrefix  I
            0    9     5  opcodeEscapePrefix  I
            0    9     6              isRexW  Z
    MethodParameters:
                    Name  Flags
      dst                 
      nds                 
      src                 
      sizePrefix          
      opcodeEscapePrefix  
      isRexW              
}
SourceFile: "AMD64BaseAssembler.java"
NestHost: org.graalvm.compiler.asm.amd64.AMD64BaseAssembler
InnerClasses:
  private abstract SIMDEncoder = org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$SIMDEncoder of org.graalvm.compiler.asm.amd64.AMD64BaseAssembler
  private VEXEncoderImpl = org.graalvm.compiler.asm.amd64.AMD64BaseAssembler$VEXEncoderImpl of org.graalvm.compiler.asm.amd64.AMD64BaseAssembler