From: Matt Caswell Date: Wed, 4 May 2016 10:14:48 +0000 (+0100) Subject: Fix some malloc failures in b_addr.c X-Git-Tag: OpenSSL_1_1_0-pre6~789 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=24854e0117000b81319665154c93e15743bf7de6;p=oweals%2Fopenssl.git Fix some malloc failures in b_addr.c There were some unchecked calls to OPENSSL_strdup(). Reviewed-by: Richard Levitte --- diff --git a/crypto/bio/b_addr.c b/crypto/bio/b_addr.c index bb6719eb2a..3a9a00c121 100644 --- a/crypto/bio/b_addr.c +++ b/crypto/bio/b_addr.c @@ -228,21 +228,35 @@ static int addr_strings(const BIO_ADDR *ap, int numeric, ntohs(BIO_ADDR_rawport(ap))); } - if (hostname) + if (hostname != NULL) *hostname = OPENSSL_strdup(host); - if (service) + if (service != NULL) *service = OPENSSL_strdup(serv); } else { #endif - if (hostname) + if (hostname != NULL) *hostname = OPENSSL_strdup(inet_ntoa(ap->s_in.sin_addr)); - if (service) { + if (service != NULL) { char serv[6]; /* port is 16 bits => max 5 decimal digits */ BIO_snprintf(serv, sizeof(serv), "%d", ntohs(ap->s_in.sin_port)); *service = OPENSSL_strdup(serv); } } + if ((hostname != NULL && *hostname == NULL) + || (service != NULL && *service == NULL)) { + if (hostname != NULL) { + OPENSSL_free(*hostname); + *hostname = NULL; + } + if (service != NULL) { + OPENSSL_free(*service); + *service = NULL; + } + BIOerr(BIO_F_ADDR_STRINGS, ERR_R_MALLOC_FAILURE); + return 0; + } + return 1; }