summaryrefslogtreecommitdiffstats
path: root/providers
diff options
context:
space:
mode:
authorNicky Mouha <nmouha@users.noreply.github.com>2023-05-17 16:46:41 -0400
committerTomas Mraz <tomas@openssl.org>2023-05-19 12:42:08 +0200
commit56a51b5a1ecd54eadc80bed4bfe5044a340787c1 (patch)
treeff5e2b56bfe662438fd6a87cc90ae37af50b53bf /providers
parentd500f04400d0acc83fe5270da860764a7d19deee (diff)
Update hkdf.c to avoid potentially vulnerable code pattern
The expression "if (a+b>c) a=c-b" is incorrect if "a+b" overflows. It should be replaced by "if (a>c-b) a=c-b", which avoids the potential overflow and is much easier to understand. This pattern is the root cause of CVE-2022-37454, a buffer overflow vulnerability in the "official" SHA-3 implementation. It has been confirmed that the addition in https://github.com/openssl/openssl/blob/master/providers/implementations/kdfs/hkdf.c#L534 cannot overflow. So this is only a minor change proposal to avoid a potentially vulnerable code pattern and to improve readability. More information: https://github.com/github/codeql/pull/12036#issuecomment-1466056959 CLA: trivial Reviewed-by: Paul Dale <pauli@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/20990)
Diffstat (limited to 'providers')
-rw-r--r--providers/implementations/kdfs/hkdf.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/providers/implementations/kdfs/hkdf.c b/providers/implementations/kdfs/hkdf.c
index f0b46a1fc5..7f42f42647 100644
--- a/providers/implementations/kdfs/hkdf.c
+++ b/providers/implementations/kdfs/hkdf.c
@@ -531,7 +531,7 @@ static int HKDF_Expand(const EVP_MD *evp_md,
if (!HMAC_Final(hmac, prev, NULL))
goto err;
- copy_len = (done_len + dig_len > okm_len) ?
+ copy_len = (dig_len > okm_len - done_len) ?
okm_len - done_len :
dig_len;