final class sun.security.pkcs11.P11PSSSignature extends java.security.SignatureSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.pkcs11.P11PSSSignature
  super_class: java.security.SignatureSpi
{
  private static final boolean DEBUG;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final java.util.Hashtable<java.lang.String, java.lang.Integer> DIGEST_LENGTHS;
    descriptor: Ljava/util/Hashtable;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Integer;>;

  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.lang.String KEY_ALGO;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "RSA"

  private final sun.security.pkcs11.wrapper.CK_MECHANISM mechanism;
    descriptor: Lsun/security/pkcs11/wrapper/CK_MECHANISM;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final int type;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

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

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

  private java.security.MessageDigest md;
    descriptor: Ljava/security/MessageDigest;
    flags: (0x0002) ACC_PRIVATE

  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 boolean initialized;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private final byte[] buffer;
    descriptor: [B
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

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

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 75
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
         1: .line 74
            putstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
         2: .line 78
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-1"
            bipush 20
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 79
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-224"
            bipush 28
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 80
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-256"
            bipush 32
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 81
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-384"
            bipush 48
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 82
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-512"
            bipush 64
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 83
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-512/224"
            bipush 28
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 84
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA-512/256"
            bipush 32
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 85
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA3-224"
            bipush 28
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        10: .line 86
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA3-256"
            bipush 32
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        11: .line 87
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA3-384"
            bipush 48
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        12: .line 88
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            ldc "SHA3-512"
            bipush 64
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        13: .line 163
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static java.lang.String toStdName(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // java.lang.String givenDigestAlg
         0: .line 93
            aload 0 /* givenDigestAlg */
            ifnonnull 1
            aconst_null
            areturn
         1: .line 95
      StackMap locals:
      StackMap stack:
            aload 0 /* givenDigestAlg */
            invokestatic sun.security.util.KnownOIDs.findMatch:(Ljava/lang/String;)Lsun/security/util/KnownOIDs;
            astore 1 /* given2 */
        start local 1 // sun.security.util.KnownOIDs given2
         2: .line 96
            aload 1 /* given2 */
            ifnonnull 4
         3: .line 97
            aload 0 /* givenDigestAlg */
            areturn
         4: .line 99
      StackMap locals: sun.security.util.KnownOIDs
      StackMap stack:
            aload 1 /* given2 */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            areturn
        end local 1 // sun.security.util.KnownOIDs given2
        end local 0 // java.lang.String givenDigestAlg
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    5     0  givenDigestAlg  Ljava/lang/String;
            2    5     1          given2  Lsun/security/util/KnownOIDs;
    MethodParameters:
                Name  Flags
      givenDigestAlg  

  private static boolean isDigestEqual(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.lang.String stdAlg
        start local 1 // java.lang.String givenAlg
         0: .line 106
            aload 0 /* stdAlg */
            ifnull 1
            aload 1 /* givenAlg */
            ifnonnull 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
         2: .line 108
      StackMap locals:
      StackMap stack:
            aload 1 /* givenAlg */
            invokestatic sun.security.pkcs11.P11PSSSignature.toStdName:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* givenAlg */
         3: .line 109
            aload 0 /* stdAlg */
            aload 1 /* givenAlg */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ireturn
        end local 1 // java.lang.String givenAlg
        end local 0 // java.lang.String stdAlg
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0    stdAlg  Ljava/lang/String;
            0    4     1  givenAlg  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      stdAlg    
      givenAlg  

  void <init>(sun.security.pkcs11.Token, java.lang.String, long);
    descriptor: (Lsun/security/pkcs11/Token;Ljava/lang/String;J)V
    flags: (0x0000) 
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // sun.security.pkcs11.Token token
        start local 2 // java.lang.String algorithm
        start local 3 // long mechId
         0: .line 167
            aload 0 /* this */
            invokespecial java.security.SignatureSpi.<init>:()V
         1: .line 128
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
         2: .line 131
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
         3: .line 132
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
         4: .line 138
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
         5: .line 147
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.initialized:Z
         6: .line 150
            aload 0 /* this */
            iconst_1
            newarray 8
            putfield sun.security.pkcs11.P11PSSSignature.buffer:[B
         7: .line 153
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
         8: .line 168
            aload 0 /* this */
            aload 1 /* token */
            putfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
         9: .line 169
            aload 0 /* this */
            aload 2 /* algorithm */
            putfield sun.security.pkcs11.P11PSSSignature.algorithm:Ljava/lang/String;
        10: .line 170
            aload 0 /* this */
            new sun.security.pkcs11.wrapper.CK_MECHANISM
            dup
            lload 3 /* mechId */
            invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(J)V
            putfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
        11: .line 171
            aload 2 /* algorithm */
            ldc "with"
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;)I
            istore 5 /* idx */
        start local 5 // int idx
        12: .line 173
            aload 0 /* this */
            iload 5 /* idx */
            iconst_m1
            if_icmpne 14
        13: .line 174
            aconst_null
            goto 15
      StackMap locals: sun.security.pkcs11.P11PSSSignature sun.security.pkcs11.Token java.lang.String long int
      StackMap stack: sun.security.pkcs11.P11PSSSignature
        14: aload 2 /* algorithm */
            iconst_0
            iload 5 /* idx */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic sun.security.pkcs11.P11PSSSignature.toStdName:(Ljava/lang/String;)Ljava/lang/String;
        15: .line 173
      StackMap locals: sun.security.pkcs11.P11PSSSignature sun.security.pkcs11.Token java.lang.String long int
      StackMap stack: sun.security.pkcs11.P11PSSSignature java.lang.String
            putfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
        16: .line 176
            lload 3 /* mechId */
            l2i
            lookupswitch { // 10
                   13: 20
                   14: 17
                   67: 17
                   68: 17
                   69: 17
                   71: 17
                   99: 17
                  100: 17
                  101: 17
                  103: 17
              default: 31
          }
        17: .line 186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_2
            putfield sun.security.pkcs11.P11PSSSignature.type:I
        18: .line 187
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
        19: .line 188
            goto 32
        20: .line 191
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            ifnull 26
            aload 1 /* token */
        21: .line 192
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            invokestatic sun.security.pkcs11.wrapper.Functions.getHashMechId:(Ljava/lang/String;)J
        22: .line 191
            invokevirtual sun.security.pkcs11.Token.getMechanismInfo:(J)Lsun/security/pkcs11/wrapper/CK_MECHANISM_INFO;
            ifnonnull 26
        23: .line 193
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        24: .line 194
            aload 2 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        25: .line 193
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 196
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            ifnonnull 27
            aconst_null
            goto 28
        27: .line 197
      StackMap locals:
      StackMap stack: sun.security.pkcs11.P11PSSSignature
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
        28: .line 196
      StackMap locals: sun.security.pkcs11.P11PSSSignature sun.security.pkcs11.Token java.lang.String long int
      StackMap stack: sun.security.pkcs11.P11PSSSignature java.security.MessageDigest
            putfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
        29: .line 198
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.type:I
        30: .line 199
            goto 32
        31: .line 201
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported mechanism: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            lload 3 /* mechId */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 203
      StackMap locals:
      StackMap stack:
            return
        end local 5 // int idx
        end local 3 // long mechId
        end local 2 // java.lang.String algorithm
        end local 1 // sun.security.pkcs11.Token token
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   33     0       this  Lsun/security/pkcs11/P11PSSSignature;
            0   33     1      token  Lsun/security/pkcs11/Token;
            0   33     2  algorithm  Ljava/lang/String;
            0   33     3     mechId  J
           12   33     5        idx  I
    Exceptions:
      throws java.security.NoSuchAlgorithmException, sun.security.pkcs11.wrapper.PKCS11Exception
    MethodParameters:
           Name  Flags
      token      
      algorithm  
      mechId     

  private static java.security.spec.PSSParameterSpec genDefaultParams(java.lang.String, sun.security.pkcs11.P11Key);
    descriptor: (Ljava/lang/String;Lsun/security/pkcs11/P11Key;)Ljava/security/spec/PSSParameterSpec;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=4, args_size=2
        start local 0 // java.lang.String digestAlg
        start local 1 // sun.security.pkcs11.P11Key key
         0: .line 209
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            aload 0 /* digestAlg */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 2 /* mdLen */
        start local 2 // int mdLen
         1: .line 210
            goto 6
        end local 2 // int mdLen
      StackMap locals:
      StackMap stack: java.lang.NullPointerException
         2: pop
         3: .line 211
            new java.security.SignatureException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported digest: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         4: .line 212
            aload 0 /* digestAlg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 211
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // int mdLen
         6: .line 214
      StackMap locals: int
      StackMap stack:
            iload 2 /* mdLen */
            aload 1 /* key */
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            iconst_3
            ishr
            iload 2 /* mdLen */
            isub
            iconst_2
            isub
            invokestatic java.lang.Integer.min:(II)I
            istore 3 /* saltLen */
        start local 3 // int saltLen
         7: .line 215
            new java.security.spec.PSSParameterSpec
            dup
            aload 0 /* digestAlg */
         8: .line 216
            ldc "MGF1"
            new java.security.spec.MGF1ParameterSpec
            dup
            aload 0 /* digestAlg */
            invokespecial java.security.spec.MGF1ParameterSpec.<init>:(Ljava/lang/String;)V
         9: .line 217
            iload 3 /* saltLen */
            iconst_1
        10: .line 215
            invokespecial java.security.spec.PSSParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;II)V
            areturn
        end local 3 // int saltLen
        end local 2 // int mdLen
        end local 1 // sun.security.pkcs11.P11Key key
        end local 0 // java.lang.String digestAlg
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0  digestAlg  Ljava/lang/String;
            0   11     1        key  Lsun/security/pkcs11/P11Key;
            1    2     2      mdLen  I
            6   11     2      mdLen  I
            7   11     3    saltLen  I
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.NullPointerException
    Exceptions:
      throws java.security.SignatureException
    MethodParameters:
           Name  Flags
      digestAlg  
      key        

  private void ensureInitialized();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=2, args_size=1
        start local 0 // sun.security.pkcs11.P11PSSSignature this
         0: .line 221
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 223
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnonnull 3
         2: .line 224
            new java.security.SignatureException
            dup
            ldc "Missing key"
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 226
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnonnull 12
         4: .line 227
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            ifnonnull 8
         5: .line 229
            new java.security.SignatureException
            dup
         6: .line 230
            ldc "Parameters required for RSASSA-PSS signature"
         7: .line 229
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 233
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokestatic sun.security.pkcs11.P11PSSSignature.genDefaultParams:(Ljava/lang/String;Lsun/security/pkcs11/P11Key;)Ljava/security/spec/PSSParameterSpec;
            putfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
         9: .line 234
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            new sun.security.pkcs11.wrapper.CK_RSA_PKCS_PSS_PARAMS
            dup
        10: .line 235
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            ldc "MGF1"
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            invokevirtual java.security.spec.PSSParameterSpec.getSaltLength:()I
            invokespecial sun.security.pkcs11.wrapper.CK_RSA_PKCS_PSS_PARAMS.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V
        11: .line 234
            invokevirtual sun.security.pkcs11.wrapper.CK_MECHANISM.setParameter:(Lsun/security/pkcs11/wrapper/CK_RSA_PKCS_PSS_PARAMS;)V
        12: .line 238
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.initialized:Z
            ifne 17
        13: .line 240
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.initialize:()V
        14: .line 241
            goto 17
      StackMap locals:
      StackMap stack: java.security.ProviderException
        15: astore 1 /* pe */
        start local 1 // java.security.ProviderException pe
        16: .line 242
            new java.security.SignatureException
            dup
            aload 1 /* pe */
            invokespecial java.security.SignatureException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.ProviderException pe
        17: .line 245
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   18     0  this  Lsun/security/pkcs11/P11PSSSignature;
           16   17     1    pe  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
          13    14      15  Class java.security.ProviderException
    Exceptions:
      throws java.security.SignatureException

  private void reset(boolean);
    descriptor: (Z)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // boolean doCancel
         0: .line 249
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.initialized:Z
            ifne 2
         1: .line 250
            return
         2: .line 252
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.initialized:Z
         3: .line 255
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            ifnonnull 9
         4: .line 263
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
         5: .line 264
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            invokevirtual sun.security.pkcs11.wrapper.CK_MECHANISM.freeHandle:()V
         6: .line 265
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
         7: .line 266
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
         8: .line 256
            return
         9: .line 259
      StackMap locals:
      StackMap stack:
            iload 1 /* doCancel */
            ifeq 18
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.explicitCancel:Z
            ifeq 18
        10: .line 260
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.cancelOperation:()V
        11: .line 262
            goto 18
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: astore 2
        13: .line 263
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
        14: .line 264
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            invokevirtual sun.security.pkcs11.wrapper.CK_MECHANISM.freeHandle:()V
        15: .line 265
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
        16: .line 266
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
        17: .line 267
            aload 2
            athrow
        18: .line 263
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
        19: .line 264
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            invokevirtual sun.security.pkcs11.wrapper.CK_MECHANISM.freeHandle:()V
        20: .line 265
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
        21: .line 266
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
        22: .line 268
            return
        end local 1 // boolean doCancel
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   23     0      this  Lsun/security/pkcs11/P11PSSSignature;
            0   23     1  doCancel  Z
      Exception table:
        from    to  target  type
           3     4      12  any
           9    12      12  any
    MethodParameters:
          Name  Flags
      doCancel  

  private void cancelOperation();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // sun.security.pkcs11.P11PSSSignature this
         0: .line 271
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.ensureValid:()V
         1: .line 277
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mode:I
            iconst_1
            if_icmpne 10
         2: .line 278
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            iconst_2
            if_icmpne 5
         3: .line 280
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            iconst_0
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignFinal:(JI)[B
            pop
         4: .line 281
            goto 25
         5: .line 283
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 6
            iconst_0
            newarray 8
            goto 7
      StackMap locals:
      StackMap stack:
         6: aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.digest:()[B
         7: .line 282
      StackMap locals:
      StackMap stack: byte[]
            astore 1 /* digest */
        start local 1 // byte[] digest
         8: .line 285
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 1 /* digest */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Sign:(J[B)[B
            pop
        end local 1 // byte[] digest
         9: .line 287
            goto 25
        10: .line 289
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            bipush 7
            iadd
            iconst_3
            ishr
            newarray 8
        11: .line 288
            astore 1 /* signature */
        start local 1 // byte[] signature
        12: .line 290
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            iconst_2
            if_icmpne 15
        13: .line 292
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 1 /* signature */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyFinal:(J[B)V
        14: .line 293
            goto 25
        15: .line 295
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 16
            iconst_0
            newarray 8
            goto 17
      StackMap locals:
      StackMap stack:
        16: aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.digest:()[B
        17: .line 294
      StackMap locals:
      StackMap stack: byte[]
            astore 2 /* digest */
        start local 2 // byte[] digest
        18: .line 297
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 2 /* digest */
            aload 1 /* signature */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Verify:(J[B[B)V
        end local 2 // byte[] digest
        end local 1 // byte[] signature
        19: .line 300
            goto 25
      StackMap locals: sun.security.pkcs11.P11PSSSignature
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        20: astore 1 /* e */
        start local 1 // sun.security.pkcs11.wrapper.PKCS11Exception e
        21: .line 301
            aload 1 /* e */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.getErrorCode:()J
            ldc 145
            lcmp
            ifne 23
        22: .line 306
            return
        23: .line 308
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11Exception
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mode:I
            iconst_1
            if_icmpne 25
        24: .line 309
            new java.security.ProviderException
            dup
            ldc "cancel failed"
            aload 1 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // sun.security.pkcs11.wrapper.PKCS11Exception e
        25: .line 313
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   26     0       this  Lsun/security/pkcs11/P11PSSSignature;
            8    9     1     digest  [B
           12   19     1  signature  [B
           18   19     2     digest  [B
           21   25     1          e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           1    19      20  Class sun.security.pkcs11.wrapper.PKCS11Exception

  private void initialize();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=1
        start local 0 // sun.security.pkcs11.P11PSSSignature this
         0: .line 319
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnonnull 4
         1: .line 320
            new java.security.ProviderException
            dup
         2: .line 321
            ldc "No Key found, call initSign/initVerify first"
         3: .line 320
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 324
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.getKeyID:()J
            lstore 1 /* keyID */
        start local 1 // long keyID
         5: .line 326
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            ifnonnull 7
         6: .line 327
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            invokevirtual sun.security.pkcs11.Token.getOpSession:()Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
         7: .line 329
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mode:I
            iconst_1
            if_icmpne 10
         8: .line 330
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            lload 1 /* keyID */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
         9: .line 331
            goto 16
        10: .line 332
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            lload 1 /* keyID */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
        11: .line 334
            goto 16
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        12: astore 3 /* e */
        start local 3 // sun.security.pkcs11.wrapper.PKCS11Exception e
        13: .line 335
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
        14: .line 336
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
            putfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
        15: .line 337
            new java.security.ProviderException
            dup
            ldc "Initialization failed"
            aload 3 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // sun.security.pkcs11.wrapper.PKCS11Exception e
        16: .line 339
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            ifeq 20
        17: .line 340
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
        18: .line 341
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnull 20
        19: .line 342
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.reset:()V
        20: .line 345
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.initialized:Z
        21: .line 346
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
        22: .line 348
            return
        end local 1 // long keyID
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   23     0   this  Lsun/security/pkcs11/P11PSSSignature;
            5   23     1  keyID  J
           13   16     3      e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           5    11      12  Class sun.security.pkcs11.wrapper.PKCS11Exception
    Exceptions:
      throws java.security.ProviderException

  private void checkKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.security.Key key
         0: .line 353
            aload 1 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            ldc "RSA"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 2
         1: .line 354
            new java.security.InvalidKeyException
            dup
            ldc "Only RSA keys are supported"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 358
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* mechInfo */
        start local 2 // sun.security.pkcs11.wrapper.CK_MECHANISM_INFO mechInfo
         3: .line 360
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM.mechanism:J
            invokevirtual sun.security.pkcs11.Token.getMechanismInfo:(J)Lsun/security/pkcs11/wrapper/CK_MECHANISM_INFO;
            astore 2 /* mechInfo */
         4: .line 361
            goto 6
      StackMap locals: sun.security.pkcs11.P11PSSSignature java.security.Key sun.security.pkcs11.wrapper.CK_MECHANISM_INFO
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
         5: astore 3
         6: .line 369
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 3 /* keySize */
        start local 3 // int keySize
         7: .line 370
            aload 2 /* mechInfo */
            ifnull 25
         8: .line 371
            aload 1 /* key */
            instanceof sun.security.pkcs11.P11Key
            ifeq 11
         9: .line 372
            aload 1 /* key */
            checkcast sun.security.pkcs11.P11Key
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            bipush 7
            iadd
            iconst_3
            ishr
            istore 3 /* keySize */
        10: .line 373
            goto 15
      StackMap locals: int
      StackMap stack:
        11: aload 1 /* key */
            instanceof java.security.interfaces.RSAKey
            ifeq 14
        12: .line 374
            aload 1 /* key */
            checkcast java.security.interfaces.RSAKey
            invokeinterface java.security.interfaces.RSAKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            iconst_3
            ishr
            istore 3 /* keySize */
        13: .line 375
            goto 15
        14: .line 376
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unrecognized key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            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
        15: .line 379
      StackMap locals:
      StackMap stack:
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMinKeySize:I
            ifeq 20
        16: .line 380
            iload 3 /* keySize */
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMinKeySize:I
            iconst_3
            ishr
            if_icmpge 20
        17: .line 381
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "RSA key must be at least "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 382
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMinKeySize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bits"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 381
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 384
      StackMap locals:
      StackMap stack:
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMaxKeySize:I
            ldc 2147483647
            if_icmpeq 25
        21: .line 385
            iload 3 /* keySize */
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMaxKeySize:I
            iconst_3
            ishr
            if_icmple 25
        22: .line 386
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "RSA key must be at most "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        23: .line 387
            aload 2 /* mechInfo */
            getfield sun.security.pkcs11.wrapper.CK_MECHANISM_INFO.iMaxKeySize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bits"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 386
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        25: .line 390
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnull 34
        26: .line 391
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            invokevirtual java.security.spec.PSSParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            astore 4 /* digestAlg */
        start local 4 // java.lang.String digestAlg
        27: .line 392
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            invokevirtual java.security.spec.PSSParameterSpec.getSaltLength:()I
            istore 5 /* sLen */
        start local 5 // int sLen
        28: .line 394
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            aload 4 /* digestAlg */
            invokestatic sun.security.pkcs11.P11PSSSignature.toStdName:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 6 /* hLen */
        start local 6 // int hLen
        29: .line 395
            iload 5 /* sLen */
            iload 6 /* hLen */
            invokestatic java.lang.Math.addExact:(II)I
            iconst_2
            invokestatic java.lang.Math.addExact:(II)I
            istore 7 /* minKeyLen */
        start local 7 // int minKeyLen
        30: .line 397
            iload 3 /* keySize */
            iload 7 /* minKeyLen */
            if_icmpge 34
        31: .line 398
            new java.security.InvalidKeyException
            dup
        32: .line 399
            new java.lang.StringBuilder
            dup
            ldc "Key is too short for current params, need min "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 7 /* minKeyLen */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 398
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // int minKeyLen
        end local 6 // int hLen
        end local 5 // int sLen
        end local 4 // java.lang.String digestAlg
        34: .line 402
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int keySize
        end local 2 // sun.security.pkcs11.wrapper.CK_MECHANISM_INFO mechInfo
        end local 1 // java.security.Key key
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   35     0       this  Lsun/security/pkcs11/P11PSSSignature;
            0   35     1        key  Ljava/security/Key;
            3   35     2   mechInfo  Lsun/security/pkcs11/wrapper/CK_MECHANISM_INFO;
            7   35     3    keySize  I
           27   34     4  digestAlg  Ljava/lang/String;
           28   34     5       sLen  I
           29   34     6       hLen  I
           30   34     7  minKeyLen  I
      Exception table:
        from    to  target  type
           3     4       5  Class sun.security.pkcs11.wrapper.PKCS11Exception
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  private void setSigParams(java.security.spec.AlgorithmParameterSpec);
    descriptor: (Ljava/security/spec/AlgorithmParameterSpec;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=9, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.security.spec.AlgorithmParameterSpec p
         0: .line 406
            aload 1 /* p */
            ifnonnull 2
         1: .line 407
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "PSS Parameter required"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 409
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            instanceof java.security.spec.PSSParameterSpec
            ifne 6
         3: .line 410
            new java.security.InvalidAlgorithmParameterException
            dup
         4: .line 411
            ldc "Only PSSParameterSpec is supported"
         5: .line 410
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 414
      StackMap locals:
      StackMap stack:
            aload 1 /* p */
            checkcast java.security.spec.PSSParameterSpec
            astore 2 /* params */
        start local 2 // java.security.spec.PSSParameterSpec params
         7: .line 415
            aload 2 /* params */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            if_acmpne 8
            return
         8: .line 417
      StackMap locals: java.security.spec.PSSParameterSpec
      StackMap stack:
            aload 2 /* params */
            invokevirtual java.security.spec.PSSParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            astore 3 /* digestAlgorithm */
        start local 3 // java.lang.String digestAlgorithm
         9: .line 418
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            ifnull 15
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            aload 3 /* digestAlgorithm */
            invokestatic sun.security.pkcs11.P11PSSSignature.isDigestEqual:(Ljava/lang/String;Ljava/lang/String;)Z
            ifne 15
        10: .line 419
            new java.security.InvalidAlgorithmParameterException
            dup
        11: .line 420
            new java.lang.StringBuilder
            dup
            ldc "Digest algorithm in Signature parameters must be "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 421
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mdAlg:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        13: .line 420
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 419
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 425
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
        16: .line 426
            aload 3 /* digestAlgorithm */
        17: .line 425
            invokestatic sun.security.pkcs11.wrapper.Functions.getHashMechId:(Ljava/lang/String;)J
            invokevirtual sun.security.pkcs11.Token.getMechanismInfo:(J)Lsun/security/pkcs11/wrapper/CK_MECHANISM_INFO;
            ifnonnull 23
        18: .line 427
            new java.security.InvalidAlgorithmParameterException
            dup
        19: .line 428
            new java.lang.StringBuilder
            dup
            ldc "Unsupported digest algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* digestAlgorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 427
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 430
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 4 /* pe */
        start local 4 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        22: .line 432
            new java.security.InvalidAlgorithmParameterException
            dup
            aload 4 /* pe */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        23: .line 435
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs11.P11PSSSignature.DIGEST_LENGTHS:Ljava/util/Hashtable;
            aload 3 /* digestAlgorithm */
            invokestatic sun.security.pkcs11.P11PSSSignature.toStdName:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 4 /* digestLen */
        start local 4 // java.lang.Integer digestLen
        24: .line 436
            aload 4 /* digestLen */
            ifnonnull 30
        25: .line 437
            new java.security.InvalidAlgorithmParameterException
            dup
        26: .line 438
            new java.lang.StringBuilder
            dup
            ldc "Unsupported digest algorithm in Signature parameters: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        27: .line 439
            aload 3 /* digestAlgorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        28: .line 438
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 437
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 442
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 2 /* params */
            invokevirtual java.security.spec.PSSParameterSpec.getMGFAlgorithm:()Ljava/lang/String;
            ldc "MGF1"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 32
        31: .line 443
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "Only supports MGF1"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 447
      StackMap locals:
      StackMap stack:
            aload 3 /* digestAlgorithm */
            astore 5 /* mgfDigestAlgo */
        start local 5 // java.lang.String mgfDigestAlgo
        33: .line 448
            aload 2 /* params */
            invokevirtual java.security.spec.PSSParameterSpec.getMGFParameters:()Ljava/security/spec/AlgorithmParameterSpec;
            astore 6 /* mgfParams */
        start local 6 // java.security.spec.AlgorithmParameterSpec mgfParams
        34: .line 449
            aload 6 /* mgfParams */
            ifnull 40
        35: .line 450
            aload 6 /* mgfParams */
            instanceof java.security.spec.MGF1ParameterSpec
            ifne 39
        36: .line 451
            new java.security.InvalidAlgorithmParameterException
            dup
        37: .line 452
            ldc "Only MGF1ParameterSpec is supported"
        38: .line 451
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        39: .line 454
      StackMap locals: java.lang.String java.security.spec.AlgorithmParameterSpec
      StackMap stack:
            aload 6 /* mgfParams */
            checkcast java.security.spec.MGF1ParameterSpec
            invokevirtual java.security.spec.MGF1ParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            astore 5 /* mgfDigestAlgo */
        40: .line 457
      StackMap locals:
      StackMap stack:
            aload 2 /* params */
            invokevirtual java.security.spec.PSSParameterSpec.getTrailerField:()I
            iconst_1
            if_icmpeq 44
        41: .line 458
            new java.security.InvalidAlgorithmParameterException
            dup
        42: .line 459
            ldc "Only supports TrailerFieldBC(1)"
        43: .line 458
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        44: .line 462
      StackMap locals:
      StackMap stack:
            aload 2 /* params */
            invokevirtual java.security.spec.PSSParameterSpec.getSaltLength:()I
            istore 7 /* saltLen */
        start local 7 // int saltLen
        45: .line 463
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnull 55
        46: .line 464
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            invokevirtual sun.security.pkcs11.P11Key.length:()I
            bipush 7
            iadd
            iconst_3
            ishr
        47: .line 465
            aload 4 /* digestLen */
            invokevirtual java.lang.Integer.intValue:()I
        48: .line 464
            isub
        49: .line 465
            iconst_2
        50: .line 464
            isub
            istore 8 /* maxSaltLen */
        start local 8 // int maxSaltLen
        51: .line 471
            iload 8 /* maxSaltLen */
            iflt 52
            iload 7 /* saltLen */
            iload 8 /* maxSaltLen */
            if_icmple 55
        52: .line 472
      StackMap locals: int int
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
        53: .line 473
            ldc "Invalid with current key size"
        54: .line 472
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        end local 8 // int maxSaltLen
        55: .line 481
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mechanism:Lsun/security/pkcs11/wrapper/CK_MECHANISM;
        56: .line 482
            new sun.security.pkcs11.wrapper.CK_RSA_PKCS_PSS_PARAMS
            dup
            aload 3 /* digestAlgorithm */
            ldc "MGF1"
        57: .line 483
            aload 5 /* mgfDigestAlgo */
            iload 7 /* saltLen */
        58: .line 482
            invokespecial sun.security.pkcs11.wrapper.CK_RSA_PKCS_PSS_PARAMS.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;I)V
        59: .line 481
            invokevirtual sun.security.pkcs11.wrapper.CK_MECHANISM.setParameter:(Lsun/security/pkcs11/wrapper/CK_RSA_PKCS_PSS_PARAMS;)V
        60: .line 484
            aload 0 /* this */
            aload 2 /* params */
            putfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
        61: .line 485
            goto 64
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
        62: astore 8 /* iae */
        start local 8 // java.lang.IllegalArgumentException iae
        63: .line 486
            new java.security.InvalidAlgorithmParameterException
            dup
            aload 8 /* iae */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 8 // java.lang.IllegalArgumentException iae
        64: .line 488
      StackMap locals:
      StackMap stack:
            return
        end local 7 // int saltLen
        end local 6 // java.security.spec.AlgorithmParameterSpec mgfParams
        end local 5 // java.lang.String mgfDigestAlgo
        end local 4 // java.lang.Integer digestLen
        end local 3 // java.lang.String digestAlgorithm
        end local 2 // java.security.spec.PSSParameterSpec params
        end local 1 // java.security.spec.AlgorithmParameterSpec p
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   65     0             this  Lsun/security/pkcs11/P11PSSSignature;
            0   65     1                p  Ljava/security/spec/AlgorithmParameterSpec;
            7   65     2           params  Ljava/security/spec/PSSParameterSpec;
            9   65     3  digestAlgorithm  Ljava/lang/String;
           22   23     4               pe  Lsun/security/pkcs11/wrapper/PKCS11Exception;
           24   65     4        digestLen  Ljava/lang/Integer;
           33   65     5    mgfDigestAlgo  Ljava/lang/String;
           34   65     6        mgfParams  Ljava/security/spec/AlgorithmParameterSpec;
           45   65     7          saltLen  I
           51   55     8       maxSaltLen  I
           63   64     8              iae  Ljava/lang/IllegalArgumentException;
      Exception table:
        from    to  target  type
          15    21      21  Class sun.security.pkcs11.wrapper.PKCS11Exception
          55    61      62  Class java.lang.IllegalArgumentException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
      Name  Flags
      p     

  protected void engineInitVerify(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.security.PublicKey publicKey
         0: .line 495
            aload 1 /* publicKey */
            ifnonnull 2
         1: .line 496
            new java.security.InvalidKeyException
            dup
            ldc "Key must not be null"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 500
      StackMap locals:
      StackMap stack:
            aload 1 /* publicKey */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            if_acmpeq 4
         3: .line 501
            aload 0 /* this */
            aload 1 /* publicKey */
            invokevirtual sun.security.pkcs11.P11PSSSignature.checkKeySize:(Ljava/security/Key;)V
         4: .line 504
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
         5: .line 505
            aload 0 /* this */
            iconst_2
            putfield sun.security.pkcs11.P11PSSSignature.mode:I
         6: .line 506
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 1 /* publicKey */
            ldc "RSA"
            invokestatic sun.security.pkcs11.P11KeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            putfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
         7: .line 509
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnull 12
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnull 12
         8: .line 511
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.initialize:()V
         9: .line 512
            goto 12
      StackMap locals:
      StackMap stack: java.security.ProviderException
        10: astore 2 /* pe */
        start local 2 // java.security.ProviderException pe
        11: .line 513
            new java.security.InvalidKeyException
            dup
            aload 2 /* pe */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.ProviderException pe
        12: .line 516
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.PublicKey publicKey
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0       this  Lsun/security/pkcs11/P11PSSSignature;
            0   13     1  publicKey  Ljava/security/PublicKey;
           11   12     2         pe  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           8     9      10  Class java.security.ProviderException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
           Name  Flags
      publicKey  

  protected void engineInitSign(java.security.PrivateKey);
    descriptor: (Ljava/security/PrivateKey;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.security.PrivateKey privateKey
         0: .line 523
            aload 1 /* privateKey */
            ifnonnull 2
         1: .line 524
            new java.security.InvalidKeyException
            dup
            ldc "Key must not be null"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 528
      StackMap locals:
      StackMap stack:
            aload 1 /* privateKey */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            if_acmpeq 4
         3: .line 529
            aload 0 /* this */
            aload 1 /* privateKey */
            invokevirtual sun.security.pkcs11.P11PSSSignature.checkKeySize:(Ljava/security/Key;)V
         4: .line 532
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
         5: .line 533
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.mode:I
         6: .line 534
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            aload 1 /* privateKey */
            ldc "RSA"
            invokestatic sun.security.pkcs11.P11KeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
            putfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
         7: .line 537
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnull 12
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnull 12
         8: .line 539
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.initialize:()V
         9: .line 540
            goto 12
      StackMap locals:
      StackMap stack: java.security.ProviderException
        10: astore 2 /* pe */
        start local 2 // java.security.ProviderException pe
        11: .line 541
            new java.security.InvalidKeyException
            dup
            aload 2 /* pe */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.ProviderException pe
        12: .line 544
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.PrivateKey privateKey
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   13     0        this  Lsun/security/pkcs11/P11PSSSignature;
            0   13     1  privateKey  Ljava/security/PrivateKey;
           11   12     2          pe  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           8     9      10  Class java.security.ProviderException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      privateKey  

  protected void engineUpdate(byte);
    descriptor: (B)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // byte b
         0: .line 549
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.ensureInitialized:()V
         1: .line 550
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
         2: .line 551
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.buffer:[B
            iconst_0
            iload 1 /* b */
            bastore
         3: .line 552
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.buffer:[B
            iconst_0
            iconst_1
            invokevirtual sun.security.pkcs11.P11PSSSignature.engineUpdate:([BII)V
         4: .line 553
            return
        end local 1 // byte b
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/pkcs11/P11PSSSignature;
            0    5     1     b  B
    Exceptions:
      throws java.security.SignatureException
    MethodParameters:
      Name  Flags
      b     

  protected void engineUpdate(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=5, args_size=4
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // byte[] b
        start local 2 // int ofs
        start local 3 // int len
         0: .line 559
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.ensureInitialized:()V
         1: .line 560
            iload 3 /* len */
            ifne 3
         2: .line 561
            return
         3: .line 564
      StackMap locals:
      StackMap stack:
            iload 3 /* len */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            iadd
            ifge 5
         4: .line 565
            new java.security.ProviderException
            dup
            ldc "Processed bytes limits exceeded."
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 567
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
         6: .line 568
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            tableswitch { // 1 - 2
                    1: 18
                    2: 7
              default: 23
          }
         7: .line 571
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mode:I
            iconst_1
            if_icmpne 11
         8: .line 572
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ": Calling C_SignUpdate"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         9: .line 573
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            lconst_0
            aload 1 /* b */
            iload 2 /* ofs */
            iload 3 /* len */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignUpdate:(JJ[BII)V
        10: .line 574
            goto 13
        11: .line 575
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ": Calling C_VerfifyUpdate"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 576
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            lconst_0
            aload 1 /* b */
            iload 2 /* ofs */
            iload 3 /* len */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyUpdate:(JJ[BII)V
        13: .line 578
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            iload 3 /* len */
            iadd
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
        14: .line 579
            goto 24
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        15: astore 4 /* e */
        start local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
        16: .line 580
            aload 0 /* this */
            iconst_0
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        17: .line 581
            new java.security.ProviderException
            dup
            aload 4 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // sun.security.pkcs11.wrapper.PKCS11Exception e
        18: .line 586
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 20
        19: .line 587
            new java.security.ProviderException
            dup
            ldc "PSS Parameters required"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 589
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            aload 1 /* b */
            iload 2 /* ofs */
            iload 3 /* len */
            invokevirtual java.security.MessageDigest.update:([BII)V
        21: .line 590
            aload 0 /* this */
            dup
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            iload 3 /* len */
            iadd
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
        22: .line 591
            goto 24
        23: .line 593
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            ldc "Internal error"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 595
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int len
        end local 2 // int ofs
        end local 1 // byte[] b
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   25     0  this  Lsun/security/pkcs11/P11PSSSignature;
            0   25     1     b  [B
            0   25     2   ofs  I
            0   25     3   len  I
           16   18     4     e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           7    14      15  Class sun.security.pkcs11.wrapper.PKCS11Exception
    Exceptions:
      throws java.security.SignatureException
    MethodParameters:
      Name  Flags
      b     
      ofs   
      len   

  protected void engineUpdate(java.nio.ByteBuffer);
    descriptor: (Ljava/nio/ByteBuffer;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=7, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.nio.ByteBuffer byteBuffer
         0: .line 601
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.ensureInitialized:()V
         1: .line 602
            goto 4
      StackMap locals:
      StackMap stack: java.security.SignatureException
         2: astore 2 /* se */
        start local 2 // java.security.SignatureException se
         3: .line 603
            new java.security.ProviderException
            dup
            aload 2 /* se */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.SignatureException se
         4: .line 605
      StackMap locals:
      StackMap stack:
            aload 1 /* byteBuffer */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            istore 2 /* len */
        start local 2 // int len
         5: .line 606
            iload 2 /* len */
            ifgt 7
         6: .line 607
            return
         7: .line 609
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.pkcs11.P11PSSSignature.isActive:Z
         8: .line 610
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            tableswitch { // 1 - 2
                    1: 30
                    2: 9
              default: 35
          }
         9: .line 612
      StackMap locals:
      StackMap stack:
            aload 1 /* byteBuffer */
            instanceof sun.nio.ch.DirectBuffer
            ifne 12
        10: .line 614
            aload 0 /* this */
            aload 1 /* byteBuffer */
            invokespecial java.security.SignatureSpi.engineUpdate:(Ljava/nio/ByteBuffer;)V
        11: .line 615
            return
        12: .line 617
      StackMap locals:
      StackMap stack:
            aload 1 /* byteBuffer */
            checkcast sun.nio.ch.DirectBuffer
            invokeinterface sun.nio.ch.DirectBuffer.address:()J
            lstore 3 /* addr */
        start local 3 // long addr
        13: .line 618
            aload 1 /* byteBuffer */
            invokevirtual java.nio.ByteBuffer.position:()I
            istore 5 /* ofs */
        start local 5 // int ofs
        14: .line 620
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.mode:I
            iconst_1
            if_icmpne 20
        15: .line 621
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ": Calling C_SignUpdate"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        16: .line 622
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
        17: .line 623
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            lload 3 /* addr */
            iload 5 /* ofs */
            i2l
            ladd
            aconst_null
            iconst_0
            iload 2 /* len */
        18: .line 622
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignUpdate:(JJ[BII)V
        19: .line 624
            goto 24
        20: .line 625
      StackMap locals: long int
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ": Calling C_VerifyUpdate"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        21: .line 626
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
        22: .line 627
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            lload 3 /* addr */
            iload 5 /* ofs */
            i2l
            ladd
            aconst_null
            iconst_0
            iload 2 /* len */
        23: .line 626
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyUpdate:(JJ[BII)V
        24: .line 629
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            iload 2 /* len */
            iadd
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
        25: .line 630
            aload 1 /* byteBuffer */
            iload 5 /* ofs */
            iload 2 /* len */
            iadd
            invokevirtual java.nio.ByteBuffer.position:(I)Ljava/nio/ByteBuffer;
            pop
        26: .line 631
            goto 37
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
        27: astore 6 /* e */
        start local 6 // sun.security.pkcs11.wrapper.PKCS11Exception e
        28: .line 632
            aload 0 /* this */
            iconst_0
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        29: .line 633
            new java.security.ProviderException
            dup
            ldc "Update failed"
            aload 6 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // sun.security.pkcs11.wrapper.PKCS11Exception e
        end local 5 // int ofs
        end local 3 // long addr
        30: .line 638
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 32
        31: .line 639
            new java.security.ProviderException
            dup
            ldc "PSS Parameters required"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 641
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            aload 1 /* byteBuffer */
            invokevirtual java.security.MessageDigest.update:(Ljava/nio/ByteBuffer;)V
        33: .line 642
            aload 0 /* this */
            dup
            getfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
            iload 2 /* len */
            iadd
            putfield sun.security.pkcs11.P11PSSSignature.bytesProcessed:I
        34: .line 643
            goto 37
        35: .line 645
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        36: .line 646
            new java.security.ProviderException
            dup
            ldc "Internal error"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
        37: .line 648
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int len
        end local 1 // java.nio.ByteBuffer byteBuffer
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   38     0        this  Lsun/security/pkcs11/P11PSSSignature;
            0   38     1  byteBuffer  Ljava/nio/ByteBuffer;
            3    4     2          se  Ljava/security/SignatureException;
            5   38     2         len  I
           13   30     3        addr  J
           14   30     5         ofs  I
           28   30     6           e  Lsun/security/pkcs11/wrapper/PKCS11Exception;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.SignatureException
          14    26      27  Class sun.security.pkcs11.wrapper.PKCS11Exception
    MethodParameters:
            Name  Flags
      byteBuffer  

  protected byte[] engineSign();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // sun.security.pkcs11.P11PSSSignature this
         0: .line 653
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.ensureInitialized:()V
         1: .line 654
            iconst_1
            istore 1 /* doCancel */
        start local 1 // boolean doCancel
         2: .line 658
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            iconst_2
            if_icmpne 5
         3: .line 660
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            iconst_0
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_SignFinal:(JI)[B
            astore 2 /* signature */
        start local 2 // byte[] signature
         4: .line 661
            goto 9
        end local 2 // byte[] signature
         5: .line 662
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 7
         6: .line 663
            new java.security.ProviderException
            dup
            ldc "PSS Parameters required"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 665
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 3 /* digest */
        start local 3 // byte[] digest
         8: .line 667
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 3 /* digest */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Sign:(J[B)[B
            astore 2 /* signature */
        end local 3 // byte[] digest
        start local 2 // byte[] signature
         9: .line 669
      StackMap locals: byte[]
      StackMap stack:
            iconst_0
            istore 1 /* doCancel */
        10: .line 670
            aload 2 /* signature */
            astore 5
        11: .line 682
            aload 0 /* this */
            iload 1 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        12: .line 670
            aload 5
            areturn
        end local 2 // byte[] signature
        13: .line 671
      StackMap locals: sun.security.pkcs11.P11PSSSignature int
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 2 /* pe */
        start local 2 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        14: .line 677
            iconst_0
            istore 1 /* doCancel */
        15: .line 678
            new java.security.ProviderException
            dup
            aload 2 /* pe */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        16: .line 679
      StackMap locals:
      StackMap stack: java.security.ProviderException
            astore 2 /* e */
        start local 2 // java.security.ProviderException e
        17: .line 680
            aload 2 /* e */
            athrow
        end local 2 // java.security.ProviderException e
        18: .line 681
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4
        19: .line 682
            aload 0 /* this */
            iload 1 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        20: .line 683
            aload 4
            athrow
        end local 1 // boolean doCancel
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   21     0       this  Lsun/security/pkcs11/P11PSSSignature;
            2   21     1   doCancel  Z
            4    5     2  signature  [B
            9   13     2  signature  [B
            8    9     3     digest  [B
           14   16     2         pe  Lsun/security/pkcs11/wrapper/PKCS11Exception;
           17   18     2          e  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           2    11      13  Class sun.security.pkcs11.wrapper.PKCS11Exception
           2    11      16  Class java.security.ProviderException
           2    11      18  any
          13    18      18  any
    Exceptions:
      throws java.security.SignatureException

  protected boolean engineVerify(byte[]);
    descriptor: ([B)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // byte[] signature
         0: .line 689
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.ensureInitialized:()V
         1: .line 690
            iconst_1
            istore 2 /* doCancel */
        start local 2 // boolean doCancel
         2: .line 693
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            iconst_2
            if_icmpne 5
         3: .line 695
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 1 /* signature */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_VerifyFinal:(J[B)V
         4: .line 696
            goto 9
         5: .line 697
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            ifnonnull 7
         6: .line 698
            new java.security.ProviderException
            dup
            ldc "PSS Parameters required"
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 700
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 3 /* digest */
        start local 3 // byte[] digest
         8: .line 702
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.token:Lsun/security/pkcs11/Token;
            getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.session:Lsun/security/pkcs11/Session;
            invokevirtual sun.security.pkcs11.Session.id:()J
            aload 3 /* digest */
            aload 1 /* signature */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Verify:(J[B[B)V
        end local 3 // byte[] digest
         9: .line 704
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 2 /* doCancel */
        10: .line 724
            aload 0 /* this */
            iload 2 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        11: .line 705
            iconst_1
            ireturn
        12: .line 706
      StackMap locals:
      StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
            astore 3 /* pe */
        start local 3 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        13: .line 707
            iconst_0
            istore 2 /* doCancel */
        14: .line 708
            aload 3 /* pe */
            invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.getErrorCode:()J
            lstore 4 /* errorCode */
        start local 4 // long errorCode
        15: .line 709
            lload 4 /* errorCode */
            ldc 192
            lcmp
            ifne 18
        16: .line 724
            aload 0 /* this */
            iload 2 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        17: .line 710
            iconst_0
            ireturn
        18: .line 712
      StackMap locals: sun.security.pkcs11.wrapper.PKCS11Exception long
      StackMap stack:
            lload 4 /* errorCode */
            ldc 193
            lcmp
            ifne 21
        19: .line 724
            aload 0 /* this */
            iload 2 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        20: .line 714
            iconst_0
            ireturn
        21: .line 717
      StackMap locals:
      StackMap stack:
            lload 4 /* errorCode */
            ldc 33
            lcmp
            ifne 24
        22: .line 724
            aload 0 /* this */
            iload 2 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        23: .line 718
            iconst_0
            ireturn
        24: .line 720
      StackMap locals:
      StackMap stack:
            new java.security.ProviderException
            dup
            aload 3 /* pe */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // long errorCode
        end local 3 // sun.security.pkcs11.wrapper.PKCS11Exception pe
        25: .line 721
      StackMap locals: sun.security.pkcs11.P11PSSSignature byte[] int
      StackMap stack: java.security.ProviderException
            astore 3 /* e */
        start local 3 // java.security.ProviderException e
        26: .line 722
            aload 3 /* e */
            athrow
        end local 3 // java.security.ProviderException e
        27: .line 723
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 6
        28: .line 724
            aload 0 /* this */
            iload 2 /* doCancel */
            invokevirtual sun.security.pkcs11.P11PSSSignature.reset:(Z)V
        29: .line 725
            aload 6
            athrow
        end local 2 // boolean doCancel
        end local 1 // byte[] signature
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   30     0       this  Lsun/security/pkcs11/P11PSSSignature;
            0   30     1  signature  [B
            2   30     2   doCancel  Z
            8    9     3     digest  [B
           13   25     3         pe  Lsun/security/pkcs11/wrapper/PKCS11Exception;
           15   25     4  errorCode  J
           26   27     3          e  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           2    10      12  Class sun.security.pkcs11.wrapper.PKCS11Exception
           2    10      25  Class java.security.ProviderException
           2    10      27  any
          12    16      27  any
          18    19      27  any
          21    22      27  any
          24    27      27  any
    Exceptions:
      throws java.security.SignatureException
    MethodParameters:
           Name  Flags
      signature  

  protected void engineSetParameter(java.lang.String, java.lang.Object);
    descriptor: (Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.lang.String param
        start local 2 // java.lang.Object value
         0: .line 733
            new java.lang.UnsupportedOperationException
            dup
            ldc "setParameter() not supported"
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.Object value
        end local 1 // java.lang.String param
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lsun/security/pkcs11/P11PSSSignature;
            0    1     1  param  Ljava/lang/String;
            0    1     2  value  Ljava/lang/Object;
    Exceptions:
      throws java.security.InvalidParameterException
    MethodParameters:
       Name  Flags
      param  
      value  

  protected void engineSetParameter(java.security.spec.AlgorithmParameterSpec);
    descriptor: (Ljava/security/spec/AlgorithmParameterSpec;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.security.spec.AlgorithmParameterSpec params
         0: .line 741
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.isActive:Z
            ifeq 4
         1: .line 742
            new java.security.ProviderException
            dup
         2: .line 743
            ldc "Cannot set parameters during operations"
         3: .line 742
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 745
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual sun.security.pkcs11.P11PSSSignature.setSigParams:(Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 746
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.type:I
            iconst_1
            if_icmpne 10
         6: .line 748
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            invokevirtual java.security.spec.PSSParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            putfield sun.security.pkcs11.P11PSSSignature.md:Ljava/security/MessageDigest;
         7: .line 749
            goto 10
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
         8: astore 2 /* nsae */
        start local 2 // java.security.NoSuchAlgorithmException nsae
         9: .line 750
            new java.security.InvalidAlgorithmParameterException
            dup
            aload 2 /* nsae */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.NoSuchAlgorithmException nsae
        10: .line 755
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.p11Key:Lsun/security/pkcs11/P11Key;
            ifnull 15
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnull 15
        11: .line 757
            aload 0 /* this */
            invokevirtual sun.security.pkcs11.P11PSSSignature.initialize:()V
        12: .line 758
            goto 15
      StackMap locals:
      StackMap stack: java.security.ProviderException
        13: astore 2 /* pe */
        start local 2 // java.security.ProviderException pe
        14: .line 759
            new java.security.InvalidAlgorithmParameterException
            dup
            aload 2 /* pe */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.ProviderException pe
        15: .line 762
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.spec.AlgorithmParameterSpec params
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   16     0    this  Lsun/security/pkcs11/P11PSSSignature;
            0   16     1  params  Ljava/security/spec/AlgorithmParameterSpec;
            9   10     2    nsae  Ljava/security/NoSuchAlgorithmException;
           14   15     2      pe  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           6     7       8  Class java.security.NoSuchAlgorithmException
          11    12      13  Class java.security.ProviderException
    Exceptions:
      throws java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      params  

  protected java.lang.Object engineGetParameter(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.pkcs11.P11PSSSignature this
        start local 1 // java.lang.String param
         0: .line 769
            new java.lang.UnsupportedOperationException
            dup
            ldc "getParameter() not supported"
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String param
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lsun/security/pkcs11/P11PSSSignature;
            0    1     1  param  Ljava/lang/String;
    Exceptions:
      throws java.security.InvalidParameterException
    MethodParameters:
       Name  Flags
      param  

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.pkcs11.P11PSSSignature this
         0: .line 775
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            ifnull 7
         1: .line 777
            ldc "RSASSA-PSS"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 1 /* ap */
        start local 1 // java.security.AlgorithmParameters ap
         2: .line 778
            aload 1 /* ap */
            aload 0 /* this */
            getfield sun.security.pkcs11.P11PSSSignature.sigParams:Ljava/security/spec/PSSParameterSpec;
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         3: .line 779
            aload 1 /* ap */
         4: areturn
        end local 1 // java.security.AlgorithmParameters ap
         5: .line 780
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 1 /* e */
        start local 1 // java.security.GeneralSecurityException e
         6: .line 781
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.GeneralSecurityException e
         7: .line 784
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 0 // sun.security.pkcs11.P11PSSSignature this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lsun/security/pkcs11/P11PSSSignature;
            2    5     1    ap  Ljava/security/AlgorithmParameters;
            6    7     1     e  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
           1     4       5  Class java.security.GeneralSecurityException
}
SourceFile: "P11PSSSignature.java"