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

  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 130
            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 85
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.minBytes:I
         6: .line 93
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
         7: .line 98
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
         8: .line 103
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
         9: .line 108
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        10: .line 113
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.decrypting:Z
        11: .line 131
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.blockSize:I
        12: .line 132
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        13: .line 133
            aload 0 /* this */
            iload 2 /* blkSize */
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        14: .line 140
            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
        15: .line 143
            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;
        16: .line 144
            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;
        17: .line 145
            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   18     0     this  Lcom/sun/crypto/provider/CipherCore;
            0   18     1     impl  Lcom/sun/crypto/provider/SymmetricCipher;
            0   18     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 156
            aload 1 /* mode */
            ifnonnull 2
         1: .line 157
            new java.security.NoSuchAlgorithmException
            dup
            ldc "null mode"
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 159
      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 161
            aload 2 /* modeUpperCase */
            ldc "ECB"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 162
            return
         5: .line 165
      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 166
            aload 2 /* modeUpperCase */
            ldc "CBC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         7: .line 167
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
         8: .line 168
            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 169
            goto 39
      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 170
            aload 0 /* this */
            bipush 6
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        12: .line 171
            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 172
            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 173
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        15: .line 174
            goto 39
      StackMap locals:
      StackMap stack:
        16: aload 2 /* modeUpperCase */
            ldc "CTR"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 22
        17: .line 175
            aload 0 /* this */
            iconst_5
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        18: .line 176
            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 177
            aload 0 /* this */
            iconst_1
            putfield com.sun.crypto.provider.CipherCore.unitBytes:I
        20: .line 178
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        21: .line 179
            goto 39
      StackMap locals:
      StackMap stack:
        22: aload 2 /* modeUpperCase */
            ldc "CFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 27
        23: .line 180
            aload 0 /* this */
            iconst_2
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        24: .line 181
            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
        25: .line 182
            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;
        26: .line 183
            goto 39
      StackMap locals:
      StackMap stack:
        27: aload 2 /* modeUpperCase */
            ldc "OFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 32
        28: .line 184
            aload 0 /* this */
            iconst_3
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        29: .line 185
            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
        30: .line 186
            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;
        31: .line 187
            goto 39
      StackMap locals:
      StackMap stack:
        32: aload 2 /* modeUpperCase */
            ldc "PCBC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 36
        33: .line 188
            aload 0 /* this */
            iconst_4
            putfield com.sun.crypto.provider.CipherCore.cipherMode:I
        34: .line 189
            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;
        35: .line 190
            goto 39
        36: .line 192
      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;
        37: .line 193
            ldc " not found"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        38: .line 192
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        39: .line 195
      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   40     0           this  Lcom/sun/crypto/provider/CipherCore;
            0   40     1           mode  Ljava/lang/String;
            3   40     2  modeUpperCase  Ljava/lang/String;
            6   40     3        rawImpl  Lcom/sun/crypto/provider/SymmetricCipher;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  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 199
            iload 2 /* blockSize */
            istore 3 /* result */
        start local 3 // int result
         1: .line 200
            aload 0 /* mode */
            invokevirtual java.lang.String.length:()I
            iload 1 /* offset */
            if_icmple 14
         2: .line 203
            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 204
            aload 5 /* num */
            invokevirtual java.lang.Integer.intValue:()I
            istore 4 /* numInt */
        start local 4 // int numInt
         4: .line 205
            iload 4 /* numInt */
            iconst_3
            ishr
            istore 3 /* result */
        end local 5 // java.lang.Integer num
         5: .line 206
            goto 10
        end local 4 // int numInt
      StackMap locals: java.lang.String int int int
      StackMap stack: java.lang.NumberFormatException
         6: pop
         7: .line 207
            new java.security.NoSuchAlgorithmException
            dup
         8: .line 208
            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 207
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 4 // int numInt
        10: .line 210
      StackMap locals: int
      StackMap stack:
            iload 4 /* numInt */
            bipush 8
            irem
            ifne 11
            iload 3 /* result */
            iload 2 /* blockSize */
            if_icmple 14
        11: .line 211
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        12: .line 212
            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 211
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // int numInt
        14: .line 215
      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=6, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.CipherCore this
        start local 1 // java.lang.String paddingScheme
         0: .line 229
            aload 1 /* paddingScheme */
            ifnonnull 2
         1: .line 230
            new javax.crypto.NoSuchPaddingException
            dup
            ldc "null padding"
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 232
      StackMap locals:
      StackMap stack:
            aload 1 /* paddingScheme */
            ldc "NoPadding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 5
         3: .line 233
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
         4: .line 234
            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 235
            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 236
            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 237
            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 238
            ldc " not implemented"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 237
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 240
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 22
        13: .line 241
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_5
            if_icmpeq 14
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 6
            if_icmpne 22
        14: .line 242
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
        15: .line 243
            new javax.crypto.NoSuchPaddingException
            dup
        16: .line 244
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_5
            if_icmpne 17
            ldc "CTR"
            goto 18
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String
      StackMap stack: new 15 new 15 new 16 new 16
        17: ldc "CTS"
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String
      StackMap stack: new 15 new 15 new 16 new 16 java.lang.String
        18: invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 245
            ldc " mode must be used with NoPadding"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        20: .line 244
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 243
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 247
      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   23     0           this  Lcom/sun/crypto/provider/CipherCore;
            0   23     1  paddingScheme  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 268
            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 272
            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 com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 3 /* totalLen */
        start local 3 // int totalLen
         1: .line 273
            iload 3 /* totalLen */
            iload 1 /* inputLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 3 /* totalLen */
         2: .line 274
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            pop
         3: .line 276
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 12
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 12
         4: .line 277
            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
         5: .line 278
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 8
         6: .line 279
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            istore 3 /* totalLen */
         7: .line 280
            goto 12
         8: .line 281
      StackMap locals: int
      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
         9: .line 282
            iload 3 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            iload 4 /* residue */
            isub
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 3 /* totalLen */
        end local 4 // int residue
        10: .line 284
            goto 12
        11: .line 285
      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 com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 3 /* totalLen */
        12: .line 290
      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   13     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   13     1   inputLen  I
            0   13     2  isDoFinal  Z
            1   13     3   totalLen  I
            9   10     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 306
            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 307
            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 324
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifne 2
         1: .line 325
            aconst_null
            areturn
         2: .line 327
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* params */
        start local 2 // java.security.AlgorithmParameters params
         3: .line 329
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.getIV:()[B
            astore 4 /* iv */
        start local 4 // byte[] iv
         4: .line 330
            aload 4 /* iv */
            ifnonnull 7
         5: .line 332
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            newarray 8
            astore 4 /* iv */
         6: .line 333
            getstatic com.sun.crypto.provider.SunJCE.RANDOM:Ljava/security/SecureRandom;
            aload 4 /* iv */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         7: .line 335
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String java.security.AlgorithmParameters top byte[]
      StackMap stack:
            aload 1 /* algName */
            ldc "RC2"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 13
         8: .line 336
            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
         9: .line 337
            new javax.crypto.spec.RC2ParameterSpec
            dup
        10: .line 338
            aload 5 /* rawImpl */
            invokevirtual com.sun.crypto.provider.RC2Crypt.getEffectiveKeyBits:()I
            aload 4 /* iv */
        11: .line 337
            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
        12: .line 339
            goto 14
        end local 3 // java.security.spec.AlgorithmParameterSpec spec
        13: .line 340
      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
        14: .line 343
      StackMap locals: com.sun.crypto.provider.CipherCore java.lang.String java.security.AlgorithmParameters java.security.spec.AlgorithmParameterSpec byte[]
      StackMap stack:
            aload 1 /* algName */
        15: .line 344
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
        16: .line 343
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
            astore 2 /* params */
        17: .line 345
            aload 2 /* params */
            aload 3 /* spec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
        18: .line 346
            goto 25
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
        19: pop
        20: .line 348
            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;
        21: .line 349
            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;
        22: .line 348
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 350
      StackMap locals:
      StackMap stack: java.security.spec.InvalidParameterSpecException
            pop
        24: .line 352
            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
        25: .line 354
      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   26     0     this  Lcom/sun/crypto/provider/CipherCore;
            0   26     1  algName  Ljava/lang/String;
            3   26     2   params  Ljava/security/AlgorithmParameters;
           12   13     3     spec  Ljava/security/spec/AlgorithmParameterSpec;
           14   26     3     spec  Ljava/security/spec/AlgorithmParameterSpec;
            4   26     4       iv  [B
            9   12     5  rawImpl  Lcom/sun/crypto/provider/RC2Crypt;
      Exception table:
        from    to  target  type
          14    18      19  Class java.security.NoSuchAlgorithmException
          14    18      23  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 390
            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 391
            goto 4
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
         2: astore 4 /* e */
        start local 4 // java.security.InvalidAlgorithmParameterException e
         3: .line 392
            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 394
      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=5, locals=8, 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 423
            aload 0 /* this */
            iload 1 /* opmode */
            iconst_2
            if_icmpeq 2
         1: .line 424
            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 423
      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 426
            aload 2 /* key */
            invokestatic com.sun.crypto.provider.CipherCore.getKeyBytes:(Ljava/security/Key;)[B
            astore 5 /* keyBytes */
        start local 5 // byte[] keyBytes
         5: .line 428
            aconst_null
            astore 6 /* ivBytes */
        start local 6 // byte[] ivBytes
         6: .line 429
            aload 3 /* params */
            ifnull 26
         7: .line 430
            aload 3 /* params */
            instanceof javax.crypto.spec.IvParameterSpec
            ifeq 15
         8: .line 431
            aload 3 /* params */
            checkcast javax.crypto.spec.IvParameterSpec
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
            astore 6 /* ivBytes */
         9: .line 432
            aload 6 /* ivBytes */
            ifnull 10
            aload 6 /* ivBytes */
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 26
        10: .line 433
      StackMap locals: byte[] byte[]
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        11: .line 434
            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;
        12: .line 435
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        13: .line 434
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 433
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 437
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.RC2ParameterSpec
            ifeq 23
        16: .line 438
            aload 3 /* params */
            checkcast javax.crypto.spec.RC2ParameterSpec
            invokevirtual javax.crypto.spec.RC2ParameterSpec.getIV:()[B
            astore 6 /* ivBytes */
        17: .line 439
            aload 6 /* ivBytes */
            ifnull 26
            aload 6 /* ivBytes */
            arraylength
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 26
        18: .line 440
            new java.security.InvalidAlgorithmParameterException
            dup
        19: .line 441
            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;
        20: .line 442
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        21: .line 441
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        22: .line 440
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 445
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        24: .line 446
            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;
        25: .line 445
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 449
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifne 31
        27: .line 450
            aload 6 /* ivBytes */
            ifnull 38
        28: .line 451
            new java.security.InvalidAlgorithmParameterException
            dup
        29: .line 452
            ldc "ECB mode cannot use IV"
        30: .line 451
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        31: .line 454
      StackMap locals:
      StackMap stack:
            aload 6 /* ivBytes */
            ifnonnull 38
        32: .line 455
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 34
        33: .line 456
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "Parameters missing"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        34: .line 460
      StackMap locals:
      StackMap stack:
            aload 4 /* random */
            ifnonnull 36
        35: .line 461
            getstatic com.sun.crypto.provider.SunJCE.RANDOM:Ljava/security/SecureRandom;
            astore 4 /* random */
        36: .line 463
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            newarray 8
            astore 6 /* ivBytes */
        37: .line 464
            aload 4 /* random */
            aload 6 /* ivBytes */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
        38: .line 467
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        39: .line 468
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        40: .line 470
            aload 2 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            astore 7 /* algorithm */
        start local 7 // java.lang.String algorithm
        41: .line 472
            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 7 /* algorithm */
            aload 5 /* keyBytes */
            aload 6 /* ivBytes */
            invokevirtual com.sun.crypto.provider.FeedbackCipher.init:(ZLjava/lang/String;[B[B)V
        42: .line 473
            return
        end local 7 // java.lang.String algorithm
        end local 6 // byte[] ivBytes
        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   43     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   43     1     opmode  I
            0   43     2        key  Ljava/security/Key;
            0   43     3     params  Ljava/security/spec/AlgorithmParameterSpec;
            0   43     4     random  Ljava/security/SecureRandom;
            5   43     5   keyBytes  [B
            6   43     6    ivBytes  [B
           41   43     7  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 478
            aconst_null
            astore 5 /* spec */
        start local 5 // java.security.spec.AlgorithmParameterSpec spec
         1: .line 479
            aconst_null
            astore 6 /* paramType */
        start local 6 // java.lang.String paramType
         2: .line 480
            aload 3 /* params */
            ifnull 10
         3: .line 485
            ldc "IV"
            astore 6 /* paramType */
         4: .line 486
            aload 3 /* params */
            ldc Ljavax/crypto/spec/IvParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            astore 5 /* spec */
         5: .line 487
            goto 10
      StackMap locals: com.sun.crypto.provider.CipherCore int java.security.Key java.security.AlgorithmParameters java.security.SecureRandom java.security.spec.AlgorithmParameterSpec java.lang.String
      StackMap stack: java.security.spec.InvalidParameterSpecException
         6: pop
         7: .line 488
            new java.security.InvalidAlgorithmParameterException
            dup
         8: .line 489
            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;
         9: .line 488
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 492
      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
        11: .line 493
            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   12     0       this  Lcom/sun/crypto/provider/CipherCore;
            0   12     1     opmode  I
            0   12     2        key  Ljava/security/Key;
            0   12     3     params  Ljava/security/AlgorithmParameters;
            0   12     4     random  Ljava/security/SecureRandom;
            1   12     5       spec  Ljava/security/spec/AlgorithmParameterSpec;
            2   12     6  paramType  Ljava/lang/String;
      Exception table:
        from    to  target  type
           3     5       6  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 500
            aload 0 /* key */
            ifnonnull 2
         1: .line 501
            new java.security.InvalidKeyException
            dup
            ldc "No key given"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 504
      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 505
            new java.security.InvalidKeyException
            dup
            ldc "Wrong format: RAW bytes needed"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 507
      StackMap locals:
      StackMap stack:
            aload 0 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 1 /* keyBytes */
        start local 1 // byte[] keyBytes
         5: .line 508
            aload 1 /* keyBytes */
            ifnonnull 7
         6: .line 509
            new java.security.InvalidKeyException
            dup
            ldc "RAW key bytes missing"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 511
      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 535
            aconst_null
            astore 4 /* output */
        start local 4 // byte[] output
         1: .line 537
            aload 0 /* this */
            iload 3 /* inputLen */
            iconst_0
            invokevirtual com.sun.crypto.provider.CipherCore.getOutputSizeByOperation:(IZ)I
            newarray 8
            astore 4 /* output */
         2: .line 538
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
         3: .line 539
            iconst_0
         4: .line 538
            invokevirtual com.sun.crypto.provider.CipherCore.update:([BII[BI)I
            istore 5 /* len */
        start local 5 // int len
         5: .line 540
            iload 5 /* len */
            aload 4 /* output */
            arraylength
            if_icmpne 8
         6: .line 541
            aload 4 /* output */
         7: areturn
         8: .line 543
      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
         9: .line 544
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 11
        10: .line 546
            aload 4 /* output */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        11: .line 548
      StackMap locals: byte[]
      StackMap stack:
            aload 6 /* copy */
        12: areturn
        end local 6 // byte[] copy
        end local 5 // int len
        13: .line 550
      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
        14: .line 552
            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   15     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   15     1        input  [B
            0   15     2  inputOffset  I
            0   15     3     inputLen  I
            1   15     4       output  [B
            5   13     5          len  I
            9   13     6         copy  [B
           14   15     5            e  Ljavax/crypto/ShortBufferException;
      Exception table:
        from    to  target  type
           1     7      13  Class javax.crypto.ShortBufferException
           8    12      13  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 582
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 6 /* len */
        start local 6 // int len
         1: .line 583
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.minBytes:I
            isub
            istore 6 /* len */
         2: .line 584
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 4
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 4
         3: .line 586
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            isub
            istore 6 /* len */
         4: .line 589
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            ifle 5
            iload 6 /* len */
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            isub
            goto 6
      StackMap locals:
      StackMap stack:
         5: iconst_0
      StackMap locals:
      StackMap stack: int
         6: istore 6 /* len */
         7: .line 592
            aload 4 /* output */
            ifnull 9
         8: .line 593
            aload 4 /* output */
            arraylength
            iload 5 /* outputOffset */
            isub
            iload 6 /* len */
            if_icmpge 13
         9: .line 594
      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
        10: .line 595
            iload 6 /* len */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        11: .line 596
            ldc " bytes long"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 594
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 599
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 7 /* outLen */
        start local 7 // int outLen
        14: .line 600
            iload 6 /* len */
            ifeq 68
        15: .line 601
            aload 1 /* input */
            aload 4 /* output */
            if_acmpne 22
        16: .line 602
            iload 5 /* outputOffset */
            iload 2 /* inputOffset */
            isub
            iload 3 /* inputLen */
            if_icmpge 22
        17: .line 603
            iload 2 /* inputOffset */
            iload 5 /* outputOffset */
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            arraylength
            if_icmpge 22
        18: .line 606
            aload 1 /* input */
            iload 2 /* inputOffset */
        19: .line 607
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
        20: .line 606
            invokestatic java.util.Arrays.copyOfRange:([BII)[B
            astore 1 /* input */
        21: .line 608
            iconst_0
            istore 2 /* inputOffset */
        22: .line 610
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            if_icmpgt 31
        23: .line 612
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 26
        24: .line 613
            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 */
        25: .line 614
            goto 27
        26: .line 615
      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 */
        27: .line 617
      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
        28: .line 618
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifeq 61
        29: .line 619
            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
        30: .line 621
            goto 61
        31: .line 622
      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
        32: .line 624
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifle 50
        33: .line 625
            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
        34: .line 626
            iload 10 /* bufferCapacity */
            ifeq 43
        35: .line 627
            iload 10 /* bufferCapacity */
            iload 8 /* inputConsumed */
            invokestatic java.lang.Math.min:(II)I
            istore 9 /* temp */
        start local 9 // int temp
        36: .line 628
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 38
        37: .line 629
            iload 9 /* temp */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 9 /* temp */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            isub
            istore 9 /* temp */
        38: .line 631
      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
        39: .line 632
            iload 2 /* inputOffset */
            iload 9 /* temp */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 2 /* inputOffset */
        40: .line 633
            iload 8 /* inputConsumed */
            iload 9 /* temp */
            isub
            istore 8 /* inputConsumed */
        41: .line 634
            iload 3 /* inputLen */
            iload 9 /* temp */
            isub
            istore 3 /* inputLen */
        42: .line 635
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 9 /* temp */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        end local 9 // int temp
        43: .line 639
      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 46
        44: .line 640
            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 */
        45: .line 641
            goto 48
        46: .line 642
      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 */
        47: .line 644
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        48: .line 646
      StackMap locals:
      StackMap stack:
            iload 5 /* outputOffset */
            iload 7 /* outLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 5 /* outputOffset */
        49: .line 647
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        end local 10 // int bufferCapacity
        50: .line 649
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int int byte[] int int int int
      StackMap stack:
            iload 8 /* inputConsumed */
            ifle 61
        51: .line 650
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 56
        52: .line 651
            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 */
        53: .line 652
            aload 4 /* output */
            iload 5 /* outputOffset */
        54: .line 651
            invokevirtual com.sun.crypto.provider.FeedbackCipher.decrypt:([BII[BI)I
            iadd
            istore 7 /* outLen */
        55: .line 653
            goto 59
        56: .line 654
      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 */
        57: .line 655
            aload 4 /* output */
            iload 5 /* outputOffset */
        58: .line 654
            invokevirtual com.sun.crypto.provider.FeedbackCipher.encrypt:([BII[BI)I
            iadd
            istore 7 /* outLen */
        59: .line 657
      StackMap locals:
      StackMap stack:
            iload 2 /* inputOffset */
            iload 8 /* inputConsumed */
            iadd
            istore 2 /* inputOffset */
        60: .line 658
            iload 3 /* inputLen */
            iload 8 /* inputConsumed */
            isub
            istore 3 /* inputLen */
        end local 8 // int inputConsumed
        61: .line 665
      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 68
        62: .line 666
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 65
        63: .line 667
            aload 0 /* this */
            dup
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            iload 6 /* len */
            isub
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        64: .line 668
            goto 68
        65: .line 669
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
        66: .line 670
            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
        67: .line 669
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
        68: .line 675
      StackMap locals:
      StackMap stack:
            iload 3 /* inputLen */
            ifle 73
        69: .line 676
            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
        70: .line 677
            iload 3 /* inputLen */
        71: .line 676
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        72: .line 678
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            putfield com.sun.crypto.provider.CipherCore.buffered:I
        73: .line 680
      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   74     0            this  Lcom/sun/crypto/provider/CipherCore;
            0   74     1           input  [B
            0   74     2     inputOffset  I
            0   74     3        inputLen  I
            0   74     4          output  [B
            0   74     5    outputOffset  I
            1   74     6             len  I
           14   74     7          outLen  I
           32   61     8   inputConsumed  I
           36   43     9            temp  I
           34   50    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 716
            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
         1: .line 717
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
         2: .line 718
            iload 3 /* inputLen */
            aload 4 /* output */
            iconst_0
         3: .line 717
            invokevirtual com.sun.crypto.provider.CipherCore.prepareInputBuffer:([BII[BI)[B
            astore 5 /* finalBuf */
        start local 5 // byte[] finalBuf
         4: .line 719
            aload 5 /* finalBuf */
            aload 1 /* input */
            if_acmpne 5
            iload 2 /* inputOffset */
            goto 6
      StackMap locals: byte[] byte[]
      StackMap stack:
         5: iconst_0
      StackMap locals:
      StackMap stack: int
         6: istore 6 /* finalOffset */
        start local 6 // int finalOffset
         7: .line 720
            aload 5 /* finalBuf */
            aload 1 /* input */
            if_acmpne 8
            iload 3 /* inputLen */
            goto 9
      StackMap locals: int
      StackMap stack:
         8: aload 5 /* finalBuf */
            arraylength
      StackMap locals:
      StackMap stack: int
         9: istore 7 /* finalBufLen */
        start local 7 // int finalBufLen
        10: .line 722
            aload 0 /* this */
            aload 5 /* finalBuf */
            iload 6 /* finalOffset */
            aload 4 /* output */
            iconst_0
        11: .line 723
            iload 7 /* finalBufLen */
            aload 1 /* input */
        12: .line 722
            invokevirtual com.sun.crypto.provider.CipherCore.fillOutputBuffer:([BI[BII[B)I
            istore 8 /* outLen */
        start local 8 // int outLen
        13: .line 725
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.endDoFinal:()V
        14: .line 726
            iload 8 /* outLen */
            aload 4 /* output */
            arraylength
            if_icmpge 20
        15: .line 727
            aload 4 /* output */
            iload 8 /* outLen */
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 9 /* copy */
        start local 9 // byte[] copy
        16: .line 728
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 18
        17: .line 730
            aload 4 /* output */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        18: .line 732
      StackMap locals: int int byte[]
      StackMap stack:
            aload 9 /* copy */
        19: areturn
        end local 9 // byte[] copy
        20: .line 734
      StackMap locals:
      StackMap stack:
            aload 4 /* output */
        21: 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
        22: .line 736
      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
        23: .line 738
            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   24     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   24     1        input  [B
            0   24     2  inputOffset  I
            0   24     3     inputLen  I
            1   22     4       output  [B
            4   22     5     finalBuf  [B
            7   22     6  finalOffset  I
           10   22     7  finalBufLen  I
           13   22     8       outLen  I
           16   20     9         copy  [B
           23   24     4            e  Ljavax/crypto/ShortBufferException;
      Exception table:
        from    to  target  type
           0    19      22  Class javax.crypto.ShortBufferException
          20    21      22  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 783
            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
         1: .line 784
            aload 0 /* this */
            aload 4 /* output */
            iload 5 /* outputOffset */
         2: .line 785
            iload 6 /* estOutSize */
         3: .line 784
            invokevirtual com.sun.crypto.provider.CipherCore.checkOutputCapacity:([BII)I
            istore 7 /* outputCapacity */
        start local 7 // int outputCapacity
         4: .line 786
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 5
            iconst_0
            goto 6
      StackMap locals: int int
      StackMap stack:
         5: iload 5 /* outputOffset */
      StackMap locals:
      StackMap stack: int
         6: istore 8 /* offset */
        start local 8 // int offset
         7: .line 787
            aload 0 /* this */
            aload 1 /* input */
            iload 2 /* inputOffset */
         8: .line 788
            iload 3 /* inputLen */
            aload 4 /* output */
            iload 5 /* outputOffset */
         9: .line 787
            invokevirtual com.sun.crypto.provider.CipherCore.prepareInputBuffer:([BII[BI)[B
            astore 9 /* finalBuf */
        start local 9 // byte[] finalBuf
        10: .line 789
            aconst_null
            astore 10 /* outWithPadding */
        start local 10 // byte[] outWithPadding
        11: .line 791
            aload 9 /* finalBuf */
            aload 1 /* input */
            if_acmpne 12
            iload 2 /* inputOffset */
            goto 13
      StackMap locals: int byte[] byte[]
      StackMap stack:
        12: iconst_0
      StackMap locals:
      StackMap stack: int
        13: istore 11 /* finalOffset */
        start local 11 // int finalOffset
        14: .line 792
            aload 9 /* finalBuf */
            aload 1 /* input */
            if_acmpne 15
            iload 3 /* inputLen */
            goto 16
      StackMap locals: int
      StackMap stack:
        15: aload 9 /* finalBuf */
            arraylength
      StackMap locals:
      StackMap stack: int
        16: istore 12 /* finalBufLen */
        start local 12 // int finalBufLen
        17: .line 794
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 21
        18: .line 800
            iload 7 /* outputCapacity */
            iload 6 /* estOutSize */
            if_icmpge 20
        19: .line 801
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.save:()V
        20: .line 805
      StackMap locals: int
      StackMap stack:
            iload 6 /* estOutSize */
            newarray 8
            astore 10 /* outWithPadding */
        21: .line 807
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 22
            aload 10 /* outWithPadding */
            goto 23
      StackMap locals:
      StackMap stack:
        22: aload 4 /* output */
      StackMap locals:
      StackMap stack: byte[]
        23: astore 13 /* outBuffer */
        start local 13 // byte[] outBuffer
        24: .line 809
            aload 0 /* this */
            aload 9 /* finalBuf */
            iload 11 /* finalOffset */
            aload 13 /* outBuffer */
        25: .line 810
            iload 8 /* offset */
            iload 12 /* finalBufLen */
            aload 1 /* input */
        26: .line 809
            invokevirtual com.sun.crypto.provider.CipherCore.fillOutputBuffer:([BI[BII[B)I
            istore 14 /* outLen */
        start local 14 // int outLen
        27: .line 812
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 37
        28: .line 814
            iload 7 /* outputCapacity */
            iload 14 /* outLen */
            if_icmpge 35
        29: .line 816
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipher:Lcom/sun/crypto/provider/FeedbackCipher;
            invokevirtual com.sun.crypto.provider.FeedbackCipher.restore:()V
        30: .line 817
            new javax.crypto.ShortBufferException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Output buffer too short: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        31: .line 818
            iload 7 /* outputCapacity */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        32: .line 819
            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;
        33: .line 820
            ldc " bytes needed"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 817
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 823
      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
        36: .line 825
            aload 10 /* outWithPadding */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        37: .line 827
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.CipherCore.endDoFinal:()V
        38: .line 828
            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   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      estOutSize  I
            4   39     7  outputCapacity  I
            7   39     8          offset  I
           10   39     9        finalBuf  [B
           11   39    10  outWithPadding  [B
           14   39    11     finalOffset  I
           17   39    12     finalBufLen  I
           24   39    13       outBuffer  [B
           27   39    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 832
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.CipherCore.buffered:I
         1: .line 833
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            putfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
         2: .line 834
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            ifeq 4
         3: .line 835
            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 837
      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 841
            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 842
            iload 3 /* padStart */
            ifge 3
         2: .line 843
            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 847
      StackMap locals: int
      StackMap stack:
            iload 3 /* padStart */
            istore 1 /* outLen */
         4: .line 848
            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 855
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 6 /* len */
        start local 6 // int len
         1: .line 857
            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 com.sun.crypto.provider.CipherCore.addExact:(II)I
            istore 7 /* totalLen */
        start local 7 // int totalLen
         2: .line 858
            iconst_0
            istore 8 /* paddingLen */
        start local 8 // int paddingLen
         3: .line 860
            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 861
            iload 7 /* totalLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            if_icmpge 7
         5: .line 862
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.diffBlocksize:I
            iload 7 /* totalLen */
            isub
            istore 8 /* paddingLen */
         6: .line 863
            goto 13
         7: .line 864
      StackMap locals: int int int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
         8: .line 865
            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 864
            isub
            istore 8 /* paddingLen */
        10: .line 867
            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 868
            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 871
      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 872
            iload 8 /* paddingLen */
            ifle 20
            iload 8 /* paddingLen */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.blockSize:I
            if_icmpeq 20
        15: .line 873
            new javax.crypto.IllegalBlockSizeException
            dup
        16: .line 874
            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 875
            ldc " when decrypting with padded cipher"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        18: .line 874
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 873
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 885
      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 886
      StackMap locals:
      StackMap stack:
            aload 1 /* input */
            aload 4 /* output */
            if_acmpne 38
        22: .line 887
            iload 5 /* outputOffset */
            iload 2 /* inputOffset */
            isub
            iload 3 /* inputLen */
            if_icmpge 38
        23: .line 888
            iload 2 /* inputOffset */
            iload 5 /* outputOffset */
            isub
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            arraylength
            if_icmpge 38
        24: .line 890
      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 891
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 8 /* paddingLen */
        26: .line 893
      StackMap locals:
      StackMap stack:
            iload 6 /* len */
            iload 8 /* paddingLen */
            invokestatic com.sun.crypto.provider.CipherCore.addExact:(II)I
            newarray 8
            astore 9 /* finalBuf */
        start local 9 // byte[] finalBuf
        27: .line 894
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            ifeq 31
        28: .line 895
            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 896
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 31
        30: .line 899
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffer:[B
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        31: .line 902
      StackMap locals: byte[]
      StackMap stack:
            iload 3 /* inputLen */
            ifeq 35
        32: .line 903
            aload 1 /* input */
            iload 2 /* inputOffset */
            aload 9 /* finalBuf */
        33: .line 904
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.buffered:I
            iload 3 /* inputLen */
        34: .line 903
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        35: .line 906
      StackMap locals:
      StackMap stack:
            iload 8 /* paddingLen */
            ifeq 37
        36: .line 907
            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 com.sun.crypto.provider.CipherCore.addExact:(II)I
            iload 8 /* paddingLen */
            invokeinterface com.sun.crypto.provider.Padding.padWithLen:([BII)V
        37: .line 909
      StackMap locals:
      StackMap stack:
            aload 9 /* finalBuf */
            areturn
        end local 9 // byte[] finalBuf
        38: .line 912
      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 922
            aload 0 /* this */
            aload 1 /* finalBuf */
            iload 2 /* finalOffset */
            aload 3 /* output */
         1: .line 923
            iload 4 /* outOfs */
            iload 5 /* finalBufLen */
         2: .line 922
            invokevirtual com.sun.crypto.provider.CipherCore.finalNoPadding:([BI[BII)I
            istore 7 /* len */
        start local 7 // int len
         3: .line 924
            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 925
            aload 0 /* this */
            iload 7 /* len */
            aload 3 /* output */
            invokevirtual com.sun.crypto.provider.CipherCore.unpad:(I[B)I
            istore 7 /* len */
         5: .line 927
      StackMap locals: int
      StackMap stack:
            iload 7 /* len */
            istore 9
         6: .line 929
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 9
         7: .line 930
            aload 1 /* finalBuf */
            aload 6 /* input */
            if_acmpeq 9
         8: .line 932
            aload 1 /* finalBuf */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
         9: .line 927
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] int top int
      StackMap stack:
            iload 9
            ireturn
        end local 7 // int len
        10: .line 928
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[]
      StackMap stack: java.lang.Throwable
            astore 8
        11: .line 929
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifne 14
        12: .line 930
            aload 1 /* finalBuf */
            aload 6 /* input */
            if_acmpeq 14
        13: .line 932
            aload 1 /* finalBuf */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        14: .line 935
      StackMap locals: com.sun.crypto.provider.CipherCore byte[] int byte[] int int byte[] top java.lang.Throwable
      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   15     0         this  Lcom/sun/crypto/provider/CipherCore;
            0   15     1     finalBuf  [B
            0   15     2  finalOffset  I
            0   15     3       output  [B
            0   15     4       outOfs  I
            0   15     5  finalBufLen  I
            0   15     6        input  [B
            3   10     7          len  I
      Exception table:
        from    to  target  type
           0     6      10  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 944
            aload 1 /* output */
            arraylength
            iload 2 /* outputOffset */
            isub
            istore 4 /* outputCapacity */
        start local 4 // int outputCapacity
         1: .line 945
            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 946
            aload 1 /* output */
            ifnull 5
            iload 4 /* outputCapacity */
            iload 5 /* minOutSize */
            if_icmpge 8
         5: .line 947
      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 948
            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 947
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 950
      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 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 957
            aload 1 /* in */
            ifnull 1
            iload 5 /* len */
            ifne 2
         1: .line 958
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
         2: .line 960
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_2
            if_icmpeq 15
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            iconst_3
            if_icmpeq 15
         3: .line 961
            iload 5 /* len */
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.unitBytes:I
            irem
            ifeq 15
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.cipherMode:I
            bipush 6
            if_icmpeq 15
         4: .line 962
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.padding:Lcom/sun/crypto/provider/Padding;
            ifnull 10
         5: .line 963
            new javax.crypto.IllegalBlockSizeException
            dup
         6: .line 964
            new java.lang.StringBuilder
            dup
            ldc "Input length (with padding) not multiple of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 965
            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;
         8: .line 964
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 963
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 967
      StackMap locals:
      StackMap stack:
            new javax.crypto.IllegalBlockSizeException
            dup
        11: .line 968
            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;
        12: .line 969
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        13: .line 968
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 967
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 972
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 6 /* outLen */
        start local 6 // int outLen
        16: .line 973
            aload 0 /* this */
            getfield com.sun.crypto.provider.CipherCore.decrypting:Z
            ifeq 19
        17: .line 974
            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 */
        18: .line 975
            goto 20
        19: .line 976
      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 */
        20: .line 978
      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   21     0    this  Lcom/sun/crypto/provider/CipherCore;
            0   21     1      in  [B
            0   21     2   inOfs  I
            0   21     3     out  [B
            0   21     4  outOfs  I
            0   21     5     len  I
           16   21     6  outLen  I
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, 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 1003
            aconst_null
            astore 2 /* result */
        start local 2 // byte[] result
         1: .line 1006
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 3 /* encodedKey */
        start local 3 // byte[] encodedKey
         2: .line 1007
            aload 3 /* encodedKey */
            ifnull 3
            aload 3 /* encodedKey */
            arraylength
            ifne 4
         3: .line 1008
      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 1011
      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 1012
            goto 7
      StackMap locals: com.sun.crypto.provider.CipherCore java.security.Key byte[]
      StackMap stack: javax.crypto.BadPaddingException
         6: pop
         7: .line 1015
      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 1044
            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 1045
            goto 6
        end local 4 // byte[] encodedKey
      StackMap locals:
      StackMap stack: javax.crypto.BadPaddingException
         2: pop
         3: .line 1046
            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 1048
      StackMap locals:
      StackMap stack: javax.crypto.IllegalBlockSizeException
            pop
         5: .line 1049
            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 1052
      StackMap locals: byte[]
      StackMap stack:
            aload 4 /* encodedKey */
            aload 2 /* wrappedKeyAlgorithm */
         7: .line 1053
            iload 3 /* wrappedKeyType */
         8: .line 1052
            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       

  static int addExact(int, int);
    descriptor: (II)I
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // int x
        start local 1 // int y
         0: .line 1069
            iload 0 /* x */
            iload 1 /* y */
            iadd
            istore 2 /* r */
        start local 2 // int r
         1: .line 1071
            iload 0 /* x */
            iload 2 /* r */
            ixor
            iload 1 /* y */
            iload 2 /* r */
            ixor
            iand
            ifge 3
         2: .line 1072
            new java.lang.ArithmeticException
            dup
            ldc "integer overflow"
            invokespecial java.lang.ArithmeticException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1074
      StackMap locals: int
      StackMap stack:
            iload 2 /* r */
            ireturn
        end local 2 // int r
        end local 1 // int y
        end local 0 // int x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0     x  I
            0    4     1     y  I
            1    4     2     r  I
    MethodParameters:
      Name  Flags
      x     
      y     

  static long addExact(long, long);
    descriptor: (JJ)J
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=6, args_size=2
        start local 0 // long x
        start local 2 // long y
         0: .line 1088
            lload 0 /* x */
            lload 2 /* y */
            ladd
            lstore 4 /* r */
        start local 4 // long r
         1: .line 1090
            lload 0 /* x */
            lload 4 /* r */
            lxor
            lload 2 /* y */
            lload 4 /* r */
            lxor
            land
            lconst_0
            lcmp
            ifge 3
         2: .line 1091
            new java.lang.ArithmeticException
            dup
            ldc "long overflow"
            invokespecial java.lang.ArithmeticException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1093
      StackMap locals: long
      StackMap stack:
            lload 4 /* r */
            lreturn
        end local 4 // long r
        end local 2 // long y
        end local 0 // long x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0     x  J
            0    4     2     y  J
            1    4     4     r  J
    MethodParameters:
      Name  Flags
      x     
      y     

  static int multiplyExact(int, int);
    descriptor: (II)I
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // int x
        start local 1 // int y
         0: .line 1107
            iload 0 /* x */
            i2l
            iload 1 /* y */
            i2l
            lmul
            lstore 2 /* r */
        start local 2 // long r
         1: .line 1108
            lload 2 /* r */
            l2i
            i2l
            lload 2 /* r */
            lcmp
            ifeq 3
         2: .line 1109
            new java.lang.ArithmeticException
            dup
            ldc "integer overflow"
            invokespecial java.lang.ArithmeticException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1111
      StackMap locals: long
      StackMap stack:
            lload 2 /* r */
            l2i
            ireturn
        end local 2 // long r
        end local 1 // int y
        end local 0 // int x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0     x  I
            0    4     1     y  I
            1    4     2     r  J
    MethodParameters:
      Name  Flags
      x     
      y     

  static long multiplyExact(long, long);
    descriptor: (JJ)J
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=10, args_size=2
        start local 0 // long x
        start local 2 // long y
         0: .line 1125
            lload 0 /* x */
            lload 2 /* y */
            lmul
            lstore 4 /* r */
        start local 4 // long r
         1: .line 1126
            lload 0 /* x */
            invokestatic java.lang.Math.abs:(J)J
            lstore 6 /* ax */
        start local 6 // long ax
         2: .line 1127
            lload 2 /* y */
            invokestatic java.lang.Math.abs:(J)J
            lstore 8 /* ay */
        start local 8 // long ay
         3: .line 1128
            lload 6 /* ax */
            lload 8 /* ay */
            lor
            bipush 31
            lushr
            lconst_0
            lcmp
            ifeq 7
         4: .line 1132
            lload 2 /* y */
            lconst_0
            lcmp
            ifeq 5
            lload 4 /* r */
            lload 2 /* y */
            ldiv
            lload 0 /* x */
            lcmp
            ifne 6
         5: .line 1133
      StackMap locals: long long long
      StackMap stack:
            lload 0 /* x */
            ldc -9223372036854775808
            lcmp
            ifne 7
            lload 2 /* y */
            ldc -1
            lcmp
            ifne 7
         6: .line 1134
      StackMap locals:
      StackMap stack:
            new java.lang.ArithmeticException
            dup
            ldc "long overflow"
            invokespecial java.lang.ArithmeticException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 1137
      StackMap locals:
      StackMap stack:
            lload 4 /* r */
            lreturn
        end local 8 // long ay
        end local 6 // long ax
        end local 4 // long r
        end local 2 // long y
        end local 0 // long x
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0     x  J
            0    8     2     y  J
            1    8     4     r  J
            2    8     6    ax  J
            3    8     8    ay  J
    MethodParameters:
      Name  Flags
      x     
      y     
}
SourceFile: "CipherCore.java"