diff options
| -rw-r--r-- | src/thread/call_once.c | 8 | ||||
| -rw-r--r-- | src/thread/pthread_getspecific.c | 2 | ||||
| -rw-r--r-- | src/thread/tss_create.c | 11 | ||||
| -rw-r--r-- | src/thread/tss_delete.c | 8 | ||||
| -rw-r--r-- | src/thread/tss_set.c | 13 | 
5 files changed, 42 insertions, 0 deletions
diff --git a/src/thread/call_once.c b/src/thread/call_once.c new file mode 100644 index 00000000..a7bc9353 --- /dev/null +++ b/src/thread/call_once.c @@ -0,0 +1,8 @@ +#include <threads.h> + +int __pthread_once(once_flag *, void (*)(void)); + +void call_once(once_flag *flag, void (*func)(void)) +{ +	__pthread_once(flag, func); +} diff --git a/src/thread/pthread_getspecific.c b/src/thread/pthread_getspecific.c index d3d09fa2..d9342a56 100644 --- a/src/thread/pthread_getspecific.c +++ b/src/thread/pthread_getspecific.c @@ -1,4 +1,5 @@  #include "pthread_impl.h" +#include <threads.h>  static void *__pthread_getspecific(pthread_key_t k)  { @@ -7,3 +8,4 @@ static void *__pthread_getspecific(pthread_key_t k)  }  weak_alias(__pthread_getspecific, pthread_getspecific); +weak_alias(__pthread_getspecific, tss_get); diff --git a/src/thread/tss_create.c b/src/thread/tss_create.c new file mode 100644 index 00000000..251d22b9 --- /dev/null +++ b/src/thread/tss_create.c @@ -0,0 +1,11 @@ +#include <threads.h> + +int __pthread_key_create(tss_t *, void (*)(void *)); + +int tss_create(tss_t *tss, tss_dtor_t dtor) +{ +	/* Different error returns are possible. C glues them together into +	 * just failure notification. Can't be optimized to a tail call, +	 * unless thrd_error equals EAGAIN. */ +	return __pthread_key_create(tss, dtor) ? thrd_error : thrd_success; +} diff --git a/src/thread/tss_delete.c b/src/thread/tss_delete.c new file mode 100644 index 00000000..35db1032 --- /dev/null +++ b/src/thread/tss_delete.c @@ -0,0 +1,8 @@ +#include <threads.h> + +int __pthread_key_delete(tss_t k); + +void tss_delete(tss_t key) +{ +	__pthread_key_delete(key); +} diff --git a/src/thread/tss_set.c b/src/thread/tss_set.c new file mode 100644 index 00000000..70c4fb72 --- /dev/null +++ b/src/thread/tss_set.c @@ -0,0 +1,13 @@ +#include "pthread_impl.h" +#include <threads.h> + +int tss_set(tss_t k, void *x) +{ +	struct pthread *self = __pthread_self(); +	/* Avoid unnecessary COW */ +	if (self->tsd[k] != x) { +		self->tsd[k] = x; +		self->tsd_used = 1; +	} +	return thrd_success; +}  | 
