diff options
author | Andreas Schwab <schwab@redhat.com> | 2010-07-12 11:37:08 +0200 |
---|---|---|
committer | Andreas Schwab <schwab@redhat.com> | 2010-07-12 11:52:23 +0200 |
commit | 23de301fe848f644cb7fab16a4ef8f167156cca8 (patch) | |
tree | eed41a07ae7ac99cf5477c840249b9f262b93b43 /nptl | |
parent | a06f3a382318e4cbc1bec49b923ef1b4f1e2a493 (diff) | |
parent | b08c89d9f36dea19634f6e59cc839f920b827116 (diff) | |
download | glibc-23de301fe848f644cb7fab16a4ef8f167156cca8.tar glibc-23de301fe848f644cb7fab16a4ef8f167156cca8.tar.gz glibc-23de301fe848f644cb7fab16a4ef8f167156cca8.tar.bz2 glibc-23de301fe848f644cb7fab16a4ef8f167156cca8.zip |
Merge remote branch 'origin/master' into fedora/master
Diffstat (limited to 'nptl')
-rw-r--r-- | nptl/ChangeLog | 13 | ||||
-rw-r--r-- | nptl/sysdeps/unix/sysv/linux/pthread_getname.c | 2 | ||||
-rw-r--r-- | nptl/tst-abstime.c | 63 |
3 files changed, 62 insertions, 16 deletions
diff --git a/nptl/ChangeLog b/nptl/ChangeLog index 8a1bef16fa..d4ce128560 100644 --- a/nptl/ChangeLog +++ b/nptl/ChangeLog @@ -1,3 +1,16 @@ +2010-07-06 Andreas Schwab <schwab@redhat.com> + + * sysdeps/unix/sysv/linux/pthread_getname.c (pthread_getname_np): + Fix type mismatch. + +2010-07-03 Ulrich Drepper <drepper@redhat.com> + + * tst-abstime.c (do_test): Some more cleanups + +2010-07-02 Ulrich Drepper <drepper@redhat.com> + + * tst-abstime.c: Correct testing and add test for sem_timedwait. + 2010-07-01 Andreas Schwab <schwab@redhat.com> Ulrich Drepper <drepper@redhat.com> diff --git a/nptl/sysdeps/unix/sysv/linux/pthread_getname.c b/nptl/sysdeps/unix/sysv/linux/pthread_getname.c index 593219b8ff..6e7786f987 100644 --- a/nptl/sysdeps/unix/sysv/linux/pthread_getname.c +++ b/nptl/sysdeps/unix/sysv/linux/pthread_getname.c @@ -42,7 +42,7 @@ pthread_getname_np (th, buf, len) if (len < TASK_COMM_LEN) return ERANGE; - if (th == THREAD_SELF) + if (pd == THREAD_SELF) return prctl (PR_GET_NAME, buf) ? errno : 0; #define FMT "/proc/self/task/%u/comm" diff --git a/nptl/tst-abstime.c b/nptl/tst-abstime.c index 73105f705d..50f35d539d 100644 --- a/nptl/tst-abstime.c +++ b/nptl/tst-abstime.c @@ -17,47 +17,80 @@ Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ -#include <assert.h> #include <errno.h> #include <pthread.h> +#include <semaphore.h> +#include <stdio.h> -pthread_cond_t c = PTHREAD_COND_INITIALIZER; -pthread_mutex_t m1 = PTHREAD_MUTEX_INITIALIZER; -pthread_mutex_t m2 = PTHREAD_MUTEX_INITIALIZER; -pthread_rwlock_t rw1 = PTHREAD_RWLOCK_INITIALIZER; -pthread_rwlock_t rw2 = PTHREAD_RWLOCK_INITIALIZER; +static pthread_cond_t c = PTHREAD_COND_INITIALIZER; +static pthread_mutex_t m1 = PTHREAD_MUTEX_INITIALIZER; +static pthread_mutex_t m2 = PTHREAD_MUTEX_INITIALIZER; +static pthread_rwlock_t rw1 = PTHREAD_RWLOCK_INITIALIZER; +static pthread_rwlock_t rw2 = PTHREAD_RWLOCK_INITIALIZER; +static sem_t sem; static void * th (void *arg) { + long int res = 0; int r; struct timespec t = { -2, 0 }; r = pthread_mutex_timedlock (&m1, &t); - assert (r == ETIMEDOUT); + if (r != ETIMEDOUT) + { + puts ("pthread_mutex_timedlock did not return ETIMEDOUT"); + res = 1; + } r = pthread_rwlock_timedrdlock (&rw1, &t); - assert (r == ETIMEDOUT); + if (r != ETIMEDOUT) + { + puts ("pthread_rwlock_timedrdlock did not return ETIMEDOUT"); + res = 1; + } r = pthread_rwlock_timedwrlock (&rw2, &t); - assert (r == ETIMEDOUT); - return 0; + if (r != ETIMEDOUT) + { + puts ("pthread_rwlock_timedwrlock did not return ETIMEDOUT"); + res = 1; + } + return (void *) res; } -int +static int do_test (void) { + int res = 0; int r; struct timespec t = { -2, 0 }; pthread_t pth; + sem_init (&sem, 0, 0); + r = sem_timedwait (&sem, &t); + if (r != -1 || errno != ETIMEDOUT) + { + puts ("sem_timedwait did not fail with ETIMEDOUT"); + res = 1; + } + pthread_mutex_lock (&m1); pthread_rwlock_wrlock (&rw1); pthread_rwlock_rdlock (&rw2); pthread_mutex_lock (&m2); - pthread_create (&pth, 0, th, 0); + if (pthread_create (&pth, 0, th, 0) != 0) + { + puts ("cannot create thread"); + return 1; + } r = pthread_cond_timedwait (&c, &m2, &t); - assert (r == ETIMEDOUT); - pthread_join (pth, 0); - return 0; + if (r != ETIMEDOUT) + { + puts ("pthread_cond_timedwait did not return ETIMEDOUT"); + res = 1; + } + void *thres; + pthread_join (pth, &thres); + return res | (thres != NULL); } |