From: Richard Levitte Date: Fri, 18 Dec 2015 12:03:45 +0000 (+0100) Subject: Fix a possible memleak X-Git-Tag: OpenSSL_1_1_0-pre2~132 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6aa0ba4bb2833b1e0d6ae98c54c79bfed8257c3a;p=openssl Fix a possible memleak If there's a failure allocating md_data, the destination pctx will have a shared pointer with the source EVP_MD_CTX, which will lead to problems when either the source or the destination is freed. Reviewed-by: Stephen Henson --- diff --git a/crypto/evp/digest.c b/crypto/evp/digest.c index 5da0e01039..33688f99e4 100644 --- a/crypto/evp/digest.c +++ b/crypto/evp/digest.c @@ -312,6 +312,13 @@ int EVP_MD_CTX_copy_ex(EVP_MD_CTX *out, const EVP_MD_CTX *in) EVP_MD_CTX_reset(out); memcpy(out, in, sizeof(*out)); + /* Null these variables, since they are getting fixed up + * properly below. Anything else may cause a memleak and/or + * double free if any of the memory allocations below fail + */ + out->md_data = NULL; + out->pctx = NULL; + if (in->md_data && out->digest->ctx_size) { if (tmp_buf) out->md_data = tmp_buf;