abstract class com.sun.crypto.provider.GaloisCounterMode extends javax.crypto.CipherSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: com.sun.crypto.provider.GaloisCounterMode
  super_class: javax.crypto.CipherSpi
{
  static int DEFAULT_IV_LEN;
    descriptor: I
    flags: (0x0008) ACC_STATIC

  static int DEFAULT_TAG_LEN;
    descriptor: I
    flags: (0x0008) ACC_STATIC

  private static final int MAX_BUF_SIZE;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 2147483647

  private static final int TRIGGERLEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 65536

  private static final int PARALLEL_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 8192

  private static final int SPLIT_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1048576

  static final byte[] EMPTY_BUF;
    descriptor: [B
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private boolean initialized;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  com.sun.crypto.provider.SymmetricCipher blockCipher;
    descriptor: Lcom/sun/crypto/provider/SymmetricCipher;
    flags: (0x0000) 

  private com.sun.crypto.provider.GaloisCounterMode$GCMEngine engine;
    descriptor: Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
    flags: (0x0002) ACC_PRIVATE

  private boolean encryption;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  int tagLenBytes;
    descriptor: I
    flags: (0x0000) 

  int keySize;
    descriptor: I
    flags: (0x0000) 

  boolean reInit;
    descriptor: Z
    flags: (0x0000) 

  byte[] lastKey;
    descriptor: [B
    flags: (0x0000) 

  byte[] lastIv;
    descriptor: [B
    flags: (0x0000) 

  byte[] iv;
    descriptor: [B
    flags: (0x0000) 

  java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0000) 

  private static final java.lang.invoke.VarHandle wrapToByteArray;
    descriptor: Ljava/lang/invoke/VarHandle;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 75
            bipush 12
            putstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_IV_LEN:I
         1: .line 76
            bipush 16
            putstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
         2: .line 93
            iconst_0
            newarray 8
            putstatic com.sun.crypto.provider.GaloisCounterMode.EMPTY_BUF:[B
         3: .line 522
            ldc [J
         4: .line 523
            getstatic java.nio.ByteOrder.BIG_ENDIAN:Ljava/nio/ByteOrder;
         5: .line 522
            invokestatic java.lang.invoke.MethodHandles.byteArrayViewVarHandle:(Ljava/lang/Class;Ljava/nio/ByteOrder;)Ljava/lang/invoke/VarHandle;
         6: .line 521
            putstatic com.sun.crypto.provider.GaloisCounterMode.wrapToByteArray:Ljava/lang/invoke/VarHandle;
         7: .line 523
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(int, com.sun.crypto.provider.SymmetricCipher);
    descriptor: (ILcom/sun/crypto/provider/SymmetricCipher;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int keySize
        start local 2 // com.sun.crypto.provider.SymmetricCipher embeddedCipher
         0: .line 118
            aload 0 /* this */
            invokespecial javax.crypto.CipherSpi.<init>:()V
         1: .line 95
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.initialized:Z
         2: .line 100
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
         3: .line 103
            aload 0 /* this */
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
            putfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
         4: .line 107
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.reInit:Z
         5: .line 108
            aload 0 /* this */
            getstatic com.sun.crypto.provider.GaloisCounterMode.EMPTY_BUF:[B
            putfield com.sun.crypto.provider.GaloisCounterMode.lastKey:[B
         6: .line 109
            aload 0 /* this */
            getstatic com.sun.crypto.provider.GaloisCounterMode.EMPTY_BUF:[B
            putfield com.sun.crypto.provider.GaloisCounterMode.lastIv:[B
         7: .line 110
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
         8: .line 111
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.random:Ljava/security/SecureRandom;
         9: .line 119
            aload 0 /* this */
            aload 2 /* embeddedCipher */
            putfield com.sun.crypto.provider.GaloisCounterMode.blockCipher:Lcom/sun/crypto/provider/SymmetricCipher;
        10: .line 120
            aload 0 /* this */
            iload 1 /* keySize */
            putfield com.sun.crypto.provider.GaloisCounterMode.keySize:I
        11: .line 121
            return
        end local 2 // com.sun.crypto.provider.SymmetricCipher embeddedCipher
        end local 1 // int keySize
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0            this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   12     1         keySize  I
            0   12     2  embeddedCipher  Lcom/sun/crypto/provider/SymmetricCipher;
    MethodParameters:
                Name  Flags
      keySize         
      embeddedCipher  

  void init(int, java.security.Key, javax.crypto.spec.GCMParameterSpec);
    descriptor: (ILjava/security/Key;Ljavax/crypto/spec/GCMParameterSpec;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // javax.crypto.spec.GCMParameterSpec spec
         0: .line 129
            aload 0 /* this */
            iload 1 /* opmode */
            iconst_1
            if_icmpeq 2
         1: .line 130
            iload 1 /* opmode */
            iconst_3
            if_icmpeq 2
            iconst_0
            goto 3
      StackMap locals:
      StackMap stack: com.sun.crypto.provider.GaloisCounterMode
         2: iconst_1
         3: .line 129
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode int java.security.Key javax.crypto.spec.GCMParameterSpec
      StackMap stack: com.sun.crypto.provider.GaloisCounterMode int
            putfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
         4: .line 132
            aload 3 /* spec */
            invokevirtual javax.crypto.spec.GCMParameterSpec.getTLen:()I
            istore 4 /* tagLen */
        start local 4 // int tagLen
         5: .line 133
            iload 4 /* tagLen */
            bipush 96
            if_icmplt 6
            iload 4 /* tagLen */
            sipush 128
            if_icmpgt 6
            iload 4 /* tagLen */
            bipush 7
            iand
            ifeq 9
         6: .line 134
      StackMap locals: int
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
         7: .line 135
            ldc "Unsupported TLen value.  Must be one of {128, 120, 112, 104, 96}"
         8: .line 134
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 138
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 4 /* tagLen */
            iconst_3
            ishr
            putfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
        10: .line 141
            aload 2 /* key */
            ifnonnull 12
        11: .line 142
            new java.security.InvalidKeyException
            dup
            ldc "The key must not be null"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 144
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 5 /* keyValue */
        start local 5 // byte[] keyValue
        13: .line 145
            aload 5 /* keyValue */
            ifnonnull 15
        14: .line 146
            new java.security.InvalidKeyException
            dup
            ldc "Key encoding must not be null"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 147
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.keySize:I
            iconst_m1
            if_icmpeq 20
            aload 5 /* keyValue */
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.keySize:I
            if_icmpeq 20
        16: .line 148
            aload 5 /* keyValue */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        17: .line 149
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "The key must be "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 150
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.keySize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 149
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 154
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
            ifeq 31
        21: .line 155
            aload 5 /* keyValue */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.lastKey:[B
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifeq 27
        22: .line 156
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.lastIv:[B
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifeq 27
        23: .line 157
            aload 5 /* keyValue */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        24: .line 158
            new java.security.InvalidAlgorithmParameterException
            dup
        25: .line 159
            ldc "Cannot reuse iv for GCM encryption"
        26: .line 158
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 163
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.lastKey:[B
            ifnull 29
        28: .line 164
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.lastKey:[B
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        29: .line 166
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* keyValue */
            putfield com.sun.crypto.provider.GaloisCounterMode.lastKey:[B
        30: .line 167
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            putfield com.sun.crypto.provider.GaloisCounterMode.lastIv:[B
        31: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.reInit:Z
        32: .line 174
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            iconst_0
            aload 2 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            aload 5 /* keyValue */
            invokevirtual com.sun.crypto.provider.SymmetricCipher.init:(ZLjava/lang/String;[B)V
        33: .line 175
            goto 38
      StackMap locals:
      StackMap stack: java.lang.Throwable
        34: astore 6
        35: .line 176
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
            ifne 37
        36: .line 177
            aload 5 /* keyValue */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        37: .line 179
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 6
            athrow
        38: .line 176
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
            ifne 40
        39: .line 177
            aload 5 /* keyValue */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        40: .line 180
      StackMap locals:
      StackMap stack:
            return
        end local 5 // byte[] keyValue
        end local 4 // int tagLen
        end local 3 // javax.crypto.spec.GCMParameterSpec spec
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   41     0      this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   41     1    opmode  I
            0   41     2       key  Ljava/security/Key;
            0   41     3      spec  Ljavax/crypto/spec/GCMParameterSpec;
            5   41     4    tagLen  I
           13   41     5  keyValue  [B
      Exception table:
        from    to  target  type
          32    34      34  any
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      spec    

  protected void engineSetMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.lang.String mode
         0: .line 184
            aload 1 /* mode */
            ldc "GCM"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 2
         1: .line 185
            new java.security.NoSuchAlgorithmException
            dup
            ldc "Mode must be GCM"
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 187
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String mode
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    3     1  mode  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  protected void engineSetPadding(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.lang.String padding
         0: .line 192
            aload 1 /* padding */
            ldc "NoPadding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 2
         1: .line 193
            new javax.crypto.NoSuchPaddingException
            dup
            ldc "Padding must be NoPadding"
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 195
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String padding
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    3     1  padding  Ljava/lang/String;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
         Name  Flags
      padding  

  protected int engineGetBlockSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 199
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            invokevirtual com.sun.crypto.provider.SymmetricCipher.getBlockSize:()I
            ireturn
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  protected int engineGetOutputSize(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int inputLen
         0: .line 204
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 205
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            iload 1 /* inputLen */
            iconst_1
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.getOutputSize:(IZ)I
            ireturn
        end local 1 // int inputLen
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    2     1  inputLen  I
    MethodParameters:
          Name  Flags
      inputLen  

  protected int engineGetKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.security.Key key
         0: .line 210
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         1: .line 211
            aload 2 /* encoded */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
         2: .line 212
            aload 2 /* encoded */
            arraylength
            invokestatic com.sun.crypto.provider.AESCrypt.isKeySizeValid:(I)Z
            ifne 6
         3: .line 213
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid key length: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         4: .line 214
            aload 2 /* encoded */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 213
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 216
      StackMap locals: byte[]
      StackMap stack:
            aload 2 /* encoded */
            arraylength
            bipush 8
            invokestatic java.lang.Math.multiplyExact:(II)I
            ireturn
        end local 2 // byte[] encoded
        end local 1 // java.security.Key key
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    7     1      key  Ljava/security/Key;
            1    7     2  encoded  [B
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  protected byte[] engineGetIV();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 221
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            ifnonnull 2
         1: .line 222
            aconst_null
            areturn
         2: .line 224
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            areturn
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  private static byte[] createIv(java.security.SecureRandom);
    descriptor: (Ljava/security/SecureRandom;)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.security.SecureRandom rand
         0: .line 236
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_IV_LEN:I
            newarray 8
            astore 1 /* iv */
        start local 1 // byte[] iv
         1: .line 237
            aload 0 /* rand */
            ifnonnull 3
         2: .line 238
            invokestatic sun.security.jca.JCAUtil.getDefSecureRandom:()Ljava/security/SecureRandom;
            astore 0 /* rand */
         3: .line 240
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* rand */
            aload 1 /* iv */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         4: .line 241
            aload 1 /* iv */
            areturn
        end local 1 // byte[] iv
        end local 0 // java.security.SecureRandom rand
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  rand  Ljava/security/SecureRandom;
            1    5     1    iv  [B
    MethodParameters:
      Name  Flags
      rand  

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 247
            new javax.crypto.spec.GCMParameterSpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            bipush 8
            imul
         1: .line 248
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            ifnonnull 2
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.random:Ljava/security/SecureRandom;
            invokestatic com.sun.crypto.provider.GaloisCounterMode.createIv:(Ljava/security/SecureRandom;)[B
            goto 3
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode
      StackMap stack: new 0 new 0 int
         2: aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
         3: .line 247
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode
      StackMap stack: new 0 new 0 int byte[]
            invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
            astore 1 /* spec */
        start local 1 // javax.crypto.spec.GCMParameterSpec spec
         4: .line 251
            ldc "GCM"
         5: .line 252
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
         6: .line 251
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
         7: .line 250
            astore 2 /* params */
        start local 2 // java.security.AlgorithmParameters params
         8: .line 253
            aload 2 /* params */
            aload 1 /* spec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         9: .line 254
            aload 2 /* params */
        10: areturn
        end local 2 // java.security.AlgorithmParameters params
        11: .line 255
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode javax.crypto.spec.GCMParameterSpec
      StackMap stack: java.security.GeneralSecurityException
            astore 2 /* e */
        start local 2 // java.security.GeneralSecurityException e
        12: .line 256
            new java.lang.RuntimeException
            dup
            aload 2 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.GeneralSecurityException e
        end local 1 // javax.crypto.spec.GCMParameterSpec spec
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   13     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            4   13     1    spec  Ljavax/crypto/spec/GCMParameterSpec;
            8   11     2  params  Ljava/security/AlgorithmParameters;
           12   13     2       e  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
           4    10      11  Class java.security.NoSuchAlgorithmException
           4    10      11  Class java.security.spec.InvalidParameterSpecException

  protected void engineInit(int, java.security.Key, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 264
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         1: .line 265
            iload 1 /* opmode */
            iconst_2
            if_icmpeq 2
            iload 1 /* opmode */
            iconst_4
            if_icmpne 3
         2: .line 266
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "No GCMParameterSpec specified"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 269
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aconst_null
            aload 3 /* random */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         4: .line 270
            goto 6
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
         5: pop
         6: .line 273
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.security.SecureRandom random
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    7     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    7     1  opmode  I
            0    7     2     key  Ljava/security/Key;
            0    7     3  random  Ljava/security/SecureRandom;
      Exception table:
        from    to  target  type
           3     4       5  Class java.security.InvalidAlgorithmParameterException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      random  

  protected void engineInit(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=5
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.spec.AlgorithmParameterSpec params
        start local 4 // java.security.SecureRandom random
         0: .line 281
            aload 0 /* this */
            aload 4 /* random */
            putfield com.sun.crypto.provider.GaloisCounterMode.random:Ljava/security/SecureRandom;
         1: .line 282
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         2: .line 283
            aload 3 /* params */
            ifnonnull 6
         3: .line 284
            aload 0 /* this */
            aload 4 /* random */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.createIv:(Ljava/security/SecureRandom;)[B
            putfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
         4: .line 285
            new javax.crypto.spec.GCMParameterSpec
            dup
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
            bipush 8
            imul
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
            astore 5 /* spec */
        start local 5 // javax.crypto.spec.GCMParameterSpec spec
         5: .line 286
            goto 16
        end local 5 // javax.crypto.spec.GCMParameterSpec spec
         6: .line 287
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.GCMParameterSpec
            ifne 10
         7: .line 288
            new java.security.InvalidAlgorithmParameterException
            dup
         8: .line 289
            ldc "AlgorithmParameterSpec not of GCMParameterSpec"
         9: .line 288
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 291
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            checkcast javax.crypto.spec.GCMParameterSpec
            astore 5 /* spec */
        start local 5 // javax.crypto.spec.GCMParameterSpec spec
        11: .line 292
            aload 0 /* this */
            aload 5 /* spec */
            invokevirtual javax.crypto.spec.GCMParameterSpec.getIV:()[B
            putfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
        12: .line 293
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            ifnonnull 14
        13: .line 294
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "IV is null"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 296
      StackMap locals: javax.crypto.spec.GCMParameterSpec
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            arraylength
            ifne 16
        15: .line 297
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "IV is empty"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        16: .line 300
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aload 5 /* spec */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.init:(ILjava/security/Key;Ljavax/crypto/spec/GCMParameterSpec;)V
        17: .line 301
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.GaloisCounterMode.initialized:Z
        18: .line 302
            return
        end local 5 // javax.crypto.spec.GCMParameterSpec spec
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.spec.AlgorithmParameterSpec params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   19     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   19     1  opmode  I
            0   19     2     key  Ljava/security/Key;
            0   19     3  params  Ljava/security/spec/AlgorithmParameterSpec;
            0   19     4  random  Ljava/security/SecureRandom;
            5    6     5    spec  Ljavax/crypto/spec/GCMParameterSpec;
           11   19     5    spec  Ljavax/crypto/spec/GCMParameterSpec;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  protected void engineInit(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.AlgorithmParameters params
        start local 4 // java.security.SecureRandom random
         0: .line 308
            aconst_null
            astore 5 /* spec */
        start local 5 // javax.crypto.spec.GCMParameterSpec spec
         1: .line 309
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         2: .line 310
            aload 3 /* params */
            ifnull 7
         3: .line 312
            aload 3 /* params */
            ldc Ljavax/crypto/spec/GCMParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.GCMParameterSpec
            astore 5 /* spec */
         4: .line 313
            goto 7
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode int java.security.Key java.security.AlgorithmParameters java.security.SecureRandom javax.crypto.spec.GCMParameterSpec
      StackMap stack: java.security.spec.InvalidParameterSpecException
         5: astore 6 /* e */
        start local 6 // java.security.spec.InvalidParameterSpecException e
         6: .line 314
            new java.security.InvalidAlgorithmParameterException
            dup
            aload 6 /* e */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.security.spec.InvalidParameterSpecException e
         7: .line 317
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aload 5 /* spec */
            aload 4 /* random */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         8: .line 318
            return
        end local 5 // javax.crypto.spec.GCMParameterSpec spec
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.AlgorithmParameters params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    9     1  opmode  I
            0    9     2     key  Ljava/security/Key;
            0    9     3  params  Ljava/security/AlgorithmParameters;
            0    9     4  random  Ljava/security/SecureRandom;
            1    9     5    spec  Ljavax/crypto/spec/GCMParameterSpec;
            6    7     6       e  Ljava/security/spec/InvalidParameterSpecException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.security.spec.InvalidParameterSpecException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  void checkInit();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 321
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.initialized:Z
            ifne 2
         1: .line 322
            new java.lang.IllegalStateException
            dup
            ldc "Operation not initialized."
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 325
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            ifnonnull 7
         3: .line 326
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.encryption:Z
            ifeq 6
         4: .line 327
            aload 0 /* this */
            new com.sun.crypto.provider.GaloisCounterMode$GCMEncrypt
            dup
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            invokespecial com.sun.crypto.provider.GaloisCounterMode$GCMEncrypt.<init>:(Lcom/sun/crypto/provider/GaloisCounterMode;Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         5: .line 328
            goto 7
         6: .line 329
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new com.sun.crypto.provider.GaloisCounterMode$GCMDecrypt
            dup
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            invokespecial com.sun.crypto.provider.GaloisCounterMode$GCMDecrypt.<init>:(Lcom/sun/crypto/provider/GaloisCounterMode;Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         7: .line 332
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  void checkReInit();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 335
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.reInit:Z
            ifeq 4
         1: .line 336
            new java.lang.IllegalStateException
            dup
         2: .line 337
            ldc "Must use either different key or  iv for GCM encryption"
         3: .line 336
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 339
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  protected byte[] engineUpdate(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 343
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 344
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         2: .line 345
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doUpdate:([BII)[B
            areturn
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    3     1        input  [B
            0    3     2  inputOffset  I
            0    3     3     inputLen  I
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  protected int engineUpdate(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=7, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
        start local 4 // byte[] output
        start local 5 // int outputOffset
         0: .line 351
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 352
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         2: .line 353
            aload 4 /* output */
            iload 5 /* outputOffset */
         3: .line 354
            aload 4 /* output */
            arraylength
            iload 5 /* outputOffset */
            isub
         4: .line 353
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         5: .line 355
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            iload 3 /* inputLen */
            iconst_0
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.getOutputSize:(IZ)I
            istore 6 /* len */
        start local 6 // int len
         6: .line 356
            iload 6 /* len */
            aload 4 /* output */
            arraylength
            iload 5 /* outputOffset */
            isub
            if_icmple 10
         7: .line 357
            new javax.crypto.ShortBufferException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Output buffer too small, must be at least "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 358
            iload 6 /* len */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 357
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 360
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
        11: .line 361
            iload 5 /* outputOffset */
        12: .line 360
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doUpdate:([BII[BI)I
            ireturn
        end local 6 // int len
        end local 5 // int outputOffset
        end local 4 // byte[] output
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   13     0          this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   13     1         input  [B
            0   13     2   inputOffset  I
            0   13     3      inputLen  I
            0   13     4        output  [B
            0   13     5  outputOffset  I
            6   13     6           len  I
    Exceptions:
      throws javax.crypto.ShortBufferException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  protected int engineUpdate(java.nio.ByteBuffer, java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.nio.ByteBuffer src
        start local 2 // java.nio.ByteBuffer dst
         0: .line 367
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 368
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_0
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.getOutputSize:(IZ)I
            istore 3 /* len */
        start local 3 // int len
         2: .line 369
            iload 3 /* len */
            aload 2 /* dst */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            if_icmple 6
         3: .line 370
            new javax.crypto.ShortBufferException
            dup
         4: .line 371
            new java.lang.StringBuilder
            dup
            ldc "Output buffer must be at least "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 3 /* len */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 370
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 373
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* src */
            aload 2 /* dst */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doUpdate:(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
            ireturn
        end local 3 // int len
        end local 2 // java.nio.ByteBuffer dst
        end local 1 // java.nio.ByteBuffer src
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    7     1   src  Ljava/nio/ByteBuffer;
            0    7     2   dst  Ljava/nio/ByteBuffer;
            2    7     3   len  I
    Exceptions:
      throws javax.crypto.ShortBufferException
    MethodParameters:
      Name  Flags
      src   
      dst   

  protected void engineUpdateAAD(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] src
        start local 2 // int offset
        start local 3 // int len
         0: .line 378
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 379
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* src */
            iload 2 /* offset */
            iload 3 /* len */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.updateAAD:([BII)V
         2: .line 380
            return
        end local 3 // int len
        end local 2 // int offset
        end local 1 // byte[] src
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    3     1     src  [B
            0    3     2  offset  I
            0    3     3     len  I
    MethodParameters:
        Name  Flags
      src     
      offset  
      len     

  protected void engineUpdateAAD(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.nio.ByteBuffer src
         0: .line 384
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 385
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.hasArray:()Z
            ifeq 7
         2: .line 386
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.position:()I
            istore 2 /* pos */
        start local 2 // int pos
         3: .line 387
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            istore 3 /* len */
        start local 3 // int len
         4: .line 388
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.array:()[B
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.arrayOffset:()I
            iload 2 /* pos */
            iadd
            iload 3 /* len */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.updateAAD:([BII)V
         5: .line 389
            aload 1 /* src */
            iload 2 /* pos */
            iload 3 /* len */
            iadd
            invokevirtual java.nio.ByteBuffer.position:(I)Ljava/nio/ByteBuffer;
            pop
        end local 3 // int len
        end local 2 // int pos
         6: .line 390
            goto 10
         7: .line 391
      StackMap locals:
      StackMap stack:
            aload 1 /* src */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            newarray 8
            astore 2 /* aad */
        start local 2 // byte[] aad
         8: .line 392
            aload 1 /* src */
            aload 2 /* aad */
            invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
            pop
         9: .line 393
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 2 /* aad */
            iconst_0
            aload 2 /* aad */
            arraylength
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.updateAAD:([BII)V
        end local 2 // byte[] aad
        10: .line 395
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.nio.ByteBuffer src
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   11     1   src  Ljava/nio/ByteBuffer;
            3    6     2   pos  I
            4    6     3   len  I
            8   10     2   aad  [B
    MethodParameters:
      Name  Flags
      src   

  protected byte[] engineDoFinal(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=7, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 400
            aload 1 /* input */
            ifnonnull 2
         1: .line 401
            getstatic com.sun.crypto.provider.GaloisCounterMode.EMPTY_BUF:[B
            astore 1 /* input */
         2: .line 404
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         3: .line 405
            goto 6
      StackMap locals:
      StackMap stack: java.lang.ArrayIndexOutOfBoundsException
         4: pop
         5: .line 406
            new javax.crypto.IllegalBlockSizeException
            dup
            ldc "input array invalid"
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 409
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         7: .line 410
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            iload 3 /* inputLen */
            iconst_1
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.getOutputSize:(IZ)I
            newarray 8
            astore 4 /* output */
        start local 4 // byte[] output
         8: .line 413
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
            iconst_0
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doFinal:([BII[BI)I
            pop
         9: .line 414
            goto 15
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[]
      StackMap stack: javax.crypto.ShortBufferException
        10: astore 5 /* e */
        start local 5 // javax.crypto.ShortBufferException e
        11: .line 415
            new java.security.ProviderException
            dup
            aload 5 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // javax.crypto.ShortBufferException e
        12: .line 416
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 6
        13: .line 418
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
        14: .line 419
            aload 6
            athrow
        15: .line 418
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
        16: .line 420
            aload 4 /* output */
            areturn
        end local 4 // byte[] output
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0         this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   17     1        input  [B
            0   17     2  inputOffset  I
            0   17     3     inputLen  I
            8   17     4       output  [B
           11   12     5            e  Ljavax/crypto/ShortBufferException;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.ArrayIndexOutOfBoundsException
           8     9      10  Class javax.crypto.ShortBufferException
           8    12      12  any
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  protected int engineDoFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=7, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
        start local 4 // byte[] output
        start local 5 // int outputOffset
         0: .line 428
            aload 1 /* input */
            ifnonnull 2
         1: .line 429
            getstatic com.sun.crypto.provider.GaloisCounterMode.EMPTY_BUF:[B
            astore 1 /* input */
         2: .line 432
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         3: .line 433
            goto 7
      StackMap locals:
      StackMap stack: java.lang.ArrayIndexOutOfBoundsException
         4: pop
         5: .line 435
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         6: .line 436
            new javax.crypto.IllegalBlockSizeException
            dup
            ldc "input array invalid"
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 438
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         8: .line 439
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
         9: .line 440
            iload 5 /* outputOffset */
        10: .line 439
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doFinal:([BII[BI)I
            istore 6 /* len */
        start local 6 // int len
        11: .line 443
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
        12: .line 445
            iload 6 /* len */
            ireturn
        end local 6 // int len
        end local 5 // int outputOffset
        end local 4 // byte[] output
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   13     0          this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   13     1         input  [B
            0   13     2   inputOffset  I
            0   13     3      inputLen  I
            0   13     4        output  [B
            0   13     5  outputOffset  I
           11   13     6           len  I
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.ArrayIndexOutOfBoundsException
    Exceptions:
      throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  protected int engineDoFinal(java.nio.ByteBuffer, java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.nio.ByteBuffer src
        start local 2 // java.nio.ByteBuffer dst
         0: .line 452
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 454
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
            aload 1 /* src */
            aload 2 /* dst */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode$GCMEngine.doFinal:(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
            istore 3 /* len */
        start local 3 // int len
         2: .line 457
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         3: .line 459
            iload 3 /* len */
            ireturn
        end local 3 // int len
        end local 2 // java.nio.ByteBuffer dst
        end local 1 // java.nio.ByteBuffer src
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    4     1   src  Ljava/nio/ByteBuffer;
            0    4     2   dst  Ljava/nio/ByteBuffer;
            2    4     3   len  I
    Exceptions:
      throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
      Name  Flags
      src   
      dst   

  protected byte[] engineWrap(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // java.security.Key key
         0: .line 465
            aconst_null
            astore 2 /* encodedKey */
        start local 2 // byte[] encodedKey
         1: .line 467
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         2: .line 469
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 2 /* encodedKey */
         3: .line 470
            aload 2 /* encodedKey */
            ifnull 4
            aload 2 /* encodedKey */
            arraylength
            ifne 7
         4: .line 471
      StackMap locals: byte[]
      StackMap stack:
            new java.security.InvalidKeyException
            dup
         5: .line 472
            ldc "Cannot get an encoding of the key to be wrapped"
         6: .line 471
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 474
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encodedKey */
            iconst_0
            aload 2 /* encodedKey */
            arraylength
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.engineDoFinal:([BII)[B
            astore 4
         8: .line 479
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
         9: .line 480
            aload 2 /* encodedKey */
            ifnull 11
        10: .line 481
            aload 2 /* encodedKey */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        11: .line 474
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode java.security.Key byte[] top byte[]
      StackMap stack:
            aload 4
            areturn
        12: .line 475
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode java.security.Key byte[]
      StackMap stack: javax.crypto.BadPaddingException
            pop
        13: .line 479
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
        14: .line 480
            aload 2 /* encodedKey */
            ifnull 21
        15: .line 481
            aload 2 /* encodedKey */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
            goto 21
        16: .line 477
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
        17: .line 479
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.engine:Lcom/sun/crypto/provider/GaloisCounterMode$GCMEngine;
        18: .line 480
            aload 2 /* encodedKey */
            ifnull 20
        19: .line 481
            aload 2 /* encodedKey */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        20: .line 483
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3
            athrow
        21: .line 484
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // byte[] encodedKey
        end local 1 // java.security.Key key
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0        this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   22     1         key  Ljava/security/Key;
            1   22     2  encodedKey  [B
      Exception table:
        from    to  target  type
           2     8      12  Class javax.crypto.BadPaddingException
           2     8      16  any
          12    13      16  any
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  protected java.security.Key engineUnwrap(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=7, args_size=4
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] wrappedKey
        start local 2 // java.lang.String wrappedKeyAlgorithm
        start local 3 // int wrappedKeyType
         0: .line 491
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.checkInit:()V
         1: .line 495
            aload 0 /* this */
            aload 1 /* wrappedKey */
            iconst_0
         2: .line 496
            aload 1 /* wrappedKey */
            arraylength
         3: .line 495
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.engineDoFinal:([BII)[B
            astore 4 /* encodedKey */
        start local 4 // byte[] encodedKey
         4: .line 497
            goto 13
        end local 4 // byte[] encodedKey
      StackMap locals:
      StackMap stack: javax.crypto.BadPaddingException
         5: pop
         6: .line 498
            new java.security.InvalidKeyException
            dup
         7: .line 499
            ldc "The wrapped key is not padded correctly"
         8: .line 498
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 500
      StackMap locals:
      StackMap stack: javax.crypto.IllegalBlockSizeException
            pop
        10: .line 501
            new java.security.InvalidKeyException
            dup
        11: .line 502
            ldc "The wrapped key does not have the correct length"
        12: .line 501
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        start local 4 // byte[] encodedKey
        13: .line 505
      StackMap locals: byte[]
      StackMap stack:
            aload 4 /* encodedKey */
            aload 2 /* wrappedKeyAlgorithm */
        14: .line 506
            iload 3 /* wrappedKeyType */
        15: .line 505
            invokestatic com.sun.crypto.provider.ConstructKeys.constructKey:([BLjava/lang/String;I)Ljava/security/Key;
            astore 6
        16: .line 508
            aload 4 /* encodedKey */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        17: .line 505
            aload 6
            areturn
        18: .line 507
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 5
        19: .line 508
            aload 4 /* encodedKey */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        20: .line 509
            aload 5
            athrow
        end local 4 // byte[] encodedKey
        end local 3 // int wrappedKeyType
        end local 2 // java.lang.String wrappedKeyAlgorithm
        end local 1 // byte[] wrappedKey
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   21     0                 this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   21     1           wrappedKey  [B
            0   21     2  wrappedKeyAlgorithm  Ljava/lang/String;
            0   21     3       wrappedKeyType  I
            4    5     4           encodedKey  [B
           13   21     4           encodedKey  [B
      Exception table:
        from    to  target  type
           1     4       5  Class javax.crypto.BadPaddingException
           1     4       9  Class javax.crypto.IllegalBlockSizeException
          13    16      18  any
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
                     Name  Flags
      wrappedKey           
      wrappedKeyAlgorithm  
      wrappedKeyType       

  static void increment32(byte[]);
    descriptor: ([B)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // byte[] value
         0: .line 515
            aload 0 /* value */
            arraylength
            iconst_1
            isub
            istore 1 /* n */
        start local 1 // int n
         1: .line 516
            goto 3
         2: .line 517
      StackMap locals: int
      StackMap stack:
            iinc 1 /* n */ -1
         3: .line 516
      StackMap locals:
      StackMap stack:
            iload 1 /* n */
            aload 0 /* value */
            arraylength
            iconst_4
            isub
            if_icmplt 4
            aload 0 /* value */
            iload 1 /* n */
            dup2
            baload
            iconst_1
            iadd
            i2b
            dup_x2
            bastore
            ifeq 2
         4: .line 519
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int n
        end local 0 // byte[] value
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0  value  [B
            1    5     1      n  I
    MethodParameters:
       Name  Flags
      value  

  private static byte[] getLengthBlock(int);
    descriptor: (I)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=2, args_size=1
        start local 0 // int ivLenInBytes
         0: .line 526
            bipush 16
            newarray 8
            astore 1 /* out */
        start local 1 // byte[] out
         1: .line 527
            getstatic com.sun.crypto.provider.GaloisCounterMode.wrapToByteArray:Ljava/lang/invoke/VarHandle;
            aload 1 /* out */
            bipush 8
            iload 0 /* ivLenInBytes */
            i2l
            ldc 4294967295
            land
            iconst_3
            lshl
            invokevirtual java.lang.invoke.VarHandle.set:([BIJ)V
         2: .line 528
            aload 1 /* out */
            areturn
        end local 1 // byte[] out
        end local 0 // int ivLenInBytes
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0  ivLenInBytes  I
            1    3     1           out  [B
    MethodParameters:
              Name  Flags
      ivLenInBytes  

  private static byte[] getLengthBlock(int, int);
    descriptor: (II)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=3, args_size=2
        start local 0 // int aLenInBytes
        start local 1 // int cLenInBytes
         0: .line 532
            bipush 16
            newarray 8
            astore 2 /* out */
        start local 2 // byte[] out
         1: .line 533
            getstatic com.sun.crypto.provider.GaloisCounterMode.wrapToByteArray:Ljava/lang/invoke/VarHandle;
            aload 2 /* out */
            iconst_0
            iload 0 /* aLenInBytes */
            i2l
            ldc 4294967295
            land
            iconst_3
            lshl
            invokevirtual java.lang.invoke.VarHandle.set:([BIJ)V
         2: .line 534
            getstatic com.sun.crypto.provider.GaloisCounterMode.wrapToByteArray:Ljava/lang/invoke/VarHandle;
            aload 2 /* out */
            bipush 8
            iload 1 /* cLenInBytes */
            i2l
            ldc 4294967295
            land
            iconst_3
            lshl
            invokevirtual java.lang.invoke.VarHandle.set:([BIJ)V
         3: .line 535
            aload 2 /* out */
            areturn
        end local 2 // byte[] out
        end local 1 // int cLenInBytes
        end local 0 // int aLenInBytes
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0  aLenInBytes  I
            0    4     1  cLenInBytes  I
            1    4     2          out  [B
    MethodParameters:
             Name  Flags
      aLenInBytes  
      cLenInBytes  

  private static byte[] expandToOneBlock(byte[], int, int, int);
    descriptor: ([BIII)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // byte[] in
        start local 1 // int inOfs
        start local 2 // int len
        start local 3 // int blockSize
         0: .line 540
            iload 2 /* len */
            iload 3 /* blockSize */
            if_icmple 2
         1: .line 541
            new java.security.ProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "input "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* len */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " too long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 543
      StackMap locals:
      StackMap stack:
            iload 2 /* len */
            iload 3 /* blockSize */
            if_icmpne 4
            iload 1 /* inOfs */
            ifne 4
         3: .line 544
            aload 0 /* in */
            areturn
         4: .line 546
      StackMap locals:
      StackMap stack:
            iload 3 /* blockSize */
            newarray 8
            astore 4 /* paddedIn */
        start local 4 // byte[] paddedIn
         5: .line 547
            aload 0 /* in */
            iload 1 /* inOfs */
            aload 4 /* paddedIn */
            iconst_0
            iload 2 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         6: .line 548
            aload 4 /* paddedIn */
            areturn
        end local 4 // byte[] paddedIn
        end local 3 // int blockSize
        end local 2 // int len
        end local 1 // int inOfs
        end local 0 // byte[] in
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0         in  [B
            0    7     1      inOfs  I
            0    7     2        len  I
            0    7     3  blockSize  I
            5    7     4   paddedIn  [B
    MethodParameters:
           Name  Flags
      in         
      inOfs      
      len        
      blockSize  

  private static byte[] getJ0(byte[], byte[], int);
    descriptor: ([B[BI)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // byte[] iv
        start local 1 // byte[] subkeyH
        start local 2 // int blockSize
         0: .line 554
            aload 0 /* iv */
            arraylength
            bipush 12
            if_icmpne 4
         1: .line 555
            aload 0 /* iv */
            iconst_0
            aload 0 /* iv */
            arraylength
            iload 2 /* blockSize */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BIII)[B
            astore 3 /* j0 */
        start local 3 // byte[] j0
         2: .line 556
            aload 3 /* j0 */
            iload 2 /* blockSize */
            iconst_1
            isub
            iconst_1
            bastore
         3: .line 557
            goto 17
        end local 3 // byte[] j0
         4: .line 558
      StackMap locals:
      StackMap stack:
            new com.sun.crypto.provider.GHASH
            dup
            aload 1 /* subkeyH */
            invokespecial com.sun.crypto.provider.GHASH.<init>:([B)V
            astore 4 /* g */
        start local 4 // com.sun.crypto.provider.GHASH g
         5: .line 559
            aload 0 /* iv */
            arraylength
            iload 2 /* blockSize */
            irem
            istore 5 /* lastLen */
        start local 5 // int lastLen
         6: .line 560
            iload 5 /* lastLen */
            ifeq 14
         7: .line 561
            aload 4 /* g */
            aload 0 /* iv */
            iconst_0
            aload 0 /* iv */
            arraylength
            iload 5 /* lastLen */
            isub
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)I
            pop
         8: .line 563
            aload 0 /* iv */
            aload 0 /* iv */
            arraylength
            iload 5 /* lastLen */
            isub
            iload 5 /* lastLen */
         9: .line 564
            iload 2 /* blockSize */
        10: .line 563
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BIII)[B
        11: .line 562
            astore 6 /* padded */
        start local 6 // byte[] padded
        12: .line 565
            aload 4 /* g */
            aload 6 /* padded */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)I
            pop
        end local 6 // byte[] padded
        13: .line 566
            goto 15
        14: .line 567
      StackMap locals: byte[] byte[] int top com.sun.crypto.provider.GHASH int
      StackMap stack:
            aload 4 /* g */
            aload 0 /* iv */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)I
            pop
        15: .line 569
      StackMap locals:
      StackMap stack:
            aload 4 /* g */
            aload 0 /* iv */
            arraylength
            invokestatic com.sun.crypto.provider.GaloisCounterMode.getLengthBlock:(I)[B
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)I
            pop
        16: .line 570
            aload 4 /* g */
            invokevirtual com.sun.crypto.provider.GHASH.digest:()[B
            astore 3 /* j0 */
        end local 5 // int lastLen
        end local 4 // com.sun.crypto.provider.GHASH g
        start local 3 // byte[] j0
        17: .line 572
      StackMap locals: byte[] byte[] int byte[]
      StackMap stack:
            aload 3 /* j0 */
            areturn
        end local 3 // byte[] j0
        end local 2 // int blockSize
        end local 1 // byte[] subkeyH
        end local 0 // byte[] iv
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   18     0         iv  [B
            0   18     1    subkeyH  [B
            0   18     2  blockSize  I
            2    4     3         j0  [B
           17   18     3         j0  [B
            5   17     4          g  Lcom/sun/crypto/provider/GHASH;
            6   17     5    lastLen  I
           12   13     6     padded  [B
    MethodParameters:
           Name  Flags
      iv         
      subkeyH    
      blockSize  

  private static int implGCMCrypt(byte[], int, int, byte[], int, byte[], int, com.sun.crypto.provider.GCTR, com.sun.crypto.provider.GHASH);
    descriptor: ([BII[BI[BILcom/sun/crypto/provider/GCTR;Lcom/sun/crypto/provider/GHASH;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=10, locals=11, args_size=9
        start local 0 // byte[] in
        start local 1 // int inOfs
        start local 2 // int inLen
        start local 3 // byte[] ct
        start local 4 // int ctOfs
        start local 5 // byte[] out
        start local 6 // int outOfs
        start local 7 // com.sun.crypto.provider.GCTR gctr
        start local 8 // com.sun.crypto.provider.GHASH ghash
         0: .line 582
            iconst_0
            istore 9 /* len */
        start local 9 // int len
         1: .line 583
            iload 2 /* inLen */
            ldc 1048576
            if_icmple 9
         2: .line 584
            goto 8
         3: .line 585
      StackMap locals: int
      StackMap stack:
            aload 0 /* in */
            iload 1 /* inOfs */
            iload 9 /* len */
            iadd
            ldc 1048576
            aload 3 /* ct */
         4: .line 586
            iload 4 /* ctOfs */
            iload 9 /* len */
            iadd
            aload 5 /* out */
            iload 6 /* outOfs */
            iload 9 /* len */
            iadd
            aload 7 /* gctr */
            aload 8 /* ghash */
         5: .line 585
            invokestatic com.sun.crypto.provider.GaloisCounterMode.implGCMCrypt0:([BII[BI[BILcom/sun/crypto/provider/GCTR;Lcom/sun/crypto/provider/GHASH;)I
            istore 10 /* partlen */
        start local 10 // int partlen
         6: .line 587
            iload 9 /* len */
            iload 10 /* partlen */
            iadd
            istore 9 /* len */
         7: .line 588
            iload 2 /* inLen */
            iload 10 /* partlen */
            isub
            istore 2 /* inLen */
        end local 10 // int partlen
         8: .line 584
      StackMap locals:
      StackMap stack:
            iload 2 /* inLen */
            ldc 1048576
            if_icmpge 3
         9: .line 591
      StackMap locals:
      StackMap stack:
            iload 2 /* inLen */
            ifle 13
        10: .line 592
            iload 9 /* len */
            aload 0 /* in */
            iload 1 /* inOfs */
            iload 9 /* len */
            iadd
            iload 2 /* inLen */
            aload 3 /* ct */
        11: .line 593
            iload 4 /* ctOfs */
            iload 9 /* len */
            iadd
            aload 5 /* out */
            iload 6 /* outOfs */
            iload 9 /* len */
            iadd
            aload 7 /* gctr */
            aload 8 /* ghash */
        12: .line 592
            invokestatic com.sun.crypto.provider.GaloisCounterMode.implGCMCrypt0:([BII[BI[BILcom/sun/crypto/provider/GCTR;Lcom/sun/crypto/provider/GHASH;)I
            iadd
            istore 9 /* len */
        13: .line 595
      StackMap locals:
      StackMap stack:
            iload 9 /* len */
            ireturn
        end local 9 // int len
        end local 8 // com.sun.crypto.provider.GHASH ghash
        end local 7 // com.sun.crypto.provider.GCTR gctr
        end local 6 // int outOfs
        end local 5 // byte[] out
        end local 4 // int ctOfs
        end local 3 // byte[] ct
        end local 2 // int inLen
        end local 1 // int inOfs
        end local 0 // byte[] in
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   14     0       in  [B
            0   14     1    inOfs  I
            0   14     2    inLen  I
            0   14     3       ct  [B
            0   14     4    ctOfs  I
            0   14     5      out  [B
            0   14     6   outOfs  I
            0   14     7     gctr  Lcom/sun/crypto/provider/GCTR;
            0   14     8    ghash  Lcom/sun/crypto/provider/GHASH;
            1   14     9      len  I
            6    8    10  partlen  I
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      ct      
      ctOfs   
      out     
      outOfs  
      gctr    
      ghash   

  private static int implGCMCrypt0(byte[], int, int, byte[], int, byte[], int, com.sun.crypto.provider.GCTR, com.sun.crypto.provider.GHASH);
    descriptor: ([BII[BI[BILcom/sun/crypto/provider/GCTR;Lcom/sun/crypto/provider/GHASH;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=13, args_size=9
        start local 0 // byte[] in
        start local 1 // int inOfs
        start local 2 // int inLen
        start local 3 // byte[] ct
        start local 4 // int ctOfs
        start local 5 // byte[] out
        start local 6 // int outOfs
        start local 7 // com.sun.crypto.provider.GCTR gctr
        start local 8 // com.sun.crypto.provider.GHASH ghash
         0: .line 621
            iload 2 /* inLen */
            iload 2 /* inLen */
            sipush 8192
            irem
            isub
            istore 2 /* inLen */
         1: .line 623
            iconst_0
            istore 9 /* len */
        start local 9 // int len
         2: .line 624
            iload 4 /* ctOfs */
            istore 10 /* cOfs */
        start local 10 // int cOfs
         3: .line 625
            iload 2 /* inLen */
            ldc 65536
            if_icmplt 15
         4: .line 626
            iconst_0
            istore 11 /* i */
        start local 11 // int i
         5: .line 627
            iload 2 /* inLen */
            bipush 6
            idiv
            istore 12 /* segments */
        start local 12 // int segments
         6: .line 628
            iload 12 /* segments */
            iload 12 /* segments */
            aload 7 /* gctr */
            getfield com.sun.crypto.provider.GCTR.blockSize:I
            irem
            isub
            istore 12 /* segments */
         7: .line 630
      StackMap locals: byte[] int int byte[] int byte[] int com.sun.crypto.provider.GCTR com.sun.crypto.provider.GHASH int int int int
      StackMap stack:
            iload 9 /* len */
            aload 7 /* gctr */
            aload 0 /* in */
            iload 1 /* inOfs */
            iload 9 /* len */
            iadd
            iload 12 /* segments */
            aload 5 /* out */
         8: .line 631
            iload 6 /* outOfs */
            iload 9 /* len */
            iadd
         9: .line 630
            invokevirtual com.sun.crypto.provider.GCTR.update:([BII[BI)I
            iadd
            istore 9 /* len */
        10: .line 632
            aload 8 /* ghash */
            aload 3 /* ct */
            iload 10 /* cOfs */
            iload 12 /* segments */
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)I
            pop
        11: .line 633
            iload 4 /* ctOfs */
            iload 9 /* len */
            iadd
            istore 10 /* cOfs */
        12: .line 634
            iinc 11 /* i */ 1
            iload 11 /* i */
            iconst_5
        13: .line 629
            if_icmplt 7
        14: .line 636
            iload 2 /* inLen */
            iload 9 /* len */
            isub
            istore 2 /* inLen */
        end local 12 // int segments
        end local 11 // int i
        15: .line 639
      StackMap locals:
      StackMap stack:
            iload 9 /* len */
            aload 7 /* gctr */
            aload 0 /* in */
            iload 1 /* inOfs */
            iload 9 /* len */
            iadd
            iload 2 /* inLen */
            aload 5 /* out */
            iload 6 /* outOfs */
            iload 9 /* len */
            iadd
            invokevirtual com.sun.crypto.provider.GCTR.update:([BII[BI)I
            iadd
            istore 9 /* len */
        16: .line 640
            aload 8 /* ghash */
            aload 3 /* ct */
            iload 10 /* cOfs */
            iload 2 /* inLen */
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)I
            pop
        17: .line 641
            iload 9 /* len */
            ireturn
        end local 10 // int cOfs
        end local 9 // int len
        end local 8 // com.sun.crypto.provider.GHASH ghash
        end local 7 // com.sun.crypto.provider.GCTR gctr
        end local 6 // int outOfs
        end local 5 // byte[] out
        end local 4 // int ctOfs
        end local 3 // byte[] ct
        end local 2 // int inLen
        end local 1 // int inOfs
        end local 0 // byte[] in
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   18     0        in  [B
            0   18     1     inOfs  I
            0   18     2     inLen  I
            0   18     3        ct  [B
            0   18     4     ctOfs  I
            0   18     5       out  [B
            0   18     6    outOfs  I
            0   18     7      gctr  Lcom/sun/crypto/provider/GCTR;
            0   18     8     ghash  Lcom/sun/crypto/provider/GHASH;
            2   18     9       len  I
            3   18    10      cOfs  I
            5   15    11         i  I
            6   15    12  segments  I
    RuntimeVisibleAnnotations: 
      jdk.internal.vm.annotation.IntrinsicCandidate()
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      ct      
      ctOfs   
      out     
      outOfs  
      gctr    
      ghash   
}
SourceFile: "GaloisCounterMode.java"
NestMembers:
  com.sun.crypto.provider.GaloisCounterMode$AES128  com.sun.crypto.provider.GaloisCounterMode$AES192  com.sun.crypto.provider.GaloisCounterMode$AES256  com.sun.crypto.provider.GaloisCounterMode$AESGCM  com.sun.crypto.provider.GaloisCounterMode$DecryptOp  com.sun.crypto.provider.GaloisCounterMode$EncryptOp  com.sun.crypto.provider.GaloisCounterMode$GCMDecrypt  com.sun.crypto.provider.GaloisCounterMode$GCMEncrypt  com.sun.crypto.provider.GaloisCounterMode$GCMEngine  com.sun.crypto.provider.GaloisCounterMode$GCMOperation
InnerClasses:
  public final AES128 = com.sun.crypto.provider.GaloisCounterMode$AES128 of com.sun.crypto.provider.GaloisCounterMode
  public final AES192 = com.sun.crypto.provider.GaloisCounterMode$AES192 of com.sun.crypto.provider.GaloisCounterMode
  public final AES256 = com.sun.crypto.provider.GaloisCounterMode$AES256 of com.sun.crypto.provider.GaloisCounterMode
  public final AESGCM = com.sun.crypto.provider.GaloisCounterMode$AESGCM of com.sun.crypto.provider.GaloisCounterMode
  final DecryptOp = com.sun.crypto.provider.GaloisCounterMode$DecryptOp of com.sun.crypto.provider.GaloisCounterMode
  final EncryptOp = com.sun.crypto.provider.GaloisCounterMode$EncryptOp of com.sun.crypto.provider.GaloisCounterMode
  GCMDecrypt = com.sun.crypto.provider.GaloisCounterMode$GCMDecrypt of com.sun.crypto.provider.GaloisCounterMode
  GCMEncrypt = com.sun.crypto.provider.GaloisCounterMode$GCMEncrypt of com.sun.crypto.provider.GaloisCounterMode
  abstract GCMEngine = com.sun.crypto.provider.GaloisCounterMode$GCMEngine of com.sun.crypto.provider.GaloisCounterMode
  public abstract GCMOperation = com.sun.crypto.provider.GaloisCounterMode$GCMOperation of com.sun.crypto.provider.GaloisCounterMode