]> git.ipfire.org Git - thirdparty/openssl.git/commitdiff
x_attrib: fix a memory leak
authorBeat Bolli <dev@drbeat.li>
Thu, 15 Aug 2024 10:35:02 +0000 (12:35 +0200)
committerTomas Mraz <tomas@openssl.org>
Wed, 21 Aug 2024 13:51:29 +0000 (15:51 +0200)
The X509_NAME object needs to be free'd even if printing it fails.

Introduced in be5adfd6e3 ("Support subjectDirectoryAttributes and
associatedInformation exts", 2024-06-18), but subsequently moved in
7bcfb41489 ("ossl_print_attribute_value(): use a sequence value only if
type is a sequence", 2024-08-05).

Signed-off-by: Beat Bolli <dev@drbeat.li>
Reviewed-by: Tom Cosgrove <tom.cosgrove@arm.com>
Reviewed-by: Tomas Mraz <tomas@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/25207)

crypto/x509/x_attrib.c

index b413a27917774ffbe3b2851e61112762fb890e53..2623398debf716386bde4002c41437b56125ac25 100644 (file)
@@ -98,6 +98,7 @@ int ossl_print_attribute_value(BIO *out,
     unsigned char *value;
     X509_NAME *xn = NULL;
     int64_t int_val;
+    int ret = 1;
 
     switch (av->type) {
     case V_ASN1_BOOLEAN:
@@ -192,9 +193,9 @@ int ossl_print_attribute_value(BIO *out,
                 return 0;
             }
             if (X509_NAME_print_ex(out, xn, indent, XN_FLAG_SEP_CPLUS_SPC) <= 0)
-                return 0;
+                ret = 0;
             X509_NAME_free(xn);
-            return 1;
+            return ret;
 
         default:
             break;