summaryrefslogtreecommitdiffstats
path: root/crypto/asn1
diff options
context:
space:
mode:
authorRichard Levitte <levitte@openssl.org>2017-10-23 16:41:06 +0200
committerRichard Levitte <levitte@openssl.org>2017-10-23 17:47:45 +0200
commitca80ba81e243c30873cd11870422a3873a64be73 (patch)
tree41e651fd2c44da2e258651f6a2e70b7e1794de29 /crypto/asn1
parent84a85b5755befabd450fbb7cc63d5e23a268ddb0 (diff)
asn1_item_embed_new(): don't free an embedded item
An embedded item wasn't allocated separately on the heap, so don't free it as if it was. Issue discovered by Pavel Kopyl Reviewed-by: Matt Caswell <matt@openssl.org> (Merged from https://github.com/openssl/openssl/pull/4572) (cherry picked from commit 590bbdfdf43b97abf8817f506f8ab46687d1eadd)
Diffstat (limited to 'crypto/asn1')
-rw-r--r--crypto/asn1/tasn_new.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/crypto/asn1/tasn_new.c b/crypto/asn1/tasn_new.c
index f695e38da0..7608b43b7f 100644
--- a/crypto/asn1/tasn_new.c
+++ b/crypto/asn1/tasn_new.c
@@ -142,7 +142,8 @@ int asn1_item_embed_new(ASN1_VALUE **pval, const ASN1_ITEM *it, int embed)
return 1;
memerr2:
- ASN1_item_ex_free(pval, it);
+ if (!embed)
+ ASN1_item_ex_free(pval, it);
memerr:
ASN1err(ASN1_F_ASN1_ITEM_EMBED_NEW, ERR_R_MALLOC_FAILURE);
#ifndef OPENSSL_NO_CRYPTO_MDEBUG
@@ -151,7 +152,8 @@ int asn1_item_embed_new(ASN1_VALUE **pval, const ASN1_ITEM *it, int embed)
return 0;
auxerr2:
- ASN1_item_ex_free(pval, it);
+ if (!embed)
+ ASN1_item_ex_free(pval, it);
auxerr:
ASN1err(ASN1_F_ASN1_ITEM_EMBED_NEW, ASN1_R_AUX_ERROR);
#ifndef OPENSSL_NO_CRYPTO_MDEBUG