summaryrefslogtreecommitdiffstats
path: root/mdk-stage1/dietlibc/libpthread/pthread_key.c
diff options
context:
space:
mode:
authorMystery Man <unknown@mandriva.org>2003-05-06 13:11:49 +0000
committerMystery Man <unknown@mandriva.org>2003-05-06 13:11:49 +0000
commit3f5d21d90abbd16f16ab69aec1e1a1853a93fd18 (patch)
tree3d9f5a32303a8d97b4b457949e64bb42b4850ea9 /mdk-stage1/dietlibc/libpthread/pthread_key.c
parent327bd24f8e4291bd1882de1990dd7339f781a9cb (diff)
downloaddrakx-backup-do-not-use-3f5d21d90abbd16f16ab69aec1e1a1853a93fd18.tar
drakx-backup-do-not-use-3f5d21d90abbd16f16ab69aec1e1a1853a93fd18.tar.gz
drakx-backup-do-not-use-3f5d21d90abbd16f16ab69aec1e1a1853a93fd18.tar.bz2
drakx-backup-do-not-use-3f5d21d90abbd16f16ab69aec1e1a1853a93fd18.tar.xz
drakx-backup-do-not-use-3f5d21d90abbd16f16ab69aec1e1a1853a93fd18.zip
This commit was manufactured by cvs2svn to create tag 'R9_0-AMD64'.R9_0-AMD64
Diffstat (limited to 'mdk-stage1/dietlibc/libpthread/pthread_key.c')
-rw-r--r--mdk-stage1/dietlibc/libpthread/pthread_key.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/mdk-stage1/dietlibc/libpthread/pthread_key.c b/mdk-stage1/dietlibc/libpthread/pthread_key.c
new file mode 100644
index 000000000..8a77f281a
--- /dev/null
+++ b/mdk-stage1/dietlibc/libpthread/pthread_key.c
@@ -0,0 +1,48 @@
+#include <unistd.h>
+#include <errno.h>
+
+#include <pthread.h>
+#include "thread_internal.h"
+
+struct _pthread_fastlock __thread_keys_lock;
+struct _thread_key __thread_keys[PTHREAD_KEYS_MAX];
+
+void __thread_start__key(int id);
+void __thread_exit__key(int id);
+
+void __thread_start__key(int id)
+{
+ int i;
+
+ if (id<2) return;
+
+ __NO_ASYNC_CANCEL_BEGIN;
+ __pthread_lock(&__thread_keys_lock);
+
+ for (i=0; i<PTHREAD_KEYS_MAX; i++) {
+ __thread_keys[i].tkd[id]=0;
+ }
+
+ __pthread_unlock(&__thread_keys_lock);
+ __NO_ASYNC_CANCEL_END;
+}
+
+void __thread_exit__key(int id)
+{
+ int i,try;
+
+ if (id<2) return;
+
+ __NO_ASYNC_CANCEL_BEGIN;
+// __pthread_lock(&__thread_keys_lock);
+
+ for (i=0; i<PTHREAD_KEYS_MAX; i++) {
+ if ((__thread_keys[i].used) && (__thread_keys[i].destructor)) {
+ for (try=0;__thread_keys[i].tkd[id] && (try<PTHREAD_DESTRUCTOR_ITERATIONS);++try)
+ __thread_keys[i].destructor(__thread_keys[i].tkd[id]);
+ }
+ }
+
+// __pthread_unlock(&__thread_keys_lock);
+ __NO_ASYNC_CANCEL_STOP;
+}