diff options
author | Nils Larsch <nils@openssl.org> | 2005-08-08 20:02:18 +0000 |
---|---|---|
committer | Nils Larsch <nils@openssl.org> | 2005-08-08 20:02:18 +0000 |
commit | eba63ef58b29c38f2849e0bc28f26f9b563fa0bb (patch) | |
tree | 3edc2af31204f763e9106dc57fad6ce890dd066e /ssl/ssl_cert.c | |
parent | 01a9792f05a2e5294c1aae8f94e96eb5651f463f (diff) |
a ssl object needs it's own instance of a ecdh key; remove obsolete comment
Diffstat (limited to 'ssl/ssl_cert.c')
-rw-r--r-- | ssl/ssl_cert.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/ssl/ssl_cert.c b/ssl/ssl_cert.c index 997528e97d..7908dcccdb 100644 --- a/ssl/ssl_cert.c +++ b/ssl/ssl_cert.c @@ -200,7 +200,6 @@ CERT *ssl_cert_dup(CERT *cert) #ifndef OPENSSL_NO_DH if (cert->dh_tmp != NULL) { - /* DH parameters don't have a reference count */ ret->dh_tmp = DHparams_dup(cert->dh_tmp); if (ret->dh_tmp == NULL) { @@ -234,8 +233,12 @@ CERT *ssl_cert_dup(CERT *cert) #ifndef OPENSSL_NO_ECDH if (cert->ecdh_tmp) { - EC_KEY_up_ref(cert->ecdh_tmp); - ret->ecdh_tmp = cert->ecdh_tmp; + ret->ecdh_tmp = EC_KEY_dup(cert->ecdh_tmp); + if (ret->ecdh_tmp == NULL) + { + SSLerr(SSL_F_SSL_CERT_DUP, ERR_R_EC_LIB); + goto err; + } } ret->ecdh_tmp_cb = cert->ecdh_tmp_cb; #endif |