From: Matt Caswell Date: Fri, 10 Jun 2016 14:30:09 +0000 (+0100) Subject: Fix an error path leak in do_ext_nconf() X-Git-Tag: OpenSSL_1_1_0-pre6~494 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8605abf13523579ecab8b1f2a4bcb8354d94af79;p=openssl Fix an error path leak in do_ext_nconf() Reviewed-by: Rich Salz --- diff --git a/crypto/x509v3/v3_conf.c b/crypto/x509v3/v3_conf.c index bc06e31af5..4e118c10ab 100644 --- a/crypto/x509v3/v3_conf.c +++ b/crypto/x509v3/v3_conf.c @@ -88,11 +88,13 @@ static X509_EXTENSION *do_ext_nconf(CONF *conf, X509V3_CTX *ctx, int ext_nid, nval = NCONF_get_section(conf, value + 1); else nval = X509V3_parse_list(value); - if (sk_CONF_VALUE_num(nval) <= 0) { + if (nval == NULL || sk_CONF_VALUE_num(nval) <= 0) { X509V3err(X509V3_F_DO_EXT_NCONF, X509V3_R_INVALID_EXTENSION_STRING); ERR_add_error_data(4, "name=", OBJ_nid2sn(ext_nid), ",section=", value); + if (*value != '@') + sk_CONF_VALUE_free(nval); return NULL; } ext_struc = method->v2i(method, ctx, nval);