diff options
author | tb <> | 2023-04-23 10:19:52 +0000 |
---|---|---|
committer | tb <> | 2023-04-23 10:19:52 +0000 |
commit | 76ef46b5ee51ec4e5bd4635ea9b83c28db71a214 (patch) | |
tree | d663d22d8bd9b3ed8b9d637b03163f8cbcffc10d /src/lib | |
parent | c18983dc1dc739de953964faac9e795eec043b64 (diff) | |
download | openbsd-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.c | 8 |
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 | } |