final class sun.security.pkcs11.P11AEADCipher extends javax.crypto.CipherSpi
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.pkcs11.P11AEADCipher
super_class: javax.crypto.CipherSpi
{
private static final int MODE_GCM;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 10
private static final int GCM_DEFAULT_TAG_LEN;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 16
private static final int GCM_DEFAULT_IV_LEN;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 16
private static final java.lang.String ALGO;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "AES"
private final sun.security.pkcs11.Token token;
descriptor: Lsun/security/pkcs11/Token;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final long mechanism;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int blockMode;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int fixedKeySize;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private sun.security.pkcs11.Session session;
descriptor: Lsun/security/pkcs11/Session;
flags: (0x0002) ACC_PRIVATE
private sun.security.pkcs11.P11Key p11Key;
descriptor: Lsun/security/pkcs11/P11Key;
flags: (0x0002) ACC_PRIVATE
private boolean initialized;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean encrypt;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private byte[] iv;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
private int tagLen;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private java.security.SecureRandom random;
descriptor: Ljava/security/SecureRandom;
flags: (0x0002) ACC_PRIVATE
private java.io.ByteArrayOutputStream dataBuffer;
descriptor: Ljava/io/ByteArrayOutputStream;
flags: (0x0002) ACC_PRIVATE
private java.io.ByteArrayOutputStream aadBuffer;
descriptor: Ljava/io/ByteArrayOutputStream;
flags: (0x0002) ACC_PRIVATE
private boolean updateCalled;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean requireReinit;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private sun.security.pkcs11.P11Key lastEncKey;
descriptor: Lsun/security/pkcs11/P11Key;
flags: (0x0002) ACC_PRIVATE
private byte[] lastEncIv;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
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=7, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial javax.crypto.CipherSpi.<init>:()V
1: aload 0
aconst_null
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
2: aload 0
aconst_null
putfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
3: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.initialized:Z
4: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
5: aload 0
aconst_null
putfield sun.security.pkcs11.P11AEADCipher.iv:[B
6: aload 0
iconst_m1
putfield sun.security.pkcs11.P11AEADCipher.tagLen:I
7: aload 0
invokestatic sun.security.jca.JCAUtil.getSecureRandom:()Ljava/security/SecureRandom;
putfield sun.security.pkcs11.P11AEADCipher.random:Ljava/security/SecureRandom;
8: aload 0
new java.io.ByteArrayOutputStream
dup
invokespecial java.io.ByteArrayOutputStream.<init>:()V
putfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
9: aload 0
new java.io.ByteArrayOutputStream
dup
invokespecial java.io.ByteArrayOutputStream.<init>:()V
putfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
10: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
11: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
12: aload 0
aconst_null
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
13: aload 0
aconst_null
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
14: aload 0
aload 1
putfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
15: aload 0
lload 3
putfield sun.security.pkcs11.P11AEADCipher.mechanism:J
16: aload 2
ldc "/"
invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
astore 5
start local 5 17: aload 5
arraylength
iconst_3
if_icmpeq 21
18: new java.security.ProviderException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported Transformation format: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
19: aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
20: invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
21: StackMap locals: sun.security.pkcs11.P11AEADCipher sun.security.pkcs11.Token java.lang.String long java.lang.String[]
StackMap stack:
aload 5
iconst_0
aaload
ldc "AES"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifne 23
22: new java.security.ProviderException
dup
ldc "Only support AES for AEAD cipher mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
23: StackMap locals:
StackMap stack:
aload 5
iconst_0
aaload
bipush 95
invokevirtual java.lang.String.indexOf:(I)I
istore 6
start local 6 24: iload 6
iconst_m1
if_icmpeq 27
25: aload 0
aload 5
iconst_0
aaload
iload 6
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
iconst_3
ishr
putfield sun.security.pkcs11.P11AEADCipher.fixedKeySize:I
26: goto 28
27: StackMap locals: int
StackMap stack:
aload 0
iconst_m1
putfield sun.security.pkcs11.P11AEADCipher.fixedKeySize:I
28: StackMap locals:
StackMap stack:
aload 0
aload 0
aload 5
iconst_1
aaload
invokevirtual sun.security.pkcs11.P11AEADCipher.parseMode:(Ljava/lang/String;)I
putfield sun.security.pkcs11.P11AEADCipher.blockMode:I
29: aload 5
iconst_2
aaload
ldc "NoPadding"
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifne 31
30: new java.security.ProviderException
dup
ldc "Only NoPadding is supported for AEAD cipher mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
31: StackMap locals:
StackMap stack:
return
end local 6 end local 5 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 32 0 this Lsun/security/pkcs11/P11AEADCipher;
0 32 1 token Lsun/security/pkcs11/Token;
0 32 2 algorithm Ljava/lang/String;
0 32 3 mechanism J
17 32 5 algoParts [Ljava/lang/String;
24 32 6 index I
Exceptions:
throws sun.security.pkcs11.wrapper.PKCS11Exception, java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
token
algorithm
mechanism
protected void engineSetMode(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: new java.security.NoSuchAlgorithmException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported mode "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
0 1 1 mode Ljava/lang/String;
Exceptions:
throws java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
mode
private int parseMode(java.lang.String);
descriptor: (Ljava/lang/String;)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 1
getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
astore 1
1: aload 1
ldc "GCM"
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 4
2: bipush 10
istore 2
start local 2 3: goto 5
end local 2 4: StackMap locals:
StackMap stack:
new java.security.NoSuchAlgorithmException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported mode "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
start local 2 5: StackMap locals: int
StackMap stack:
iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/pkcs11/P11AEADCipher;
0 6 1 mode Ljava/lang/String;
3 4 2 result I
5 6 2 result I
Exceptions:
throws java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
mode
protected void engineSetPadding(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: new javax.crypto.NoSuchPaddingException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported padding "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
0 1 1 padding Ljava/lang/String;
Exceptions:
throws javax.crypto.NoSuchPaddingException
MethodParameters:
Name Flags
padding
protected int engineGetBlockSize();
descriptor: ()I
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: bipush 16
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
protected int engineGetOutputSize(int);
descriptor: (I)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
invokevirtual sun.security.pkcs11.P11AEADCipher.doFinalLength:(I)I
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
0 1 1 inputLen I
MethodParameters:
Name Flags
inputLen
protected byte[] engineGetIV();
descriptor: ()[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
ifnonnull 1
aconst_null
goto 2
StackMap locals:
StackMap stack:
1: aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
invokevirtual byte[].clone:()Ljava/lang/Object;
checkcast byte[]
StackMap locals:
StackMap stack: byte[]
2: areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/pkcs11/P11AEADCipher;
protected java.security.AlgorithmParameters engineGetParameters();
descriptor: ()Ljava/security/AlgorithmParameters;
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 7
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
ifnonnull 7
aload 0
getfield sun.security.pkcs11.P11AEADCipher.tagLen:I
iconst_m1
if_icmpne 7
1: aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 2
default: 5
}
2: StackMap locals:
StackMap stack:
aload 0
bipush 16
newarray 8
putfield sun.security.pkcs11.P11AEADCipher.iv:[B
3: aload 0
bipush 16
putfield sun.security.pkcs11.P11AEADCipher.tagLen:I
4: goto 6
5: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
ldc "Unsupported mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.random:Ljava/security/SecureRandom;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
invokevirtual java.security.SecureRandom.nextBytes:([B)V
7: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 8
default: 11
}
8: StackMap locals:
StackMap stack:
ldc "GCM"
astore 2
start local 2 9: new javax.crypto.spec.GCMParameterSpec
dup
aload 0
getfield sun.security.pkcs11.P11AEADCipher.tagLen:I
iconst_3
ishl
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
invokespecial javax.crypto.spec.GCMParameterSpec.<init>:(I[B)V
astore 1
start local 1 10: goto 12
end local 2 end local 1 11: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
ldc "Unsupported mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
start local 1 start local 2 12: StackMap locals: java.security.spec.AlgorithmParameterSpec java.lang.String
StackMap stack:
aload 2
invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
13: astore 3
start local 3 14: aload 3
aload 1
invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
15: aload 3
16: areturn
end local 3 end local 2 end local 1 17: StackMap locals: sun.security.pkcs11.P11AEADCipher
StackMap stack: java.security.GeneralSecurityException
astore 1
start local 1 18: new java.security.ProviderException
dup
ldc "Could not encode parameters"
aload 1
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lsun/security/pkcs11/P11AEADCipher;
10 11 1 spec Ljava/security/spec/AlgorithmParameterSpec;
12 17 1 spec Ljava/security/spec/AlgorithmParameterSpec;
9 11 2 apAlgo Ljava/lang/String;
12 17 2 apAlgo Ljava/lang/String;
14 17 3 params Ljava/security/AlgorithmParameters;
18 19 1 e Ljava/security/GeneralSecurityException;
Exception table:
from to target type
7 16 17 Class java.security.GeneralSecurityException
protected void engineInit(int, java.security.Key, java.security.SecureRandom);
descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: iload 1
iconst_2
if_icmpne 2
1: new java.security.InvalidKeyException
dup
ldc "Parameters required for decryption"
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
3: aload 0
iload 1
aload 2
aconst_null
iconst_m1
aload 3
invokevirtual sun.security.pkcs11.P11AEADCipher.implInit:(ILjava/security/Key;[BILjava/security/SecureRandom;)V
4: goto 7
StackMap locals:
StackMap stack: java.security.InvalidAlgorithmParameterException
5: astore 4
start local 4 6: new java.security.InvalidKeyException
dup
ldc "init() failed"
aload 4
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 4 7: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lsun/security/pkcs11/P11AEADCipher;
0 8 1 opmode I
0 8 2 key Ljava/security/Key;
0 8 3 sr Ljava/security/SecureRandom;
6 7 4 e Ljava/security/InvalidAlgorithmParameterException;
Exception table:
from to target type
3 4 5 Class java.security.InvalidAlgorithmParameterException
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
opmode
key
sr
protected void engineInit(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=7, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: iload 1
iconst_2
if_icmpne 4
aload 3
ifnonnull 4
1: new java.security.InvalidAlgorithmParameterException
dup
2: ldc "Parameters required for decryption"
3: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
5: aconst_null
astore 5
start local 5 6: iconst_m1
istore 6
start local 6 7: aload 3
ifnull 17
8: aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 9
default: 16
}
9: StackMap locals: byte[] int
StackMap stack:
aload 3
instanceof javax.crypto.spec.GCMParameterSpec
ifne 13
10: new java.security.InvalidAlgorithmParameterException
dup
11: ldc "Only GCMParameterSpec is supported"
12: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
13: StackMap locals:
StackMap stack:
aload 3
checkcast javax.crypto.spec.GCMParameterSpec
invokevirtual javax.crypto.spec.GCMParameterSpec.getIV:()[B
astore 5
14: aload 3
checkcast javax.crypto.spec.GCMParameterSpec
invokevirtual javax.crypto.spec.GCMParameterSpec.getTLen:()I
iconst_3
ishr
istore 6
15: goto 17
16: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
ldc "Unsupported mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
17: StackMap locals:
StackMap stack:
aload 0
iload 1
aload 2
aload 5
iload 6
aload 4
invokevirtual sun.security.pkcs11.P11AEADCipher.implInit:(ILjava/security/Key;[BILjava/security/SecureRandom;)V
18: return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lsun/security/pkcs11/P11AEADCipher;
0 19 1 opmode I
0 19 2 key Ljava/security/Key;
0 19 3 params Ljava/security/spec/AlgorithmParameterSpec;
0 19 4 sr Ljava/security/SecureRandom;
6 19 5 ivValue [B
7 19 6 tagLen I
Exceptions:
throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
MethodParameters:
Name Flags
opmode
key
params
sr
protected void engineInit(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=6, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: iload 1
iconst_2
if_icmpne 4
aload 3
ifnonnull 4
1: new java.security.InvalidAlgorithmParameterException
dup
2: ldc "Parameters required for decryption"
3: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
5: aconst_null
astore 5
start local 5 6: aload 3
ifnull 12
7: aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 8
default: 11
}
8: StackMap locals: java.security.spec.AlgorithmParameterSpec
StackMap stack:
aload 3
ldc Ljavax/crypto/spec/GCMParameterSpec;
invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
9: astore 5
10: goto 12
11: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
ldc "Unsupported mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
12: StackMap locals:
StackMap stack:
aload 0
iload 1
aload 2
aload 5
aload 4
invokevirtual sun.security.pkcs11.P11AEADCipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
end local 5 13: goto 16
StackMap locals: sun.security.pkcs11.P11AEADCipher int java.security.Key java.security.AlgorithmParameters java.security.SecureRandom
StackMap stack: java.security.spec.InvalidParameterSpecException
14: astore 5
start local 5 15: new java.security.InvalidAlgorithmParameterException
dup
aload 5
invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 5 16: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lsun/security/pkcs11/P11AEADCipher;
0 17 1 opmode I
0 17 2 key Ljava/security/Key;
0 17 3 params Ljava/security/AlgorithmParameters;
0 17 4 sr Ljava/security/SecureRandom;
6 13 5 paramSpec Ljava/security/spec/AlgorithmParameterSpec;
15 16 5 ex Ljava/security/spec/InvalidParameterSpecException;
Exception table:
from to target type
5 13 14 Class java.security.spec.InvalidParameterSpecException
Exceptions:
throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
MethodParameters:
Name Flags
opmode
key
params
sr
private void implInit(int, java.security.Key, byte[], int, java.security.SecureRandom);
descriptor: (ILjava/security/Key;[BILjava/security/SecureRandom;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=8, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
iconst_1
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
1: aload 0
getfield sun.security.pkcs11.P11AEADCipher.fixedKeySize:I
iconst_m1
if_icmpeq 7
2: aload 2
instanceof sun.security.pkcs11.P11Key
ifeq 3
aload 2
checkcast sun.security.pkcs11.P11Key
invokevirtual sun.security.pkcs11.P11Key.length:()I
iconst_3
ishr
goto 4
3: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.security.Key.getEncoded:()[B
arraylength
StackMap locals:
StackMap stack: int
4: aload 0
getfield sun.security.pkcs11.P11AEADCipher.fixedKeySize:I
5: if_icmpeq 7
6: new java.security.InvalidKeyException
dup
ldc "Key size is invalid"
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 2
ldc "AES"
invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
astore 6
start local 6 8: iload 1
tableswitch { // 1 - 2
1: 9
2: 18
default: 21
}
9: StackMap locals: sun.security.pkcs11.P11Key
StackMap stack:
aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
10: aload 0
aload 3
aload 0
getfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
invokestatic java.util.Arrays.equals:([B[B)Z
ifeq 12
11: aload 6
aload 0
getfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
if_acmpne 12
iconst_1
goto 13
StackMap locals:
StackMap stack: sun.security.pkcs11.P11AEADCipher
12: iconst_0
13: StackMap locals: sun.security.pkcs11.P11AEADCipher int java.security.Key byte[] int java.security.SecureRandom sun.security.pkcs11.P11Key
StackMap stack: sun.security.pkcs11.P11AEADCipher int
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
14: aload 0
getfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
ifeq 24
15: new java.security.InvalidAlgorithmParameterException
dup
16: ldc "Cannot reuse iv for GCM encryption"
17: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
18: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
19: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
20: goto 24
21: StackMap locals:
StackMap stack:
new java.security.InvalidAlgorithmParameterException
dup
22: new java.lang.StringBuilder
dup
ldc "Unsupported mode: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 1
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
23: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
24: StackMap locals:
StackMap stack:
aload 5
ifnull 26
25: aload 0
aload 5
putfield sun.security.pkcs11.P11AEADCipher.random:Ljava/security/SecureRandom;
26: StackMap locals:
StackMap stack:
aload 3
ifnonnull 33
iload 4
iconst_m1
if_icmpne 33
27: aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 28
default: 32
}
28: StackMap locals:
StackMap stack:
bipush 16
newarray 8
astore 3
29: aload 0
getfield sun.security.pkcs11.P11AEADCipher.random:Ljava/security/SecureRandom;
aload 3
invokevirtual java.security.SecureRandom.nextBytes:([B)V
30: bipush 16
istore 4
31: goto 33
32: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
ldc "Unsupported mode"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
33: StackMap locals:
StackMap stack:
aload 0
aload 3
putfield sun.security.pkcs11.P11AEADCipher.iv:[B
34: aload 0
iload 4
putfield sun.security.pkcs11.P11AEADCipher.tagLen:I
35: aload 0
aload 6
putfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
36: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.initialize:()V
37: goto 42
StackMap locals:
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
38: astore 7
start local 7 39: aload 7
invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.getErrorCode:()J
ldc 113
lcmp
ifne 41
40: new java.security.InvalidAlgorithmParameterException
dup
ldc "Bad params"
aload 7
invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
41: StackMap locals: sun.security.pkcs11.wrapper.PKCS11Exception
StackMap stack:
new java.security.InvalidKeyException
dup
ldc "Could not initialize cipher"
aload 7
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 7 42: StackMap locals:
StackMap stack:
return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 43 0 this Lsun/security/pkcs11/P11AEADCipher;
0 43 1 opmode I
0 43 2 key Ljava/security/Key;
0 43 3 iv [B
0 43 4 tagLen I
0 43 5 sr Ljava/security/SecureRandom;
8 43 6 newKey Lsun/security/pkcs11/P11Key;
39 42 7 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
36 37 38 Class sun.security.pkcs11.wrapper.PKCS11Exception
Exceptions:
throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
MethodParameters:
Name Flags
opmode
key
iv
tagLen
sr
private void cancelOperation();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=13, locals=6, args_size=1
start local 0 0: aload 0
iconst_0
invokevirtual sun.security.pkcs11.P11AEADCipher.doFinalLength:(I)I
istore 1
start local 1 1: iload 1
newarray 8
astore 2
start local 2 2: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
astore 3
start local 3 3: aload 3
arraylength
istore 4
start local 4 4: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 9
5: aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lconst_0
aload 3
iconst_0
iload 4
6: lconst_0
aload 2
iconst_0
iload 1
7: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Encrypt:(JJ[BIIJ[BII)I
pop
8: goto 18
9: StackMap locals: sun.security.pkcs11.P11AEADCipher int byte[] byte[] int
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lconst_0
aload 3
iconst_0
iload 4
10: lconst_0
aload 2
iconst_0
iload 1
11: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Decrypt:(JJ[BIIJ[BII)I
pop
12: goto 18
StackMap locals:
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
13: astore 5
start local 5 14: aload 5
invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.getErrorCode:()J
ldc 145
lcmp
ifne 16
15: return
16: StackMap locals: sun.security.pkcs11.wrapper.PKCS11Exception
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 18
17: new java.security.ProviderException
dup
ldc "Cancel failed"
aload 5
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 5 18: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lsun/security/pkcs11/P11AEADCipher;
1 19 1 bufLen I
2 19 2 buffer [B
3 19 3 in [B
4 19 4 inLen I
14 18 5 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
4 12 13 Class sun.security.pkcs11.wrapper.PKCS11Exception
private void ensureInitialized();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.initialized:Z
ifeq 2
aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.size:()I
ifle 2
1: aload 0
iconst_1
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.initialized:Z
ifne 4
3: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.initialize:()V
4: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/pkcs11/P11AEADCipher;
Exceptions:
throws sun.security.pkcs11.wrapper.PKCS11Exception
private void initialize();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=9, locals=6, args_size=1
start local 0 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
ifnonnull 4
1: new java.security.ProviderException
dup
2: ldc "Operation cannot be performed without calling engineInit first"
3: invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
ifeq 8
5: new java.lang.IllegalStateException
dup
6: ldc "Must use either different key or iv for GCM encryption"
7: invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
8: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
invokevirtual sun.security.pkcs11.Token.ensureValid:()V
9: aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.size:()I
ifle 10
aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
goto 11
StackMap locals:
StackMap stack:
10: aconst_null
StackMap locals:
StackMap stack: byte[]
11: astore 1
start local 1 12: aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
invokevirtual sun.security.pkcs11.P11Key.getKeyID:()J
lstore 2
start local 2 13: aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
tableswitch { // 10 - 10
10: 14
default: 18
}
14: StackMap locals: byte[] long
StackMap stack:
new sun.security.pkcs11.wrapper.CK_MECHANISM
dup
aload 0
getfield sun.security.pkcs11.P11AEADCipher.mechanism:J
15: new sun.security.pkcs11.wrapper.CK_GCM_PARAMS
dup
aload 0
getfield sun.security.pkcs11.P11AEADCipher.tagLen:I
iconst_3
ishl
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
aload 1
invokespecial sun.security.pkcs11.wrapper.CK_GCM_PARAMS.<init>:(I[B[B)V
16: invokespecial sun.security.pkcs11.wrapper.CK_MECHANISM.<init>:(JLsun/security/pkcs11/wrapper/CK_GCM_PARAMS;)V
astore 4
start local 4 17: goto 19
end local 4 18: StackMap locals:
StackMap stack:
new java.security.ProviderException
dup
new java.lang.StringBuilder
dup
ldc "Unsupported mode: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield sun.security.pkcs11.P11AEADCipher.blockMode:I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
start local 4 19: StackMap locals: sun.security.pkcs11.wrapper.CK_MECHANISM
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
ifnonnull 21
20: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
invokevirtual sun.security.pkcs11.Token.getOpSession:()Lsun/security/pkcs11/Session;
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
21: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 26
22: aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
aload 4
23: lload 2
24: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_EncryptInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
25: goto 38
26: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
aload 4
27: lload 2
28: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_DecryptInit:(JLsun/security/pkcs11/wrapper/CK_MECHANISM;J)V
end local 4 29: goto 38
StackMap locals: sun.security.pkcs11.P11AEADCipher byte[] long
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
30: astore 4
start local 4 31: aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
32: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
33: aload 4
athrow
end local 4 34: StackMap locals:
StackMap stack: java.lang.Throwable
astore 5
35: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
36: aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
37: aload 5
athrow
38: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
39: aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
40: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.initialized:Z
41: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 42 0 this Lsun/security/pkcs11/P11AEADCipher;
12 42 1 aad [B
13 42 2 p11KeyID J
17 18 4 mechWithParams Lsun/security/pkcs11/wrapper/CK_MECHANISM;
19 29 4 mechWithParams Lsun/security/pkcs11/wrapper/CK_MECHANISM;
31 34 4 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
13 29 30 Class sun.security.pkcs11.wrapper.PKCS11Exception
13 34 34 any
Exceptions:
throws sun.security.pkcs11.wrapper.PKCS11Exception
private int doFinalLength(int);
descriptor: (I)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: iload 1
ifge 2
1: new java.security.ProviderException
dup
ldc "Invalid negative input length"
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
iload 1
aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.size:()I
iadd
istore 2
start local 2 3: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 5
4: iload 2
aload 0
getfield sun.security.pkcs11.P11AEADCipher.tagLen:I
iadd
istore 2
5: StackMap locals: int
StackMap stack:
iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/pkcs11/P11AEADCipher;
0 6 1 inLen I
3 6 2 result I
MethodParameters:
Name Flags
inLen
private void reset(boolean);
descriptor: (Z)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.initialized:Z
ifne 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.initialized:Z
3: aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
ifnonnull 8
4: aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
5: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
6: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
7: return
8: StackMap locals:
StackMap stack:
iload 1
ifeq 16
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.explicitCancel:Z
ifeq 16
9: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.cancelOperation:()V
10: goto 16
StackMap locals:
StackMap stack: java.lang.Throwable
11: astore 2
12: aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
13: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
14: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
15: aload 2
athrow
16: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
invokevirtual sun.security.pkcs11.P11Key.releaseKeyID:()V
17: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Token.releaseSession:(Lsun/security/pkcs11/Session;)Lsun/security/pkcs11/Session;
putfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
18: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.reset:()V
19: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lsun/security/pkcs11/P11AEADCipher;
0 20 1 doCancel Z
Exception table:
from to target type
3 4 11 any
8 11 11 any
MethodParameters:
Name Flags
doCancel
protected byte[] engineUpdate(byte[], int, int);
descriptor: ([BII)[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
1: aload 0
aload 1
iload 2
iload 3
invokevirtual sun.security.pkcs11.P11AEADCipher.implUpdate:([BII)I
pop
2: iconst_0
newarray 8
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/pkcs11/P11AEADCipher;
0 3 1 in [B
0 3 2 inOfs I
0 3 3 inLen I
MethodParameters:
Name Flags
in
inOfs
inLen
protected int engineUpdate(byte[], int, int, byte[], int);
descriptor: ([BII[BI)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
1: aload 0
aload 1
iload 2
iload 3
invokevirtual sun.security.pkcs11.P11AEADCipher.implUpdate:([BII)I
pop
2: iconst_0
ireturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/pkcs11/P11AEADCipher;
0 3 1 in [B
0 3 2 inOfs I
0 3 3 inLen I
0 3 4 out [B
0 3 5 outOfs I
Exceptions:
throws javax.crypto.ShortBufferException
MethodParameters:
Name Flags
in
inOfs
inLen
out
outOfs
protected int engineUpdate(java.nio.ByteBuffer, java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
1: aload 0
aload 1
invokevirtual sun.security.pkcs11.P11AEADCipher.implUpdate:(Ljava/nio/ByteBuffer;)I
pop
2: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/pkcs11/P11AEADCipher;
0 3 1 inBuffer Ljava/nio/ByteBuffer;
0 3 2 outBuffer Ljava/nio/ByteBuffer;
Exceptions:
throws javax.crypto.ShortBufferException
MethodParameters:
Name Flags
inBuffer
outBuffer
protected synchronized void engineUpdateAAD(byte[], int, int);
descriptor: ([BII)V
flags: (0x0024) ACC_PROTECTED, ACC_SYNCHRONIZED
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 1
ifnull 1
iload 2
iflt 1
iload 2
iload 3
iadd
aload 1
arraylength
if_icmple 2
1: StackMap locals:
StackMap stack:
new java.lang.IllegalArgumentException
dup
ldc "Invalid AAD"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
ifeq 6
3: new java.lang.IllegalStateException
dup
4: ldc "Must use either different key or iv for GCM encryption"
5: invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
ifnonnull 8
7: new java.lang.IllegalStateException
dup
ldc "Need to initialize Cipher first"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
8: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
ifeq 12
9: new java.lang.IllegalStateException
dup
10: ldc "Update has been called; no more AAD data"
11: invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
12: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.aadBuffer:Ljava/io/ByteArrayOutputStream;
aload 1
iload 2
iload 3
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
13: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lsun/security/pkcs11/P11AEADCipher;
0 14 1 src [B
0 14 2 srcOfs I
0 14 3 srcLen I
Exceptions:
throws java.lang.IllegalStateException
MethodParameters:
Name Flags
src
srcOfs
srcLen
protected void engineUpdateAAD(java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 2
1: new java.lang.IllegalArgumentException
dup
ldc "Invalid AAD"
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 1
invokevirtual java.nio.ByteBuffer.remaining:()I
newarray 8
astore 2
start local 2 3: aload 1
aload 2
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
4: aload 0
aload 2
iconst_0
aload 2
arraylength
invokevirtual sun.security.pkcs11.P11AEADCipher.engineUpdateAAD:([BII)V
5: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/pkcs11/P11AEADCipher;
0 6 1 src Ljava/nio/ByteBuffer;
3 6 2 srcBytes [B
Exceptions:
throws java.lang.IllegalStateException
MethodParameters:
Name Flags
src
protected byte[] engineDoFinal(byte[], int, int);
descriptor: ([BII)[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=6, locals=9, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
iload 3
invokevirtual sun.security.pkcs11.P11AEADCipher.doFinalLength:(I)I
istore 4
start local 4 1: iload 4
newarray 8
astore 5
start local 5 2: aload 0
aload 1
iload 2
iload 3
aload 5
iconst_0
invokevirtual sun.security.pkcs11.P11AEADCipher.engineDoFinal:([BII[BI)I
istore 6
start local 6 3: aload 5
iconst_0
iload 6
invokestatic sun.security.pkcs11.P11Util.convert:([BII)[B
astore 8
4: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
5: aload 8
areturn
end local 6 end local 5 6: StackMap locals: sun.security.pkcs11.P11AEADCipher byte[] int int int
StackMap stack: javax.crypto.ShortBufferException
astore 5
start local 5 7: new java.security.ProviderException
dup
aload 5
invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 5 8: StackMap locals:
StackMap stack: java.lang.Throwable
astore 7
9: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
10: aload 7
athrow
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lsun/security/pkcs11/P11AEADCipher;
0 11 1 in [B
0 11 2 inOfs I
0 11 3 inLen I
1 11 4 minOutLen I
2 6 5 out [B
3 6 6 n I
7 8 5 e Ljavax/crypto/ShortBufferException;
Exception table:
from to target type
1 4 6 Class javax.crypto.ShortBufferException
1 4 8 any
6 8 8 any
Exceptions:
throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
in
inOfs
inLen
protected int engineDoFinal(byte[], int, int, byte[], int);
descriptor: ([BII[BI)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=8, locals=8, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
aload 1
iload 2
iload 3
aload 4
iload 5
aload 4
arraylength
iload 5
isub
invokevirtual sun.security.pkcs11.P11AEADCipher.implDoFinal:([BII[BII)I
istore 7
1: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
2: iload 7
ireturn
3: StackMap locals:
StackMap stack: java.lang.Throwable
astore 6
4: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
5: aload 6
athrow
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/pkcs11/P11AEADCipher;
0 6 1 in [B
0 6 2 inOfs I
0 6 3 inLen I
0 6 4 out [B
0 6 5 outOfs I
Exception table:
from to target type
0 1 3 any
Exceptions:
throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
in
inOfs
inLen
out
outOfs
protected int engineDoFinal(java.nio.ByteBuffer, java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
aload 2
invokevirtual sun.security.pkcs11.P11AEADCipher.implDoFinal:(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
istore 4
1: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
2: iload 4
ireturn
3: StackMap locals:
StackMap stack: java.lang.Throwable
astore 3
4: aload 0
iconst_0
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
5: aload 3
athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/pkcs11/P11AEADCipher;
0 6 1 inBuffer Ljava/nio/ByteBuffer;
0 6 2 outBuffer Ljava/nio/ByteBuffer;
Exception table:
from to target type
0 1 3 any
Exceptions:
throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
inBuffer
outBuffer
private int implUpdate(byte[], int, int);
descriptor: ([BII)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: iload 3
ifle 8
1: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.updateCalled:Z
2: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.ensureInitialized:()V
3: goto 7
StackMap locals:
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
4: astore 4
start local 4 5: aload 0
iconst_0
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
6: new java.security.ProviderException
dup
ldc "update() failed"
aload 4
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 4 7: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
aload 1
iload 2
iload 3
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
8: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lsun/security/pkcs11/P11AEADCipher;
0 9 1 in [B
0 9 2 inOfs I
0 9 3 inLen I
5 7 4 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
2 3 4 Class sun.security.pkcs11.wrapper.PKCS11Exception
MethodParameters:
Name Flags
in
inOfs
inLen
private int implUpdate(java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual java.nio.ByteBuffer.remaining:()I
istore 2
start local 2 1: iload 2
ifle 10
2: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.ensureInitialized:()V
3: goto 7
StackMap locals: sun.security.pkcs11.P11AEADCipher java.nio.ByteBuffer int
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
4: astore 3
start local 3 5: aload 0
iconst_0
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
6: new java.security.ProviderException
dup
ldc "update() failed"
aload 3
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 7: StackMap locals:
StackMap stack:
iload 2
newarray 8
astore 3
start local 3 8: aload 1
aload 3
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
9: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
aload 3
iconst_0
aload 3
arraylength
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
end local 3 10: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lsun/security/pkcs11/P11AEADCipher;
0 11 1 inBuf Ljava/nio/ByteBuffer;
1 11 2 inLen I
5 7 3 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
8 10 3 data [B
Exception table:
from to target type
2 3 4 Class sun.security.pkcs11.wrapper.PKCS11Exception
MethodParameters:
Name Flags
inBuf
private int implDoFinal(byte[], int, int, byte[], int, int);
descriptor: ([BII[BII)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=13, locals=12, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 0
iload 3
invokevirtual sun.security.pkcs11.P11AEADCipher.doFinalLength:(I)I
istore 7
start local 7 1: iload 6
iload 7
if_icmpge 3
2: new javax.crypto.ShortBufferException
dup
invokespecial javax.crypto.ShortBufferException.<init>:()V
athrow
3: StackMap locals: int
StackMap stack:
iconst_1
istore 8
start local 8 4: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.ensureInitialized:()V
5: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.size:()I
ifle 12
6: aload 1
ifnull 9
iload 2
ifle 9
iload 3
ifle 9
7: iload 2
aload 1
arraylength
iload 3
isub
if_icmpge 9
8: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
aload 1
iload 2
iload 3
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
9: StackMap locals: int
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
astore 1
10: iconst_0
istore 2
11: aload 1
arraylength
istore 3
12: StackMap locals:
StackMap stack:
iconst_0
istore 9
start local 9 13: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 19
14: aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lconst_0
aload 1
iload 2
iload 3
15: lconst_0
aload 4
iload 5
iload 6
16: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Encrypt:(JJ[BIIJ[BII)I
istore 9
17: iconst_0
istore 8
18: goto 30
19: StackMap locals: int
StackMap stack:
iload 3
ifne 26
20: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 24
21: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
22: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
23: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
24: StackMap locals:
StackMap stack:
aload 0
iload 8
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
25: iconst_0
ireturn
26: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lconst_0
aload 1
iload 2
iload 3
27: lconst_0
aload 4
iload 5
iload 6
28: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Decrypt:(JJ[BIIJ[BII)I
istore 9
29: iconst_0
istore 8
30: StackMap locals:
StackMap stack:
iload 9
istore 11
31: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 35
32: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
33: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
34: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
35: StackMap locals: sun.security.pkcs11.P11AEADCipher byte[] int int byte[] int int int int int top int
StackMap stack:
aload 0
iload 8
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
36: iload 11
ireturn
end local 9 37: StackMap locals: sun.security.pkcs11.P11AEADCipher byte[] int int byte[] int int int int
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
astore 9
start local 9 38: iconst_0
istore 8
39: aload 0
aload 9
invokevirtual sun.security.pkcs11.P11AEADCipher.handleException:(Lsun/security/pkcs11/wrapper/PKCS11Exception;)V
40: new java.security.ProviderException
dup
ldc "doFinal() failed"
aload 9
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 9 41: StackMap locals:
StackMap stack: java.lang.Throwable
astore 10
42: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 46
43: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
44: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
45: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
46: StackMap locals: sun.security.pkcs11.P11AEADCipher byte[] int int byte[] int int int int top java.lang.Throwable
StackMap stack:
aload 0
iload 8
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
47: aload 10
athrow
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 48 0 this Lsun/security/pkcs11/P11AEADCipher;
0 48 1 in [B
0 48 2 inOfs I
0 48 3 inLen I
0 48 4 out [B
0 48 5 outOfs I
0 48 6 outLen I
1 48 7 requiredOutLen I
4 48 8 doCancel Z
13 37 9 k I
38 41 9 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
4 20 37 Class sun.security.pkcs11.wrapper.PKCS11Exception
26 31 37 Class sun.security.pkcs11.wrapper.PKCS11Exception
4 20 41 any
26 31 41 any
37 41 41 any
Exceptions:
throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
in
inOfs
inLen
out
outOfs
outLen
private int implDoFinal(java.nio.ByteBuffer, java.nio.ByteBuffer);
descriptor: (Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I
flags: (0x0002) ACC_PRIVATE
Code:
stack=13, locals=18, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
istore 3
start local 3 1: aload 1
invokevirtual java.nio.ByteBuffer.remaining:()I
istore 4
start local 4 2: aload 0
iload 4
invokevirtual sun.security.pkcs11.P11AEADCipher.doFinalLength:(I)I
istore 5
start local 5 3: iload 3
iload 5
if_icmpge 5
4: new javax.crypto.ShortBufferException
dup
invokespecial javax.crypto.ShortBufferException.<init>:()V
athrow
5: StackMap locals: int int int
StackMap stack:
iconst_1
istore 6
start local 6 6: aload 0
invokevirtual sun.security.pkcs11.P11AEADCipher.ensureInitialized:()V
7: lconst_0
lstore 7
start local 7 8: aconst_null
astore 9
start local 9 9: iconst_0
istore 10
start local 10 10: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.size:()I
ifle 19
11: iload 4
ifle 15
12: iload 4
newarray 8
astore 11
start local 11 13: aload 1
aload 11
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
14: aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
aload 11
iconst_0
aload 11
arraylength
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
end local 11 15: StackMap locals: sun.security.pkcs11.P11AEADCipher java.nio.ByteBuffer java.nio.ByteBuffer int int int int long byte[] int
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.dataBuffer:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
astore 9
16: iconst_0
istore 10
17: aload 9
arraylength
istore 4
18: goto 29
19: StackMap locals:
StackMap stack:
aload 1
instanceof sun.nio.ch.DirectBuffer
ifeq 23
20: aload 1
checkcast sun.nio.ch.DirectBuffer
invokeinterface sun.nio.ch.DirectBuffer.address:()J
lstore 7
21: aload 1
invokevirtual java.nio.ByteBuffer.position:()I
istore 10
22: goto 29
23: StackMap locals:
StackMap stack:
aload 1
invokevirtual java.nio.ByteBuffer.hasArray:()Z
ifeq 27
24: aload 1
invokevirtual java.nio.ByteBuffer.array:()[B
astore 9
25: aload 1
invokevirtual java.nio.ByteBuffer.position:()I
aload 1
invokevirtual java.nio.ByteBuffer.arrayOffset:()I
iadd
istore 10
26: goto 29
27: StackMap locals:
StackMap stack:
iload 4
newarray 8
astore 9
28: aload 1
aload 9
invokevirtual java.nio.ByteBuffer.get:([B)Ljava/nio/ByteBuffer;
pop
29: StackMap locals:
StackMap stack:
lconst_0
lstore 11
start local 11 30: aconst_null
astore 13
start local 13 31: iconst_0
istore 14
start local 14 32: aload 2
instanceof sun.nio.ch.DirectBuffer
ifeq 36
33: aload 2
checkcast sun.nio.ch.DirectBuffer
invokeinterface sun.nio.ch.DirectBuffer.address:()J
lstore 11
34: aload 2
invokevirtual java.nio.ByteBuffer.position:()I
istore 14
35: goto 41
36: StackMap locals: long byte[] int
StackMap stack:
aload 2
invokevirtual java.nio.ByteBuffer.hasArray:()Z
ifeq 40
37: aload 2
invokevirtual java.nio.ByteBuffer.array:()[B
astore 13
38: aload 2
invokevirtual java.nio.ByteBuffer.position:()I
aload 2
invokevirtual java.nio.ByteBuffer.arrayOffset:()I
iadd
istore 14
39: goto 41
40: StackMap locals:
StackMap stack:
iload 3
newarray 8
astore 13
41: StackMap locals:
StackMap stack:
iconst_0
istore 15
start local 15 42: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 48
43: aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lload 7
aload 9
iload 10
iload 4
44: lload 11
aload 13
iload 14
iload 3
45: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Encrypt:(JJ[BIIJ[BII)I
istore 15
46: iconst_0
istore 6
47: goto 59
48: StackMap locals: int
StackMap stack:
iload 4
ifne 55
49: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 53
50: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
51: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
52: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
53: StackMap locals:
StackMap stack:
aload 0
iload 6
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
54: iconst_0
ireturn
55: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
getfield sun.security.pkcs11.Token.p11:Lsun/security/pkcs11/wrapper/PKCS11;
aload 0
getfield sun.security.pkcs11.P11AEADCipher.session:Lsun/security/pkcs11/Session;
invokevirtual sun.security.pkcs11.Session.id:()J
lload 7
aload 9
iload 10
iload 4
56: lload 11
aload 13
iload 14
iload 3
57: invokevirtual sun.security.pkcs11.wrapper.PKCS11.C_Decrypt:(JJ[BIIJ[BII)I
istore 15
58: iconst_0
istore 6
59: StackMap locals:
StackMap stack:
aload 2
aload 2
invokevirtual java.nio.ByteBuffer.position:()I
iload 15
iadd
invokevirtual java.nio.ByteBuffer.position:(I)Ljava/nio/ByteBuffer;
pop
60: iload 15
istore 17
61: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 65
62: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
63: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
64: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
65: StackMap locals: sun.security.pkcs11.P11AEADCipher java.nio.ByteBuffer java.nio.ByteBuffer int int int int long byte[] int long byte[] int int top int
StackMap stack:
aload 0
iload 6
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
66: iload 17
ireturn
end local 15 end local 14 end local 13 end local 11 end local 10 end local 9 end local 7 67: StackMap locals: sun.security.pkcs11.P11AEADCipher java.nio.ByteBuffer java.nio.ByteBuffer int int int int
StackMap stack: sun.security.pkcs11.wrapper.PKCS11Exception
astore 7
start local 7 68: iconst_0
istore 6
69: aload 0
aload 7
invokevirtual sun.security.pkcs11.P11AEADCipher.handleException:(Lsun/security/pkcs11/wrapper/PKCS11Exception;)V
70: new java.security.ProviderException
dup
ldc "doFinal() failed"
aload 7
invokespecial java.security.ProviderException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 7 71: StackMap locals:
StackMap stack: java.lang.Throwable
astore 16
72: aload 0
getfield sun.security.pkcs11.P11AEADCipher.encrypt:Z
ifeq 76
73: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.p11Key:Lsun/security/pkcs11/P11Key;
putfield sun.security.pkcs11.P11AEADCipher.lastEncKey:Lsun/security/pkcs11/P11Key;
74: aload 0
aload 0
getfield sun.security.pkcs11.P11AEADCipher.iv:[B
putfield sun.security.pkcs11.P11AEADCipher.lastEncIv:[B
75: aload 0
iconst_1
putfield sun.security.pkcs11.P11AEADCipher.requireReinit:Z
76: StackMap locals: sun.security.pkcs11.P11AEADCipher java.nio.ByteBuffer java.nio.ByteBuffer int int int int top top top top top top top top top java.lang.Throwable
StackMap stack:
aload 0
iload 6
invokevirtual sun.security.pkcs11.P11AEADCipher.reset:(Z)V
77: aload 16
athrow
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 78 0 this Lsun/security/pkcs11/P11AEADCipher;
0 78 1 inBuffer Ljava/nio/ByteBuffer;
0 78 2 outBuffer Ljava/nio/ByteBuffer;
1 78 3 outLen I
2 78 4 inLen I
3 78 5 requiredOutLen I
6 78 6 doCancel Z
8 67 7 inAddr J
9 67 9 in [B
10 67 10 inOfs I
13 15 11 temp [B
30 67 11 outAddr J
31 67 13 outArray [B
32 67 14 outOfs I
42 67 15 k I
68 71 7 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
Exception table:
from to target type
6 49 67 Class sun.security.pkcs11.wrapper.PKCS11Exception
55 61 67 Class sun.security.pkcs11.wrapper.PKCS11Exception
6 49 71 any
55 61 71 any
67 71 71 any
Exceptions:
throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
inBuffer
outBuffer
private void handleException(sun.security.pkcs11.wrapper.PKCS11Exception);
descriptor: (Lsun/security/pkcs11/wrapper/PKCS11Exception;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.getErrorCode:()J
lstore 2
start local 2 1: lload 2
ldc 336
lcmp
ifne 4
2: new javax.crypto.ShortBufferException
dup
invokespecial javax.crypto.ShortBufferException.<init>:()V
aload 1
invokevirtual javax.crypto.ShortBufferException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
3: checkcast javax.crypto.ShortBufferException
athrow
4: StackMap locals: long
StackMap stack:
lload 2
ldc 33
lcmp
ifeq 6
5: lload 2
ldc 65
lcmp
ifne 8
6: StackMap locals:
StackMap stack:
new javax.crypto.IllegalBlockSizeException
dup
aload 1
invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.toString:()Ljava/lang/String;
invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual javax.crypto.IllegalBlockSizeException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
7: checkcast javax.crypto.IllegalBlockSizeException
athrow
8: StackMap locals:
StackMap stack:
lload 2
ldc 64
lcmp
ifeq 10
9: lload 2
ldc 5
lcmp
ifne 12
10: StackMap locals:
StackMap stack:
new javax.crypto.BadPaddingException
dup
aload 1
invokevirtual sun.security.pkcs11.wrapper.PKCS11Exception.toString:()Ljava/lang/String;
invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual javax.crypto.BadPaddingException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
11: checkcast javax.crypto.BadPaddingException
athrow
12: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lsun/security/pkcs11/P11AEADCipher;
0 13 1 e Lsun/security/pkcs11/wrapper/PKCS11Exception;
1 13 2 errorCode J
Exceptions:
throws javax.crypto.ShortBufferException, javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
MethodParameters:
Name Flags
e
protected byte[] engineWrap(java.security.Key);
descriptor: (Ljava/security/Key;)[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: new java.lang.UnsupportedOperationException
dup
ldc "engineWrap()"
invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
0 1 1 key Ljava/security/Key;
Exceptions:
throws javax.crypto.IllegalBlockSizeException, java.security.InvalidKeyException
MethodParameters:
Name Flags
key
protected java.security.Key engineUnwrap(byte[], java.lang.String, int);
descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: new java.lang.UnsupportedOperationException
dup
ldc "engineUnwrap()"
invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/pkcs11/P11AEADCipher;
0 1 1 wrappedKey [B
0 1 2 wrappedKeyAlgorithm Ljava/lang/String;
0 1 3 wrappedKeyType I
Exceptions:
throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
wrappedKey
wrappedKeyAlgorithm
wrappedKeyType
protected int engineGetKeySize(java.security.Key);
descriptor: (Ljava/security/Key;)I
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.pkcs11.P11AEADCipher.token:Lsun/security/pkcs11/Token;
aload 1
ldc "AES"
1: invokestatic sun.security.pkcs11.P11SecretKeyFactory.convertKey:(Lsun/security/pkcs11/Token;Ljava/security/Key;Ljava/lang/String;)Lsun/security/pkcs11/P11Key;
2: invokevirtual sun.security.pkcs11.P11Key.length:()I
3: istore 2
start local 2 4: iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/pkcs11/P11AEADCipher;
0 5 1 key Ljava/security/Key;
4 5 2 n I
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
key
}
SourceFile: "P11AEADCipher.java"