]> git.ipfire.org Git - thirdparty/openssl.git/commitdiff
Add locking to CRYPTO_secure_used
authorNeil Horman <nhorman@openssl.org>
Wed, 22 Nov 2023 19:20:39 +0000 (14:20 -0500)
committerNeil Horman <nhorman@openssl.org>
Fri, 1 Dec 2023 14:42:13 +0000 (09:42 -0500)
Coverity issue 1551719 noted CRYPTO_secure_used referenced a shared
variable without taking the appropriate read lock.  Add that.

Reviewed-by: Tomas Mraz <tomas@openssl.org>
Reviewed-by: Todd Short <todd.short@me.com>
(Merged from https://github.com/openssl/openssl/pull/22802)

(cherry picked from commit 7eae6ee0e503b0961d4f2e75baac981f2766b892)

crypto/mem_sec.c

index e1a319347715db5daa42497306407e67a12be036..b6bdb6bb43595f621f57243955ae0957416c8d0e 100644 (file)
@@ -238,11 +238,17 @@ int CRYPTO_secure_allocated(const void *ptr)
 
 size_t CRYPTO_secure_used(void)
 {
+    size_t ret = 0;
+
 #ifndef OPENSSL_NO_SECURE_MEMORY
-    return secure_mem_used;
-#else
-    return 0;
+    if (!CRYPTO_THREAD_read_lock(sec_malloc_lock))
+        return 0;
+
+    ret = secure_mem_used;
+
+    CRYPTO_THREAD_unlock(sec_malloc_lock);
 #endif /* OPENSSL_NO_SECURE_MEMORY */
+    return ret;
 }
 
 size_t CRYPTO_secure_actual_size(void *ptr)