diff options
author | Thomas Pfaff <tpfaff@gmx.net> | 2003-04-08 18:29:37 +0000 |
---|---|---|
committer | Thomas Pfaff <tpfaff@gmx.net> | 2003-04-08 18:29:37 +0000 |
commit | e3501c78cad9d0a94e9004d4cfc40fe3c783549f (patch) | |
tree | ec8813aee63d042f021631a14abe767d75774a6d /winsup/testsuite | |
parent | 29d0fe3f748c5a2d26a3fe3e3fe925ca94ff02e2 (diff) | |
download | newlib-e3501c78cad9d0a94e9004d4cfc40fe3c783549f.zip newlib-e3501c78cad9d0a94e9004d4cfc40fe3c783549f.tar.gz newlib-e3501c78cad9d0a94e9004d4cfc40fe3c783549f.tar.bz2 |
* winsup.api/pthread/condvar9.c: Fix test.
Diffstat (limited to 'winsup/testsuite')
-rw-r--r-- | winsup/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | winsup/testsuite/winsup.api/pthread/condvar9.c | 27 |
2 files changed, 20 insertions, 11 deletions
diff --git a/winsup/testsuite/ChangeLog b/winsup/testsuite/ChangeLog index 3a5eadf..eb30680 100644 --- a/winsup/testsuite/ChangeLog +++ b/winsup/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2003-04-08 Thomas Pfaff <tpfaff@gmx.net> + + * winsup.api/pthread/condvar9.c: Fix test. + 2003-03-27 Thomas Pfaff <tpfaff@gmx.net> * winsup.api/pthread/rwlock1.c: Remove pthreads-win32 header. diff --git a/winsup/testsuite/winsup.api/pthread/condvar9.c b/winsup/testsuite/winsup.api/pthread/condvar9.c index 04b8d32..2945562 100644 --- a/winsup/testsuite/winsup.api/pthread/condvar9.c +++ b/winsup/testsuite/winsup.api/pthread/condvar9.c @@ -18,7 +18,7 @@ * - * * Description: - * - Make NUMTHREADS threads wait on CV, cancel one, broadcast signal them, + * - Make NUMTHREADS threads wait on CV, broadcast signal them, cancel them * and then repeat. * * Environment: @@ -79,6 +79,7 @@ static pthread_mutex_t start_flag = PTHREAD_MUTEX_INITIALIZER; static struct timespec abstime = { 0, 0 }; static int awoken; +static int not_canceled; static void * mythread(void * arg) @@ -107,14 +108,18 @@ mythread(void * arg) while (! (cvthing.shared > 0)) assert(pthread_cond_timedwait(&cvthing.notbusy, &cvthing.lock, &abstime) == 0); + assert(cvthing.shared > 0); + + awoken++; + + pthread_testcancel(); + pthread_cleanup_pop(0); #ifdef _MSC_VER #pragma inline_depth() #endif - assert(cvthing.shared > 0); - - awoken++; + not_canceled++; assert(pthread_mutex_unlock(&cvthing.lock) == 0); @@ -127,7 +132,6 @@ main() int failed = 0; int i; int first, last; - int canceledThreads = 0; pthread_t t[NUMTHREADS + 1]; struct timeb currSysTime; const DWORD NANOSEC_PER_MILLISEC = 1000000; @@ -149,6 +153,7 @@ main() assert((t[0] = pthread_self()) != NULL); awoken = 0; + not_canceled = 0; for (first = 1, last = NUMTHREADS / 2; first < NUMTHREADS; @@ -180,12 +185,11 @@ main() cvthing.shared++; - assert(pthread_mutex_unlock(&cvthing.lock) == 0); - - assert(pthread_cancel(t[(first + last) / 2]) == 0); - canceledThreads++; - assert(pthread_cond_broadcast(&cvthing.notbusy) == 0); + for (i = first; i <= last; i++) + assert(pthread_cancel(t[i]) == 0); + + assert(pthread_mutex_unlock(&cvthing.lock) == 0); /* * Give threads time to complete. @@ -225,7 +229,8 @@ main() * Check any results here. */ - assert(awoken == NUMTHREADS - canceledThreads); + assert(awoken == NUMTHREADS); + assert(not_canceled == 0); /* * Success. |