final class sun.security.pkcs11.P11RSACipher extends javax.crypto.CipherSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.pkcs11.P11RSACipher
  super_class: javax.crypto.CipherSpi
{
  private static final int PKCS1_MIN_PADDING_LENGTH;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 11

  private static final byte[] B0;
    descriptor: [B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

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

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

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

  private final sun.security.pkcs11.Token token;
    descriptor: Lsun/security/pkcs11/Token;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String algorithm;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final long mechanism;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private sun.security.pkcs11.Session session;
    descriptor: Lsun/security/pkcs11/Session;
    flags: (0x0002) ACC_PRIVATE

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

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

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

  private sun.security.pkcs11.P11Key p11Key;
    descriptor: Lsun/security/pkcs11/P11Key;
    flags: (0x0002) ACC_PRIVATE

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

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

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

  private java.security.spec.AlgorithmParameterSpec spec;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 56
            iconst_0
            newarray 8
            putstatic sun.security.pkcs11.P11RSACipher.B0:[B
         1: .line 65
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(sun.security.pkcs11.Token, java.lang.String, long);
    descriptor: (Lsun/security/pkcs11/Token;Ljava/lang/String;J)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // sun.security.pkcs11.Token token
        start local 2 // java.lang.String algorithm
        start local 3 // long mechanism
         0: .line 107
            aload 0 /* this */
            invokespecial javax.crypto.CipherSpi.<init>:()V
         1: .line 100
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs11.P11RSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
         2: .line 108
            aload 0 /* this */
            aload 1 /* token */
            putfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
         3: .line 109
            aload 0 /* this */
            ldc "RSA"
            putfield sun.security.pkcs11.P11RSACipher.algorithm:Ljava/lang/String;
         4: .line 110
            aload 0 /* this */
            lload 3 /* mechanism */
            putfield sun.security.pkcs11.P11RSACipher.mechanism:J
         5: .line 111
            return
        end local 3 // long mechanism
        end local 2 // java.lang.String algorithm
        end local 1 // sun.security.pkcs11.Token token
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lsun/security/pkcs11/P11RSACipher;
            0    6     1      token  Lsun/security/pkcs11/Token;
            0    6     2  algorithm  Ljava/lang/String;
            0    6     3  mechanism  J
    Exceptions:
      throws sun.security.pkcs11.wrapper.PKCS11Exception
    MethodParameters:
           Name  Flags
      token      
      algorithm  
      mechanism  

  protected void engineSetMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // java.lang.String mode
         0: .line 116
            aload 1 /* mode */
            ldc "ECB"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 2
         1: .line 117
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported mode "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 119
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String mode
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/pkcs11/P11RSACipher;
            0    3     1  mode  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  protected void engineSetPadding(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // java.lang.String padding
         0: .line 123
            aload 1 /* padding */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            astore 2 /* lowerPadding */
        start local 2 // java.lang.String lowerPadding
         1: .line 124
            aload 2 /* lowerPadding */
            ldc "pkcs1Padding"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 3
         2: .line 127
            new javax.crypto.NoSuchPaddingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported padding "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* padding */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 129
      StackMap locals: java.lang.String
      StackMap stack:
            return
        end local 2 // java.lang.String lowerPadding
        end local 1 // java.lang.String padding
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lsun/security/pkcs11/P11RSACipher;
            0    4     1       padding  Ljava/lang/String;
            1    4     2  lowerPadding  Ljava/lang/String;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
         Name  Flags
      padding  

  protected int engineGetBlockSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 134
            iconst_0
            ireturn
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs11/P11RSACipher;

  protected int engineGetOutputSize(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // int inputLen
         0: .line 140
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.outputSize:I
            ireturn
        end local 1 // int inputLen
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lsun/security/pkcs11/P11RSACipher;
            0    1     1  inputLen  I
    MethodParameters:
          Name  Flags
      inputLen  

  protected byte[] engineGetIV();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 146
            aconst_null
            areturn
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs11/P11RSACipher;

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 152
            aconst_null
            areturn
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs11/P11RSACipher;

  protected void engineInit(int, java.security.Key, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 158
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
         1: .line 159
            return
        end local 3 // java.security.SecureRandom random
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lsun/security/pkcs11/P11RSACipher;
            0    2     1  opmode  I
            0    2     2     key  Ljava/security/Key;
            0    2     3  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      random  

  protected void engineInit(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // sun.security.pkcs11.P11RSACipher 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 165
            aload 3 /* params */
            ifnull 7
         1: .line 166
            aload 3 /* params */
            instanceof sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            ifne 5
         2: .line 167
            new java.security.InvalidAlgorithmParameterException
            dup
         3: .line 168
            ldc "Parameters not supported"
         4: .line 167
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* params */
            putfield sun.security.pkcs11.P11RSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
         6: .line 171
            aload 0 /* this */
            aload 4 /* random */
            putfield sun.security.pkcs11.P11RSACipher.random:Ljava/security/SecureRandom;
         7: .line 173
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
         8: .line 174
            return
        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 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lsun/security/pkcs11/P11RSACipher;
            0    9     1  opmode  I
            0    9     2     key  Ljava/security/Key;
            0    9     3  params  Ljava/security/spec/AlgorithmParameterSpec;
            0    9     4  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  protected void engineInit(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // sun.security.pkcs11.P11RSACipher 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 180
            aload 3 /* params */
            ifnull 4
         1: .line 181
            new java.security.InvalidAlgorithmParameterException
            dup
         2: .line 182
            ldc "Parameters not supported"
         3: .line 181
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 184
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
         5: .line 185
            return
        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 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lsun/security/pkcs11/P11RSACipher;
            0    6     1  opmode  I
            0    6     2     key  Ljava/security/Key;
            0    6     3  params  Ljava/security/AlgorithmParameters;
            0    6     4  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  private void implInit(int, java.security.Key);
    descriptor: (ILjava/security/Key;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
         0: .line 188
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.cancelOperation:()V
         1: .line 189
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 2 /* key */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.algorithm:Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11KeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            putfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
         2: .line 191
            iload 1 /* opmode */
            iconst_1
            if_icmpne 5
         3: .line 192
            iconst_1
            istore 3 /* encrypt */
        start local 3 // boolean encrypt
         4: .line 193
            goto 21
        end local 3 // boolean encrypt
      StackMap locals:
      StackMap stack:
         5: iload 1 /* opmode */
            iconst_2
            if_icmpne 8
         6: .line 194
            iconst_0
            istore 3 /* encrypt */
        start local 3 // boolean encrypt
         7: .line 195
            goto 21
        end local 3 // boolean encrypt
      StackMap locals:
      StackMap stack:
         8: iload 1 /* opmode */
            iconst_3
            if_icmpne 14
         9: .line 196
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.isPublic:()Z
            ifne 13
        10: .line 197
            new java.security.InvalidKeyException
            dup
        11: .line 198
            ldc "Wrap has to be used with public keys"
        12: .line 197
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 201
      StackMap locals:
      StackMap stack:
            return
        14: .line 202
      StackMap locals:
      StackMap stack:
            iload 1 /* opmode */
            iconst_4
            if_icmpne 20
        15: .line 203
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.isPrivate:()Z
            ifne 19
        16: .line 204
            new java.security.InvalidKeyException
            dup
        17: .line 205
            ldc "Unwrap has to be used with private keys"
        18: .line 204
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 209
      StackMap locals:
      StackMap stack:
            return
        20: .line 211
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported mode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* opmode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        start local 3 // boolean encrypt
        21: .line 213
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.isPublic:()Z
            ifeq 26
        22: .line 214
            aload 0 /* this */
            iload 3 /* encrypt */
            ifeq 23
            iconst_1
            goto 24
      StackMap locals:
      StackMap stack: sun.security.pkcs11.P11RSACipher
        23: iconst_4
      StackMap locals: sun.security.pkcs11.P11RSACipher int java.security.Key int
      StackMap stack: sun.security.pkcs11.P11RSACipher int
        24: putfield sun.security.pkcs11.P11RSACipher.mode:I
        25: .line 215
            goto 32
      StackMap locals:
      StackMap stack:
        26: aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.isPrivate:()Z
            ifeq 31
        27: .line 216
            aload 0 /* this */
            iload 3 /* encrypt */
            ifeq 28
            iconst_3
            goto 29
      StackMap locals:
      StackMap stack: sun.security.pkcs11.P11RSACipher
        28: iconst_2
      StackMap locals: sun.security.pkcs11.P11RSACipher int java.security.Key int
      StackMap stack: sun.security.pkcs11.P11RSACipher int
        29: putfield sun.security.pkcs11.P11RSACipher.mode:I
        30: .line 217
            goto 32
        31: .line 218
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 220
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            bipush 7
            iadd
            iconst_3
            ishr
            istore 4 /* n */
        start local 4 // int n
        33: .line 221
            aload 0 /* this */
            iload 4 /* n */
            putfield sun.security.pkcs11.P11RSACipher.outputSize:I
        34: .line 222
            aload 0 /* this */
            iload 4 /* n */
            newarray 8
            putfield sun.security.pkcs11.P11RSACipher.buffer:[B
        35: .line 223
            aload 0 /* this */
            iload 3 /* encrypt */
            ifeq 36
            iload 4 /* n */
            bipush 11
            isub
            goto 37
      StackMap locals: sun.security.pkcs11.P11RSACipher int java.security.Key int int
      StackMap stack: sun.security.pkcs11.P11RSACipher
        36: iload 4 /* n */
      StackMap locals: sun.security.pkcs11.P11RSACipher int java.security.Key int int
      StackMap stack: sun.security.pkcs11.P11RSACipher int
        37: putfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
        38: .line 225
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.initialize:()V
        39: .line 226
            goto 42
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        40: astore 5 /* e */
        start local 5 // sun.security.pkcs11.wrapper.PKCS11Exception e
        41: .line 227
            new java.security.InvalidKeyException
            dup
            ldc "init() failed"
            aload 5 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // sun.security.pkcs11.wrapper.PKCS11Exception e
        42: .line 229
      StackMap locals:
      StackMap stack:
            return
        end local 4 // int n
        end local 3 // boolean encrypt
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   43     0     this  Lsun/security/pkcs11/P11RSACipher;
            0   43     1   opmode  I
            0   43     2      key  Ljava/security/Key;
            4    5     3  encrypt  Z
            7    8     3  encrypt  Z
           21   43     3  encrypt  Z
           33   43     4        n  I
           41   42     5        e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
          38    39      40  Class sun.security.pkcs11.wrapper.PKCS11Exception
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     

  private void cancelOperation();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=5, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 232
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 233
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.initialized:Z
            ifne 3
         2: .line 234
            return
         3: .line 236
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11RSACipher.initialized:Z
         4: .line 237
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            ifnull 5
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.explicitCancel:Z
            ifne 6
         5: .line 238
      StackMap locals:
      StackMap stack:
            return
         6: .line 240
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.hasObjects:()Z
            ifne 9
         7: .line 241
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.killSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
         8: .line 242
            return
         9: .line 245
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            astore 1 /* p11 */
        start local 1 // sun.security.pkcs11.wrapper.PKCS11 p11
        10: .line 246
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            istore 2 /* inLen */
        start local 2 // int inLen
        11: .line 247
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            arraylength
            istore 3 /* outLen */
        start local 3 // int outLen
        12: .line 248
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mode:I
            tableswitch { // 1 - 4
                    1: 13
                    2: 17
                    3: 21
                    4: 26
              default: 30
          }
        13: .line 250
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11 int int
      StackMap stack:
            aload 1 /* p11 */
        14: .line 251
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 2 /* inLen */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 3 /* outLen */
        15: .line 250
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Encrypt:(J[BII[BII)I
            pop
        16: .line 252
            goto 32
        17: .line 254
      StackMap locals:
      StackMap stack:
            aload 1 /* p11 */
        18: .line 255
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 2 /* inLen */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 3 /* outLen */
        19: .line 254
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Decrypt:(J[BII[BII)I
            pop
        20: .line 256
            goto 32
        21: .line 258
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            newarray 8
            astore 4 /* tmpBuffer */
        start local 4 // byte[] tmpBuffer
        22: .line 259
            aload 1 /* p11 */
        23: .line 260
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 4 /* tmpBuffer */
        24: .line 259
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Sign:(J[B)[B
            pop
        25: .line 261
            goto 32
        end local 4 // byte[] tmpBuffer
        26: .line 263
      StackMap locals:
      StackMap stack:
            aload 1 /* p11 */
        27: .line 264
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 2 /* inLen */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            iload 3 /* outLen */
        28: .line 263
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyRecover:(J[BII[BII)I
            pop
        29: .line 265
            goto 32
        30: .line 267
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            ldc "internal error"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // int outLen
        end local 2 // int inLen
        end local 1 // sun.security.pkcs11.wrapper.PKCS11 p11
        31: .line 269
      StackMap locals: sun.security.pkcs11.P11RSACipher
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            pop
        32: .line 272
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   33     0       this  Lsun/security/pkcs11/P11RSACipher;
           10   31     1        p11  Lsun/security/pkcs11/wrapper/PKCS11;
           11   31     2      inLen  I
           12   31     3     outLen  I
           22   26     4  tmpBuffer  [B
      Exception table:
        from    to  target  type
           9    31      31  Class sun.security.pkcs11.wrapper.PKCS11Exception

  private void ensureInitialized();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 275
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 276
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.initialized:Z
            ifne 3
         2: .line 277
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.initialize:()V
         3: .line 279
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/pkcs11/P11RSACipher;
    Exceptions:
      throws sun.security.pkcs11.wrapper.PKCS11Exception

  private void initialize();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 282
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            ifnonnull 2
         1: .line 283
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.getOpSession:()Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
         2: .line 285
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            astore 1 /* p11 */
        start local 1 // sun.security.pkcs11.wrapper.PKCS11 p11
         3: .line 286
            new sun.security.pkcs11.wrapper.CK_MECHANISM
            dup
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mechanism:J
            invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(J)V
            astore 2 /* ckMechanism */
        start local 2 // sun.security.pkcs11.wrapper.CK_MECHANISM ckMechanism
         4: .line 287
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mode:I
            tableswitch { // 1 - 4
                    1: 5
                    2: 7
                    3: 9
                    4: 11
              default: 13
          }
         5: .line 289
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11 sun.security.pkcs11.wrapper.CK_MECHANISM
      StackMap stack:
            aload 1 /* p11 */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 2 /* ckMechanism */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_EncryptInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
         6: .line 290
            goto 14
         7: .line 292
      StackMap locals:
      StackMap stack:
            aload 1 /* p11 */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 2 /* ckMechanism */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_DecryptInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
         8: .line 293
            goto 14
         9: .line 295
      StackMap locals:
      StackMap stack:
            aload 1 /* p11 */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 2 /* ckMechanism */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
        10: .line 296
            goto 14
        11: .line 298
      StackMap locals:
      StackMap stack:
            aload 1 /* p11 */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 2 /* ckMechanism */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyRecoverInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
        12: .line 299
            goto 14
        13: .line 301
      StackMap locals:
      StackMap stack:
            new java.lang.AssertionError
            dup
            ldc "internal error"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        14: .line 303
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11RSACipher.bufOfs:I
        15: .line 304
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11RSACipher.initialized:Z
        16: .line 305
            return
        end local 2 // sun.security.pkcs11.wrapper.CK_MECHANISM ckMechanism
        end local 1 // sun.security.pkcs11.wrapper.PKCS11 p11
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0         this  Lsun/security/pkcs11/P11RSACipher;
            3   17     1          p11  Lsun/security/pkcs11/wrapper/PKCS11;
            4   17     2  ckMechanism  Lsun/security/pkcs11/wrapper/CK_MECHANISM;
    Exceptions:
      throws sun.security.pkcs11.wrapper.PKCS11Exception

  private void implUpdate(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 309
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.ensureInitialized:()V
         1: .line 310
            goto 4
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
         2: astore 4 /* e */
        start local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
         3: .line 311
            new java.security.ProviderException
            dup
            ldc "update() failed"
            aload 4 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
         4: .line 313
      StackMap locals:
      StackMap stack:
            iload 3 /* inLen */
            ifeq 5
            aload 1 /* in */
            ifnonnull 6
         5: .line 314
      StackMap locals:
      StackMap stack:
            return
         6: .line 316
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            iload 3 /* inLen */
            iadd
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            if_icmple 9
         7: .line 317
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            iconst_1
            iadd
            putfield sun.security.pkcs11.P11RSACipher.bufOfs:I
         8: .line 318
            return
         9: .line 320
      StackMap locals:
      StackMap stack:
            aload 1 /* in */
            iload 2 /* inOfs */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            iload 3 /* inLen */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        10: .line 321
            aload 0 /* this */
            dup
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            iload 3 /* inLen */
            iadd
            putfield sun.security.pkcs11.P11RSACipher.bufOfs:I
        11: .line 322
            return
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   12     0   this  Lsun/security/pkcs11/P11RSACipher;
            0   12     1     in  [B
            0   12     2  inOfs  I
            0   12     3  inLen  I
            3    4     4      e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           0     1       2  Class sun.security.pkcs11.wrapper.PKCS11Exception
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  private int implDoFinal(byte[], int, int);
    descriptor: ([BII)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=9, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] out
        start local 2 // int outOfs
        start local 3 // int outLen
         0: .line 326
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            if_icmple 4
         1: .line 327
            new javax.crypto.IllegalBlockSizeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Data must not be longer than "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 328
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 327
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 331
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.ensureInitialized:()V
         5: .line 332
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            astore 4 /* p11 */
        start local 4 // sun.security.pkcs11.wrapper.PKCS11 p11
         6: .line 334
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mode:I
            tableswitch { // 1 - 4
                    1: 7
                    2: 11
                    3: 15
                    4: 23
              default: 27
          }
         7: .line 336
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11
      StackMap stack:
            aload 4 /* p11 */
         8: .line 337
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            aload 1 /* out */
            iload 2 /* outOfs */
            iload 3 /* outLen */
         9: .line 336
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Encrypt:(J[BII[BII)I
            istore 5 /* n */
        start local 5 // int n
        10: .line 338
            goto 28
        end local 5 // int n
        11: .line 340
      StackMap locals:
      StackMap stack:
            aload 4 /* p11 */
        12: .line 341
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            aload 1 /* out */
            iload 2 /* outOfs */
            iload 3 /* outLen */
        13: .line 340
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Decrypt:(J[BII[BII)I
            istore 5 /* n */
        start local 5 // int n
        14: .line 342
            goto 28
        end local 5 // int n
        15: .line 344
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            newarray 8
            astore 6 /* tmpBuffer */
        start local 6 // byte[] tmpBuffer
        16: .line 345
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 6 /* tmpBuffer */
            iconst_0
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        17: .line 346
            aload 4 /* p11 */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 6 /* tmpBuffer */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Sign:(J[B)[B
            astore 6 /* tmpBuffer */
        18: .line 347
            aload 6 /* tmpBuffer */
            arraylength
            iload 3 /* outLen */
            if_icmple 20
        19: .line 348
            new javax.crypto.BadPaddingException
            dup
            ldc "Output buffer too small"
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 350
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] int int sun.security.pkcs11.wrapper.PKCS11 top byte[]
      StackMap stack:
            aload 6 /* tmpBuffer */
            iconst_0
            aload 1 /* out */
            iload 2 /* outOfs */
            aload 6 /* tmpBuffer */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        21: .line 351
            aload 6 /* tmpBuffer */
            arraylength
            istore 5 /* n */
        start local 5 // int n
        22: .line 352
            goto 28
        end local 6 // byte[] tmpBuffer
        end local 5 // int n
        23: .line 354
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] int int sun.security.pkcs11.wrapper.PKCS11
      StackMap stack:
            aload 4 /* p11 */
        24: .line 355
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.bufOfs:I
            aload 1 /* out */
            iload 2 /* outOfs */
            iload 3 /* outLen */
        25: .line 354
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyRecover:(J[BII[BII)I
            istore 5 /* n */
        start local 5 // int n
        26: .line 356
            goto 28
        end local 5 // int n
        27: .line 358
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            ldc "internal error"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        start local 5 // int n
        28: .line 360
      StackMap locals: int
      StackMap stack:
            iload 5 /* n */
            istore 8
        29: .line 365
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11RSACipher.initialized:Z
        30: .line 366
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
        31: .line 360
            iload 8
            ireturn
        end local 5 // int n
        end local 4 // sun.security.pkcs11.wrapper.PKCS11 p11
        32: .line 361
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] int int
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 4 /* e */
        start local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
        33: .line 362
            new javax.crypto.BadPaddingException
            dup
        34: .line 363
            ldc "doFinal() failed"
        35: .line 362
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
        36: .line 363
            aload 4 /* e */
            invokevirtual javax.crypto.BadPaddingException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
        37: .line 362
            checkcast javax.crypto.BadPaddingException
            athrow
        end local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
        38: .line 364
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 7
        39: .line 365
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11RSACipher.initialized:Z
        40: .line 366
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11RSACipher.session:Lsun/security/pkcs11/Session;
        41: .line 367
            aload 7
            athrow
        end local 3 // int outLen
        end local 2 // int outOfs
        end local 1 // byte[] out
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   42     0       this  Lsun/security/pkcs11/P11RSACipher;
            0   42     1        out  [B
            0   42     2     outOfs  I
            0   42     3     outLen  I
            6   32     4        p11  Lsun/security/pkcs11/wrapper/PKCS11;
           10   11     5          n  I
           14   15     5          n  I
           22   23     5          n  I
           26   27     5          n  I
           28   32     5          n  I
           16   23     6  tmpBuffer  [B
           33   38     4          e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           4    29      32  Class sun.security.pkcs11.wrapper.PKCS11Exception
           4    29      38  any
          32    38      38  any
    Exceptions:
      throws javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
        Name  Flags
      out     
      outOfs  
      outLen  

  protected byte[] engineUpdate(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 372
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.pkcs11.P11RSACipher.implUpdate:([BII)V
         1: .line 373
            getstatic sun.security.pkcs11.P11RSACipher.B0:[B
            areturn
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lsun/security/pkcs11/P11RSACipher;
            0    2     1     in  [B
            0    2     2  inOfs  I
            0    2     3  inLen  I
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  protected int engineUpdate(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 379
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.pkcs11.P11RSACipher.implUpdate:([BII)V
         1: .line 380
            iconst_0
            ireturn
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lsun/security/pkcs11/P11RSACipher;
            0    2     1      in  [B
            0    2     2   inOfs  I
            0    2     3   inLen  I
            0    2     4     out  [B
            0    2     5  outOfs  I
    Exceptions:
      throws javax.crypto.ShortBufferException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      out     
      outOfs  

  protected byte[] engineDoFinal(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 386
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.pkcs11.P11RSACipher.implUpdate:([BII)V
         1: .line 387
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            arraylength
            invokevirtual sun.security.pkcs11.P11RSACipher.implDoFinal:([BII)I
            istore 4 /* n */
        start local 4 // int n
         2: .line 388
            iload 4 /* n */
            newarray 8
            astore 5 /* out */
        start local 5 // byte[] out
         3: .line 389
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.buffer:[B
            iconst_0
            aload 5 /* out */
            iconst_0
            iload 4 /* n */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 390
            aload 5 /* out */
            areturn
        end local 5 // byte[] out
        end local 4 // int n
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lsun/security/pkcs11/P11RSACipher;
            0    5     1     in  [B
            0    5     2  inOfs  I
            0    5     3  inLen  I
            2    5     4      n  I
            3    5     5    out  [B
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  protected int engineDoFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=6, args_size=6
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 397
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.pkcs11.P11RSACipher.implUpdate:([BII)V
         1: .line 398
            aload 0 /* this */
            aload 4 /* out */
            iload 5 /* outOfs */
            aload 4 /* out */
            arraylength
            iload 5 /* outOfs */
            isub
            invokevirtual sun.security.pkcs11.P11RSACipher.implDoFinal:([BII)I
            ireturn
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lsun/security/pkcs11/P11RSACipher;
            0    2     1      in  [B
            0    2     2   inOfs  I
            0    2     3   inLen  I
            0    2     4     out  [B
            0    2     5  outOfs  I
    Exceptions:
      throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      out     
      outOfs  

  private byte[] doFinal();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // sun.security.pkcs11.P11RSACipher this
         0: .line 402
            sipush 2048
            newarray 8
            astore 1 /* t */
        start local 1 // byte[] t
         1: .line 403
            aload 0 /* this */
            aload 1 /* t */
            iconst_0
            aload 1 /* t */
            arraylength
            invokevirtual sun.security.pkcs11.P11RSACipher.implDoFinal:([BII)I
            istore 2 /* n */
        start local 2 // int n
         2: .line 404
            iload 2 /* n */
            newarray 8
            astore 3 /* out */
        start local 3 // byte[] out
         3: .line 405
            aload 1 /* t */
            iconst_0
            aload 3 /* out */
            iconst_0
            iload 2 /* n */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 406
            aload 3 /* out */
            areturn
        end local 3 // byte[] out
        end local 2 // int n
        end local 1 // byte[] t
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/pkcs11/P11RSACipher;
            1    5     1     t  [B
            2    5     2     n  I
            3    5     3   out  [B
    Exceptions:
      throws javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException

  protected byte[] engineWrap(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=8, args_size=2
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // java.security.Key key
         0: .line 418
            aload 1 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            astore 2 /* keyAlg */
        start local 2 // java.lang.String keyAlg
         1: .line 419
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 1 /* key */
            aload 2 /* keyAlg */
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            astore 3 /* secretKey */
        start local 3 // sun.security.pkcs11.P11Key secretKey
         2: .line 420
            aconst_null
            astore 4 /* s */
        start local 4 // sun.security.pkcs11.Session s
         3: .line 422
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.getOpSession:()Lsun/security/pkcs11/Session;
            astore 4 /* s */
         4: .line 423
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 4 /* s */
            invokevirtual sun.security.pkcs11.Session.id:()J
            new sun.security.pkcs11.wrapper.CK_MECHANISM
            dup
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mechanism:J
            invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(J)V
         5: .line 424
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
            aload 3 /* secretKey */
            getfield sun.security.pkcs11.P11Key.keyID:J
         6: .line 423
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_WrapKey:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;JJ)[B
            astore 5 /* b */
        start local 5 // byte[] b
         7: .line 425
            aload 5 /* b */
            astore 7
         8: .line 429
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 4 /* s */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
         9: .line 425
            aload 7
            areturn
        end local 5 // byte[] b
        10: .line 426
      StackMap locals: sun.security.pkcs11.P11RSACipher java.security.Key java.lang.String sun.security.pkcs11.P11Key sun.security.pkcs11.Session
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 5 /* e */
        start local 5 // sun.security.pkcs11.wrapper.PKCS11Exception e
        11: .line 427
            new java.security.InvalidKeyException
            dup
            ldc "wrap() failed"
            aload 5 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // sun.security.pkcs11.wrapper.PKCS11Exception e
        12: .line 428
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 6
        13: .line 429
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 4 /* s */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        14: .line 430
            aload 6
            athrow
        end local 4 // sun.security.pkcs11.Session s
        end local 3 // sun.security.pkcs11.P11Key secretKey
        end local 2 // java.lang.String keyAlg
        end local 1 // java.security.Key key
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   15     0       this  Lsun/security/pkcs11/P11RSACipher;
            0   15     1        key  Ljava/security/Key;
            1   15     2     keyAlg  Ljava/lang/String;
            2   15     3  secretKey  Lsun/security/pkcs11/P11Key;
            3   15     4          s  Lsun/security/pkcs11/Session;
            7   10     5          b  [B
           11   12     5          e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           3     8      10  Class sun.security.pkcs11.wrapper.PKCS11Exception
           3     8      12  any
          10    12      12  any
    Exceptions:
      throws java.security.InvalidKeyException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
      Name  Flags
      key   

  protected java.security.Key engineUnwrap(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=9, locals=15, args_size=4
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // byte[] wrappedKey
        start local 2 // java.lang.String algorithm
        start local 3 // int type
         0: .line 437
            aload 2 /* algorithm */
            ldc "TlsRsaPremasterSecret"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         1: .line 436
            istore 4 /* isTlsRsaPremasterSecret */
        start local 4 // boolean isTlsRsaPremasterSecret
         2: .line 438
            aconst_null
            astore 5 /* failover */
        start local 5 // java.lang.Exception failover
         3: .line 441
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.supportsRawSecretKeyImport:()Z
            ifeq 35
         4: .line 443
            aload 0 /* this */
            iconst_2
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
         5: .line 445
            aload 1 /* wrappedKey */
            arraylength
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.maxInputSize:I
            if_icmple 7
         6: .line 446
            new java.security.InvalidKeyException
            dup
            ldc "Key is too long for unwrapping"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 449
      StackMap locals: int java.lang.Exception
      StackMap stack:
            aconst_null
            astore 6 /* encoded */
        start local 6 // byte[] encoded
         8: .line 450
            aload 0 /* this */
            aload 1 /* wrappedKey */
            iconst_0
            aload 1 /* wrappedKey */
            arraylength
            invokevirtual sun.security.pkcs11.P11RSACipher.implUpdate:([BII)V
         9: .line 452
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11RSACipher.doFinal:()[B
            astore 6 /* encoded */
        10: .line 453
            goto 18
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: javax.crypto.BadPaddingException
        11: astore 7 /* e */
        start local 7 // javax.crypto.BadPaddingException e
        12: .line 454
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 15
        13: .line 455
            aload 7 /* e */
            astore 5 /* failover */
        14: .line 456
            goto 18
        15: .line 457
      StackMap locals: javax.crypto.BadPaddingException
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "Unwrapping failed"
            aload 7 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // javax.crypto.BadPaddingException e
        16: .line 459
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: javax.crypto.IllegalBlockSizeException
            astore 7 /* e */
        start local 7 // javax.crypto.IllegalBlockSizeException e
        17: .line 461
            new java.security.InvalidKeyException
            dup
            ldc "Unwrapping failed"
            aload 7 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // javax.crypto.IllegalBlockSizeException e
        18: .line 464
      StackMap locals:
      StackMap stack:
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 29
        19: .line 465
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            instanceof sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            ifne 23
        20: .line 466
            new java.lang.IllegalStateException
            dup
        21: .line 467
            ldc "No TlsRsaPremasterSecretParameterSpec specified"
        22: .line 466
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 472
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
        24: .line 471
            astore 7 /* psps */
        start local 7 // sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec psps
        25: .line 474
            aload 7 /* psps */
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getClientVersion:()I
            aload 7 /* psps */
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getServerVersion:()I
        26: .line 475
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.random:Ljava/security/SecureRandom;
            aload 6 /* encoded */
            aload 5 /* failover */
            ifnull 27
            iconst_1
            goto 28
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception byte[] sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
      StackMap stack: int int java.security.SecureRandom byte[]
        27: iconst_0
        28: .line 473
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception byte[] sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
      StackMap stack: int int java.security.SecureRandom byte[] int
            invokestatic sun.security.util.KeyUtil.checkTlsPreMasterSecretKey:(IILjava/security/SecureRandom;[BZ)[B
            astore 6 /* encoded */
        end local 7 // sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec psps
        29: .line 478
      StackMap locals:
      StackMap stack:
            aload 6 /* encoded */
            aload 2 /* algorithm */
            iload 3 /* type */
            invokestatic sun.security.pkcs11.ConstructKeys.constructKey:([BLjava/lang/String;I)Ljava/security/Key;
            astore 9
        30: .line 481
            aload 0 /* this */
            iconst_4
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
        31: .line 478
            aload 9
            areturn
        end local 6 // byte[] encoded
        32: .line 479
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception
      StackMap stack: java.lang.Throwable
            astore 8
        33: .line 481
            aload 0 /* this */
            iconst_4
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11RSACipher.implInit:(ILjava/security/Key;)V
        34: .line 482
            aload 8
            athrow
        35: .line 484
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 6 /* s */
        start local 6 // sun.security.pkcs11.Session s
        36: .line 485
            aconst_null
            astore 7 /* secretKey */
        start local 7 // javax.crypto.SecretKey secretKey
        37: .line 488
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.getObjSession:()Lsun/security/pkcs11/Session;
            astore 6 /* s */
        38: .line 489
            ldc 16
            lstore 8 /* keyType */
        start local 8 // long keyType
        39: .line 490
            iconst_2
            anewarray sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            iconst_0
        40: .line 491
            new sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            lconst_0
            ldc 4
            invokespecial sun.security.pkcs11.wrapper.CK_ATTRIBUTE.<init>:(JJ)V
            aastore
            dup
            iconst_1
        41: .line 492
            new sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            ldc 256
            lload 8 /* keyType */
            invokespecial sun.security.pkcs11.wrapper.CK_ATTRIBUTE.<init>:(JJ)V
            aastore
        42: .line 490
            astore 10 /* attributes */
        start local 10 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        43: .line 494
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
        44: .line 495
            ldc "import"
            ldc 4
            lload 8 /* keyType */
            aload 10 /* attributes */
        45: .line 494
            invokevirtual sun.security.pkcs11.Token.getAttributes:(Ljava/lang/String;JJ[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
            astore 10 /* attributes */
        46: .line 496
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 6 /* s */
            invokevirtual sun.security.pkcs11.Session.id:()J
        47: .line 497
            new sun.security.pkcs11.wrapper.CK_MECHANISM
            dup
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.mechanism:J
            invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(J)V
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.p11Key:Lsun/security/pkcs11/P11Key;
            getfield sun.security.pkcs11.P11Key.keyID:J
        48: .line 498
            aload 1 /* wrappedKey */
            aload 10 /* attributes */
        49: .line 496
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_UnwrapKey:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J[B[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)J
            lstore 11 /* keyID */
        start local 11 // long keyID
        50: .line 499
            aload 6 /* s */
            lload 11 /* keyID */
        51: .line 500
            aload 2 /* algorithm */
            sipush 384
            aload 10 /* attributes */
        52: .line 499
            invokestatic sun.security.pkcs11.P11Key.secretKey:(Lsun/security/pkcs11/Session;JLjava/lang/String;I[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Ljavax/crypto/SecretKey;
            astore 7 /* secretKey */
        end local 11 // long keyID
        end local 10 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        end local 8 // long keyType
        53: .line 501
            goto 59
      StackMap locals: sun.security.pkcs11.P11RSACipher byte[] java.lang.String int int java.lang.Exception sun.security.pkcs11.Session javax.crypto.SecretKey
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        54: astore 8 /* e */
        start local 8 // sun.security.pkcs11.wrapper.PKCS11Exception e
        55: .line 502
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 58
        56: .line 503
            aload 8 /* e */
            astore 5 /* failover */
        57: .line 504
            goto 59
        58: .line 505
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11Exception
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "unwrap() failed"
            aload 8 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // sun.security.pkcs11.wrapper.PKCS11Exception e
        59: .line 509
      StackMap locals:
      StackMap stack:
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 66
        60: .line 511
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
        61: .line 510
            astore 8 /* psps */
        start local 8 // sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec psps
        62: .line 515
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 6 /* s */
        63: .line 516
            aload 5 /* failover */
            aload 7 /* secretKey */
        64: .line 517
            aload 8 /* psps */
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getClientVersion:()I
            aload 8 /* psps */
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getServerVersion:()I
        65: .line 515
            invokestatic sun.security.pkcs11.P11RSACipher.polishPreMasterSecretKey:(Lsun/security/pkcs11/Token;Lsun/security/pkcs11/Session;Ljava/lang/Exception;Ljavax/crypto/SecretKey;II)Ljavax/crypto/SecretKey;
            astore 7 /* secretKey */
        end local 8 // sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec psps
        66: .line 520
      StackMap locals:
      StackMap stack:
            aload 7 /* secretKey */
            astore 14
        67: .line 522
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 6 /* s */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        68: .line 520
            aload 14
            areturn
        69: .line 521
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 13
        70: .line 522
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 6 /* s */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        71: .line 523
            aload 13
            athrow
        end local 7 // javax.crypto.SecretKey secretKey
        end local 6 // sun.security.pkcs11.Session s
        end local 5 // java.lang.Exception failover
        end local 4 // boolean isTlsRsaPremasterSecret
        end local 3 // int type
        end local 2 // java.lang.String algorithm
        end local 1 // byte[] wrappedKey
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   72     0                     this  Lsun/security/pkcs11/P11RSACipher;
            0   72     1               wrappedKey  [B
            0   72     2                algorithm  Ljava/lang/String;
            0   72     3                     type  I
            2   72     4  isTlsRsaPremasterSecret  Z
            3   72     5                 failover  Ljava/lang/Exception;
            8   32     6                  encoded  [B
           12   16     7                        e  Ljavax/crypto/BadPaddingException;
           17   18     7                        e  Ljavax/crypto/IllegalBlockSizeException;
           25   29     7                     psps  Lsun/security/internal/spec/TlsRsaPremasterSecretParameterSpec;
           36   72     6                        s  Lsun/security/pkcs11/Session;
           37   72     7                secretKey  Ljavax/crypto/SecretKey;
           39   53     8                  keyType  J
           43   53    10               attributes  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
           50   53    11                    keyID  J
           55   59     8                        e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
           62   66     8                     psps  Lsun/security/internal/spec/TlsRsaPremasterSecretParameterSpec;
      Exception table:
        from    to  target  type
           9    10      11  Class javax.crypto.BadPaddingException
           9    10      16  Class javax.crypto.IllegalBlockSizeException
           5    30      32  any
          37    53      54  Class sun.security.pkcs11.wrapper.PKCS11Exception
          37    67      69  any
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
            Name  Flags
      wrappedKey  
      algorithm   
      type        

  protected int engineGetKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11RSACipher this
        start local 1 // java.security.Key key
         0: .line 529
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.token:Lsun/security/pkcs11/Token;
            aload 1 /* key */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11RSACipher.algorithm:Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11KeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            istore 2 /* n */
        start local 2 // int n
         1: .line 530
            iload 2 /* n */
            ireturn
        end local 2 // int n
        end local 1 // java.security.Key key
        end local 0 // sun.security.pkcs11.P11RSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/pkcs11/P11RSACipher;
            0    2     1   key  Ljava/security/Key;
            1    2     2     n  I
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  private static javax.crypto.SecretKey polishPreMasterSecretKey(sun.security.pkcs11.Token, sun.security.pkcs11.Session, java.lang.Exception, javax.crypto.SecretKey, int, int);
    descriptor: (Lsun/security/pkcs11/Token;Lsun/security/pkcs11/Session;Ljava/lang/Exception;Ljavax/crypto/SecretKey;II)Ljavax/crypto/SecretKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=11, args_size=6
        start local 0 // sun.security.pkcs11.Token token
        start local 1 // sun.security.pkcs11.Session session
        start local 2 // java.lang.Exception failover
        start local 3 // javax.crypto.SecretKey unwrappedKey
        start local 4 // int clientVersion
        start local 5 // int serverVersion
         0: .line 539
            new sun.security.pkcs11.wrapper.CK_VERSION
            dup
         1: .line 540
            iload 4 /* clientVersion */
            bipush 8
            iushr
            sipush 255
            iand
            iload 4 /* clientVersion */
            sipush 255
            iand
         2: .line 539
            invokespecial sun.security.pkcs11.wrapper.CK_VERSION.<init>:(II)V
            astore 7 /* version */
        start local 7 // sun.security.pkcs11.wrapper.CK_VERSION version
         3: .line 542
            aload 0 /* token */
         4: .line 543
            ldc "generate"
            ldc 4
         5: .line 544
            ldc 16
            iconst_0
            anewarray sun.security.pkcs11.wrapper.CK_ATTRIBUTE
         6: .line 542
            invokevirtual sun.security.pkcs11.Token.getAttributes:(Ljava/lang/String;JJ[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
            astore 8 /* attributes */
        start local 8 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
         7: .line 545
            aload 0 /* token */
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 1 /* session */
            invokevirtual sun.security.pkcs11.Session.id:()J
         8: .line 546
            new sun.security.pkcs11.wrapper.CK_MECHANISM
            dup
            ldc 880
            aload 7 /* version */
            invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(JLsun/security/pkcs11/wrapper/CK_VERSION;)V
         9: .line 547
            aload 8 /* attributes */
        10: .line 545
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_GenerateKey:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)J
            lstore 9 /* keyID */
        start local 9 // long keyID
        11: .line 548
            aload 1 /* session */
        12: .line 549
            lload 9 /* keyID */
            ldc "TlsRsaPremasterSecret"
            sipush 384
            aload 8 /* attributes */
        13: .line 548
            invokestatic sun.security.pkcs11.P11Key.secretKey:(Lsun/security/pkcs11/Session;JLjava/lang/String;I[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Ljavax/crypto/SecretKey;
            astore 6 /* newKey */
        end local 9 // long keyID
        end local 8 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        start local 6 // javax.crypto.SecretKey newKey
        14: .line 550
            goto 19
        end local 6 // javax.crypto.SecretKey newKey
      StackMap locals: sun.security.pkcs11.Token sun.security.pkcs11.Session java.lang.Exception javax.crypto.SecretKey int int top sun.security.pkcs11.wrapper.CK_VERSION
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        15: astore 8 /* e */
        start local 8 // sun.security.pkcs11.wrapper.PKCS11Exception e
        16: .line 551
            new java.security.ProviderException
            dup
        17: .line 552
            ldc "Could not generate premaster secret"
            aload 8 /* e */
        18: .line 551
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // sun.security.pkcs11.wrapper.PKCS11Exception e
        start local 6 // javax.crypto.SecretKey newKey
        19: .line 555
      StackMap locals: sun.security.pkcs11.Token sun.security.pkcs11.Session java.lang.Exception javax.crypto.SecretKey int int javax.crypto.SecretKey sun.security.pkcs11.wrapper.CK_VERSION
      StackMap stack:
            aload 2 /* failover */
            ifnonnull 20
            aload 3 /* unwrappedKey */
            goto 21
      StackMap locals:
      StackMap stack:
        20: aload 6 /* newKey */
      StackMap locals:
      StackMap stack: javax.crypto.SecretKey
        21: areturn
        end local 7 // sun.security.pkcs11.wrapper.CK_VERSION version
        end local 6 // javax.crypto.SecretKey newKey
        end local 5 // int serverVersion
        end local 4 // int clientVersion
        end local 3 // javax.crypto.SecretKey unwrappedKey
        end local 2 // java.lang.Exception failover
        end local 1 // sun.security.pkcs11.Session session
        end local 0 // sun.security.pkcs11.Token token
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   22     0          token  Lsun/security/pkcs11/Token;
            0   22     1        session  Lsun/security/pkcs11/Session;
            0   22     2       failover  Ljava/lang/Exception;
            0   22     3   unwrappedKey  Ljavax/crypto/SecretKey;
            0   22     4  clientVersion  I
            0   22     5  serverVersion  I
           14   15     6         newKey  Ljavax/crypto/SecretKey;
           19   22     6         newKey  Ljavax/crypto/SecretKey;
            3   22     7        version  Lsun/security/pkcs11/wrapper/CK_VERSION;
            7   14     8     attributes  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
           11   14     9          keyID  J
           16   19     8              e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           3    14      15  Class sun.security.pkcs11.wrapper.PKCS11Exception
    MethodParameters:
               Name  Flags
      token          
      session        
      failover       
      unwrappedKey   
      clientVersion  
      serverVersion  
}
SourceFile: "P11RSACipher.java"