From: Matt Caswell Date: Wed, 8 Nov 2017 13:22:59 +0000 (+0000) Subject: Fix an s_client memory leak X-Git-Tag: OpenSSL_1_1_1-pre1~455 X-Git-Url: https://git.openssl.org/?p=openssl.git;a=commitdiff_plain;h=44f19af7434cdb996f1ce11789150baa07db27e6 Fix an s_client memory leak We were using OPENSSL_strdup() unnecessarily and then failing to free it. There is no reason to use OPENSSL_strdup() in this scenario - so just remove it. Reviewed-by: Ben Kaduk (Merged from https://github.com/openssl/openssl/pull/4699) --- diff --git a/apps/s_client.c b/apps/s_client.c index d2aa01d76a..58ed1a5343 100644 --- a/apps/s_client.c +++ b/apps/s_client.c @@ -918,7 +918,7 @@ int s_client_main(int argc, char **argv) #if defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_MSDOS) struct timeval tv; #endif - char *servername = NULL; + const char *servername = NULL; int noservername = 0; const char *alpn_in = NULL; tlsextctx tlsextcbp = { NULL, 0 }; @@ -1924,16 +1924,9 @@ int s_client_main(int argc, char **argv) } /* By default the SNI should be the same as was set in the session */ if (!noservername && servername == NULL) { - const char *sni = SSL_SESSION_get0_hostname(sess); + servername = SSL_SESSION_get0_hostname(sess); - if (sni != NULL) { - servername = OPENSSL_strdup(sni); - if (servername == NULL) { - BIO_printf(bio_err, "Can't set server name\n"); - ERR_print_errors(bio_err); - goto end; - } - } else { + if (servername == NULL) { /* * Force no SNI to be sent so we are consistent with the * session.