diff options
author | Ulrich Drepper <drepper@redhat.com> | 2010-07-02 07:08:07 -0700 |
---|---|---|
committer | Andreas Schwab <schwab@redhat.com> | 2010-12-01 15:35:21 +0100 |
commit | dcb52a4a9c67c5e4a26688e599dcb33b40eb14a4 (patch) | |
tree | 791772da8dbfdda2c19299091d2591e5bcc02480 | |
parent | 66c60fc87d9f291d9283bec674ab9fa01e21483d (diff) | |
download | glibc-dcb52a4a9c67c5e4a26688e599dcb33b40eb14a4.zip glibc-dcb52a4a9c67c5e4a26688e599dcb33b40eb14a4.tar.gz glibc-dcb52a4a9c67c5e4a26688e599dcb33b40eb14a4.tar.bz2 |
Improve new tst-abstime test.
(cherry picked from commit 145569dc4130d102363e17c7322e250310cbc397)
-rw-r--r-- | nptl/ChangeLog | 4 | ||||
-rw-r--r-- | nptl/tst-abstime.c | 57 |
2 files changed, 47 insertions, 14 deletions
diff --git a/nptl/ChangeLog b/nptl/ChangeLog index 0e363e4..a68edb3 100644 --- a/nptl/ChangeLog +++ b/nptl/ChangeLog @@ -1,3 +1,7 @@ +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/tst-abstime.c b/nptl/tst-abstime.c index 73105f7..eb8e8ac 100644 --- a/nptl/tst-abstime.c +++ b/nptl/tst-abstime.c @@ -17,47 +17,76 @@ 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); 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); } |