diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2011-11-06 13:25:18 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2011-11-06 13:25:18 +0100 |
commit | e4de8df465f6c984fc1ac337167499cca7700f63 (patch) | |
tree | c55601fc2e39971abb3d63aca80140513b242dc6 /libpthread/sysdeps/hurd | |
parent | e5642a3d703a9441efc68c8e05cd5534f867275f (diff) | |
parent | a1a10da44a300bc501582db93280f257b2f87386 (diff) |
Merge branch 'libpthread' into libpthread-moved
Diffstat (limited to 'libpthread/sysdeps/hurd')
-rw-r--r-- | libpthread/sysdeps/hurd/pt-getspecific.c | 4 | ||||
-rw-r--r-- | libpthread/sysdeps/hurd/pt-setspecific.c | 4 |
2 files changed, 7 insertions, 1 deletions
diff --git a/libpthread/sysdeps/hurd/pt-getspecific.c b/libpthread/sysdeps/hurd/pt-getspecific.c index 30605984..71ec63c6 100644 --- a/libpthread/sysdeps/hurd/pt-getspecific.c +++ b/libpthread/sysdeps/hurd/pt-getspecific.c @@ -27,7 +27,9 @@ pthread_getspecific (pthread_key_t key) { struct __pthread *self; - assert (key < __pthread_key_count); + if (key < 0 || key >= __pthread_key_count + || __pthread_key_destructors[key] == PTHREAD_KEY_INVALID) + return NULL; self = _pthread_self (); if (! self->thread_specifics) diff --git a/libpthread/sysdeps/hurd/pt-setspecific.c b/libpthread/sysdeps/hurd/pt-setspecific.c index 89ca4d7f..d0b7302f 100644 --- a/libpthread/sysdeps/hurd/pt-setspecific.c +++ b/libpthread/sysdeps/hurd/pt-setspecific.c @@ -28,6 +28,10 @@ pthread_setspecific (pthread_key_t key, const void *value) error_t err; struct __pthread *self = _pthread_self (); + if (key < 0 || key >= __pthread_key_count + || __pthread_key_destructors[key] == PTHREAD_KEY_INVALID) + return EINVAL; + if (! self->thread_specifics) { err = hurd_ihash_create (&self->thread_specifics, HURD_IHASH_NO_LOCP); |