summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAndreas Baumann <abaumann@yahoo.com>2011-10-31 19:54:01 +0100
committerAndreas Baumann <abaumann@yahoo.com>2011-10-31 19:54:01 +0100
commitd725022844380852476dbef00d7dc3c2e7a37fdb (patch)
tree7df0f711e45b5b7a737d82ef2fcdabf1d2d168fd /src
parent780a04f1961d766f524386eb9c58574738fbfbb3 (diff)
downloadwolfbones-d725022844380852476dbef00d7dc3c2e7a37fdb.tar.gz
wolfbones-d725022844380852476dbef00d7dc3c2e7a37fdb.tar.bz2
added a HAVE_THREADS flag
Diffstat (limited to 'src')
-rw-r--r--src/GNUmakefile5
-rw-r--r--src/port/netdb.c8
-rw-r--r--src/port/string.c8
3 files changed, 20 insertions, 1 deletions
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 <errno.h> /* 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 <errno.h> /* 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;
}