diff options
author | rpj <rpj> | 2001-07-05 15:19:22 +0000 |
---|---|---|
committer | rpj <rpj> | 2001-07-05 15:19:22 +0000 |
commit | ec27b9c8303540de6b5a8ebefee114f3cdd436f0 (patch) | |
tree | 965ddfd011b9deb0091d2930fd55ce250c54ed58 /tests/barrier4.c | |
parent | 99e8ecc5759668fd3af379eaddd70b4ae50ecd7f (diff) |
* barrier.c: Remove static initialisation - irrelevent
for this object.
* pthread.h (PTHREAD_BARRIER_INITIALIZER): Removed.
* rwlock.c (pthread_rwlock_wrlock): This routine is
not a cancelation point - disable deferred
cancelation around call to pthread_cond_wait().
tests/ChangeLog:
* spin1.c: New; testing spinlocks.
* spin2.c: New; testing spinlocks.
* spin3.c: New; testing spinlocks.
* spin4.c: New; testing spinlocks.
* barrier1.c: New; testing barriers.
* barrier2.c: New; testing barriers.
* barrier3.c: New; testing barriers.
* barrier4.c: New; testing barriers.
* GNUmakefile: Add new tests.
* Makefile: Add new tests.
Diffstat (limited to 'tests/barrier4.c')
-rw-r--r-- | tests/barrier4.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/tests/barrier4.c b/tests/barrier4.c new file mode 100644 index 0000000..1dd8291 --- /dev/null +++ b/tests/barrier4.c @@ -0,0 +1,64 @@ +/* + * barrier4.c + * + * Declare a single barrier object, multiple wait on it, + * and then destroy it. + * + */ + +#include "test.h" + +enum { + NUMTHREADS = 16 +}; + +pthread_barrier_t barrier = NULL; +pthread_mutex_t mx = PTHREAD_MUTEX_INITIALIZER; +static int result1 = -1; +static int result2 = -1; +static int serialThreadCount = 0; +static int otherThreadCount = 0; + +void * func(void * arg) +{ + int result = pthread_barrier_wait(&barrier); + + assert(pthread_mutex_lock(&mx) == 0); + if (result == PTHREAD_BARRIER_SERIAL_THREAD) + { + serialThreadCount++; + } + else + { + otherThreadCount++; + } + assert(pthread_mutex_lock(&mx) == 0); + + return NULL; +} + +int +main() +{ + pthread_t t[NUMTHREADS + 1]; + + assert(pthread_barrier_init(&barrier, NULL, NUMTHREADS) == 0); + + for (i = 0; i < NUMTHREADS; i++) + { + assert(pthread_create(&t[i], NULL, func, NULL) == 0); + } + + for (i = 0; i < NUMTHREADS; i++) + { + assert(pthread_join(t[i], NULL) == 0); + } + + assert(serialThreadCount == 1); + + assert(pthread_barrier_destroy(&barrier) == 0); + + assert(pthread_mutex_destroy(&mx) == 0); + + return 0; +} |