final class com.sun.crypto.provider.CipherCore
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.crypto.provider.CipherCore
  super_class: java.lang.Object
{
  private byte[] buffer;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  static final int GCM_MODE;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 7

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

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

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

  void <init>(com.sun.crypto.provider.SymmetricCipher, int);
    descriptor: (Lcom/sun/crypto/provider/SymmetricCipher;I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // com.sun.crypto.provider.SymmetricCipher impl
        start local 2 // int blkSize
         0: .line 150
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 60
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.buffer:[B
         2: .line 65
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.blockSize:I
         3: .line 70
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
         4: .line 75
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
         5: .line 87
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.minBytes:I
         6: .line 95
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
         7: .line 100
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
         8: .line 105
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
         9: .line 110
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        10: .line 115
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.decrypting:Z
        11: .line 142
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.requireReinit:Z
        12: .line 143
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.lastEncKey:[B
        13: .line 144
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.lastEncIv:[B
        14: .line 151
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.blockSize:I
        15: .line 152
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        16: .line 153
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        17: .line 160
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            iconst_2
            imul
            newarray 8
            putfield com.sun.crypto.provider.CipherCore.buffer:[B
        18: .line 163
            aload 0 /* this */
            new com.sun.crypto.provider.ElectronicCodeBook
            dup
            aload 1 /* impl */
            invokespecial com.sun.crypto.provider.ElectronicCodeBook.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        19: .line 164
            aload 0 /* this */
            new com.sun.crypto.provider.PKCS5Padding
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokespecial com.sun.crypto.provider.PKCS5Padding.<init>:(I)V
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        20: .line 165
            return
        end local 2 // int blkSize
        end local 1 // com.sun.crypto.provider.SymmetricCipher impl
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   21     0     this  Lcom/sun/crypto/provider/CipherCore;
            0   21     1     impl  Lcom/sun/crypto/provider/SymmetricCipher;
            0   21     2  blkSize  I
    MethodParameters:
         Name  Flags
      impl     
      blkSize  

  void setMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // java.lang.String mode
         0: .line 176
            aload 1 /* mode */
            ifnonnull 2
         1: .line 177
            new java.security.NoSuchAlgorithmException
            dup
            ldc "null mode"
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 179
      StackMap locals:
      StackMap stack:
            aload 1 /* mode */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
            astore 2 /* modeUpperCase */
        start local 2 // java.lang.String modeUpperCase
         3: .line 181
            aload 2 /* modeUpperCase */
            ldc "ECB"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 182
            return
         5: .line 185
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.getEmbeddedCipher:()Lcom/sun/crypto/provider/SymmetricCipher;
            astore 3 /* rawImpl */
        start local 3 // com.sun.crypto.provider.SymmetricCipher rawImpl
         6: .line 186
            aload 2 /* modeUpperCase */
            ldc "CBC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         7: .line 187
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
         8: .line 188
            aload 0 /* this */
            new com.sun.crypto.provider.CipherBlockChaining
            dup
            aload 3 /* rawImpl */
            invokespecial com.sun.crypto.provider.CipherBlockChaining.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
         9: .line 189
            goto 48
      StackMap locals: com.sun.crypto.provider.SymmetricCipher
      StackMap stack:
        10: aload 2 /* modeUpperCase */
            ldc "CTS"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
        11: .line 190
            aload 0 /* this */
            bipush 6
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        12: .line 191
            aload 0 /* this */
            new com.sun.crypto.provider.CipherTextStealing
            dup
            aload 3 /* rawImpl */
            invokespecial com.sun.crypto.provider.CipherTextStealing.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        13: .line 192
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            iconst_1
            iadd
            putfield com.sun.crypto.provider.CipherCore.minBytes:I
        14: .line 193
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        15: .line 194
            goto 48
      StackMap locals:
      StackMap stack:
        16: aload 2 /* modeUpperCase */
            ldc "CTR"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 22
        17: .line 195
            aload 0 /* this */
            iconst_5
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        18: .line 196
            aload 0 /* this */
            new com.sun.crypto.provider.CounterMode
            dup
            aload 3 /* rawImpl */
            invokespecial com.sun.crypto.provider.CounterMode.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        19: .line 197
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        20: .line 198
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        21: .line 199
            goto 48
      StackMap locals:
      StackMap stack:
        22: aload 2 /* modeUpperCase */
            ldc "GCM"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 31
        23: .line 201
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            bipush 16
            if_icmpeq 27
        24: .line 202
            new java.security.NoSuchAlgorithmException
            dup
        25: .line 203
            ldc "GCM mode can only be used for AES cipher"
        26: .line 202
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 205
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            bipush 7
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        28: .line 206
            aload 0 /* this */
            new com.sun.crypto.provider.GaloisCounterMode
            dup
            aload 3 /* rawImpl */
            invokespecial com.sun.crypto.provider.GaloisCounterMode.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        29: .line 207
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        30: .line 208
            goto 48
      StackMap locals:
      StackMap stack:
        31: aload 2 /* modeUpperCase */
            ldc "CFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 36
        32: .line 209
            aload 0 /* this */
            iconst_2
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        33: .line 210
            aload 0 /* this */
            aload 1 /* mode */
            ldc "CFB"
            invokevirtual java.lang.String.length:()I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokestatic com.sun.crypto.provider.CipherCore.getNumOfUnit:(Ljava/lang/String;II)I
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        34: .line 211
            aload 0 /* this */
            new com.sun.crypto.provider.CipherFeedback
            dup
            aload 3 /* rawImpl */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            invokespecial com.sun.crypto.provider.CipherFeedback.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;I)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        35: .line 212
            goto 48
      StackMap locals:
      StackMap stack:
        36: aload 2 /* modeUpperCase */
            ldc "OFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 41
        37: .line 213
            aload 0 /* this */
            iconst_3
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        38: .line 214
            aload 0 /* this */
            aload 1 /* mode */
            ldc "OFB"
            invokevirtual java.lang.String.length:()I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokestatic com.sun.crypto.provider.CipherCore.getNumOfUnit:(Ljava/lang/String;II)I
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        39: .line 215
            aload 0 /* this */
            new com.sun.crypto.provider.OutputFeedback
            dup
            aload 3 /* rawImpl */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            invokespecial com.sun.crypto.provider.OutputFeedback.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;I)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        40: .line 216
            goto 48
      StackMap locals:
      StackMap stack:
        41: aload 2 /* modeUpperCase */
            ldc "PCBC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 45
        42: .line 217
            aload 0 /* this */
            iconst_4
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        43: .line 218
            aload 0 /* this */
            new com.sun.crypto.provider.PCBC
            dup
            aload 3 /* rawImpl */
            invokespecial com.sun.crypto.provider.PCBC.<init>:(Lcom/sun/crypto/provider/SymmetricCipher;)V
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
        44: .line 219
            goto 48
        45: .line 221
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Cipher mode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        46: .line 222
            ldc " not found"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        47: .line 221
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        48: .line 224
      StackMap locals:
      StackMap stack:
            return
        end local 3 // com.sun.crypto.provider.SymmetricCipher rawImpl
        end local 2 // java.lang.String modeUpperCase
        end local 1 // java.lang.String mode
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   49     0           this  Lcom/sun/crypto/provider/CipherCore;
            0   49     1           mode  Ljava/lang/String;
            3   49     2  modeUpperCase  Ljava/lang/String;
            6   49     3        rawImpl  Lcom/sun/crypto/provider/SymmetricCipher;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  int getMode();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.CipherCore this
         0: .line 232
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ireturn
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/crypto/provider/CipherCore;

  private static int getNumOfUnit(java.lang.String, int, int);
    descriptor: (Ljava/lang/String;II)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // java.lang.String mode
        start local 1 // int offset
        start local 2 // int blockSize
         0: .line 237
            iload 2 /* blockSize */
            istore 3 /* result */
        start local 3 // int result
         1: .line 238
            aload 0 /* mode */
            invokevirtual java.lang.String.length:()I
            iload 1 /* offset */
            if_icmple 14
         2: .line 241
            aload 0 /* mode */
            iload 1 /* offset */
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.valueOf:(Ljava/lang/String;)Ljava/lang/Integer;
            astore 5 /* num */
        start local 5 // java.lang.Integer num
         3: .line 242
            aload 5 /* num */
            invokevirtual java.lang.Integer.intValue:()I
            istore 4 /* numInt */
        start local 4 // int numInt
         4: .line 243
            iload 4 /* numInt */
            iconst_3
            ishr
            istore 3 /* result */
        end local 5 // java.lang.Integer num
         5: .line 244
            goto 10
        end local 4 // int numInt
      StackMap locals: java.lang.String int int int
      StackMap stack: java.lang.NumberFormatException
         6: pop
         7: .line 245
            new java.security.NoSuchAlgorithmException
            dup
         8: .line 246
            new java.lang.StringBuilder
            dup
            ldc "Algorithm mode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not implemented"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 245
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 4 // int numInt
        10: .line 248
      StackMap locals: int
      StackMap stack:
            iload 4 /* numInt */
            bipush 8
            irem
            ifne 11
            iload 3 /* result */
            iload 2 /* blockSize */
            if_icmple 14
        11: .line 249
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        12: .line 250
            new java.lang.StringBuilder
            dup
            ldc "Invalid algorithm mode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 249
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // int numInt
        14: .line 253
      StackMap locals:
      StackMap stack:
            iload 3 /* result */
            ireturn
        end local 3 // int result
        end local 2 // int blockSize
        end local 1 // int offset
        end local 0 // java.lang.String mode
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   15     0       mode  Ljava/lang/String;
            0   15     1     offset  I
            0   15     2  blockSize  I
            1   15     3     result  I
            4    6     4     numInt  I
           10   14     4     numInt  I
            3    5     5        num  Ljava/lang/Integer;
      Exception table:
        from    to  target  type
           2     5       6  Class java.lang.NumberFormatException
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      mode       
      offset     
      blockSize  

  void setPadding(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // java.lang.String paddingScheme
         0: .line 267
            aload 1 /* paddingScheme */
            ifnonnull 2
         1: .line 268
            new javax.crypto.NoSuchPaddingException
            dup
            ldc "null padding"
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 270
      StackMap locals:
      StackMap stack:
            aload 1 /* paddingScheme */
            ldc "NoPadding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 5
         3: .line 271
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
         4: .line 272
            goto 12
      StackMap locals:
      StackMap stack:
         5: aload 1 /* paddingScheme */
            ldc "ISO10126Padding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 8
         6: .line 273
            aload 0 /* this */
            new com.sun.crypto.provider.ISO10126Padding
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokespecial com.sun.crypto.provider.ISO10126Padding.<init>:(I)V
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
         7: .line 274
            goto 12
      StackMap locals:
      StackMap stack:
         8: aload 1 /* paddingScheme */
            ldc "PKCS5Padding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 12
         9: .line 275
            new javax.crypto.NoSuchPaddingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Padding: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* paddingScheme */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        10: .line 276
            ldc " not implemented"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 275
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 278
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 27
        13: .line 279
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_5
            if_icmpeq 15
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 6
            if_icmpeq 15
        14: .line 280
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 27
        15: .line 281
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        16: .line 282
            aconst_null
            astore 2 /* modeStr */
        start local 2 // java.lang.String modeStr
        17: .line 283
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            tableswitch { // 5 - 7
                    5: 18
                    6: 22
                    7: 20
              default: 23
          }
        18: .line 285
      StackMap locals: java.lang.String
      StackMap stack:
            ldc "CTR"
            astore 2 /* modeStr */
        19: .line 286
            goto 23
        20: .line 288
      StackMap locals:
      StackMap stack:
            ldc "GCM"
            astore 2 /* modeStr */
        21: .line 289
            goto 23
        22: .line 291
      StackMap locals:
      StackMap stack:
            ldc "CTS"
            astore 2 /* modeStr */
        23: .line 296
      StackMap locals:
      StackMap stack:
            aload 2 /* modeStr */
            ifnull 27
        24: .line 297
            new javax.crypto.NoSuchPaddingException
            dup
        25: .line 298
            new java.lang.StringBuilder
            dup
            aload 2 /* modeStr */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " mode must be used with NoPadding"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 297
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.String modeStr
        27: .line 301
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String paddingScheme
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   28     0           this  Lcom/sun/crypto/provider/CipherCore;
            0   28     1  paddingScheme  Ljava/lang/String;
           17   27     2        modeStr  Ljava/lang/String;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
               Name  Flags
      paddingScheme  

  int getOutputSize(int);
    descriptor: (I)I
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // int inputLen
         0: .line 322
            aload 0 /* this */
            iload 1 /* inputLen */
            iconst_1
            invokevirtual com.sun.crypto.provider.CipherCore.getOutputSizeByOperation:(IZ)I
            ireturn
        end local 1 // int inputLen
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lcom/sun/crypto/provider/CipherCore;
            0    1     1  inputLen  I
    MethodParameters:
          Name  Flags
      inputLen  

  private int getOutputSizeByOperation(int, boolean);
    descriptor: (IZ)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // int inputLen
        start local 2 // boolean isDoFinal
         0: .line 326
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.getBufferedLength:()I
            invokestatic java.lang.Math.addExact:(II)I
            istore 3 /* totalLen */
        start local 3 // int totalLen
         1: .line 327
            iload 3 /* totalLen */
            iload 1 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
            istore 3 /* totalLen */
         2: .line 328
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            tableswitch { // 7 - 7
                    7: 3
              default: 12
          }
         3: .line 330
      StackMap locals: int
      StackMap stack:
            iload 2 /* isDoFinal */
            ifeq 9
         4: .line 331
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            checkcast com.sun.crypto.provider.GaloisCounterMode
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.getTagLen:()I
            istore 4 /* tagLen */
        start local 4 // int tagLen
         5: .line 332
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 8
         6: .line 333
            iload 3 /* totalLen */
            iload 4 /* tagLen */
            invokestatic java.lang.Math.addExact:(II)I
            istore 3 /* totalLen */
         7: .line 334
            goto 9
         8: .line 335
      StackMap locals: int
      StackMap stack:
            iload 3 /* totalLen */
            iload 4 /* tagLen */
            isub
            istore 3 /* totalLen */
        end local 4 // int tagLen
         9: .line 338
      StackMap locals:
      StackMap stack:
            iload 3 /* totalLen */
            ifge 21
        10: .line 339
            iconst_0
            istore 3 /* totalLen */
        11: .line 341
            goto 21
        12: .line 343
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 21
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 21
        13: .line 344
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 20
        14: .line 345
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 17
        15: .line 346
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            istore 3 /* totalLen */
        16: .line 347
            goto 21
        17: .line 348
      StackMap locals:
      StackMap stack:
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            irem
            istore 4 /* residue */
        start local 4 // int residue
        18: .line 349
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            iload 4 /* residue */
            isub
            invokestatic java.lang.Math.addExact:(II)I
            istore 3 /* totalLen */
        end local 4 // int residue
        19: .line 351
            goto 21
        20: .line 352
      StackMap locals:
      StackMap stack:
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            iload 3 /* totalLen */
            invokeinterface com.sun.crypto.provider.Padding.padLength:(I)I
            invokestatic java.lang.Math.addExact:(II)I
            istore 3 /* totalLen */
        21: .line 357
      StackMap locals:
      StackMap stack:
            iload 3 /* totalLen */
            ireturn
        end local 3 // int totalLen
        end local 2 // boolean isDoFinal
        end local 1 // int inputLen
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   22     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   22     1   inputLen  I
            0   22     2  isDoFinal  Z
            1   22     3   totalLen  I
            5    9     4     tagLen  I
           18   19     4    residue  I
    MethodParameters:
           Name  Flags
      inputLen   
      isDoFinal  

  byte[] getIV();
    descriptor: ()[B
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // com.sun.crypto.provider.CipherCore this
         0: .line 373
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.getIV:()[B
            astore 1 /* iv */
        start local 1 // byte[] iv
         1: .line 374
            aload 1 /* iv */
            ifnonnull 2
            aconst_null
            goto 3
      StackMap locals: byte[]
      StackMap stack:
         2: aload 1 /* iv */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
      StackMap locals:
      StackMap stack: byte[]
         3: areturn
        end local 1 // byte[] iv
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/sun/crypto/provider/CipherCore;
            1    4     1    iv  [B

  java.security.AlgorithmParameters getParameters(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/AlgorithmParameters;
    flags: (0x0000) 
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // java.lang.String algName
         0: .line 391
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifne 2
         1: .line 392
            aconst_null
            areturn
         2: .line 394
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* params */
        start local 2 // java.security.AlgorithmParameters params
         3: .line 396
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.getIV:()[B
            astore 4 /* iv */
        start local 4 // byte[] iv
         4: .line 397
            aload 4 /* iv */
            ifnonnull 10
         5: .line 399
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 8
         6: .line 400
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_IV_LEN:I
            newarray 8
            astore 4 /* iv */
         7: .line 401
            goto 9
         8: .line 402
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String java.security.AlgorithmParameters top byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            newarray 8
            astore 4 /* iv */
         9: .line 404
      StackMap locals:
      StackMap stack:
            invokestatic com.sun.crypto.provider.SunJCE.getRandom:()Ljava/security/SecureRandom;
            aload 4 /* iv */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
        10: .line 406
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 16
        11: .line 407
            ldc "GCM"
            astore 1 /* algName */
        12: .line 408
            new javax.crypto.spec.GCMParameterSpec
            dup
        13: .line 409
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            checkcast com.sun.crypto.provider.GaloisCounterMode
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.getTagLen:()I
            bipush 8
            imul
            aload 4 /* iv */
        14: .line 408
            invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
            astore 3 /* spec */
        start local 3 // java.security.spec.AlgorithmParameterSpec spec
        15: .line 410
            goto 23
        end local 3 // java.security.spec.AlgorithmParameterSpec spec
        16: .line 411
      StackMap locals:
      StackMap stack:
            aload 1 /* algName */
            ldc "RC2"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 22
        17: .line 412
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.getEmbeddedCipher:()Lcom/sun/crypto/provider/SymmetricCipher;
            checkcast com.sun.crypto.provider.RC2Crypt
            astore 5 /* rawImpl */
        start local 5 // com.sun.crypto.provider.RC2Crypt rawImpl
        18: .line 413
            new javax.crypto.spec.RC2ParameterSpec
            dup
        19: .line 414
            aload 5 /* rawImpl */
            invokevirtual com.sun.crypto.provider.RC2Crypt.getEffectiveKeyBits:()I
            aload 4 /* iv */
        20: .line 413
            invokespecial javax.crypto.spec.RC2ParameterSpec.<init>:(I[B)V
            astore 3 /* spec */
        end local 5 // com.sun.crypto.provider.RC2Crypt rawImpl
        start local 3 // java.security.spec.AlgorithmParameterSpec spec
        21: .line 415
            goto 23
        end local 3 // java.security.spec.AlgorithmParameterSpec spec
        22: .line 416
      StackMap locals:
      StackMap stack:
            new javax.crypto.spec.IvParameterSpec
            dup
            aload 4 /* iv */
            invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
            astore 3 /* spec */
        start local 3 // java.security.spec.AlgorithmParameterSpec spec
        23: .line 420
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String java.security.AlgorithmParameters java.security.spec.AlgorithmParameterSpec byte[]
      StackMap stack:
            aload 1 /* algName */
        24: .line 421
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
        25: .line 420
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
            astore 2 /* params */
        26: .line 422
            aload 2 /* params */
            aload 3 /* spec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
        27: .line 423
            goto 34
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
        28: pop
        29: .line 425
            new java.lang.RuntimeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Cannot find "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* algName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        30: .line 426
            ldc " AlgorithmParameters implementation in SunJCE provider"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        31: .line 425
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 427
      StackMap locals:
      StackMap stack: java.security.spec.InvalidParameterSpecException
            pop
        33: .line 429
            new java.lang.RuntimeException
            dup
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 3 /* spec */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " not supported"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        34: .line 431
      StackMap locals:
      StackMap stack:
            aload 2 /* params */
            areturn
        end local 4 // byte[] iv
        end local 3 // java.security.spec.AlgorithmParameterSpec spec
        end local 2 // java.security.AlgorithmParameters params
        end local 1 // java.lang.String algName
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   35     0     this  Lcom/sun/crypto/provider/CipherCore;
            0   35     1  algName  Ljava/lang/String;
            3   35     2   params  Ljava/security/AlgorithmParameters;
           15   16     3     spec  Ljava/security/spec/AlgorithmParameterSpec;
           21   22     3     spec  Ljava/security/spec/AlgorithmParameterSpec;
           23   35     3     spec  Ljava/security/spec/AlgorithmParameterSpec;
            4   35     4       iv  [B
           18   21     5  rawImpl  Lcom/sun/crypto/provider/RC2Crypt;
      Exception table:
        from    to  target  type
          23    27      28  Class java.security.NoSuchAlgorithmException
          23    27      32  Class java.security.spec.InvalidParameterSpecException
    MethodParameters:
         Name  Flags
      algName  

  void init(int, java.security.Key, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 467
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aconst_null
            aload 3 /* random */
            invokevirtual com.sun.crypto.provider.CipherCore.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         1: .line 468
            goto 4
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
         2: astore 4 /* e */
        start local 4 // java.security.InvalidAlgorithmParameterException e
         3: .line 469
            new java.security.InvalidKeyException
            dup
            aload 4 /* e */
            invokevirtual java.security.InvalidAlgorithmParameterException.getMessage:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.InvalidAlgorithmParameterException e
         4: .line 471
      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.CipherCore this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lcom/sun/crypto/provider/CipherCore;
            0    5     1  opmode  I
            0    5     2     key  Ljava/security/Key;
            0    5     3  random  Ljava/security/SecureRandom;
            3    4     4       e  Ljava/security/InvalidAlgorithmParameterException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.InvalidAlgorithmParameterException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      random  

  void init(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=9, args_size=5
        start local 0 // com.sun.crypto.provider.CipherCore 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 500
            aload 0 /* this */
            iload 1 /* opmode */
            iconst_2
            if_icmpeq 2
         1: .line 501
            iload 1 /* opmode */
            iconst_4
            if_icmpeq 2
            iconst_0
            goto 3
      StackMap locals:
      StackMap stack: com.sun.crypto.provider.CipherCore
         2: iconst_1
         3: .line 500
      StackMap locals: com.sun.crypto.provider.CipherCore int java.security.Key java.security.spec.AlgorithmParameterSpec java.security.SecureRandom
      StackMap stack: com.sun.crypto.provider.CipherCore int
            putfield com.sun.crypto.provider.CipherCore.decrypting:Z
         4: .line 503
            aload 2 /* key */
            invokestatic com.sun.crypto.provider.CipherCore.getKeyBytes:(Ljava/security/Key;)[B
            astore 5 /* keyBytes */
        start local 5 // byte[] keyBytes
         5: .line 504
            iconst_m1
            istore 6 /* tagLen */
        start local 6 // int tagLen
         6: .line 505
            aconst_null
            astore 7 /* ivBytes */
        start local 7 // byte[] ivBytes
         7: .line 506
            aload 3 /* params */
            ifnull 40
         8: .line 507
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 21
         9: .line 508
            aload 3 /* params */
            instanceof javax.crypto.spec.GCMParameterSpec
            ifeq 18
        10: .line 509
            aload 3 /* params */
            checkcast javax.crypto.spec.GCMParameterSpec
            invokevirtual javax.crypto.spec.GCMParameterSpec.getTLen:()I
            istore 6 /* tagLen */
        11: .line 510
            iload 6 /* tagLen */
            bipush 96
            if_icmplt 12
            iload 6 /* tagLen */
            sipush 128
            if_icmpgt 12
            iload 6 /* tagLen */
            bipush 7
            iand
            ifeq 15
        12: .line 511
      StackMap locals: byte[] int byte[]
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        13: .line 512
            ldc "Unsupported TLen value; must be one of {128, 120, 112, 104, 96}"
        14: .line 511
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 515
      StackMap locals:
      StackMap stack:
            iload 6 /* tagLen */
            iconst_3
            ishr
            istore 6 /* tagLen */
        16: .line 516
            aload 3 /* params */
            checkcast javax.crypto.spec.GCMParameterSpec
            invokevirtual javax.crypto.spec.GCMParameterSpec.getIV:()[B
            astore 7 /* ivBytes */
        17: .line 517
            goto 40
        18: .line 518
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        19: .line 519
            new java.lang.StringBuilder
            dup
            ldc "Unsupported parameter: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* params */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 518
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 522
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.IvParameterSpec
            ifeq 29
        22: .line 523
            aload 3 /* params */
            checkcast javax.crypto.spec.IvParameterSpec
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
            astore 7 /* ivBytes */
        23: .line 524
            aload 7 /* ivBytes */
            ifnull 24
            aload 7 /* ivBytes */
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 40
        24: .line 525
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        25: .line 526
            new java.lang.StringBuilder
            dup
            ldc "Wrong IV length: must be "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        26: .line 527
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        27: .line 526
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        28: .line 525
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 529
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.RC2ParameterSpec
            ifeq 37
        30: .line 530
            aload 3 /* params */
            checkcast javax.crypto.spec.RC2ParameterSpec
            invokevirtual javax.crypto.spec.RC2ParameterSpec.getIV:()[B
            astore 7 /* ivBytes */
        31: .line 531
            aload 7 /* ivBytes */
            ifnull 40
            aload 7 /* ivBytes */
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 40
        32: .line 532
            new java.security.InvalidAlgorithmParameterException
            dup
        33: .line 533
            new java.lang.StringBuilder
            dup
            ldc "Wrong IV length: must be "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        34: .line 534
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        35: .line 533
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        36: .line 532
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        37: .line 537
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        38: .line 538
            new java.lang.StringBuilder
            dup
            ldc "Unsupported parameter: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* params */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        39: .line 537
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        40: .line 542
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifne 45
        41: .line 543
            aload 7 /* ivBytes */
            ifnull 55
        42: .line 544
            new java.security.InvalidAlgorithmParameterException
            dup
        43: .line 545
            ldc "ECB mode cannot use IV"
        44: .line 544
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        45: .line 547
      StackMap locals:
      StackMap stack:
            aload 7 /* ivBytes */
            ifnonnull 55
        46: .line 548
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 48
        47: .line 549
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "Parameters missing"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        48: .line 553
      StackMap locals:
      StackMap stack:
            aload 4 /* random */
            ifnonnull 50
        49: .line 554
            invokestatic com.sun.crypto.provider.SunJCE.getRandom:()Ljava/security/SecureRandom;
            astore 4 /* random */
        50: .line 556
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 53
        51: .line 557
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_IV_LEN:I
            newarray 8
            astore 7 /* ivBytes */
        52: .line 558
            goto 54
        53: .line 559
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            newarray 8
            astore 7 /* ivBytes */
        54: .line 561
      StackMap locals:
      StackMap stack:
            aload 4 /* random */
            aload 7 /* ivBytes */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
        55: .line 564
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        56: .line 565
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        57: .line 567
            aload 2 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            astore 8 /* algorithm */
        start local 8 // java.lang.String algorithm
        58: .line 570
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 79
        59: .line 571
            iload 6 /* tagLen */
            iconst_m1
            if_icmpne 61
        60: .line 572
            getstatic com.sun.crypto.provider.GaloisCounterMode.DEFAULT_TAG_LEN:I
            istore 6 /* tagLen */
        61: .line 574
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 64
        62: .line 575
            aload 0 /* this */
            iload 6 /* tagLen */
            putfield com.sun.crypto.provider.CipherCore.minBytes:I
        63: .line 576
            goto 75
        64: .line 578
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        65: .line 579
            aload 7 /* ivBytes */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.lastEncIv:[B
            invokestatic java.util.Arrays.equals:([B[B)Z
            ifeq 67
        66: .line 580
            aload 5 /* keyBytes */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.lastEncKey:[B
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifeq 67
            iconst_1
            goto 68
      StackMap locals:
      StackMap stack: com.sun.crypto.provider.CipherCore
        67: iconst_0
        68: .line 578
      StackMap locals: com.sun.crypto.provider.CipherCore int java.security.Key java.security.spec.AlgorithmParameterSpec java.security.SecureRandom byte[] int byte[] java.lang.String
      StackMap stack: com.sun.crypto.provider.CipherCore int
            putfield com.sun.crypto.provider.CipherCore.requireReinit:Z
        69: .line 581
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.requireReinit:Z
            ifeq 73
        70: .line 582
            new java.security.InvalidAlgorithmParameterException
            dup
        71: .line 583
            ldc "Cannot reuse iv for GCM encryption"
        72: .line 582
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        73: .line 585
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 7 /* ivBytes */
            putfield com.sun.crypto.provider.CipherCore.lastEncIv:[B
        74: .line 586
            aload 0 /* this */
            aload 5 /* keyBytes */
            putfield com.sun.crypto.provider.CipherCore.lastEncKey:[B
        75: .line 588
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            checkcast com.sun.crypto.provider.GaloisCounterMode
        76: .line 589
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            aload 8 /* algorithm */
            aload 5 /* keyBytes */
            aload 7 /* ivBytes */
            iload 6 /* tagLen */
        77: .line 588
            invokevirtual com.sun.crypto.provider.GaloisCounterMode.init:(ZLjava/lang/String;[B[BI)V
        78: .line 590
            goto 80
        79: .line 591
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            aload 8 /* algorithm */
            aload 5 /* keyBytes */
            aload 7 /* ivBytes */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.init:(ZLjava/lang/String;[B[B)V
        80: .line 594
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.requireReinit:Z
        81: .line 595
            return
        end local 8 // java.lang.String algorithm
        end local 7 // byte[] ivBytes
        end local 6 // int tagLen
        end local 5 // byte[] keyBytes
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   82     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   82     1     opmode  I
            0   82     2        key  Ljava/security/Key;
            0   82     3     params  Ljava/security/spec/AlgorithmParameterSpec;
            0   82     4     random  Ljava/security/SecureRandom;
            5   82     5   keyBytes  [B
            6   82     6     tagLen  I
            7   82     7    ivBytes  [B
           58   82     8  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  void init(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // com.sun.crypto.provider.CipherCore 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 600
            aconst_null
            astore 5 /* spec */
        start local 5 // java.security.spec.AlgorithmParameterSpec spec
         1: .line 601
            aconst_null
            astore 6 /* paramType */
        start local 6 // java.lang.String paramType
         2: .line 602
            aload 3 /* params */
            ifnull 14
         3: .line 604
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 7
         4: .line 605
            ldc "GCM"
            astore 6 /* paramType */
         5: .line 606
            aload 3 /* params */
            ldc Ljavax/crypto/spec/GCMParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            astore 5 /* spec */
         6: .line 607
            goto 14
         7: .line 611
      StackMap locals: java.security.spec.AlgorithmParameterSpec java.lang.String
      StackMap stack:
            ldc "IV"
            astore 6 /* paramType */
         8: .line 612
            aload 3 /* params */
            ldc Ljavax/crypto/spec/IvParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            astore 5 /* spec */
         9: .line 614
            goto 14
      StackMap locals:
      StackMap stack: java.security.spec.InvalidParameterSpecException
        10: pop
        11: .line 615
            new java.security.InvalidAlgorithmParameterException
            dup
        12: .line 616
            new java.lang.StringBuilder
            dup
            ldc "Wrong parameter type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* paramType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " expected"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 615
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 619
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aload 5 /* spec */
            aload 4 /* random */
            invokevirtual com.sun.crypto.provider.CipherCore.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
        15: .line 620
            return
        end local 6 // java.lang.String paramType
        end local 5 // java.security.spec.AlgorithmParameterSpec 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.CipherCore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   16     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   16     1     opmode  I
            0   16     2        key  Ljava/security/Key;
            0   16     3     params  Ljava/security/AlgorithmParameters;
            0   16     4     random  Ljava/security/SecureRandom;
            1   16     5       spec  Ljava/security/spec/AlgorithmParameterSpec;
            2   16     6  paramType  Ljava/lang/String;
      Exception table:
        from    to  target  type
           3     9      10  Class java.security.spec.InvalidParameterSpecException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  static byte[] getKeyBytes(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.security.Key key
         0: .line 627
            aload 0 /* key */
            ifnonnull 2
         1: .line 628
            new java.security.InvalidKeyException
            dup
            ldc "No key given"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 631
      StackMap locals:
      StackMap stack:
            ldc "RAW"
            aload 0 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 4
         3: .line 632
            new java.security.InvalidKeyException
            dup
            ldc "Wrong format: RAW bytes needed"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 634
      StackMap locals:
      StackMap stack:
            aload 0 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 1 /* keyBytes */
        start local 1 // byte[] keyBytes
         5: .line 635
            aload 1 /* keyBytes */
            ifnonnull 7
         6: .line 636
            new java.security.InvalidKeyException
            dup
            ldc "RAW key bytes missing"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 638
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* keyBytes */
            areturn
        end local 1 // byte[] keyBytes
        end local 0 // java.security.Key key
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    8     0       key  Ljava/security/Key;
            5    8     1  keyBytes  [B
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  byte[] update(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0000) 
    Code:
      stack=6, locals=7, args_size=4
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 662
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.checkReinit:()V
         1: .line 664
            aconst_null
            astore 4 /* output */
        start local 4 // byte[] output
         2: .line 666
            aload 0 /* this */
            iload 3 /* inputLen */
            iconst_0
            invokevirtual com.sun.crypto.provider.CipherCore.getOutputSizeByOperation:(IZ)I
            newarray 8
            astore 4 /* output */
         3: .line 667
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
         4: .line 668
            iconst_0
         5: .line 667
            invokevirtual com.sun.crypto.provider.CipherCore.update:([BII[BI)I
            istore 5 /* len */
        start local 5 // int len
         6: .line 669
            iload 5 /* len */
            aload 4 /* output */
            arraylength
            if_icmpne 9
         7: .line 670
            aload 4 /* output */
         8: areturn
         9: .line 672
      StackMap locals: byte[] int
      StackMap stack:
            aload 4 /* output */
            iload 5 /* len */
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 6 /* copy */
        start local 6 // byte[] copy
        10: .line 673
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 12
        11: .line 675
            aload 4 /* output */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        12: .line 677
      StackMap locals: byte[]
      StackMap stack:
            aload 6 /* copy */
        13: areturn
        end local 6 // byte[] copy
        end local 5 // int len
        14: .line 679
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int int byte[]
      StackMap stack: javax.crypto.ShortBufferException
            astore 5 /* e */
        start local 5 // javax.crypto.ShortBufferException e
        15: .line 681
            new java.security.ProviderException
            dup
            ldc "Unexpected exception"
            aload 5 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // javax.crypto.ShortBufferException e
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   16     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   16     1        input  [B
            0   16     2  inputOffset  I
            0   16     3     inputLen  I
            2   16     4       output  [B
            6   14     5          len  I
           10   14     6         copy  [B
           15   16     5            e  Ljavax/crypto/ShortBufferException;
      Exception table:
        from    to  target  type
           2     8      14  Class javax.crypto.ShortBufferException
           9    13      14  Class javax.crypto.ShortBufferException
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  int update(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=7, locals=11, args_size=6
        start local 0 // com.sun.crypto.provider.CipherCore 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 710
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.checkReinit:()V
         1: .line 713
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
            istore 6 /* len */
        start local 6 // int len
         2: .line 714
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.minBytes:I
            isub
            istore 6 /* len */
         3: .line 715
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 5
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 5
         4: .line 717
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            isub
            istore 6 /* len */
         5: .line 720
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            ifle 6
            iload 6 /* len */
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            isub
            goto 7
      StackMap locals:
      StackMap stack:
         6: iconst_0
      StackMap locals:
      StackMap stack: int
         7: istore 6 /* len */
         8: .line 723
            aload 4 /* output */
            ifnull 10
         9: .line 724
            aload 4 /* output */
            arraylength
            iload 5 /* outputOffset */
            isub
            iload 6 /* len */
            if_icmpge 14
        10: .line 725
      StackMap locals:
      StackMap stack:
            new javax.crypto.ShortBufferException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Output buffer must be (at least) "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 726
            iload 6 /* len */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        12: .line 727
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 725
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 730
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 7 /* outLen */
        start local 7 // int outLen
        15: .line 731
            iload 6 /* len */
            ifeq 69
        16: .line 732
            aload 1 /* input */
            aload 4 /* output */
            if_acmpne 23
        17: .line 733
            iload 5 /* outputOffset */
            iload 2 /* inputOffset */
            isub
            iload 3 /* inputLen */
            if_icmpge 23
        18: .line 734
            iload 2 /* inputOffset */
            iload 5 /* outputOffset */
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            arraylength
            if_icmpge 23
        19: .line 737
            aload 1 /* input */
            iload 2 /* inputOffset */
        20: .line 738
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
        21: .line 737
            invokestatic java.util.Arrays.copyOfRange:([BII)[B
            astore 1 /* input */
        22: .line 739
            iconst_0
            istore 2 /* inputOffset */
        23: .line 741
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            if_icmpgt 32
        24: .line 743
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 27
        25: .line 744
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            iload 6 /* len */
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.decrypt:([BII[BI)I
            istore 7 /* outLen */
        26: .line 745
            goto 28
        27: .line 746
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            iload 6 /* len */
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.encrypt:([BII[BI)I
            istore 7 /* outLen */
        28: .line 748
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 6 /* len */
            isub
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        29: .line 749
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifeq 62
        30: .line 750
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        31: .line 752
            goto 62
        32: .line 753
      StackMap locals:
      StackMap stack:
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            isub
            istore 8 /* inputConsumed */
        start local 8 // int inputConsumed
        33: .line 755
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifle 51
        34: .line 756
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            isub
            istore 10 /* bufferCapacity */
        start local 10 // int bufferCapacity
        35: .line 757
            iload 10 /* bufferCapacity */
            ifeq 44
        36: .line 758
            iload 10 /* bufferCapacity */
            iload 8 /* inputConsumed */
            invokestatic java.lang.Math.min:(II)I
            istore 9 /* temp */
        start local 9 // int temp
        37: .line 759
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 39
        38: .line 760
            iload 9 /* temp */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 9 /* temp */
            invokestatic java.lang.Math.addExact:(II)I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            isub
            istore 9 /* temp */
        39: .line 762
      StackMap locals: int int int
      StackMap stack:
            aload 1 /* input */
            iload 2 /* inputOffset */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 9 /* temp */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        40: .line 763
            iload 2 /* inputOffset */
            iload 9 /* temp */
            invokestatic java.lang.Math.addExact:(II)I
            istore 2 /* inputOffset */
        41: .line 764
            iload 8 /* inputConsumed */
            iload 9 /* temp */
            isub
            istore 8 /* inputConsumed */
        42: .line 765
            iload 3 /* inputLen */
            iload 9 /* temp */
            isub
            istore 3 /* inputLen */
        43: .line 766
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 9 /* temp */
            invokestatic java.lang.Math.addExact:(II)I
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        end local 9 // int temp
        44: .line 770
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int int byte[] int int int int top int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 47
        45: .line 771
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.decrypt:([BII[BI)I
            istore 7 /* outLen */
        46: .line 772
            goto 49
        47: .line 773
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.encrypt:([BII[BI)I
            istore 7 /* outLen */
        48: .line 775
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        49: .line 777
      StackMap locals:
      StackMap stack:
            iload 5 /* outputOffset */
            iload 7 /* outLen */
            invokestatic java.lang.Math.addExact:(II)I
            istore 5 /* outputOffset */
        50: .line 778
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        end local 10 // int bufferCapacity
        51: .line 780
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int int byte[] int int int int
      StackMap stack:
            iload 8 /* inputConsumed */
            ifle 62
        52: .line 781
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 57
        53: .line 782
            iload 7 /* outLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 8 /* inputConsumed */
        54: .line 783
            aload 4 /* output */
            iload 5 /* outputOffset */
        55: .line 782
            invokevirtual com.sun.crypto.provider.FeedbackCipher.decrypt:([BII[BI)I
            iadd
            istore 7 /* outLen */
        56: .line 784
            goto 60
        57: .line 785
      StackMap locals:
      StackMap stack:
            iload 7 /* outLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 8 /* inputConsumed */
        58: .line 786
            aload 4 /* output */
            iload 5 /* outputOffset */
        59: .line 785
            invokevirtual com.sun.crypto.provider.FeedbackCipher.encrypt:([BII[BI)I
            iadd
            istore 7 /* outLen */
        60: .line 788
      StackMap locals:
      StackMap stack:
            iload 2 /* inputOffset */
            iload 8 /* inputConsumed */
            iadd
            istore 2 /* inputOffset */
        61: .line 789
            iload 3 /* inputLen */
            iload 8 /* inputConsumed */
            isub
            istore 3 /* inputLen */
        end local 8 // int inputConsumed
        62: .line 795
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 69
        63: .line 796
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 66
        64: .line 797
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            iload 6 /* len */
            isub
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        65: .line 798
            goto 69
        66: .line 799
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
        67: .line 800
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            irem
            isub
        68: .line 799
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        69: .line 805
      StackMap locals:
      StackMap stack:
            iload 3 /* inputLen */
            ifle 74
        70: .line 806
            aload 1 /* input */
            iload 2 /* inputOffset */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
        71: .line 807
            iload 3 /* inputLen */
        72: .line 806
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        73: .line 808
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        74: .line 810
      StackMap locals:
      StackMap stack:
            iload 7 /* outLen */
            ireturn
        end local 7 // int outLen
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   75     0            this  Lcom/sun/crypto/provider/CipherCore;
            0   75     1           input  [B
            0   75     2     inputOffset  I
            0   75     3        inputLen  I
            0   75     4          output  [B
            0   75     5    outputOffset  I
            2   75     6             len  I
           15   75     7          outLen  I
           33   62     8   inputConsumed  I
           37   44     9            temp  I
           35   51    10  bufferCapacity  I
    Exceptions:
      throws javax.crypto.ShortBufferException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  byte[] doFinal(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0000) 
    Code:
      stack=7, locals=10, args_size=4
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 846
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.checkReinit:()V
         1: .line 847
            aload 0 /* this */
            iload 3 /* inputLen */
            iconst_1
            invokevirtual com.sun.crypto.provider.CipherCore.getOutputSizeByOperation:(IZ)I
            newarray 8
            astore 4 /* output */
        start local 4 // byte[] output
         2: .line 848
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
         3: .line 849
            iload 3 /* inputLen */
            aload 4 /* output */
            iconst_0
         4: .line 848
            invokevirtual com.sun.crypto.provider.CipherCore.prepareInputBuffer:([BII[BI)[B
            astore 5 /* finalBuf */
        start local 5 // byte[] finalBuf
         5: .line 850
            aload 5 /* finalBuf */
            aload 1 /* input */
            if_acmpne 6
            iload 2 /* inputOffset */
            goto 7
      StackMap locals: byte[] byte[]
      StackMap stack:
         6: iconst_0
      StackMap locals:
      StackMap stack: int
         7: istore 6 /* finalOffset */
        start local 6 // int finalOffset
         8: .line 851
            aload 5 /* finalBuf */
            aload 1 /* input */
            if_acmpne 9
            iload 3 /* inputLen */
            goto 10
      StackMap locals: int
      StackMap stack:
         9: aload 5 /* finalBuf */
            arraylength
      StackMap locals:
      StackMap stack: int
        10: istore 7 /* finalBufLen */
        start local 7 // int finalBufLen
        11: .line 853
            aload 0 /* this */
            aload 5 /* finalBuf */
            iload 6 /* finalOffset */
            aload 4 /* output */
            iconst_0
        12: .line 854
            iload 7 /* finalBufLen */
            aload 1 /* input */
        13: .line 853
            invokevirtual com.sun.crypto.provider.CipherCore.fillOutputBuffer:([BI[BII[B)I
            istore 8 /* outLen */
        start local 8 // int outLen
        14: .line 856
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.endDoFinal:()V
        15: .line 857
            iload 8 /* outLen */
            aload 4 /* output */
            arraylength
            if_icmpge 21
        16: .line 858
            aload 4 /* output */
            iload 8 /* outLen */
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 9 /* copy */
        start local 9 // byte[] copy
        17: .line 859
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 19
        18: .line 861
            aload 4 /* output */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        19: .line 863
      StackMap locals: int int byte[]
      StackMap stack:
            aload 9 /* copy */
        20: areturn
        end local 9 // byte[] copy
        21: .line 865
      StackMap locals:
      StackMap stack:
            aload 4 /* output */
        22: areturn
        end local 8 // int outLen
        end local 7 // int finalBufLen
        end local 6 // int finalOffset
        end local 5 // byte[] finalBuf
        end local 4 // byte[] output
        23: .line 867
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int int
      StackMap stack: javax.crypto.ShortBufferException
            astore 4 /* e */
        start local 4 // javax.crypto.ShortBufferException e
        24: .line 869
            new java.security.ProviderException
            dup
            ldc "Unexpected exception"
            aload 4 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // javax.crypto.ShortBufferException e
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   25     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   25     1        input  [B
            0   25     2  inputOffset  I
            0   25     3     inputLen  I
            2   23     4       output  [B
            5   23     5     finalBuf  [B
            8   23     6  finalOffset  I
           11   23     7  finalBufLen  I
           14   23     8       outLen  I
           17   21     9         copy  [B
           24   25     4            e  Ljavax/crypto/ShortBufferException;
      Exception table:
        from    to  target  type
           0    20      23  Class javax.crypto.ShortBufferException
          21    22      23  Class javax.crypto.ShortBufferException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  int doFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0000) 
    Code:
      stack=7, locals=15, args_size=6
        start local 0 // com.sun.crypto.provider.CipherCore 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 913
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.checkReinit:()V
         1: .line 915
            aload 0 /* this */
            iload 3 /* inputLen */
            iconst_1
            invokevirtual com.sun.crypto.provider.CipherCore.getOutputSizeByOperation:(IZ)I
            istore 6 /* estOutSize */
        start local 6 // int estOutSize
         2: .line 916
            aload 0 /* this */
            aload 4 /* output */
            iload 5 /* outputOffset */
         3: .line 917
            iload 6 /* estOutSize */
         4: .line 916
            invokevirtual com.sun.crypto.provider.CipherCore.checkOutputCapacity:([BII)I
            istore 7 /* outputCapacity */
        start local 7 // int outputCapacity
         5: .line 918
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 6
            iconst_0
            goto 7
      StackMap locals: int int
      StackMap stack:
         6: iload 5 /* outputOffset */
      StackMap locals:
      StackMap stack: int
         7: istore 8 /* offset */
        start local 8 // int offset
         8: .line 919
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
         9: .line 920
            iload 3 /* inputLen */
            aload 4 /* output */
            iload 5 /* outputOffset */
        10: .line 919
            invokevirtual com.sun.crypto.provider.CipherCore.prepareInputBuffer:([BII[BI)[B
            astore 9 /* finalBuf */
        start local 9 // byte[] finalBuf
        11: .line 921
            aconst_null
            astore 10 /* outWithPadding */
        start local 10 // byte[] outWithPadding
        12: .line 923
            aload 9 /* finalBuf */
            aload 1 /* input */
            if_acmpne 13
            iload 2 /* inputOffset */
            goto 14
      StackMap locals: int byte[] byte[]
      StackMap stack:
        13: iconst_0
      StackMap locals:
      StackMap stack: int
        14: istore 11 /* finalOffset */
        start local 11 // int finalOffset
        15: .line 924
            aload 9 /* finalBuf */
            aload 1 /* input */
            if_acmpne 16
            iload 3 /* inputLen */
            goto 17
      StackMap locals: int
      StackMap stack:
        16: aload 9 /* finalBuf */
            arraylength
      StackMap locals:
      StackMap stack: int
        17: istore 12 /* finalBufLen */
        start local 12 // int finalBufLen
        18: .line 926
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 22
        19: .line 932
            iload 7 /* outputCapacity */
            iload 6 /* estOutSize */
            if_icmpge 21
        20: .line 933
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.save:()V
        21: .line 937
      StackMap locals: int
      StackMap stack:
            iload 6 /* estOutSize */
            newarray 8
            astore 10 /* outWithPadding */
        22: .line 939
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 23
            aload 10 /* outWithPadding */
            goto 24
      StackMap locals:
      StackMap stack:
        23: aload 4 /* output */
      StackMap locals:
      StackMap stack: byte[]
        24: astore 13 /* outBuffer */
        start local 13 // byte[] outBuffer
        25: .line 941
            aload 0 /* this */
            aload 9 /* finalBuf */
            iload 11 /* finalOffset */
            aload 13 /* outBuffer */
        26: .line 942
            iload 8 /* offset */
            iload 12 /* finalBufLen */
            aload 1 /* input */
        27: .line 941
            invokevirtual com.sun.crypto.provider.CipherCore.fillOutputBuffer:([BI[BII[B)I
            istore 14 /* outLen */
        start local 14 // int outLen
        28: .line 944
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 38
        29: .line 946
            iload 7 /* outputCapacity */
            iload 14 /* outLen */
            if_icmpge 36
        30: .line 948
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.restore:()V
        31: .line 949
            new javax.crypto.ShortBufferException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Output buffer too short: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        32: .line 950
            iload 7 /* outputCapacity */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        33: .line 951
            ldc " bytes given, "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 14 /* outLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        34: .line 952
            ldc " bytes needed"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 949
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 955
      StackMap locals: byte[] int
      StackMap stack:
            aload 10 /* outWithPadding */
            iconst_0
            aload 4 /* output */
            iload 5 /* outputOffset */
            iload 14 /* outLen */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        37: .line 957
            aload 10 /* outWithPadding */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        38: .line 959
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.endDoFinal:()V
        39: .line 960
            iload 14 /* outLen */
            ireturn
        end local 14 // int outLen
        end local 13 // byte[] outBuffer
        end local 12 // int finalBufLen
        end local 11 // int finalOffset
        end local 10 // byte[] outWithPadding
        end local 9 // byte[] finalBuf
        end local 8 // int offset
        end local 7 // int outputCapacity
        end local 6 // int estOutSize
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   40     0            this  Lcom/sun/crypto/provider/CipherCore;
            0   40     1           input  [B
            0   40     2     inputOffset  I
            0   40     3        inputLen  I
            0   40     4          output  [B
            0   40     5    outputOffset  I
            2   40     6      estOutSize  I
            5   40     7  outputCapacity  I
            8   40     8          offset  I
           11   40     9        finalBuf  [B
           12   40    10  outWithPadding  [B
           15   40    11     finalOffset  I
           18   40    12     finalBufLen  I
           25   40    13       outBuffer  [B
           28   40    14          outLen  I
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.ShortBufferException, javax.crypto.BadPaddingException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  private void endDoFinal();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.CipherCore this
         0: .line 964
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
         1: .line 965
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
         2: .line 966
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifeq 4
         3: .line 967
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.reset:()V
         4: .line 969
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/sun/crypto/provider/CipherCore;

  private int unpad(int, byte[]);
    descriptor: (I[B)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // int outLen
        start local 2 // byte[] outWithPadding
         0: .line 973
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            aload 2 /* outWithPadding */
            iconst_0
            iload 1 /* outLen */
            invokeinterface com.sun.crypto.provider.Padding.unpad:([BII)I
            istore 3 /* padStart */
        start local 3 // int padStart
         1: .line 974
            iload 3 /* padStart */
            ifge 3
         2: .line 975
            new javax.crypto.BadPaddingException
            dup
            ldc "Given final block not properly padded. Such issues can arise if a bad key is used during decryption."
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 979
      StackMap locals: int
      StackMap stack:
            iload 3 /* padStart */
            istore 1 /* outLen */
         4: .line 980
            iload 1 /* outLen */
            ireturn
        end local 3 // int padStart
        end local 2 // byte[] outWithPadding
        end local 1 // int outLen
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    5     0            this  Lcom/sun/crypto/provider/CipherCore;
            0    5     1          outLen  I
            0    5     2  outWithPadding  [B
            1    5     3        padStart  I
    Exceptions:
      throws javax.crypto.BadPaddingException
    MethodParameters:
                Name  Flags
      outLen          
      outWithPadding  

  private byte[] prepareInputBuffer(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=10, args_size=6
        start local 0 // com.sun.crypto.provider.CipherCore 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 987
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
            istore 6 /* len */
        start local 6 // int len
         1: .line 989
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.getBufferedLength:()I
            invokestatic java.lang.Math.addExact:(II)I
            istore 7 /* totalLen */
        start local 7 // int totalLen
         2: .line 990
            iconst_0
            istore 8 /* paddingLen */
        start local 8 // int paddingLen
         3: .line 992
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 11
         4: .line 993
            iload 7 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 7
         5: .line 994
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            iload 7 /* totalLen */
            isub
            istore 8 /* paddingLen */
         6: .line 995
            goto 13
         7: .line 996
      StackMap locals: int int int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
         8: .line 997
            iload 7 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            irem
         9: .line 996
            isub
            istore 8 /* paddingLen */
        10: .line 999
            goto 13
      StackMap locals:
      StackMap stack:
        11: aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 13
        12: .line 1000
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            iload 7 /* totalLen */
            invokeinterface com.sun.crypto.provider.Padding.padLength:(I)I
            istore 8 /* paddingLen */
        13: .line 1003
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 20
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 20
        14: .line 1004
            iload 8 /* paddingLen */
            ifle 20
            iload 8 /* paddingLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 20
        15: .line 1005
            new javax.crypto.IllegalBlockSizeException
            dup
        16: .line 1006
            new java.lang.StringBuilder
            dup
            ldc "Input length must be multiple of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        17: .line 1007
            ldc " when decrypting with padded cipher"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        18: .line 1006
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 1005
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 1017
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifne 24
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 21
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnonnull 24
        21: .line 1018
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            aload 4 /* output */
            if_acmpne 38
        22: .line 1019
            iload 5 /* outputOffset */
            iload 2 /* inputOffset */
            isub
            iload 3 /* inputLen */
            if_icmpge 38
        23: .line 1020
            iload 2 /* inputOffset */
            iload 5 /* outputOffset */
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            arraylength
            if_icmpge 38
        24: .line 1022
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 25
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnonnull 26
        25: .line 1023
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 8 /* paddingLen */
        26: .line 1025
      StackMap locals:
      StackMap stack:
            iload 6 /* len */
            iload 8 /* paddingLen */
            invokestatic java.lang.Math.addExact:(II)I
            newarray 8
            astore 9 /* finalBuf */
        start local 9 // byte[] finalBuf
        27: .line 1026
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifeq 31
        28: .line 1027
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            aload 9 /* finalBuf */
            iconst_0
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        29: .line 1028
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 31
        30: .line 1031
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        31: .line 1034
      StackMap locals: byte[]
      StackMap stack:
            iload 3 /* inputLen */
            ifeq 35
        32: .line 1035
            aload 1 /* input */
            iload 2 /* inputOffset */
            aload 9 /* finalBuf */
        33: .line 1036
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
        34: .line 1035
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        35: .line 1038
      StackMap locals:
      StackMap stack:
            iload 8 /* paddingLen */
            ifeq 37
        36: .line 1039
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            aload 9 /* finalBuf */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic java.lang.Math.addExact:(II)I
            iload 8 /* paddingLen */
            invokeinterface com.sun.crypto.provider.Padding.padWithLen:([BII)V
        37: .line 1041
      StackMap locals:
      StackMap stack:
            aload 9 /* finalBuf */
            areturn
        end local 9 // byte[] finalBuf
        38: .line 1043
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            areturn
        end local 8 // int paddingLen
        end local 7 // int totalLen
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   39     0          this  Lcom/sun/crypto/provider/CipherCore;
            0   39     1         input  [B
            0   39     2   inputOffset  I
            0   39     3      inputLen  I
            0   39     4        output  [B
            0   39     5  outputOffset  I
            1   39     6           len  I
            2   39     7      totalLen  I
            3   39     8    paddingLen  I
           27   38     9      finalBuf  [B
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.ShortBufferException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  private int fillOutputBuffer(byte[], int, byte[], int, int, byte[]);
    descriptor: ([BI[BII[B)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=10, args_size=7
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] finalBuf
        start local 2 // int finalOffset
        start local 3 // byte[] output
        start local 4 // int outOfs
        start local 5 // int finalBufLen
        start local 6 // byte[] input
         0: .line 1053
            aload 0 /* this */
            aload 1 /* finalBuf */
            iload 2 /* finalOffset */
            aload 3 /* output */
         1: .line 1054
            iload 4 /* outOfs */
            iload 5 /* finalBufLen */
         2: .line 1053
            invokevirtual com.sun.crypto.provider.CipherCore.finalNoPadding:([BI[BII)I
            istore 7 /* len */
        start local 7 // int len
         3: .line 1055
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 5
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 5
         4: .line 1056
            aload 0 /* this */
            iload 7 /* len */
            aload 3 /* output */
            invokevirtual com.sun.crypto.provider.CipherCore.unpad:(I[B)I
            istore 7 /* len */
         5: .line 1058
      StackMap locals: int
      StackMap stack:
            iload 7 /* len */
            istore 9
         6: .line 1060
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 12
         7: .line 1062
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 8
            iconst_1
            goto 9
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] int top int
      StackMap stack: com.sun.crypto.provider.CipherCore
         8: iconst_0
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] int top int
      StackMap stack: com.sun.crypto.provider.CipherCore int
         9: putfield com.sun.crypto.provider.CipherCore.requireReinit:Z
        10: .line 1063
            aload 1 /* finalBuf */
            aload 6 /* input */
            if_acmpeq 12
        11: .line 1065
            aload 1 /* finalBuf */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        12: .line 1058
      StackMap locals:
      StackMap stack:
            iload 9
            ireturn
        end local 7 // int len
        13: .line 1059
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[]
      StackMap stack: java.lang.Throwable
            astore 8
        14: .line 1060
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 20
        15: .line 1062
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpne 16
            iconst_1
            goto 17
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] top java.lang.Throwable
      StackMap stack: com.sun.crypto.provider.CipherCore
        16: iconst_0
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] top java.lang.Throwable
      StackMap stack: com.sun.crypto.provider.CipherCore int
        17: putfield com.sun.crypto.provider.CipherCore.requireReinit:Z
        18: .line 1063
            aload 1 /* finalBuf */
            aload 6 /* input */
            if_acmpeq 20
        19: .line 1065
            aload 1 /* finalBuf */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        20: .line 1068
      StackMap locals:
      StackMap stack:
            aload 8
            athrow
        end local 6 // byte[] input
        end local 5 // int finalBufLen
        end local 4 // int outOfs
        end local 3 // byte[] output
        end local 2 // int finalOffset
        end local 1 // byte[] finalBuf
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   21     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   21     1     finalBuf  [B
            0   21     2  finalOffset  I
            0   21     3       output  [B
            0   21     4       outOfs  I
            0   21     5  finalBufLen  I
            0   21     6        input  [B
            3   13     7          len  I
      Exception table:
        from    to  target  type
           0     6      13  any
    Exceptions:
      throws javax.crypto.ShortBufferException, javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
             Name  Flags
      finalBuf     
      finalOffset  
      output       
      outOfs       
      finalBufLen  
      input        

  private int checkOutputCapacity(byte[], int, int);
    descriptor: ([BII)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] output
        start local 2 // int outputOffset
        start local 3 // int estOutSize
         0: .line 1077
            aload 1 /* output */
            arraylength
            iload 2 /* outputOffset */
            isub
            istore 4 /* outputCapacity */
        start local 4 // int outputCapacity
         1: .line 1078
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 2
            iload 3 /* estOutSize */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            isub
            goto 3
      StackMap locals: int
      StackMap stack:
         2: iload 3 /* estOutSize */
      StackMap locals:
      StackMap stack: int
         3: istore 5 /* minOutSize */
        start local 5 // int minOutSize
         4: .line 1079
            aload 1 /* output */
            ifnull 5
            iload 4 /* outputCapacity */
            iload 5 /* minOutSize */
            if_icmpge 8
         5: .line 1080
      StackMap locals: int
      StackMap stack:
            new javax.crypto.ShortBufferException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Output buffer must be (at least) "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 1081
            iload 5 /* minOutSize */
            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;
         7: .line 1080
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 1083
      StackMap locals:
      StackMap stack:
            iload 4 /* outputCapacity */
            ireturn
        end local 5 // int minOutSize
        end local 4 // int outputCapacity
        end local 3 // int estOutSize
        end local 2 // int outputOffset
        end local 1 // byte[] output
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    9     0            this  Lcom/sun/crypto/provider/CipherCore;
            0    9     1          output  [B
            0    9     2    outputOffset  I
            0    9     3      estOutSize  I
            1    9     4  outputCapacity  I
            4    9     5      minOutSize  I
    Exceptions:
      throws javax.crypto.ShortBufferException
    MethodParameters:
              Name  Flags
      output        
      outputOffset  
      estOutSize    

  private void checkReinit();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.CipherCore this
         0: .line 1087
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.requireReinit:Z
            ifeq 4
         1: .line 1088
            new java.lang.IllegalStateException
            dup
         2: .line 1089
            ldc "Must use either different key or iv for GCM encryption"
         3: .line 1088
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 1091
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/sun/crypto/provider/CipherCore;

  private int finalNoPadding(byte[], int, byte[], int, int);
    descriptor: ([BI[BII)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=7, args_size=6
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // byte[] out
        start local 4 // int outOfs
        start local 5 // int len
         0: .line 1098
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpeq 2
            aload 1 /* in */
            ifnull 1
            iload 5 /* len */
            ifne 2
         1: .line 1099
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 1101
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_2
            if_icmpeq 16
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_3
            if_icmpeq 16
         3: .line 1102
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 7
            if_icmpeq 16
         4: .line 1103
            iload 5 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            ifeq 16
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 6
            if_icmpeq 16
         5: .line 1104
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 11
         6: .line 1105
            new javax.crypto.IllegalBlockSizeException
            dup
         7: .line 1106
            new java.lang.StringBuilder
            dup
            ldc "Input length (with padding) not multiple of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 1107
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 1106
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 1105
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 1109
      StackMap locals:
      StackMap stack:
            new javax.crypto.IllegalBlockSizeException
            dup
        12: .line 1110
            new java.lang.StringBuilder
            dup
            ldc "Input length not multiple of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        13: .line 1111
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        14: .line 1110
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 1109
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        16: .line 1114
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 6 /* outLen */
        start local 6 // int outLen
        17: .line 1115
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 20
        18: .line 1116
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 5 /* len */
            aload 3 /* out */
            iload 4 /* outOfs */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.decryptFinal:([BII[BI)I
            istore 6 /* outLen */
        19: .line 1117
            goto 21
        20: .line 1118
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 5 /* len */
            aload 3 /* out */
            iload 4 /* outOfs */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.encryptFinal:([BII[BI)I
            istore 6 /* outLen */
        21: .line 1120
      StackMap locals:
      StackMap stack:
            iload 6 /* outLen */
            ireturn
        end local 6 // int outLen
        end local 5 // int len
        end local 4 // int outOfs
        end local 3 // byte[] out
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   22     0    this  Lcom/sun/crypto/provider/CipherCore;
            0   22     1      in  [B
            0   22     2   inOfs  I
            0   22     3     out  [B
            0   22     4  outOfs  I
            0   22     5     len  I
           17   22     6  outLen  I
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.AEADBadTagException, javax.crypto.ShortBufferException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      out     
      outOfs  
      len     

  byte[] wrap(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0000) 
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // java.security.Key key
         0: .line 1145
            aconst_null
            astore 2 /* result */
        start local 2 // byte[] result
         1: .line 1148
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 3 /* encodedKey */
        start local 3 // byte[] encodedKey
         2: .line 1149
            aload 3 /* encodedKey */
            ifnull 3
            aload 3 /* encodedKey */
            arraylength
            ifne 4
         3: .line 1150
      StackMap locals: byte[] byte[]
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "Cannot get an encoding of the key to be wrapped"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 1153
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* encodedKey */
            iconst_0
            aload 3 /* encodedKey */
            arraylength
            invokevirtual com.sun.crypto.provider.CipherCore.doFinal:([BII)[B
            astore 2 /* result */
        end local 3 // byte[] encodedKey
         5: .line 1154
            goto 7
      StackMap locals: com.sun.crypto.provider.CipherCore java.security.Key byte[]
      StackMap stack: javax.crypto.BadPaddingException
         6: pop
         7: .line 1157
      StackMap locals:
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 2 // byte[] result
        end local 1 // java.security.Key key
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0        this  Lcom/sun/crypto/provider/CipherCore;
            0    8     1         key  Ljava/security/Key;
            1    8     2      result  [B
            2    5     3  encodedKey  [B
      Exception table:
        from    to  target  type
           1     5       6  Class javax.crypto.BadPaddingException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  java.security.Key unwrap(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // byte[] wrappedKey
        start local 2 // java.lang.String wrappedKeyAlgorithm
        start local 3 // int wrappedKeyType
         0: .line 1186
            aload 0 /* this */
            aload 1 /* wrappedKey */
            iconst_0
            aload 1 /* wrappedKey */
            arraylength
            invokevirtual com.sun.crypto.provider.CipherCore.doFinal:([BII)[B
            astore 4 /* encodedKey */
        start local 4 // byte[] encodedKey
         1: .line 1187
            goto 6
        end local 4 // byte[] encodedKey
      StackMap locals:
      StackMap stack: javax.crypto.BadPaddingException
         2: pop
         3: .line 1188
            new java.security.InvalidKeyException
            dup
            ldc "The wrapped key is not padded correctly"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 1190
      StackMap locals:
      StackMap stack: javax.crypto.IllegalBlockSizeException
            pop
         5: .line 1191
            new java.security.InvalidKeyException
            dup
            ldc "The wrapped key does not have the correct length"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        start local 4 // byte[] encodedKey
         6: .line 1194
      StackMap locals: byte[]
      StackMap stack:
            aload 4 /* encodedKey */
            aload 2 /* wrappedKeyAlgorithm */
         7: .line 1195
            iload 3 /* wrappedKeyType */
         8: .line 1194
            invokestatic com.sun.crypto.provider.ConstructKeys.constructKey:([BLjava/lang/String;I)Ljava/security/Key;
            areturn
        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.CipherCore this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    9     0                 this  Lcom/sun/crypto/provider/CipherCore;
            0    9     1           wrappedKey  [B
            0    9     2  wrappedKeyAlgorithm  Ljava/lang/String;
            0    9     3       wrappedKeyType  I
            1    2     4           encodedKey  [B
            6    9     4           encodedKey  [B
      Exception table:
        from    to  target  type
           0     1       2  Class javax.crypto.BadPaddingException
           0     1       4  Class javax.crypto.IllegalBlockSizeException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
                     Name  Flags
      wrappedKey           
      wrappedKeyAlgorithm  
      wrappedKeyType       

  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.CipherCore this
        start local 1 // byte[] src
        start local 2 // int offset
        start local 3 // int len
         0: .line 1223
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.checkReinit:()V
         1: .line 1224
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            aload 1 /* src */
            iload 2 /* offset */
            iload 3 /* len */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.updateAAD:([BII)V
         2: .line 1225
            return
        end local 3 // int len
        end local 2 // int offset
        end local 1 // byte[] src
        end local 0 // com.sun.crypto.provider.CipherCore this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lcom/sun/crypto/provider/CipherCore;
            0    3     1     src  [B
            0    3     2  offset  I
            0    3     3     len  I
    MethodParameters:
        Name  Flags
      src     
      offset  
      len     
}
SourceFile: "CipherCore.java"