mirror of https://github.com/wolfSSL/wolfssl.git
Fix libdispatch usage condition
parent
4d837e74c4
commit
2ddfe15c4f
|
@ -24,6 +24,10 @@
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
#include <AvailabilityMacros.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <wolfssl/wolfcrypt/settings.h>
|
#include <wolfssl/wolfcrypt/settings.h>
|
||||||
#include <wolfssl/wolfcrypt/types.h>
|
#include <wolfssl/wolfcrypt/types.h>
|
||||||
#include <wolfssl/wolfcrypt/error-crypt.h>
|
#include <wolfssl/wolfcrypt/error-crypt.h>
|
||||||
|
@ -3814,86 +3818,8 @@ char* mystrnstr(const char* s1, const char* s2, unsigned int n)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WOLFSSL_COND
|
#ifdef WOLFSSL_COND
|
||||||
#ifndef __MACH__
|
#if defined(__APPLE__) && MAC_OS_X_VERSION_MIN_REQUIRED >= 1060 \
|
||||||
/* Generic POSIX conditional */
|
&& !defined(__ppc__)
|
||||||
int wolfSSL_CondInit(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_mutex_init(&cond->mutex, NULL) != 0)
|
|
||||||
return MEMORY_E;
|
|
||||||
|
|
||||||
if (pthread_cond_init(&cond->cond, NULL) != 0) {
|
|
||||||
/* Keep compilers happy that we are using the return code */
|
|
||||||
if (pthread_mutex_destroy(&cond->mutex) != 0)
|
|
||||||
return MEMORY_E;
|
|
||||||
return MEMORY_E;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wolfSSL_CondFree(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
int ret = 0;
|
|
||||||
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_mutex_destroy(&cond->mutex) != 0)
|
|
||||||
ret = MEMORY_E;
|
|
||||||
|
|
||||||
if (pthread_cond_destroy(&cond->cond) != 0)
|
|
||||||
ret = MEMORY_E;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wolfSSL_CondStart(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_mutex_lock(&cond->mutex) != 0)
|
|
||||||
return BAD_MUTEX_E;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wolfSSL_CondSignal(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_cond_signal(&cond->cond) != 0)
|
|
||||||
return MEMORY_E;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wolfSSL_CondWait(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_cond_wait(&cond->cond, &cond->mutex) != 0)
|
|
||||||
return MEMORY_E;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int wolfSSL_CondEnd(COND_TYPE* cond)
|
|
||||||
{
|
|
||||||
if (cond == NULL)
|
|
||||||
return BAD_FUNC_ARG;
|
|
||||||
|
|
||||||
if (pthread_mutex_unlock(&cond->mutex) != 0)
|
|
||||||
return BAD_MUTEX_E;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#else /* __MACH__ */
|
|
||||||
/* Apple style dispatch semaphore */
|
/* Apple style dispatch semaphore */
|
||||||
int wolfSSL_CondInit(COND_TYPE* cond)
|
int wolfSSL_CondInit(COND_TYPE* cond)
|
||||||
{
|
{
|
||||||
|
@ -3985,6 +3911,87 @@ char* mystrnstr(const char* s1, const char* s2, unsigned int n)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else /* Generic POSIX conditional */
|
||||||
|
|
||||||
|
int wolfSSL_CondInit(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_mutex_init(&cond->mutex, NULL) != 0)
|
||||||
|
return MEMORY_E;
|
||||||
|
|
||||||
|
if (pthread_cond_init(&cond->cond, NULL) != 0) {
|
||||||
|
/* Keep compilers happy that we are using the return code */
|
||||||
|
if (pthread_mutex_destroy(&cond->mutex) != 0)
|
||||||
|
return MEMORY_E;
|
||||||
|
return MEMORY_E;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int wolfSSL_CondFree(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_mutex_destroy(&cond->mutex) != 0)
|
||||||
|
ret = MEMORY_E;
|
||||||
|
|
||||||
|
if (pthread_cond_destroy(&cond->cond) != 0)
|
||||||
|
ret = MEMORY_E;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
int wolfSSL_CondStart(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_mutex_lock(&cond->mutex) != 0)
|
||||||
|
return BAD_MUTEX_E;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int wolfSSL_CondSignal(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_cond_signal(&cond->cond) != 0)
|
||||||
|
return MEMORY_E;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int wolfSSL_CondWait(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_cond_wait(&cond->cond, &cond->mutex) != 0)
|
||||||
|
return MEMORY_E;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int wolfSSL_CondEnd(COND_TYPE* cond)
|
||||||
|
{
|
||||||
|
if (cond == NULL)
|
||||||
|
return BAD_FUNC_ARG;
|
||||||
|
|
||||||
|
if (pthread_mutex_unlock(&cond->mutex) != 0)
|
||||||
|
return BAD_MUTEX_E;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* __MACH__ */
|
#endif /* __MACH__ */
|
||||||
#endif /* WOLFSSL_COND */
|
#endif /* WOLFSSL_COND */
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,10 @@ decouple library dependencies with standard string, memory and so on.
|
||||||
#include <wolfssl/wolfcrypt/settings.h>
|
#include <wolfssl/wolfcrypt/settings.h>
|
||||||
#include <wolfssl/wolfcrypt/wc_port.h>
|
#include <wolfssl/wolfcrypt/wc_port.h>
|
||||||
|
|
||||||
|
#ifdef __APPLE__
|
||||||
|
#include <AvailabilityMacros.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
@ -1490,18 +1494,19 @@ typedef struct w64wrapper {
|
||||||
typedef size_t THREAD_TYPE;
|
typedef size_t THREAD_TYPE;
|
||||||
#define WOLFSSL_THREAD
|
#define WOLFSSL_THREAD
|
||||||
#elif defined(WOLFSSL_PTHREADS)
|
#elif defined(WOLFSSL_PTHREADS)
|
||||||
#ifndef __MACH__
|
#if defined(__APPLE__) && MAC_OS_X_VERSION_MIN_REQUIRED >= 1060 \
|
||||||
#include <pthread.h>
|
&& !defined(__ppc__)
|
||||||
typedef struct COND_TYPE {
|
|
||||||
pthread_mutex_t mutex;
|
|
||||||
pthread_cond_t cond;
|
|
||||||
} COND_TYPE;
|
|
||||||
#else
|
|
||||||
#include <dispatch/dispatch.h>
|
#include <dispatch/dispatch.h>
|
||||||
typedef struct COND_TYPE {
|
typedef struct COND_TYPE {
|
||||||
wolfSSL_Mutex mutex;
|
wolfSSL_Mutex mutex;
|
||||||
dispatch_semaphore_t cond;
|
dispatch_semaphore_t cond;
|
||||||
} COND_TYPE;
|
} COND_TYPE;
|
||||||
|
#else
|
||||||
|
#include <pthread.h>
|
||||||
|
typedef struct COND_TYPE {
|
||||||
|
pthread_mutex_t mutex;
|
||||||
|
pthread_cond_t cond;
|
||||||
|
} COND_TYPE;
|
||||||
#endif
|
#endif
|
||||||
typedef void* THREAD_RETURN;
|
typedef void* THREAD_RETURN;
|
||||||
typedef pthread_t THREAD_TYPE;
|
typedef pthread_t THREAD_TYPE;
|
||||||
|
|
Loading…
Reference in New Issue