From: Pauli Date: Mon, 14 Jun 2021 11:22:55 +0000 (+1000) Subject: cms: free PKEY_CTX X-Git-Tag: openssl-3.0.0-beta1~60 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=dfb0b8d63a1b627c5d796ba0174ee4693b330989;p=thirdparty%2Fopenssl.git cms: free PKEY_CTX Preventing a memory leak. Reviewed-by: Tomas Mraz Reviewed-by: David von Oheimb (Merged from https://github.com/openssl/openssl/pull/15731) --- diff --git a/crypto/cms/cms_ec.c b/crypto/cms/cms_ec.c index ca66d9fcf8b..87ce88e743d 100644 --- a/crypto/cms/cms_ec.c +++ b/crypto/cms/cms_ec.c @@ -38,6 +38,7 @@ static EVP_PKEY *pkey_type2param(int ptype, const void *pval, goto err; } OSSL_DECODER_CTX_free(ctx); + return pkey; } else if (ptype == V_ASN1_OBJECT) { const ASN1_OBJECT *poid = pval; char groupname[OSSL_MAX_NAME_SIZE]; @@ -53,12 +54,12 @@ static EVP_PKEY *pkey_type2param(int ptype, const void *pval, } if (EVP_PKEY_paramgen(pctx, &pkey) <= 0) goto err; - } else { - ERR_raise(ERR_LIB_CMS, CMS_R_DECODE_ERROR); - goto err; + EVP_PKEY_CTX_free(pctx); + return pkey; } - return pkey; + ERR_raise(ERR_LIB_CMS, CMS_R_DECODE_ERROR); + return NULL; err: EVP_PKEY_free(pkey);