From: Matt Caswell Date: Tue, 26 Jun 2018 14:40:54 +0000 (+0100) Subject: Fix a NULL ptr deref in error path in tls_process_cke_dhe() X-Git-Tag: OpenSSL_1_1_1-pre9~210 X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=commitdiff_plain;h=b6ff436fcb597663ffcfe6d724d207cf120e7250 Fix a NULL ptr deref in error path in tls_process_cke_dhe() Fixes #6574 Reviewed-by: Richard Levitte (Merged from https://github.com/openssl/openssl/pull/6593) --- diff --git a/ssl/statem/statem_srvr.c b/ssl/statem/statem_srvr.c index 9c44be0301..26cd850d12 100644 --- a/ssl/statem/statem_srvr.c +++ b/ssl/statem/statem_srvr.c @@ -3129,14 +3129,13 @@ static int tls_process_cke_dhe(SSL *s, PACKET *pkt) SSL_R_BN_LIB); goto err; } + cdh = EVP_PKEY_get0_DH(ckey); pub_key = BN_bin2bn(data, i, NULL); - - if (pub_key == NULL || !DH_set0_key(cdh, pub_key, NULL)) { + if (pub_key == NULL || cdh == NULL || !DH_set0_key(cdh, pub_key, NULL)) { SSLfatal(s, SSL_AD_INTERNAL_ERROR, SSL_F_TLS_PROCESS_CKE_DHE, ERR_R_INTERNAL_ERROR); - if (pub_key != NULL) - BN_free(pub_key); + BN_free(pub_key); goto err; }