diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2011-11-06 13:25:27 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2011-11-06 13:25:27 +0100 |
commit | 8f34bd6d8695f68dfaeeb7a72c812db67aa90bbf (patch) | |
tree | f5293c830540b1444a68ad4c86ef172ba4c187bc /libpthread/sysdeps/hurd/pt-key-delete.c | |
parent | 873332500bcc7a705566d0338b117d3df86aac05 (diff) | |
parent | e4de8df465f6c984fc1ac337167499cca7700f63 (diff) |
Merge branch 'libpthread-moved' into upstream-merged
Diffstat (limited to 'libpthread/sysdeps/hurd/pt-key-delete.c')
-rw-r--r-- | libpthread/sysdeps/hurd/pt-key-delete.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libpthread/sysdeps/hurd/pt-key-delete.c b/libpthread/sysdeps/hurd/pt-key-delete.c index 2426bb11..9d88647e 100644 --- a/libpthread/sysdeps/hurd/pt-key-delete.c +++ b/libpthread/sysdeps/hurd/pt-key-delete.c @@ -35,8 +35,27 @@ pthread_key_delete (pthread_key_t key) err = EINVAL; else { + int i; + __pthread_key_destructors[key] = PTHREAD_KEY_INVALID; __pthread_key_invalid_count ++; + + pthread_rwlock_rdlock (&__pthread_threads_lock); + for (i = 0; i < __pthread_num_threads; ++i) + { + struct __pthread *t; + + t = __pthread_threads[i]; + + if (t == NULL) + continue; + + /* Just remove the key, no need to care whether it was + already there. */ + if (t->thread_specifics) + hurd_ihash_remove (t->thread_specifics, key); + } + pthread_rwlock_unlock (&__pthread_threads_lock); } __pthread_mutex_unlock (&__pthread_key_lock); |