final class com.sun.crypto.provider.GaloisCounterMode extends com.sun.crypto.provider.FeedbackCipher
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.crypto.provider.GaloisCounterMode
  super_class: com.sun.crypto.provider.FeedbackCipher
{
  static int DEFAULT_TAG_LEN;
    descriptor: I
    flags: (0x0008) ACC_STATIC

  static int DEFAULT_IV_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 java.io.ByteArrayOutputStream aadBuffer;
    descriptor: Ljava/io/ByteArrayOutputStream;
    flags: (0x0002) ACC_PRIVATE

  private int sizeOfAAD;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.io.ByteArrayOutputStream ibuffer;
    descriptor: Ljava/io/ByteArrayOutputStream;
    flags: (0x0002) ACC_PRIVATE

  private int tagLenBytes;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private byte[] subkeyH;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private byte[] preCounterBlock;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private com.sun.crypto.provider.GCTR gctrPAndC;
    descriptor: Lcom/sun/crypto/provider/GCTR;
    flags: (0x0002) ACC_PRIVATE

  private com.sun.crypto.provider.GHASH ghashAllToS;
    descriptor: Lcom/sun/crypto/provider/GHASH;
    flags: (0x0002) ACC_PRIVATE

  private int processed;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private byte[] aadBufferSave;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private int sizeOfAADSave;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private byte[] ibufferSave;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private int processedSave;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 51
            bipush 16
            putstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
         1: .line 52
            bipush 12
            putstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_IV_LEN:I
         2: .line 65
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  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 96
            aload 0 /* value */
            arraylength
            bipush 16
            if_icmpeq 2
         1: .line 98
            new java.security.ProviderException
            dup
            ldc "Illegal counter block length"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 101
      StackMap locals:
      StackMap stack:
            aload 0 /* value */
            arraylength
            iconst_1
            isub
            istore 1 /* n */
        start local 1 // int n
         3: .line 102
            goto 5
         4: .line 103
      StackMap locals: int
      StackMap stack:
            iinc 1 /* n */ -1
         5: .line 102
      StackMap locals:
      StackMap stack:
            iload 1 /* n */
            aload 0 /* value */
            arraylength
            iconst_4
            isub
            if_icmplt 6
            aload 0 /* value */
            iload 1 /* n */
            dup2
            baload
            iconst_1
            iadd
            i2b
            dup_x2
            bastore
            ifeq 4
         6: .line 105
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int n
        end local 0 // byte[] value
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0  value  [B
            3    7     1      n  I
    MethodParameters:
       Name  Flags
      value  

  private static byte[] getLengthBlock(int);
    descriptor: (I)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // int ivLenInBytes
         0: .line 108
            iload 0 /* ivLenInBytes */
            i2l
            iconst_3
            lshl
            lstore 1 /* ivLen */
        start local 1 // long ivLen
         1: .line 109
            bipush 16
            newarray 8
            astore 3 /* out */
        start local 3 // byte[] out
         2: .line 110
            aload 3 /* out */
            bipush 8
            lload 1 /* ivLen */
            bipush 56
            lushr
            l2i
            i2b
            bastore
         3: .line 111
            aload 3 /* out */
            bipush 9
            lload 1 /* ivLen */
            bipush 48
            lushr
            l2i
            i2b
            bastore
         4: .line 112
            aload 3 /* out */
            bipush 10
            lload 1 /* ivLen */
            bipush 40
            lushr
            l2i
            i2b
            bastore
         5: .line 113
            aload 3 /* out */
            bipush 11
            lload 1 /* ivLen */
            bipush 32
            lushr
            l2i
            i2b
            bastore
         6: .line 114
            aload 3 /* out */
            bipush 12
            lload 1 /* ivLen */
            bipush 24
            lushr
            l2i
            i2b
            bastore
         7: .line 115
            aload 3 /* out */
            bipush 13
            lload 1 /* ivLen */
            bipush 16
            lushr
            l2i
            i2b
            bastore
         8: .line 116
            aload 3 /* out */
            bipush 14
            lload 1 /* ivLen */
            bipush 8
            lushr
            l2i
            i2b
            bastore
         9: .line 117
            aload 3 /* out */
            bipush 15
            lload 1 /* ivLen */
            l2i
            i2b
            bastore
        10: .line 118
            aload 3 /* out */
            areturn
        end local 3 // byte[] out
        end local 1 // long ivLen
        end local 0 // int ivLenInBytes
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   11     0  ivLenInBytes  I
            1   11     1         ivLen  J
            2   11     3           out  [B
    MethodParameters:
              Name  Flags
      ivLenInBytes  

  private static byte[] getLengthBlock(int, int);
    descriptor: (II)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // int aLenInBytes
        start local 1 // int cLenInBytes
         0: .line 122
            iload 0 /* aLenInBytes */
            i2l
            iconst_3
            lshl
            lstore 2 /* aLen */
        start local 2 // long aLen
         1: .line 123
            iload 1 /* cLenInBytes */
            i2l
            iconst_3
            lshl
            lstore 4 /* cLen */
        start local 4 // long cLen
         2: .line 124
            bipush 16
            newarray 8
            astore 6 /* out */
        start local 6 // byte[] out
         3: .line 125
            aload 6 /* out */
            iconst_0
            lload 2 /* aLen */
            bipush 56
            lushr
            l2i
            i2b
            bastore
         4: .line 126
            aload 6 /* out */
            iconst_1
            lload 2 /* aLen */
            bipush 48
            lushr
            l2i
            i2b
            bastore
         5: .line 127
            aload 6 /* out */
            iconst_2
            lload 2 /* aLen */
            bipush 40
            lushr
            l2i
            i2b
            bastore
         6: .line 128
            aload 6 /* out */
            iconst_3
            lload 2 /* aLen */
            bipush 32
            lushr
            l2i
            i2b
            bastore
         7: .line 129
            aload 6 /* out */
            iconst_4
            lload 2 /* aLen */
            bipush 24
            lushr
            l2i
            i2b
            bastore
         8: .line 130
            aload 6 /* out */
            iconst_5
            lload 2 /* aLen */
            bipush 16
            lushr
            l2i
            i2b
            bastore
         9: .line 131
            aload 6 /* out */
            bipush 6
            lload 2 /* aLen */
            bipush 8
            lushr
            l2i
            i2b
            bastore
        10: .line 132
            aload 6 /* out */
            bipush 7
            lload 2 /* aLen */
            l2i
            i2b
            bastore
        11: .line 133
            aload 6 /* out */
            bipush 8
            lload 4 /* cLen */
            bipush 56
            lushr
            l2i
            i2b
            bastore
        12: .line 134
            aload 6 /* out */
            bipush 9
            lload 4 /* cLen */
            bipush 48
            lushr
            l2i
            i2b
            bastore
        13: .line 135
            aload 6 /* out */
            bipush 10
            lload 4 /* cLen */
            bipush 40
            lushr
            l2i
            i2b
            bastore
        14: .line 136
            aload 6 /* out */
            bipush 11
            lload 4 /* cLen */
            bipush 32
            lushr
            l2i
            i2b
            bastore
        15: .line 137
            aload 6 /* out */
            bipush 12
            lload 4 /* cLen */
            bipush 24
            lushr
            l2i
            i2b
            bastore
        16: .line 138
            aload 6 /* out */
            bipush 13
            lload 4 /* cLen */
            bipush 16
            lushr
            l2i
            i2b
            bastore
        17: .line 139
            aload 6 /* out */
            bipush 14
            lload 4 /* cLen */
            bipush 8
            lushr
            l2i
            i2b
            bastore
        18: .line 140
            aload 6 /* out */
            bipush 15
            lload 4 /* cLen */
            l2i
            i2b
            bastore
        19: .line 141
            aload 6 /* out */
            areturn
        end local 6 // byte[] out
        end local 4 // long cLen
        end local 2 // long aLen
        end local 1 // int cLenInBytes
        end local 0 // int aLenInBytes
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   20     0  aLenInBytes  I
            0   20     1  cLenInBytes  I
            1   20     2         aLen  J
            2   20     4         cLen  J
            3   20     6          out  [B
    MethodParameters:
             Name  Flags
      aLenInBytes  
      cLenInBytes  

  private static byte[] expandToOneBlock(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // byte[] in
        start local 1 // int inOfs
        start local 2 // int len
         0: .line 145
            iload 2 /* len */
            bipush 16
            if_icmple 2
         1: .line 146
            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 148
      StackMap locals:
      StackMap stack:
            iload 2 /* len */
            bipush 16
            if_icmpne 4
            iload 1 /* inOfs */
            ifne 4
         3: .line 149
            aload 0 /* in */
            areturn
         4: .line 151
      StackMap locals:
      StackMap stack:
            bipush 16
            newarray 8
            astore 3 /* paddedIn */
        start local 3 // byte[] paddedIn
         5: .line 152
            aload 0 /* in */
            iload 1 /* inOfs */
            aload 3 /* paddedIn */
            iconst_0
            iload 2 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         6: .line 153
            aload 3 /* paddedIn */
            areturn
        end local 3 // byte[] paddedIn
        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
            5    7     3  paddedIn  [B
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      len    

  private static byte[] getJ0(byte[], byte[]);
    descriptor: ([B[B)[B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // byte[] iv
        start local 1 // byte[] subkeyH
         0: .line 159
            aload 0 /* iv */
            arraylength
            bipush 12
            if_icmpne 4
         1: .line 160
            aload 0 /* iv */
            iconst_0
            aload 0 /* iv */
            arraylength
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BII)[B
            astore 2 /* j0 */
        start local 2 // byte[] j0
         2: .line 161
            aload 2 /* j0 */
            bipush 15
            iconst_1
            bastore
         3: .line 162
            goto 16
        end local 2 // byte[] j0
         4: .line 163
      StackMap locals:
      StackMap stack:
            new com.sun.crypto.provider.GHASH
            dup
            aload 1 /* subkeyH */
            invokespecial com.sun.crypto.provider.GHASH.<init>:([B)V
            astore 3 /* g */
        start local 3 // com.sun.crypto.provider.GHASH g
         5: .line 164
            aload 0 /* iv */
            arraylength
            bipush 16
            irem
            istore 4 /* lastLen */
        start local 4 // int lastLen
         6: .line 165
            iload 4 /* lastLen */
            ifeq 12
         7: .line 166
            aload 3 /* g */
            aload 0 /* iv */
            iconst_0
            aload 0 /* iv */
            arraylength
            iload 4 /* lastLen */
            isub
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
         8: .line 168
            aload 0 /* iv */
            aload 0 /* iv */
            arraylength
            iload 4 /* lastLen */
            isub
            iload 4 /* lastLen */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BII)[B
         9: .line 167
            astore 5 /* padded */
        start local 5 // byte[] padded
        10: .line 169
            aload 3 /* g */
            aload 5 /* padded */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        end local 5 // byte[] padded
        11: .line 170
            goto 13
        12: .line 171
      StackMap locals: byte[] byte[] top com.sun.crypto.provider.GHASH int
      StackMap stack:
            aload 3 /* g */
            aload 0 /* iv */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        13: .line 173
      StackMap locals:
      StackMap stack:
            aload 0 /* iv */
            arraylength
            invokestatic com.sun.crypto.provider.GaloisCounterMode.getLengthBlock:(I)[B
            astore 5 /* lengthBlock */
        start local 5 // byte[] lengthBlock
        14: .line 174
            aload 3 /* g */
            aload 5 /* lengthBlock */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        15: .line 175
            aload 3 /* g */
            invokevirtual com.sun.crypto.provider.GHASH.digest:()[B
            astore 2 /* j0 */
        end local 5 // byte[] lengthBlock
        end local 4 // int lastLen
        end local 3 // com.sun.crypto.provider.GHASH g
        start local 2 // byte[] j0
        16: .line 177
      StackMap locals: byte[] byte[] byte[]
      StackMap stack:
            aload 2 /* j0 */
            areturn
        end local 2 // byte[] j0
        end local 1 // byte[] subkeyH
        end local 0 // byte[] iv
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0           iv  [B
            0   17     1      subkeyH  [B
            2    4     2           j0  [B
           16   17     2           j0  [B
            5   16     3            g  Lcom/sun/crypto/provider/GHASH;
            6   16     4      lastLen  I
           10   11     5       padded  [B
           14   16     5  lengthBlock  [B
    MethodParameters:
         Name  Flags
      iv       
      subkeyH  

  private static void checkDataLength(int, int);
    descriptor: (II)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // int processed
        start local 1 // int len
         0: .line 181
            iload 0 /* processed */
            ldc 2147483647
            iload 1 /* len */
            isub
            if_icmple 2
         1: .line 182
            new java.security.ProviderException
            dup
            ldc "SunJCE provider only supports input size up to 2147483647 bytes"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 185
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int len
        end local 0 // int processed
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  processed  I
            0    3     1        len  I
    MethodParameters:
           Name  Flags
      processed  
      len        

  void <init>(com.sun.crypto.provider.SymmetricCipher);
    descriptor: (Lcom/sun/crypto/provider/SymmetricCipher;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // com.sun.crypto.provider.SymmetricCipher embeddedCipher
         0: .line 188
            aload 0 /* this */
            aload 1 /* embeddedCipher */
            invokespecial com.sun.crypto.provider.FeedbackCipher.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
         1: .line 68
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
         2: .line 69
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
         3: .line 72
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
         4: .line 75
            aload 0 /* this */
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
            putfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
         5: .line 79
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.subkeyH:[B
         6: .line 80
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.preCounterBlock:[B
         7: .line 82
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
         8: .line 83
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
         9: .line 86
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
        10: .line 89
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBufferSave:[B
        11: .line 90
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAADSave:I
        12: .line 91
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.ibufferSave:[B
        13: .line 92
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.processedSave:I
        14: .line 189
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
        15: .line 190
            return
        end local 1 // com.sun.crypto.provider.SymmetricCipher embeddedCipher
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   16     0            this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   16     1  embeddedCipher  Lcom/sun/crypto/provider/SymmetricCipher;
    MethodParameters:
                Name  Flags
      embeddedCipher  

  java.lang.String getFeedback();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 198
            ldc "GCM"
            areturn
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  void reset();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 207
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnonnull 3
         1: .line 208
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
         2: .line 209
            goto 4
         3: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
         4: .line 212
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            ifnull 5
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            invokevirtual com.sun.crypto.provider.GCTR.reset:()V
         5: .line 213
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            ifnull 6
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            invokevirtual com.sun.crypto.provider.GHASH.reset:()V
         6: .line 214
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
         7: .line 215
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
         8: .line 216
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 10
         9: .line 217
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
        10: .line 219
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  void save();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 225
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            putfield com.sun.crypto.provider.GaloisCounterMode.processedSave:I
         1: .line 226
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAADSave:I
         2: .line 227
            aload 0 /* this */
         3: .line 228
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 4
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            ifne 5
         4: .line 229
      StackMap locals:
      StackMap stack: com.sun.crypto.provider.GaloisCounterMode
            aconst_null
            goto 6
      StackMap locals:
      StackMap stack: com.sun.crypto.provider.GaloisCounterMode
         5: aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
         6: .line 227
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode
      StackMap stack: com.sun.crypto.provider.GaloisCounterMode byte[]
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBufferSave:[B
         7: .line 230
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            ifnull 8
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            invokevirtual com.sun.crypto.provider.GCTR.save:()V
         8: .line 231
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            ifnull 9
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            invokevirtual com.sun.crypto.provider.GHASH.save:()V
         9: .line 232
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 11
        10: .line 233
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            putfield com.sun.crypto.provider.GaloisCounterMode.ibufferSave:[B
        11: .line 235
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  void restore();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 241
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processedSave:I
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
         1: .line 242
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAADSave:I
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
         2: .line 243
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 6
         3: .line 244
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
         4: .line 245
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBufferSave:[B
            ifnull 6
         5: .line 246
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBufferSave:[B
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBufferSave:[B
            arraylength
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         6: .line 249
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            ifnull 7
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            invokevirtual com.sun.crypto.provider.GCTR.restore:()V
         7: .line 250
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            ifnull 8
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            invokevirtual com.sun.crypto.provider.GHASH.restore:()V
         8: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 11
         9: .line 252
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
        10: .line 253
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibufferSave:[B
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibufferSave:[B
            arraylength
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
        11: .line 255
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;

  void init(boolean, java.lang.String, byte[], byte[]);
    descriptor: (ZLjava/lang/String;[B[B)V
    flags: (0x0000) 
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // boolean decrypting
        start local 2 // java.lang.String algorithm
        start local 3 // byte[] key
        start local 4 // byte[] iv
         0: .line 273
            aload 0 /* this */
            iload 1 /* decrypting */
            aload 2 /* algorithm */
            aload 3 /* key */
            aload 4 /* iv */
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.init:(ZLjava/lang/String;[B[BI)V
         1: .line 274
            return
        end local 4 // byte[] iv
        end local 3 // byte[] key
        end local 2 // java.lang.String algorithm
        end local 1 // boolean decrypting
        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  decrypting  Z
            0    2     2   algorithm  Ljava/lang/String;
            0    2     3         key  [B
            0    2     4          iv  [B
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
            Name  Flags
      decrypting  
      algorithm   
      key         
      iv          

  void init(boolean, java.lang.String, byte[], byte[], int);
    descriptor: (ZLjava/lang/String;[B[BI)V
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // boolean decrypting
        start local 2 // java.lang.String algorithm
        start local 3 // byte[] keyValue
        start local 4 // byte[] ivValue
        start local 5 // int tagLenBytes
         0: .line 292
            aload 3 /* keyValue */
            ifnonnull 2
         1: .line 293
            new java.security.InvalidKeyException
            dup
            ldc "Internal error"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 295
      StackMap locals:
      StackMap stack:
            aload 4 /* ivValue */
            ifnonnull 4
         3: .line 296
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "Internal error"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 298
      StackMap locals:
      StackMap stack:
            aload 4 /* ivValue */
            arraylength
            ifne 6
         5: .line 299
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "IV is empty"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 303
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            iconst_0
            aload 2 /* algorithm */
            aload 3 /* keyValue */
            invokevirtual com.sun.crypto.provider.SymmetricCipher.init:(ZLjava/lang/String;[B)V
         7: .line 304
            aload 0 /* this */
            bipush 16
            newarray 8
            putfield com.sun.crypto.provider.GaloisCounterMode.subkeyH:[B
         8: .line 305
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            bipush 16
            newarray 8
            iconst_0
         9: .line 306
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.subkeyH:[B
            iconst_0
        10: .line 305
            invokevirtual com.sun.crypto.provider.SymmetricCipher.encryptBlock:([BI[BI)V
        11: .line 308
            aload 0 /* this */
            aload 4 /* ivValue */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
        12: .line 309
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.iv:[B
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.subkeyH:[B
            invokestatic com.sun.crypto.provider.GaloisCounterMode.getJ0:([B[B)[B
            putfield com.sun.crypto.provider.GaloisCounterMode.preCounterBlock:[B
        13: .line 310
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.preCounterBlock:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            astore 6 /* j0Plus1 */
        start local 6 // byte[] j0Plus1
        14: .line 311
            aload 6 /* j0Plus1 */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.increment32:([B)V
        15: .line 312
            aload 0 /* this */
            new com.sun.crypto.provider.GCTR
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            aload 6 /* j0Plus1 */
            invokespecial com.sun.crypto.provider.GCTR.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;[B)V
            putfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
        16: .line 313
            aload 0 /* this */
            new com.sun.crypto.provider.GHASH
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.subkeyH:[B
            invokespecial com.sun.crypto.provider.GHASH.<init>:([B)V
            putfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
        17: .line 315
            aload 0 /* this */
            iload 5 /* tagLenBytes */
            putfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
        18: .line 316
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnonnull 21
        19: .line 317
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
        20: .line 318
            goto 22
        21: .line 319
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
        22: .line 321
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
        23: .line 322
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
        24: .line 323
            iload 1 /* decrypting */
            ifeq 26
        25: .line 324
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
        26: .line 326
      StackMap locals:
      StackMap stack:
            return
        end local 6 // byte[] j0Plus1
        end local 5 // int tagLenBytes
        end local 4 // byte[] ivValue
        end local 3 // byte[] keyValue
        end local 2 // java.lang.String algorithm
        end local 1 // boolean decrypting
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   27     0         this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   27     1   decrypting  Z
            0   27     2    algorithm  Ljava/lang/String;
            0   27     3     keyValue  [B
            0   27     4      ivValue  [B
            0   27     5  tagLenBytes  I
           14   27     6      j0Plus1  [B
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
             Name  Flags
      decrypting   
      algorithm    
      keyValue     
      ivValue      
      tagLenBytes  

  void updateAAD(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0000) 
    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 353
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 3
         1: .line 354
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            aload 1 /* src */
            iload 2 /* offset */
            iload 3 /* len */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         2: .line 355
            goto 6
         3: .line 357
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
         4: .line 358
            ldc "Update has been called; no more AAD data"
         5: .line 357
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 360
      StackMap locals:
      StackMap stack:
            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    7     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0    7     1     src  [B
            0    7     2  offset  I
            0    7     3     len  I
    MethodParameters:
        Name  Flags
      src     
      offset  
      len     

  void processAAD();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 364
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            ifnull 14
         1: .line 365
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            ifle 13
         2: .line 366
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            astore 1 /* aad */
        start local 1 // byte[] aad
         3: .line 367
            aload 0 /* this */
            aload 1 /* aad */
            arraylength
            putfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
         4: .line 369
            aload 1 /* aad */
            arraylength
            bipush 16
            irem
            istore 2 /* lastLen */
        start local 2 // int lastLen
         5: .line 370
            iload 2 /* lastLen */
            ifeq 12
         6: .line 371
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 1 /* aad */
            iconst_0
            aload 1 /* aad */
            arraylength
            iload 2 /* lastLen */
            isub
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
         7: .line 372
            aload 1 /* aad */
            aload 1 /* aad */
            arraylength
            iload 2 /* lastLen */
            isub
         8: .line 373
            iload 2 /* lastLen */
         9: .line 372
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BII)[B
            astore 3 /* padded */
        start local 3 // byte[] padded
        10: .line 374
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 3 /* padded */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        end local 3 // byte[] padded
        11: .line 375
            goto 13
        12: .line 376
      StackMap locals: byte[] int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 1 /* aad */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        end local 2 // int lastLen
        end local 1 // byte[] aad
        13: .line 379
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.GaloisCounterMode.aadBuffer:Ljava/io/ByteArrayOutputStream;
        14: .line 381
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   15     0     this  Lcom/sun/crypto/provider/GaloisCounterMode;
            3   13     1      aad  [B
            5   13     2  lastLen  I
           10   11     3   padded  [B

  void doLastBlock(byte[], int, int, byte[], int, boolean);
    descriptor: ([BII[BIZ)V
    flags: (0x0000) 
    Code:
      stack=6, locals=13, args_size=7
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOfs
        start local 6 // boolean isEncrypt
         0: .line 388
            iload 3 /* len */
            istore 9 /* ilen */
        start local 9 // int ilen
         1: .line 390
            iload 6 /* isEncrypt */
            ifeq 5
         2: .line 391
            aload 4 /* out */
            astore 7 /* ct */
        start local 7 // byte[] ct
         3: .line 392
            iload 5 /* outOfs */
            istore 8 /* ctOfs */
        start local 8 // int ctOfs
         4: .line 393
            goto 7
        end local 8 // int ctOfs
        end local 7 // byte[] ct
         5: .line 394
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[] int int top top int
      StackMap stack:
            aload 1 /* in */
            astore 7 /* ct */
        start local 7 // byte[] ct
         6: .line 395
            iload 2 /* inOfs */
            istore 8 /* ctOfs */
        start local 8 // int ctOfs
         7: .line 399
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[] int int byte[] int int
      StackMap stack:
            iload 3 /* len */
            ldc 65536
            if_icmple 20
         8: .line 400
            iconst_0
            istore 10 /* i */
        start local 10 // int i
         9: .line 404
            iload 3 /* len */
            sipush 1024
            idiv
            istore 12 /* count */
        start local 12 // int count
        10: .line 406
            goto 17
        11: .line 407
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[] int int byte[] int int int top int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            aload 1 /* in */
            iload 2 /* inOfs */
            bipush 96
            aload 4 /* out */
            iload 5 /* outOfs */
            invokevirtual com.sun.crypto.provider.GCTR.update:([BII[BI)I
            istore 11 /* tlen */
        start local 11 // int tlen
        12: .line 408
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 7 /* ct */
            iload 8 /* ctOfs */
            iload 11 /* tlen */
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
        13: .line 409
            iload 2 /* inOfs */
            iload 11 /* tlen */
            iadd
            istore 2 /* inOfs */
        14: .line 410
            iload 5 /* outOfs */
            iload 11 /* tlen */
            iadd
            istore 5 /* outOfs */
        15: .line 411
            iload 8 /* ctOfs */
            iload 11 /* tlen */
            iadd
            istore 8 /* ctOfs */
        16: .line 412
            iinc 10 /* i */ 1
        end local 11 // int tlen
        17: .line 406
      StackMap locals:
      StackMap stack:
            iload 12 /* count */
            iload 10 /* i */
            if_icmpgt 11
        18: .line 414
            iload 9 /* ilen */
            iload 12 /* count */
            bipush 96
            imul
            isub
            istore 9 /* ilen */
        19: .line 415
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            iload 12 /* count */
            bipush 96
            imul
            iadd
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
        end local 12 // int count
        end local 10 // int i
        20: .line 418
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[] int int byte[] int int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 9 /* ilen */
            aload 4 /* out */
            iload 5 /* outOfs */
            invokevirtual com.sun.crypto.provider.GCTR.doFinal:([BII[BI)I
            pop
        21: .line 419
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            iload 9 /* ilen */
            iadd
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
        22: .line 421
            iload 9 /* ilen */
            bipush 16
            irem
            istore 10 /* lastLen */
        start local 10 // int lastLen
        23: .line 422
            iload 10 /* lastLen */
            ifeq 29
        24: .line 423
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 7 /* ct */
            iload 8 /* ctOfs */
            iload 9 /* ilen */
            iload 10 /* lastLen */
            isub
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
        25: .line 424
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
        26: .line 425
            aload 7 /* ct */
            iload 8 /* ctOfs */
            iload 9 /* ilen */
            iadd
            iload 10 /* lastLen */
            isub
            iload 10 /* lastLen */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.expandToOneBlock:([BII)[B
        27: .line 424
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        28: .line 426
            goto 30
        29: .line 427
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 7 /* ct */
            iload 8 /* ctOfs */
            iload 9 /* ilen */
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
        30: .line 429
      StackMap locals:
      StackMap stack:
            return
        end local 10 // int lastLen
        end local 9 // int ilen
        end local 8 // int ctOfs
        end local 7 // byte[] ct
        end local 6 // boolean isEncrypt
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   31     0       this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   31     1         in  [B
            0   31     2      inOfs  I
            0   31     3        len  I
            0   31     4        out  [B
            0   31     5     outOfs  I
            0   31     6  isEncrypt  Z
            3    5     7         ct  [B
            6   31     7         ct  [B
            4    5     8      ctOfs  I
            7   31     8      ctOfs  I
            1   31     9       ilen  I
            9   20    10          i  I
           12   17    11       tlen  I
           10   20    12      count  I
           23   31    10    lastLen  I
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException
    MethodParameters:
           Name  Flags
      in         
      inOfs      
      len        
      out        
      outOfs     
      isEncrypt  

  int encrypt(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=6, locals=6, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 449
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockSize:I
            invokestatic sun.security.util.ArrayUtil.blockSizeCheck:(II)V
         1: .line 451
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            iload 3 /* len */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.checkDataLength:(II)V
         2: .line 453
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.processAAD:()V
         3: .line 455
            iload 3 /* len */
            ifle 9
         4: .line 456
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         5: .line 457
            aload 4 /* out */
            iload 5 /* outOfs */
            iload 3 /* len */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         6: .line 459
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.gctrPAndC:Lcom/sun/crypto/provider/GCTR;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            aload 4 /* out */
            iload 5 /* outOfs */
            invokevirtual com.sun.crypto.provider.GCTR.update:([BII[BI)I
            pop
         7: .line 460
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            iload 3 /* len */
            iadd
            putfield com.sun.crypto.provider.GaloisCounterMode.processed:I
         8: .line 461
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 4 /* out */
            iload 5 /* outOfs */
            iload 3 /* len */
            invokevirtual com.sun.crypto.provider.GHASH.update:([BII)V
         9: .line 464
      StackMap locals:
      StackMap stack:
            iload 3 /* len */
            ireturn
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   10     1      in  [B
            0   10     2   inOfs  I
            0   10     3     len  I
            0   10     4     out  [B
            0   10     5  outOfs  I
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      len     
      out     
      outOfs  

  int encryptFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=7, locals=10, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 479
            iload 3 /* len */
            ldc 2147483647
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            isub
            if_icmple 4
         1: .line 480
            new javax.crypto.ShortBufferException
            dup
         2: .line 481
            ldc "Can't fit both data and tag into one buffer"
         3: .line 480
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 484
      StackMap locals:
      StackMap stack:
            aload 4 /* out */
            iload 5 /* outOfs */
         5: .line 485
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            iadd
         6: .line 484
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         7: .line 486
            goto 10
      StackMap locals:
      StackMap stack: java.lang.ArrayIndexOutOfBoundsException
         8: pop
         9: .line 487
            new javax.crypto.ShortBufferException
            dup
            ldc "Output buffer too small"
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 490
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            iload 3 /* len */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.checkDataLength:(II)V
        11: .line 492
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.processAAD:()V
        12: .line 493
            iload 3 /* len */
            ifle 15
        13: .line 494
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
        14: .line 496
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            aload 4 /* out */
            iload 5 /* outOfs */
            iconst_1
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.doLastBlock:([BII[BIZ)V
        15: .line 500
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            invokestatic com.sun.crypto.provider.GaloisCounterMode.getLengthBlock:(II)[B
        16: .line 499
            astore 6 /* lengthBlock */
        start local 6 // byte[] lengthBlock
        17: .line 501
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 6 /* lengthBlock */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        18: .line 502
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            invokevirtual com.sun.crypto.provider.GHASH.digest:()[B
            astore 7 /* s */
        start local 7 // byte[] s
        19: .line 503
            aload 7 /* s */
            arraylength
            newarray 8
            astore 8 /* sOut */
        start local 8 // byte[] sOut
        20: .line 504
            new com.sun.crypto.provider.GCTR
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.preCounterBlock:[B
            invokespecial com.sun.crypto.provider.GCTR.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;[B)V
            astore 9 /* gctrForSToTag */
        start local 9 // com.sun.crypto.provider.GCTR gctrForSToTag
        21: .line 505
            aload 9 /* gctrForSToTag */
            aload 7 /* s */
            iconst_0
            aload 7 /* s */
            arraylength
            aload 8 /* sOut */
            iconst_0
            invokevirtual com.sun.crypto.provider.GCTR.doFinal:([BII[BI)I
            pop
        22: .line 507
            aload 8 /* sOut */
            iconst_0
            aload 4 /* out */
            iload 5 /* outOfs */
            iload 3 /* len */
            iadd
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        23: .line 508
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            iadd
            ireturn
        end local 9 // com.sun.crypto.provider.GCTR gctrForSToTag
        end local 8 // byte[] sOut
        end local 7 // byte[] s
        end local 6 // byte[] lengthBlock
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   24     0           this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   24     1             in  [B
            0   24     2          inOfs  I
            0   24     3            len  I
            0   24     4            out  [B
            0   24     5         outOfs  I
           17   24     6    lengthBlock  [B
           19   24     7              s  [B
           20   24     8           sOut  [B
           21   24     9  gctrForSToTag  Lcom/sun/crypto/provider/GCTR;
      Exception table:
        from    to  target  type
           4     7       8  Class java.lang.ArrayIndexOutOfBoundsException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.ShortBufferException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      len     
      out     
      outOfs  

  int decrypt(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 529
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.blockSize:I
            invokestatic sun.security.util.ArrayUtil.blockSizeCheck:(II)V
         1: .line 531
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            iload 3 /* len */
            invokestatic com.sun.crypto.provider.GaloisCounterMode.checkDataLength:(II)V
         2: .line 533
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.processAAD:()V
         3: .line 535
            iload 3 /* len */
            ifle 6
         4: .line 539
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         5: .line 540
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         6: .line 542
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOfs
        end local 1 // byte[] in
        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      in  [B
            0    7     2   inOfs  I
            0    7     3     len  I
            0    7     4     out  [B
            0    7     5  outOfs  I
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      len     
      out     
      outOfs  

  int decryptFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=7, locals=13, args_size=6
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 565
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            if_icmpge 2
         1: .line 566
            new javax.crypto.AEADBadTagException
            dup
            ldc "Input too short - need tag"
            invokespecial javax.crypto.AEADBadTagException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 571
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            isub
            invokestatic com.sun.crypto.provider.GaloisCounterMode.checkDataLength:(II)V
         3: .line 574
            aload 4 /* out */
            iload 5 /* outOfs */
         4: .line 575
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            iload 3 /* len */
            iadd
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            isub
         5: .line 574
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
         6: .line 576
            goto 9
      StackMap locals:
      StackMap stack: java.lang.ArrayIndexOutOfBoundsException
         7: pop
         8: .line 577
            new javax.crypto.ShortBufferException
            dup
            ldc "Output buffer too small"
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 580
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.processAAD:()V
        10: .line 582
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokestatic sun.security.util.ArrayUtil.nullAndBoundsCheck:([BII)V
        11: .line 585
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            newarray 8
            astore 6 /* tag */
        start local 6 // byte[] tag
        12: .line 586
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            iadd
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            isub
            aload 6 /* tag */
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        13: .line 587
            iload 3 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            isub
            istore 3 /* len */
        14: .line 591
            aload 1 /* in */
            aload 4 /* out */
            if_acmpeq 15
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            ifle 21
        15: .line 592
      StackMap locals: byte[]
      StackMap stack:
            iload 3 /* len */
            ifle 17
        16: .line 593
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
        17: .line 597
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            astore 1 /* in */
        18: .line 598
            iconst_0
            istore 2 /* inOfs */
        19: .line 599
            aload 1 /* in */
            arraylength
            istore 3 /* len */
        20: .line 600
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
        21: .line 603
      StackMap locals:
      StackMap stack:
            iload 3 /* len */
            ifle 23
        22: .line 604
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* len */
            aload 4 /* out */
            iload 5 /* outOfs */
            iconst_0
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.doLastBlock:([BII[BIZ)V
        23: .line 608
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.sizeOfAAD:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.processed:I
            invokestatic com.sun.crypto.provider.GaloisCounterMode.getLengthBlock:(II)[B
        24: .line 607
            astore 7 /* lengthBlock */
        start local 7 // byte[] lengthBlock
        25: .line 609
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            aload 7 /* lengthBlock */
            invokevirtual com.sun.crypto.provider.GHASH.update:([B)V
        26: .line 611
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ghashAllToS:Lcom/sun/crypto/provider/GHASH;
            invokevirtual com.sun.crypto.provider.GHASH.digest:()[B
            astore 8 /* s */
        start local 8 // byte[] s
        27: .line 612
            aload 8 /* s */
            arraylength
            newarray 8
            astore 9 /* sOut */
        start local 9 // byte[] sOut
        28: .line 613
            new com.sun.crypto.provider.GCTR
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.embeddedCipher:Lcom/sun/crypto/provider/SymmetricCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.preCounterBlock:[B
            invokespecial com.sun.crypto.provider.GCTR.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;[B)V
            astore 10 /* gctrForSToTag */
        start local 10 // com.sun.crypto.provider.GCTR gctrForSToTag
        29: .line 614
            aload 10 /* gctrForSToTag */
            aload 8 /* s */
            iconst_0
            aload 8 /* s */
            arraylength
            aload 9 /* sOut */
            iconst_0
            invokevirtual com.sun.crypto.provider.GCTR.doFinal:([BII[BI)I
            pop
        30: .line 617
            iconst_0
            istore 11 /* mismatch */
        start local 11 // int mismatch
        31: .line 618
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        32: goto 35
        33: .line 619
      StackMap locals: com.sun.crypto.provider.GaloisCounterMode byte[] int int byte[] int byte[] byte[] byte[] byte[] com.sun.crypto.provider.GCTR int int
      StackMap stack:
            iload 11 /* mismatch */
            aload 6 /* tag */
            iload 12 /* i */
            baload
            aload 9 /* sOut */
            iload 12 /* i */
            baload
            ixor
            ior
            istore 11 /* mismatch */
        34: .line 618
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        35: iload 12 /* i */
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes:I
            if_icmplt 33
        end local 12 // int i
        36: .line 622
            iload 11 /* mismatch */
            ifeq 38
        37: .line 623
            new javax.crypto.AEADBadTagException
            dup
            ldc "Tag mismatch!"
            invokespecial javax.crypto.AEADBadTagException.<init>:(Ljava/lang/String;)V
            athrow
        38: .line 626
      StackMap locals:
      StackMap stack:
            iload 3 /* len */
            ireturn
        end local 11 // int mismatch
        end local 10 // com.sun.crypto.provider.GCTR gctrForSToTag
        end local 9 // byte[] sOut
        end local 8 // byte[] s
        end local 7 // byte[] lengthBlock
        end local 6 // byte[] tag
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   39     0           this  Lcom/sun/crypto/provider/GaloisCounterMode;
            0   39     1             in  [B
            0   39     2          inOfs  I
            0   39     3            len  I
            0   39     4            out  [B
            0   39     5         outOfs  I
           12   39     6            tag  [B
           25   39     7    lengthBlock  [B
           27   39     8              s  [B
           28   39     9           sOut  [B
           29   39    10  gctrForSToTag  Lcom/sun/crypto/provider/GCTR;
           31   39    11       mismatch  I
           32   36    12              i  I
      Exception table:
        from    to  target  type
           3     6       7  Class java.lang.ArrayIndexOutOfBoundsException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.AEADBadTagException, javax.crypto.ShortBufferException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      len     
      out     
      outOfs  

  int getTagLen();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 631
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.tagLenBytes: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;

  int getBufferedLength();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.GaloisCounterMode this
         0: .line 635
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            ifnonnull 2
         1: .line 636
            iconst_0
            ireturn
         2: .line 638
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.GaloisCounterMode.ibuffer:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            ireturn
        end local 0 // com.sun.crypto.provider.GaloisCounterMode this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/crypto/provider/GaloisCounterMode;
}
SourceFile: "GaloisCounterMode.java"