summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorTheo Buehler <tb@cvs.openbsd.org>2021-07-26 16:54:21 +0000
committerTheo Buehler <tb@cvs.openbsd.org>2021-07-26 16:54:21 +0000
commit33d9b4173483c2b608a7317db3a0573abbfb8347 (patch)
tree02793c3ef42629d482d81651355c5eba3dfc55c6 /lib
parent56723366f46f73851957e45bb0626922be30a797 (diff)
Add error checks for i2d_X509_NAME()
This avoids potential malloc(-1) and malloc(0), spotted by schwarze while documenting X509_ocspid_print(). ok schwarze
Diffstat (limited to 'lib')
-rw-r--r--lib/libcrypto/asn1/t_x509.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/lib/libcrypto/asn1/t_x509.c b/lib/libcrypto/asn1/t_x509.c
index 1cef35dfca6..42b00a729aa 100644
--- a/lib/libcrypto/asn1/t_x509.c
+++ b/lib/libcrypto/asn1/t_x509.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: t_x509.c,v 1.33 2021/07/06 11:26:25 schwarze Exp $ */
+/* $OpenBSD: t_x509.c,v 1.34 2021/07/26 16:54:20 tb Exp $ */
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
* All rights reserved.
*
@@ -261,10 +261,12 @@ X509_ocspid_print(BIO *bp, X509 *x)
in OCSP requests */
if (BIO_printf(bp, " Subject OCSP hash: ") <= 0)
goto err;
- derlen = i2d_X509_NAME(x->cert_info->subject, NULL);
+ if ((derlen = i2d_X509_NAME(x->cert_info->subject, NULL)) <= 0)
+ goto err;
if ((der = dertmp = malloc(derlen)) == NULL)
goto err;
- i2d_X509_NAME(x->cert_info->subject, &dertmp);
+ if (i2d_X509_NAME(x->cert_info->subject, &dertmp) <= 0)
+ goto err;
if (!EVP_Digest(der, derlen, SHA1md, NULL, EVP_sha1(), NULL))
goto err;