final class sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator implements sun.security.ssl.SSLKeyAgreementGenerator
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator
super_class: java.lang.Object
{
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 // sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator this
0: .line 388
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 390
return
end local 0 // sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ECDHKeyExchange$ECDHEKAGenerator;
public sun.security.ssl.SSLKeyDerivation createKeyDerivation(sun.security.ssl.HandshakeContext);
descriptor: (Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLKeyDerivation;
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=9, args_size=2
start local 0 // sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator this
start local 1 // sun.security.ssl.HandshakeContext context
0: .line 395
aconst_null
astore 2 /* ecdhePossession */
start local 2 // sun.security.ssl.ECDHKeyExchange$ECDHEPossession ecdhePossession
1: .line 396
aconst_null
astore 3 /* ecdheCredentials */
start local 3 // sun.security.ssl.ECDHKeyExchange$ECDHECredentials ecdheCredentials
2: .line 397
aload 1 /* context */
getfield sun.security.ssl.HandshakeContext.handshakePossessions:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 18
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials top java.util.Iterator
StackMap stack:
3: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.SSLPossession
astore 4 /* poss */
start local 4 // sun.security.ssl.SSLPossession poss
4: .line 398
aload 4 /* poss */
instanceof sun.security.ssl.ECDHKeyExchange$ECDHEPossession
ifne 6
5: .line 399
goto 18
6: .line 402
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials sun.security.ssl.SSLPossession java.util.Iterator
StackMap stack:
aload 4 /* poss */
checkcast sun.security.ssl.ECDHKeyExchange$ECDHEPossession
getfield sun.security.ssl.ECDHKeyExchange$ECDHEPossession.namedGroup:Lsun/security/ssl/NamedGroup;
astore 6 /* ng */
start local 6 // sun.security.ssl.NamedGroup ng
7: .line 403
aload 1 /* context */
getfield sun.security.ssl.HandshakeContext.handshakeCredentials:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 8
goto 14
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials sun.security.ssl.SSLPossession java.util.Iterator sun.security.ssl.NamedGroup top java.util.Iterator
StackMap stack:
8: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.SSLCredentials
astore 7 /* cred */
start local 7 // sun.security.ssl.SSLCredentials cred
9: .line 404
aload 7 /* cred */
instanceof sun.security.ssl.ECDHKeyExchange$ECDHECredentials
ifne 11
10: .line 405
goto 14
11: .line 407
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials sun.security.ssl.SSLPossession java.util.Iterator sun.security.ssl.NamedGroup sun.security.ssl.SSLCredentials java.util.Iterator
StackMap stack:
aload 6 /* ng */
aload 7 /* cred */
checkcast sun.security.ssl.ECDHKeyExchange$ECDHECredentials
getfield sun.security.ssl.ECDHKeyExchange$ECDHECredentials.namedGroup:Lsun/security/ssl/NamedGroup;
invokevirtual sun.security.ssl.NamedGroup.equals:(Ljava/lang/Object;)Z
ifeq 14
12: .line 408
aload 7 /* cred */
checkcast sun.security.ssl.ECDHKeyExchange$ECDHECredentials
astore 3 /* ecdheCredentials */
13: .line 409
goto 15
end local 7 // sun.security.ssl.SSLCredentials cred
14: .line 403
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials sun.security.ssl.SSLPossession java.util.Iterator sun.security.ssl.NamedGroup top java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 8
15: .line 413
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials sun.security.ssl.SSLPossession java.util.Iterator sun.security.ssl.NamedGroup
StackMap stack:
aload 3 /* ecdheCredentials */
ifnull 18
16: .line 414
aload 4 /* poss */
checkcast sun.security.ssl.ECDHKeyExchange$ECDHEPossession
astore 2 /* ecdhePossession */
17: .line 415
goto 19
end local 6 // sun.security.ssl.NamedGroup ng
end local 4 // sun.security.ssl.SSLPossession poss
18: .line 397
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials top java.util.Iterator
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
19: .line 419
StackMap locals: sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator sun.security.ssl.HandshakeContext sun.security.ssl.ECDHKeyExchange$ECDHEPossession sun.security.ssl.ECDHKeyExchange$ECDHECredentials
StackMap stack:
aload 2 /* ecdhePossession */
ifnull 20
aload 3 /* ecdheCredentials */
ifnonnull 23
20: .line 420
StackMap locals:
StackMap stack:
aload 1 /* context */
getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
21: .line 421
ldc "No sufficient ECDHE key agreement parameters negotiated"
22: .line 420
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
23: .line 424
StackMap locals:
StackMap stack:
new sun.security.ssl.KAKeyDerivation
dup
ldc "ECDH"
aload 1 /* context */
24: .line 425
aload 2 /* ecdhePossession */
getfield sun.security.ssl.ECDHKeyExchange$ECDHEPossession.privateKey:Ljava/security/PrivateKey;
aload 3 /* ecdheCredentials */
getfield sun.security.ssl.ECDHKeyExchange$ECDHECredentials.popPublicKey:Ljava/security/interfaces/ECPublicKey;
25: .line 424
invokespecial sun.security.ssl.KAKeyDerivation.<init>:(Ljava/lang/String;Lsun/security/ssl/HandshakeContext;Ljava/security/PrivateKey;Ljava/security/PublicKey;)V
areturn
end local 3 // sun.security.ssl.ECDHKeyExchange$ECDHECredentials ecdheCredentials
end local 2 // sun.security.ssl.ECDHKeyExchange$ECDHEPossession ecdhePossession
end local 1 // sun.security.ssl.HandshakeContext context
end local 0 // sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator this
LocalVariableTable:
Start End Slot Name Signature
0 26 0 this Lsun/security/ssl/ECDHKeyExchange$ECDHEKAGenerator;
0 26 1 context Lsun/security/ssl/HandshakeContext;
1 26 2 ecdhePossession Lsun/security/ssl/ECDHKeyExchange$ECDHEPossession;
2 26 3 ecdheCredentials Lsun/security/ssl/ECDHKeyExchange$ECDHECredentials;
4 18 4 poss Lsun/security/ssl/SSLPossession;
7 18 6 ng Lsun/security/ssl/NamedGroup;
9 14 7 cred Lsun/security/ssl/SSLCredentials;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
}
SourceFile: "ECDHKeyExchange.java"
NestHost: sun.security.ssl.ECDHKeyExchange
InnerClasses:
final ECDHECredentials = sun.security.ssl.ECDHKeyExchange$ECDHECredentials of sun.security.ssl.ECDHKeyExchange
private final ECDHEKAGenerator = sun.security.ssl.ECDHKeyExchange$ECDHEKAGenerator of sun.security.ssl.ECDHKeyExchange
final ECDHEPossession = sun.security.ssl.ECDHKeyExchange$ECDHEPossession of sun.security.ssl.ECDHKeyExchange