diff options
| author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-08-01 02:00:19 +0200 |
|---|---|---|
| committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-08-01 02:00:19 +0200 |
| commit | e54ae7d1bdfc689a0dc60438f7d3aa5cf68b4560 (patch) | |
| tree | 6fba55f1c8392af93bdbbe8f54f51fd84e28cd03 /libpthread/tests/test-7.c | |
| parent | 91beae771a8a09b59376f2f52212771c390ab14a (diff) | |
| parent | d3c289d5867fefd5340328b7bd8cec32ca726d92 (diff) | |
Merge commit 'upstream/20090404'
Diffstat (limited to 'libpthread/tests/test-7.c')
| -rw-r--r-- | libpthread/tests/test-7.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/libpthread/tests/test-7.c b/libpthread/tests/test-7.c new file mode 100644 index 00000000..bd97acfa --- /dev/null +++ b/libpthread/tests/test-7.c @@ -0,0 +1,66 @@ +#define _GNU_SOURCE + +#include <pthread.h> +#include <stdio.h> +#include <error.h> +#include <errno.h> + +#define THREADS 10 +#define KEYS 400 + +pthread_key_t key[KEYS]; + +void * +thr (void *arg) +{ + error_t err; + int i; + + for (i = 0; i < KEYS; i ++) + { + printf ("pthread_getspecific(%d).\n", key[i]); + assert (pthread_getspecific (key[i]) == NULL); + printf ("pthread_setspecific(%d, %d).\n", key[i], pthread_self ()); + err = pthread_setspecific (key[i], (void *) pthread_self ()); + printf ("pthread_setspecific(%d, %d) => %d.\n", key[i], pthread_self (), err); + assert_perror (err); + } + + return 0; +} + +int +main (int argc, char **argv) +{ + error_t err; + int i; + pthread_t tid[THREADS]; + + void des (void *val) + { + assert ((pthread_t) val == pthread_self ()); + } + + for (i = 0; i < KEYS; i ++) + err = pthread_key_create (&key[i], des); + + for (i = 0; i < THREADS; i ++) + { + err = pthread_create (&tid[i], 0, thr, 0); + if (err) + error (1, err, "pthread_create (%d)", i); + } + + for (i = 0; i < THREADS; i ++) + { + void *ret; + + err = pthread_join (tid[i], &ret); + if (err) + error (1, err, "pthread_join"); + + assert (ret == 0); + } + + return 0; +} |
