The branch master has been updated
via 23dd0c9f8dc6f7edf4b872d13e5644dfbbee585b (commit)
from 2f8e53d7944b3d659c8ae678163eb0f096a6d992 (commit)
- Log -----------------------------------------------------------------
commit 23dd0c9f8dc6f7edf4b872d13e5644dfbbee585b
Author: Dr. Stephen Henson <[email protected]>
Date: Wed Jul 20 02:57:23 2016 +0100
fix crypto-mdebug build
Reviewed-by: Rich Salz <[email protected]>
-----------------------------------------------------------------------
Summary of changes:
crypto/mem_dbg.c | 13 +++++++++++--
1 file changed, 11 insertions(+), 2 deletions(-)
diff --git a/crypto/mem_dbg.c b/crypto/mem_dbg.c
index 0307c02..dc3f8ff 100644
--- a/crypto/mem_dbg.c
+++ b/crypto/mem_dbg.c
@@ -11,6 +11,7 @@
#include <stdlib.h>
#include <time.h>
#include "internal/cryptlib.h"
+#include "internal/thread_once.h"
#include <openssl/crypto.h>
#include <openssl/buffer.h>
#include "internal/bio.h"
@@ -87,11 +88,19 @@ static unsigned int num_disable = 0;
*/
static CRYPTO_THREAD_ID disabling_threadid;
-static void do_memdbg_init(void)
+DEFINE_RUN_ONCE_STATIC(do_memdbg_init)
{
malloc_lock = CRYPTO_THREAD_lock_new();
long_malloc_lock = CRYPTO_THREAD_lock_new();
- CRYPTO_THREAD_init_local(&appinfokey, NULL);
+ if (malloc_lock == NULL || long_malloc_lock == NULL
+ || !CRYPTO_THREAD_init_local(&appinfokey, NULL)) {
+ CRYPTO_THREAD_lock_free(malloc_lock);
+ malloc_lock = NULL;
+ CRYPTO_THREAD_lock_free(long_malloc_lock);
+ long_malloc_lock = NULL;
+ return 0;
+ }
+ return 1;
}
static void app_info_free(APP_INFO *inf)
_____
openssl-commits mailing list
To unsubscribe: https://mta.openssl.org/mailman/listinfo/openssl-commits