From d725022844380852476dbef00d7dc3c2e7a37fdb Mon Sep 17 00:00:00 2001 From: Andreas Baumann Date: Mon, 31 Oct 2011 19:54:01 +0100 Subject: added a HAVE_THREADS flag --- src/GNUmakefile | 5 ++++- src/port/netdb.c | 8 ++++++++ src/port/string.c | 8 ++++++++ 3 files changed, 20 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/GNUmakefile b/src/GNUmakefile index ab948de..dd111de 100644 --- a/src/GNUmakefile +++ b/src/GNUmakefile @@ -6,9 +6,12 @@ INCLUDE_DIRS = -I$(TOPDIR)/include/wolf -I. BINS = -THREADING_OBJS = \ +THREADING_OBJS = +ifeq "$(ENABLE_THREADS)" "1" +THREADING_OBJS = $(THREADING_OBJS) \ threads/mutex.o \ threads/threads.o +endif PORT_OBJS = \ port/string.o \ diff --git a/src/port/netdb.c b/src/port/netdb.c index b913ef9..ea4458e 100644 --- a/src/port/netdb.c +++ b/src/port/netdb.c @@ -236,31 +236,39 @@ const char *wolf_port_gai_strerror( int errcode ) { #include "port/string.h" /* for strncmp */ #include /* for errno */ +#ifdef HAVE_THREADS static bool mutex_initialized = false; static wolf_mutex_t mutex; +#endif int wolf_port_gai_strerror_r( int errcode, char *buf, size_t buflen ) { int safe_errno = errno; const char *msg; /* critical section as gai_strerror is not thread-safe */ +#ifdef HAVE_THREADS if( !mutex_initialized ) { wolf_mutex_init( &mutex ); mutex_initialized = true; } wolf_mutex_lock( &mutex ); +#endif msg = gai_strerror( errcode ); if( strncmp( msg, "Unknown GAI errror", strlen( "Unknown GAI error" ) ) == 0 /* our own stub implementation */ ) { (void)snprintf( buf, buflen, "Unknown GAI error %d", errcode ); errno = EINVAL; +#ifdef HAVE_THREADS wolf_mutex_unlock( &mutex ); +#endif return -1; } strncpy( buf, msg, buflen-1 ); errno = safe_errno; +#ifdef HAVE_THREADS wolf_mutex_unlock( &mutex ); +#endif return 0; } diff --git a/src/port/string.c b/src/port/string.c index 398788c..9c360d0 100644 --- a/src/port/string.c +++ b/src/port/string.c @@ -49,19 +49,23 @@ char *wolf_port_strdup( const char *s ) { #include /* for errno */ #include "threads/mutex.h" /* for mutexes */ +#ifdef HAVE_THREADS static bool mutex_initialized = false; static wolf_mutex_t mutex; +#endif int wolf_port_strerror_r( int num, char *buf, size_t buflen ) { int safe_errno = errno; const char *msg; /* critical section as strerror is not thread-safe */ +#ifdef HAVE_THREADS if( !mutex_initialized ) { wolf_mutex_init( &mutex ); mutex_initialized = true; } wolf_mutex_lock( &mutex ); +#endif msg = strerror( num ); /* TODO: can we detect illegal error numbers? For sure on Linux NULL @@ -73,13 +77,17 @@ int wolf_port_strerror_r( int num, char *buf, size_t buflen ) { /* Linux returns an empty string in this case, why? */ (void)snprintf( buf, buflen, "Unknown error %d", num ); errno = EINVAL; +#ifdef HAVE_THREADS wolf_mutex_unlock( &mutex ); +#endif return -1; } strncpy( buf, msg, buflen-1 ); errno = safe_errno; +#ifdef HAVE_THREADS wolf_mutex_unlock( &mutex ); +#endif return 0; } -- cgit v1.2.3-54-g00ecf