diff options
author | Benjamin Barenblat <bbaren at mit.edu> | 2015-09-20 17:46:07 -0400 |
---|---|---|
committer | Benjamin Barenblat <bbaren at mit.edu> | 2015-09-20 17:46:07 -0400 |
commit | 438e05e7ea9949b7ee61e40a2a6bc7e1c1d4b8f3 (patch) | |
tree | 37b337e60f9df517c895327003f41b83d717cf28 /src/c | |
parent | 03f1d80a665c4de6fd83ff6dc9399dda97838efa (diff) |
Use correct OpenSSL thread safety macros on OS X (closes #209)
Create an Autoconf test to determine if pthread_t is a pointer or scalar
type, and use the appropriate CRYPTO_THREADID_set macro based on the
result.
Diffstat (limited to 'src/c')
-rw-r--r-- | src/c/openssl.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/c/openssl.c b/src/c/openssl.c index 6d018707..206a3bc8 100644 --- a/src/c/openssl.c +++ b/src/c/openssl.c @@ -34,9 +34,15 @@ static void random_password() { } // OpenSSL callbacks +#ifdef PTHREAD_T_IS_POINTER +# define CRYPTO_THREADID_SET CRYPTO_THREADID_set_pointer +#else +# define CRYPTO_THREADID_SET CRYPTO_THREADID_set_numeric +#endif static void thread_id(CRYPTO_THREADID *const result) { - CRYPTO_THREADID_set_numeric(result, pthread_self()); + CRYPTO_THREADID_SET(result, pthread_self()); } +#undef CRYPTO_THREADID_SET static void lock_or_unlock(const int mode, const int type, const char *file, const int line) { pthread_mutex_t *const lock = &openssl_locks[type]; |