summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authortb <>2023-04-23 10:19:52 +0000
committertb <>2023-04-23 10:19:52 +0000
commit76ef46b5ee51ec4e5bd4635ea9b83c28db71a214 (patch)
treed663d22d8bd9b3ed8b9d637b03163f8cbcffc10d /src/lib
parentc18983dc1dc739de953964faac9e795eec043b64 (diff)
downloadopenbsd-76ef46b5ee51ec4e5bd4635ea9b83c28db71a214.tar.gz
openbsd-76ef46b5ee51ec4e5bd4635ea9b83c28db71a214.tar.bz2
openbsd-76ef46b5ee51ec4e5bd4635ea9b83c28db71a214.zip
Align hex_to_string with OpenSSL 1.1 behavior
This is a bit of a strange one. When this function was moved and renamed, somehow checks for NULL pointers and 0 length were lost. Whether that was due to great review missing it or great review suggesting it, is unclear. Now the function can actually legitimately be called with a length of 0 (as ASN.1 OCTET STRINGS can have length 0) and "" is the appropriate representation for that, so the fix is to allocate a 0 octet. That much was correct. What was completely missed is that a long can be negative which will then still lead to an out-of-bounds access. So fix that as well. Finally, don't malloc 3 * len + 1 without overflow checking. Rather use calloc's internal checks. The + 1 isn't really needed anyway. All this is still really gross and can be done much more cleanly and safely with CBB/CBS. This will done later once we have better regress coverage. ok jsing
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/libcrypto/x509/x509_utl.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/lib/libcrypto/x509/x509_utl.c b/src/lib/libcrypto/x509/x509_utl.c
index 1a043d93d5..b6f1919b39 100644
--- a/src/lib/libcrypto/x509/x509_utl.c
+++ b/src/lib/libcrypto/x509/x509_utl.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: x509_utl.c,v 1.9 2023/04/23 09:58:38 tb Exp $ */ 1/* $OpenBSD: x509_utl.c,v 1.10 2023/04/23 10:19:52 tb Exp $ */
2/* Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL 2/* Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL
3 * project. 3 * project.
4 */ 4 */
@@ -471,9 +471,11 @@ hex_to_string(const unsigned char *buffer, long len)
471 int i; 471 int i;
472 static const char hexdig[] = "0123456789ABCDEF"; 472 static const char hexdig[] = "0123456789ABCDEF";
473 473
474 if (!buffer || !len) 474 if (len < 0)
475 return NULL; 475 return NULL;
476 if (!(tmp = malloc(len * 3 + 1))) { 476 if (len == 0)
477 return calloc(1, 1);
478 if ((tmp = calloc(len, 3)) == NULL) {
477 X509V3error(ERR_R_MALLOC_FAILURE); 479 X509V3error(ERR_R_MALLOC_FAILURE);
478 return NULL; 480 return NULL;
479 } 481 }