final class sun.security.pkcs11.P11SecretKeyFactory extends javax.crypto.SecretKeyFactorySpi
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.pkcs11.P11SecretKeyFactory
  super_class: javax.crypto.SecretKeyFactorySpi
{
  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 static final java.util.Map<java.lang.String, java.lang.Long> keyTypes;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/Long;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 64
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putstatic sun.security.pkcs11.P11SecretKeyFactory.keyTypes:Ljava/util/Map;
         1: .line 65
            ldc "RC4"
            ldc 18
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         2: .line 66
            ldc "ARCFOUR"
            ldc 18
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         3: .line 67
            ldc "DES"
            ldc 19
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         4: .line 68
            ldc "DESede"
            ldc 21
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         5: .line 69
            ldc "AES"
            ldc 31
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         6: .line 70
            ldc "Blowfish"
            ldc 32
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         7: .line 74
            ldc "RC2"
            ldc 17
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         8: .line 75
            ldc "IDEA"
            ldc 26
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
         9: .line 77
            ldc "TlsPremasterSecret"
            ldc 2147483429
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
        10: .line 78
            ldc "TlsRsaPremasterSecret"
            ldc 2147483430
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
        11: .line 79
            ldc "TlsMasterSecret"
            ldc 2147483431
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
        12: .line 80
            ldc "Generic"
            ldc 16
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.addKeyType:(Ljava/lang/String;J)V
        13: .line 81
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(sun.security.pkcs11.Token, java.lang.String);
    descriptor: (Lsun/security/pkcs11/Token;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.pkcs11.P11SecretKeyFactory this
        start local 1 // sun.security.pkcs11.Token token
        start local 2 // java.lang.String algorithm
         0: .line 56
            aload 0 /* this */
            invokespecial javax.crypto.SecretKeyFactorySpi.<init>:()V
         1: .line 57
            aload 0 /* this */
            aload 1 /* token */
            putfield sun.security.pkcs11.P11SecretKeyFactory.token:Lsun/security/pkcs11/Token;
         2: .line 58
            aload 0 /* this */
            aload 2 /* algorithm */
            putfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
         3: .line 59
            return
        end local 2 // java.lang.String algorithm
        end local 1 // sun.security.pkcs11.Token token
        end local 0 // sun.security.pkcs11.P11SecretKeyFactory this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lsun/security/pkcs11/P11SecretKeyFactory;
            0    4     1      token  Lsun/security/pkcs11/Token;
            0    4     2  algorithm  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      token      
      algorithm  

  private static void addKeyType(java.lang.String, long);
    descriptor: (Ljava/lang/String;J)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // java.lang.String name
        start local 1 // long id
         0: .line 84
            lload 1 /* id */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            astore 3 /* l */
        start local 3 // java.lang.Long l
         1: .line 85
            getstatic sun.security.pkcs11.P11SecretKeyFactory.keyTypes:Ljava/util/Map;
            aload 0 /* name */
            aload 3 /* l */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 86
            getstatic sun.security.pkcs11.P11SecretKeyFactory.keyTypes:Ljava/util/Map;
            aload 0 /* name */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 3 /* l */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 87
            return
        end local 3 // java.lang.Long l
        end local 1 // long id
        end local 0 // java.lang.String name
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  name  Ljava/lang/String;
            0    4     1    id  J
            1    4     3     l  Ljava/lang/Long;
    MethodParameters:
      Name  Flags
      name  
      id    

  static long getPKCS11KeyType(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 92
            aload 0 /* algorithm */
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.getKeyType:(Ljava/lang/String;)J
            lstore 1 /* kt */
        start local 1 // long kt
         1: .line 93
            lload 1 /* kt */
            ldc -1
            lcmp
            ifeq 2
            lload 1 /* kt */
            ldc 2147483426
            lcmp
            ifle 3
         2: .line 94
      StackMap locals: long
      StackMap stack:
            ldc 16
            lstore 1 /* kt */
         3: .line 96
      StackMap locals:
      StackMap stack:
            lload 1 /* kt */
            lreturn
        end local 1 // long kt
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0  algorithm  Ljava/lang/String;
            1    4     1         kt  J
    MethodParameters:
           Name  Flags
      algorithm  

  static long getKeyType(java.lang.String);
    descriptor: (Ljava/lang/String;)J
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 101
            getstatic sun.security.pkcs11.P11SecretKeyFactory.keyTypes:Ljava/util/Map;
            aload 0 /* algorithm */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            astore 1 /* l */
        start local 1 // java.lang.Long l
         1: .line 102
            aload 1 /* l */
            ifnonnull 9
         2: .line 103
            aload 0 /* algorithm */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
            astore 0 /* algorithm */
         3: .line 104
            getstatic sun.security.pkcs11.P11SecretKeyFactory.keyTypes:Ljava/util/Map;
            aload 0 /* algorithm */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Long
            astore 1 /* l */
         4: .line 105
            aload 1 /* l */
            ifnonnull 9
         5: .line 106
            aload 0 /* algorithm */
            ldc "HMAC"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 7
         6: .line 107
            ldc 2147483427
            lreturn
         7: .line 108
      StackMap locals: java.lang.Long
      StackMap stack:
            aload 0 /* algorithm */
            ldc "SSLMAC"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 9
         8: .line 109
            ldc 2147483428
            lreturn
         9: .line 113
      StackMap locals:
      StackMap stack:
            aload 1 /* l */
            ifnull 10
            aload 1 /* l */
            invokevirtual java.lang.Long.longValue:()J
            goto 11
      StackMap locals:
      StackMap stack:
        10: ldc -1
      StackMap locals:
      StackMap stack: long
        11: lreturn
        end local 1 // java.lang.Long l
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0  algorithm  Ljava/lang/String;
            1   12     1          l  Ljava/lang/Long;
    MethodParameters:
           Name  Flags
      algorithm  

  static sun.security.pkcs11.P11Key convertKey(sun.security.pkcs11.Token, java.security.Key, java.lang.String);
    descriptor: (Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.pkcs11.Token token
        start local 1 // java.security.Key key
        start local 2 // java.lang.String algo
         0: .line 122
            aload 0 /* token */
            aload 1 /* key */
            aload 2 /* algo */
            aconst_null
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Lsun/security/pkcs11/P11Key;
            areturn
        end local 2 // java.lang.String algo
        end local 1 // java.security.Key key
        end local 0 // sun.security.pkcs11.Token token
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  token  Lsun/security/pkcs11/Token;
            0    1     1    key  Ljava/security/Key;
            0    1     2   algo  Ljava/lang/String;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
       Name  Flags
      token  
      key    
      algo   

  static sun.security.pkcs11.P11Key convertKey(sun.security.pkcs11.Token, java.security.Key, java.lang.String, sun.security.pkcs11.wrapper.CK_ATTRIBUTE[]);
    descriptor: (Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Lsun/security/pkcs11/P11Key;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=14, args_size=4
        start local 0 // sun.security.pkcs11.Token token
        start local 1 // java.security.Key key
        start local 2 // java.lang.String algo
        start local 3 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] extraAttrs
         0: .line 133
            aload 0 /* token */
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 134
            aload 1 /* key */
            ifnonnull 3
         2: .line 135
            new java.security.InvalidKeyException
            dup
            ldc "Key must not be null"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 137
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            instanceof javax.crypto.SecretKey
            ifne 5
         4: .line 138
            new java.security.InvalidKeyException
            dup
            ldc "Key must be a SecretKey"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 141
      StackMap locals:
      StackMap stack:
            aload 2 /* algo */
            ifnonnull 9
         6: .line 142
            aload 1 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            astore 2 /* algo */
         7: .line 143
            aload 2 /* algo */
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.getKeyType:(Ljava/lang/String;)J
            lstore 4 /* algoType */
        start local 4 // long algoType
         8: .line 144
            goto 16
        end local 4 // long algoType
         9: .line 145
      StackMap locals:
      StackMap stack:
            aload 2 /* algo */
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.getKeyType:(Ljava/lang/String;)J
            lstore 4 /* algoType */
        start local 4 // long algoType
        10: .line 146
            aload 1 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.getKeyType:(Ljava/lang/String;)J
            lstore 6 /* keyAlgorithmType */
        start local 6 // long keyAlgorithmType
        11: .line 147
            lload 4 /* algoType */
            lload 6 /* keyAlgorithmType */
            lcmp
            ifeq 16
        12: .line 148
            lload 4 /* algoType */
            ldc 2147483427
            lcmp
            ifeq 16
            lload 4 /* algoType */
            ldc 2147483428
            lcmp
            ifeq 16
        13: .line 151
            new java.security.InvalidKeyException
            dup
        14: .line 152
            new java.lang.StringBuilder
            dup
            ldc "Key algorithm must be "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* algo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 151
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // long keyAlgorithmType
        16: .line 156
      StackMap locals: long
      StackMap stack:
            aload 1 /* key */
            instanceof sun.security.pkcs11.P11Key
            ifeq 44
        17: .line 157
            aload 1 /* key */
            checkcast sun.security.pkcs11.P11Key
            astore 6 /* p11Key */
        start local 6 // sun.security.pkcs11.P11Key p11Key
        18: .line 158
            aload 6 /* p11Key */
            getfield sun.security.pkcs11.P11Key.token:Lsun/security/pkcs11/Token;
            aload 0 /* token */
            if_acmpne 44
        19: .line 159
            aload 3 /* extraAttrs */
            ifnull 43
        20: .line 160
            aconst_null
            astore 7 /* newP11Key */
        start local 7 // sun.security.pkcs11.P11Key newP11Key
        21: .line 161
            aconst_null
            astore 8 /* session */
        start local 8 // sun.security.pkcs11.Session session
        22: .line 162
            aload 6 /* p11Key */
            invokevirtual sun.security.pkcs11.P11Key.getKeyID:()J
            lstore 9 /* p11KeyID */
        start local 9 // long p11KeyID
        23: .line 164
            aload 0 /* token */
            invokevirtual sun.security.pkcs11.Token.getObjSession:()Lsun/security/pkcs11/Session;
            astore 8 /* session */
        24: .line 165
            aload 0 /* token */
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Session.id:()J
        25: .line 166
            lload 9 /* p11KeyID */
            aload 3 /* extraAttrs */
        26: .line 165
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_CopyObject:(JJ[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)J
            lstore 11 /* newKeyID */
        start local 11 // long newKeyID
        27: .line 167
            aload 8 /* session */
        28: .line 168
            lload 11 /* newKeyID */
            aload 6 /* p11Key */
            getfield sun.security.pkcs11.P11Key.algorithm:Ljava/lang/String;
            aload 6 /* p11Key */
            getfield sun.security.pkcs11.P11Key.keyLength:I
        29: .line 169
            aload 3 /* extraAttrs */
        30: .line 167
            invokestatic sun.security.pkcs11.P11Key.secretKey:(Lsun/security/pkcs11/Session;JLjava/lang/String;I[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Ljavax/crypto/SecretKey;
            checkcast sun.security.pkcs11.P11Key
            astore 7 /* newP11Key */
        end local 11 // long newKeyID
        31: .line 170
            goto 40
      StackMap locals: sun.security.pkcs11.Token java.security.Key java.lang.String sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] long sun.security.pkcs11.P11Key sun.security.pkcs11.P11Key sun.security.pkcs11.Session long
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        32: astore 11 /* p11e */
        start local 11 // sun.security.pkcs11.wrapper.PKCS11Exception p11e
        33: .line 171
            new java.security.InvalidKeyException
            dup
        34: .line 172
            ldc "Cannot duplicate the PKCS11 key"
            aload 11 /* p11e */
        35: .line 171
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 11 // sun.security.pkcs11.wrapper.PKCS11Exception p11e
        36: .line 173
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 13
        37: .line 174
            aload 6 /* p11Key */
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
        38: .line 175
            aload 0 /* token */
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        39: .line 176
            aload 13
            athrow
        40: .line 174
      StackMap locals:
      StackMap stack:
            aload 6 /* p11Key */
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
        41: .line 175
            aload 0 /* token */
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        42: .line 177
            aload 7 /* newP11Key */
            astore 6 /* p11Key */
        end local 9 // long p11KeyID
        end local 8 // sun.security.pkcs11.Session session
        end local 7 // sun.security.pkcs11.P11Key newP11Key
        43: .line 179
      StackMap locals:
      StackMap stack:
            aload 6 /* p11Key */
            areturn
        end local 6 // sun.security.pkcs11.P11Key p11Key
        44: .line 182
      StackMap locals:
      StackMap stack:
            aload 0 /* token */
            getfield sun.security.pkcs11.Token.secretCache:Lsun/security/pkcs11/KeyCache;
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.KeyCache.get:(Ljava/security/Key;)Lsun/security/pkcs11/P11Key;
            astore 6 /* p11Key */
        start local 6 // sun.security.pkcs11.P11Key p11Key
        45: .line 183
            aload 6 /* p11Key */
            ifnull 47
        46: .line 184
            aload 6 /* p11Key */
            areturn
        47: .line 186
      StackMap locals: sun.security.pkcs11.P11Key
      StackMap stack:
            ldc "RAW"
            aload 1 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 49
        48: .line 187
            new java.security.InvalidKeyException
            dup
            ldc "Encoded format must be RAW"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        49: .line 189
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 7 /* encoded */
        start local 7 // byte[] encoded
        50: .line 190
            aload 0 /* token */
            aload 7 /* encoded */
            aload 2 /* algo */
            lload 4 /* algoType */
            aload 3 /* extraAttrs */
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.createKey:(Lsun/security/pkcs11/Token;[BLjava/lang/String;J[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Lsun/security/pkcs11/P11Key;
            astore 6 /* p11Key */
        51: .line 191
            aload 0 /* token */
            getfield sun.security.pkcs11.Token.secretCache:Lsun/security/pkcs11/KeyCache;
            aload 1 /* key */
            aload 6 /* p11Key */
            invokevirtual sun.security.pkcs11.KeyCache.put:(Ljava/security/Key;Lsun/security/pkcs11/P11Key;)V
        52: .line 192
            aload 6 /* p11Key */
            areturn
        end local 7 // byte[] encoded
        end local 6 // sun.security.pkcs11.P11Key p11Key
        end local 4 // long algoType
        end local 3 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] extraAttrs
        end local 2 // java.lang.String algo
        end local 1 // java.security.Key key
        end local 0 // sun.security.pkcs11.Token token
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   53     0             token  Lsun/security/pkcs11/Token;
            0   53     1               key  Ljava/security/Key;
            0   53     2              algo  Ljava/lang/String;
            0   53     3        extraAttrs  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
            8    9     4          algoType  J
           10   53     4          algoType  J
           11   16     6  keyAlgorithmType  J
           18   44     6            p11Key  Lsun/security/pkcs11/P11Key;
           21   43     7         newP11Key  Lsun/security/pkcs11/P11Key;
           22   43     8           session  Lsun/security/pkcs11/Session;
           23   43     9          p11KeyID  J
           27   31    11          newKeyID  J
           33   36    11              p11e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
           45   53     6            p11Key  Lsun/security/pkcs11/P11Key;
           50   53     7           encoded  [B
      Exception table:
        from    to  target  type
          23    31      32  Class sun.security.pkcs11.wrapper.PKCS11Exception
          23    36      36  any
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      token       
      key         
      algo        
      extraAttrs  

  static void fixDESParity(byte[], int);
    descriptor: ([BI)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // byte[] key
        start local 1 // int offset
         0: .line 196
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 6
         2: .line 197
      StackMap locals: int
      StackMap stack:
            aload 0 /* key */
            iload 1 /* offset */
            baload
            sipush 254
            iand
            istore 3 /* b */
        start local 3 // int b
         3: .line 198
            iload 3 /* b */
            iload 3 /* b */
            invokestatic java.lang.Integer.bitCount:(I)I
            iconst_1
            iand
            iconst_1
            ixor
            ior
            istore 3 /* b */
         4: .line 199
            aload 0 /* key */
            iload 1 /* offset */
            iinc 1 /* offset */ 1
            iload 3 /* b */
            i2b
            bastore
        end local 3 // int b
         5: .line 196
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         6: iload 2 /* i */
            bipush 8
            if_icmplt 2
        end local 2 // int i
         7: .line 201
            return
        end local 1 // int offset
        end local 0 // byte[] key
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0     key  [B
            0    8     1  offset  I
            1    7     2       i  I
            3    5     3       b  I
    MethodParameters:
        Name  Flags
      key     
      offset  

  private static sun.security.pkcs11.P11Key createKey(sun.security.pkcs11.Token, byte[], java.lang.String, long, sun.security.pkcs11.wrapper.CK_ATTRIBUTE[]);
    descriptor: (Lsun/security/pkcs11/Token;[BLjava/lang/String;J[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Lsun/security/pkcs11/P11Key;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=15, args_size=5
        start local 0 // sun.security.pkcs11.Token token
        start local 1 // byte[] encoded
        start local 2 // java.lang.String algorithm
        start local 3 // long keyType
        start local 5 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] extraAttrs
         0: .line 206
            aload 1 /* encoded */
            arraylength
            iconst_3
            ishl
            istore 6 /* n */
        start local 6 // int n
         1: .line 207
            iload 6 /* n */
            istore 7 /* keyLength */
        start local 7 // int keyLength
         2: .line 209
            lload 3 /* keyType */
            l2i
            lookupswitch { // 11
                   16: 28
                   18: 20
                   19: 3
                   21: 7
                   31: 17
                   32: 23
           2147483427: 30
           2147483428: 30
           2147483429: 28
           2147483430: 28
           2147483431: 28
              default: 36
          }
         3: .line 212
      StackMap locals: int int
      StackMap stack:
            ldc 288
            iload 6 /* n */
            aload 0 /* token */
            invokestatic sun.security.pkcs11.P11KeyGenerator.checkKeySize:(JILsun/security/pkcs11/Token;)I
         4: .line 211
            istore 7 /* keyLength */
         5: .line 213
            aload 1 /* encoded */
            iconst_0
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.fixDESParity:([BI)V
         6: .line 214
            goto 45
         7: .line 217
      StackMap locals:
      StackMap stack:
            ldc 305
            iload 6 /* n */
            aload 0 /* token */
            invokestatic sun.security.pkcs11.P11KeyGenerator.checkKeySize:(JILsun/security/pkcs11/Token;)I
         8: .line 216
            istore 7 /* keyLength */
         9: .line 218
            aload 1 /* encoded */
            iconst_0
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.fixDESParity:([BI)V
        10: .line 219
            aload 1 /* encoded */
            bipush 8
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.fixDESParity:([BI)V
        11: .line 220
            iload 7 /* keyLength */
            bipush 112
            if_icmpne 14
        12: .line 221
            ldc 20
            lstore 3 /* keyType */
        13: .line 222
            goto 45
        14: .line 223
      StackMap locals:
      StackMap stack:
            ldc 21
            lstore 3 /* keyType */
        15: .line 224
            aload 1 /* encoded */
            bipush 16
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.fixDESParity:([BI)V
        16: .line 226
            goto 45
        17: .line 229
      StackMap locals:
      StackMap stack:
            ldc 4224
            iload 6 /* n */
            aload 0 /* token */
            invokestatic sun.security.pkcs11.P11KeyGenerator.checkKeySize:(JILsun/security/pkcs11/Token;)I
        18: .line 228
            istore 7 /* keyLength */
        19: .line 230
            goto 45
        20: .line 233
      StackMap locals:
      StackMap stack:
            ldc 272
            iload 6 /* n */
            aload 0 /* token */
            invokestatic sun.security.pkcs11.P11KeyGenerator.checkKeySize:(JILsun/security/pkcs11/Token;)I
        21: .line 232
            istore 7 /* keyLength */
        22: .line 234
            goto 45
        23: .line 237
      StackMap locals:
      StackMap stack:
            ldc 4240
            iload 6 /* n */
        24: .line 238
            aload 0 /* token */
        25: .line 237
            invokestatic sun.security.pkcs11.P11KeyGenerator.checkKeySize:(JILsun/security/pkcs11/Token;)I
        26: .line 236
            istore 7 /* keyLength */
        27: .line 239
            goto 45
        28: .line 244
      StackMap locals:
      StackMap stack:
            ldc 16
            lstore 3 /* keyType */
        29: .line 245
            goto 45
        30: .line 248
      StackMap locals:
      StackMap stack:
            iload 6 /* n */
            ifne 34
        31: .line 249
            new java.security.InvalidKeyException
            dup
        32: .line 250
            ldc "MAC keys must not be empty"
        33: .line 249
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        34: .line 252
      StackMap locals:
      StackMap stack:
            ldc 16
            lstore 3 /* keyType */
        35: .line 253
            goto 45
        36: .line 255
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown algorithm "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        37: .line 256
            aload 2 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        38: .line 255
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        39: .line 258
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
            astore 8 /* iape */
        start local 8 // java.security.InvalidAlgorithmParameterException iape
        40: .line 259
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid key for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        41: .line 260
            aload 8 /* iape */
        42: .line 259
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // java.security.InvalidAlgorithmParameterException iape
        43: .line 261
      StackMap locals:
      StackMap stack: java.security.ProviderException
            astore 8 /* pe */
        start local 8 // java.security.ProviderException pe
        44: .line 262
            new java.security.InvalidKeyException
            dup
            ldc "Could not create key"
            aload 8 /* pe */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // java.security.ProviderException pe
        45: .line 264
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* session */
        start local 8 // sun.security.pkcs11.Session session
        46: .line 267
            aload 5 /* extraAttrs */
            ifnull 52
        47: .line 268
            iconst_3
            aload 5 /* extraAttrs */
            arraylength
            iadd
            anewarray sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            astore 9 /* attributes */
        start local 9 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        48: .line 269
            aload 5 /* extraAttrs */
            iconst_0
            aload 9 /* attributes */
            iconst_3
        49: .line 270
            aload 5 /* extraAttrs */
            arraylength
        50: .line 269
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        51: .line 271
            goto 53
        end local 9 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        52: .line 272
      StackMap locals: sun.security.pkcs11.Session
      StackMap stack:
            iconst_3
            anewarray sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            astore 9 /* attributes */
        start local 9 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        53: .line 274
      StackMap locals: sun.security.pkcs11.wrapper.CK_ATTRIBUTE[]
      StackMap stack:
            aload 9 /* attributes */
            iconst_0
            new sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            lconst_0
            ldc 4
            invokespecial sun.security.pkcs11.wrapper.CK_ATTRIBUTE.<init>:(JJ)V
            aastore
        54: .line 275
            aload 9 /* attributes */
            iconst_1
            new sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            ldc 256
            lload 3 /* keyType */
            invokespecial sun.security.pkcs11.wrapper.CK_ATTRIBUTE.<init>:(JJ)V
            aastore
        55: .line 276
            aload 9 /* attributes */
            iconst_2
            new sun.security.pkcs11.wrapper.CK_ATTRIBUTE
            dup
            ldc 17
            aload 1 /* encoded */
            invokespecial sun.security.pkcs11.wrapper.CK_ATTRIBUTE.<init>:(JLjava/lang/Object;)V
            aastore
        56: .line 277
            aload 0 /* token */
        57: .line 278
            ldc "import"
            ldc 4
            lload 3 /* keyType */
            aload 9 /* attributes */
        58: .line 277
            invokevirtual sun.security.pkcs11.Token.getAttributes:(Ljava/lang/String;JJ[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
            astore 9 /* attributes */
        59: .line 279
            aload 0 /* token */
            invokevirtual sun.security.pkcs11.Token.getObjSession:()Lsun/security/pkcs11/Session;
            astore 8 /* session */
        60: .line 280
            aload 0 /* token */
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 9 /* attributes */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_CreateObject:(J[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)J
            lstore 10 /* keyID */
        start local 10 // long keyID
        61: .line 282
            aload 8 /* session */
            lload 10 /* keyID */
            aload 2 /* algorithm */
            iload 7 /* keyLength */
            aload 9 /* attributes */
        62: .line 281
            invokestatic sun.security.pkcs11.P11Key.secretKey:(Lsun/security/pkcs11/Session;JLjava/lang/String;I[Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;)Ljavax/crypto/SecretKey;
            checkcast sun.security.pkcs11.P11Key
            astore 12 /* p11Key */
        start local 12 // sun.security.pkcs11.P11Key p11Key
        63: .line 283
            aload 12 /* p11Key */
            astore 14
        64: .line 287
            aload 0 /* token */
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        65: .line 283
            aload 14
            areturn
        end local 12 // sun.security.pkcs11.P11Key p11Key
        end local 10 // long keyID
        end local 9 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] attributes
        66: .line 284
      StackMap locals: sun.security.pkcs11.Token byte[] java.lang.String long sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] int int sun.security.pkcs11.Session
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 9 /* e */
        start local 9 // sun.security.pkcs11.wrapper.PKCS11Exception e
        67: .line 285
            new java.security.InvalidKeyException
            dup
            ldc "Could not create key"
            aload 9 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 9 // sun.security.pkcs11.wrapper.PKCS11Exception e
        68: .line 286
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 13
        69: .line 287
            aload 0 /* token */
            aload 8 /* session */
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            pop
        70: .line 288
            aload 13
            athrow
        end local 8 // sun.security.pkcs11.Session session
        end local 7 // int keyLength
        end local 6 // int n
        end local 5 // sun.security.pkcs11.wrapper.CK_ATTRIBUTE[] extraAttrs
        end local 3 // long keyType
        end local 2 // java.lang.String algorithm
        end local 1 // byte[] encoded
        end local 0 // sun.security.pkcs11.Token token
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   71     0       token  Lsun/security/pkcs11/Token;
            0   71     1     encoded  [B
            0   71     2   algorithm  Ljava/lang/String;
            0   71     3     keyType  J
            0   71     5  extraAttrs  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
            1   71     6           n  I
            2   71     7   keyLength  I
           40   43     8        iape  Ljava/security/InvalidAlgorithmParameterException;
           44   45     8          pe  Ljava/security/ProviderException;
           46   71     8     session  Lsun/security/pkcs11/Session;
           48   52     9  attributes  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
           53   66     9  attributes  [Lsun/security/pkcs11/wrapper/CK_ATTRIBUTE;
           61   66    10       keyID  J
           63   66    12      p11Key  Lsun/security/pkcs11/P11Key;
           67   68     9           e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           2    39      39  Class java.security.InvalidAlgorithmParameterException
           2    39      43  Class java.security.ProviderException
          46    64      66  Class sun.security.pkcs11.wrapper.PKCS11Exception
          46    64      68  any
          66    68      68  any
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      token       
      encoded     
      algorithm   
      keyType     
      extraAttrs  

  protected javax.crypto.SecretKey engineGenerateSecret(java.security.spec.KeySpec);
    descriptor: (Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11SecretKeyFactory this
        start local 1 // java.security.spec.KeySpec keySpec
         0: .line 294
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 295
            aload 1 /* keySpec */
            ifnonnull 3
         2: .line 296
            new java.security.spec.InvalidKeySpecException
            dup
            ldc "KeySpec must not be null"
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 298
      StackMap locals:
      StackMap stack:
            aload 1 /* keySpec */
            instanceof javax.crypto.spec.SecretKeySpec
            ifeq 9
         4: .line 300
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.token:Lsun/security/pkcs11/Token;
            aload 1 /* keySpec */
            checkcast javax.crypto.SecretKey
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            astore 2 /* key */
        start local 2 // java.security.Key key
         5: .line 301
            aload 2 /* key */
            checkcast javax.crypto.SecretKey
         6: areturn
        end local 2 // java.security.Key key
         7: .line 302
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
            astore 2 /* e */
        start local 2 // java.security.InvalidKeyException e
         8: .line 303
            new java.security.spec.InvalidKeySpecException
            dup
            aload 2 /* e */
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.InvalidKeyException e
         9: .line 305
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            ldc "DES"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 14
        10: .line 306
            aload 1 /* keySpec */
            instanceof javax.crypto.spec.DESKeySpec
            ifeq 19
        11: .line 307
            aload 1 /* keySpec */
            checkcast javax.crypto.spec.DESKeySpec
            invokevirtual javax.crypto.spec.DESKeySpec.getKey:()[B
            astore 2 /* keyBytes */
        start local 2 // byte[] keyBytes
        12: .line 308
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 2 /* keyBytes */
            ldc "DES"
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            astore 1 /* keySpec */
        13: .line 309
            aload 0 /* this */
            aload 1 /* keySpec */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.engineGenerateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            areturn
        end local 2 // byte[] keyBytes
        14: .line 311
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            ldc "DESede"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 19
        15: .line 312
            aload 1 /* keySpec */
            instanceof javax.crypto.spec.DESedeKeySpec
            ifeq 19
        16: .line 313
            aload 1 /* keySpec */
            checkcast javax.crypto.spec.DESedeKeySpec
            invokevirtual javax.crypto.spec.DESedeKeySpec.getKey:()[B
            astore 2 /* keyBytes */
        start local 2 // byte[] keyBytes
        17: .line 314
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 2 /* keyBytes */
            ldc "DESede"
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            astore 1 /* keySpec */
        18: .line 315
            aload 0 /* this */
            aload 1 /* keySpec */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.engineGenerateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            areturn
        end local 2 // byte[] keyBytes
        19: .line 318
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidKeySpecException
            dup
        20: .line 319
            new java.lang.StringBuilder
            dup
            ldc "Unsupported spec: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* keySpec */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 318
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.spec.KeySpec keySpec
        end local 0 // sun.security.pkcs11.P11SecretKeyFactory this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   22     0      this  Lsun/security/pkcs11/P11SecretKeyFactory;
            0   22     1   keySpec  Ljava/security/spec/KeySpec;
            5    7     2       key  Ljava/security/Key;
            8    9     2         e  Ljava/security/InvalidKeyException;
           12   14     2  keyBytes  [B
           17   19     2  keyBytes  [B
      Exception table:
        from    to  target  type
           4     6       7  Class java.security.InvalidKeyException
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    MethodParameters:
         Name  Flags
      keySpec  

  private byte[] getKeyBytes(javax.crypto.SecretKey);
    descriptor: (Ljavax/crypto/SecretKey;)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11SecretKeyFactory this
        start local 1 // javax.crypto.SecretKey key
         0: .line 324
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.engineTranslateKey:(Ljavax/crypto/SecretKey;)Ljavax/crypto/SecretKey;
            astore 1 /* key */
         1: .line 325
            ldc "RAW"
            aload 1 /* key */
            invokeinterface javax.crypto.SecretKey.getFormat:()Ljava/lang/String;
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 5
         2: .line 326
            new java.security.spec.InvalidKeySpecException
            dup
         3: .line 327
            ldc "Could not obtain key bytes"
         4: .line 326
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 329
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            astore 2 /* k */
        start local 2 // byte[] k
         6: .line 330
            aload 2 /* k */
         7: areturn
        end local 2 // byte[] k
         8: .line 331
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
            astore 2 /* e */
        start local 2 // java.security.InvalidKeyException e
         9: .line 332
            new java.security.spec.InvalidKeySpecException
            dup
            aload 2 /* e */
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.InvalidKeyException e
        end local 1 // javax.crypto.SecretKey key
        end local 0 // sun.security.pkcs11.P11SecretKeyFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lsun/security/pkcs11/P11SecretKeyFactory;
            0   10     1   key  Ljavax/crypto/SecretKey;
            6    8     2     k  [B
            9   10     2     e  Ljava/security/InvalidKeyException;
      Exception table:
        from    to  target  type
           0     7       8  Class java.security.InvalidKeyException
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    MethodParameters:
      Name  Flags
      key   

  protected java.security.spec.KeySpec engineGetKeySpec(javax.crypto.SecretKey, java.lang.Class<?>);
    descriptor: (Ljavax/crypto/SecretKey;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // sun.security.pkcs11.P11SecretKeyFactory this
        start local 1 // javax.crypto.SecretKey key
        start local 2 // java.lang.Class keySpec
         0: .line 339
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 340
            aload 1 /* key */
            ifnull 2
            aload 2 /* keySpec */
            ifnonnull 5
         2: .line 341
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidKeySpecException
            dup
         3: .line 342
            ldc "key and keySpec must not be null"
         4: .line 341
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 344
      StackMap locals:
      StackMap stack:
            ldc Ljavax/crypto/spec/SecretKeySpec;
            aload 2 /* keySpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 7
         6: .line 345
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.getKeyBytes:(Ljavax/crypto/SecretKey;)[B
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            areturn
         7: .line 346
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            ldc "DES"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 13
         8: .line 348
            ldc Ljavax/crypto/spec/DESKeySpec;
            aload 2 /* keySpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 19
         9: .line 349
            new javax.crypto.spec.DESKeySpec
            dup
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.getKeyBytes:(Ljavax/crypto/SecretKey;)[B
            invokespecial javax.crypto.spec.DESKeySpec.<init>:([B)V
        10: areturn
        11: .line 351
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
            astore 3 /* e */
        start local 3 // java.security.InvalidKeyException e
        12: .line 352
            new java.security.spec.InvalidKeySpecException
            dup
            aload 3 /* e */
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.security.InvalidKeyException e
        13: .line 354
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            ldc "DESede"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 19
        14: .line 356
            ldc Ljavax/crypto/spec/DESedeKeySpec;
            aload 2 /* keySpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 19
        15: .line 357
            new javax.crypto.spec.DESedeKeySpec
            dup
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.P11SecretKeyFactory.getKeyBytes:(Ljavax/crypto/SecretKey;)[B
            invokespecial javax.crypto.spec.DESedeKeySpec.<init>:([B)V
        16: areturn
        17: .line 359
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
            astore 3 /* e */
        start local 3 // java.security.InvalidKeyException e
        18: .line 360
            new java.security.spec.InvalidKeySpecException
            dup
            aload 3 /* e */
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.security.InvalidKeyException e
        19: .line 363
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidKeySpecException
            dup
        20: .line 364
            new java.lang.StringBuilder
            dup
            ldc "Unsupported spec: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* keySpec */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 363
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.Class keySpec
        end local 1 // javax.crypto.SecretKey key
        end local 0 // sun.security.pkcs11.P11SecretKeyFactory this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   22     0     this  Lsun/security/pkcs11/P11SecretKeyFactory;
            0   22     1      key  Ljavax/crypto/SecretKey;
            0   22     2  keySpec  Ljava/lang/Class<*>;
           12   13     3        e  Ljava/security/InvalidKeyException;
           18   19     3        e  Ljava/security/InvalidKeyException;
      Exception table:
        from    to  target  type
           8    10      11  Class java.security.InvalidKeyException
          14    16      17  Class java.security.InvalidKeyException
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    Signature: (Ljavax/crypto/SecretKey;Ljava/lang/Class<*>;)Ljava/security/spec/KeySpec;
    MethodParameters:
         Name  Flags
      key      
      keySpec  

  protected javax.crypto.SecretKey engineTranslateKey(javax.crypto.SecretKey);
    descriptor: (Ljavax/crypto/SecretKey;)Ljavax/crypto/SecretKey;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.pkcs11.P11SecretKeyFactory this
        start local 1 // javax.crypto.SecretKey key
         0: .line 370
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.token:Lsun/security/pkcs11/Token;
            aload 1 /* key */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11SecretKeyFactory.algorithm:Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            checkcast javax.crypto.SecretKey
            areturn
        end local 1 // javax.crypto.SecretKey key
        end local 0 // sun.security.pkcs11.P11SecretKeyFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs11/P11SecretKeyFactory;
            0    1     1   key  Ljavax/crypto/SecretKey;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   
}
SourceFile: "P11SecretKeyFactory.java"