diff options
author | Ulrich Drepper <drepper@redhat.com> | 2003-02-27 04:42:04 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2003-02-27 04:42:04 +0000 |
commit | 695799feb3e640323ec86b469517f87ca16e99ff (patch) | |
tree | a2a6a206ca9a4986bd5dd584cf60d8b2356a67ab /nptl/tst-dlsym1.c | |
parent | b1531183c5796e3be5aa193e294970ec3fac7d30 (diff) | |
download | glibc-695799feb3e640323ec86b469517f87ca16e99ff.tar.gz |
Update.
* Makefile (tests): Add tst-dlsym1.
* tst-dlsym1.c: New file.
Diffstat (limited to 'nptl/tst-dlsym1.c')
-rw-r--r-- | nptl/tst-dlsym1.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/nptl/tst-dlsym1.c b/nptl/tst-dlsym1.c new file mode 100644 index 0000000000..3744570c7f --- /dev/null +++ b/nptl/tst-dlsym1.c @@ -0,0 +1,66 @@ +/* Test case by Hui Huang <hui.huang@sun.com>. */ +#include <dlfcn.h> +#include <pthread.h> +#include <stdio.h> +#include <stdlib.h> + + +static void * +start_routine (void *args) +{ + int i; + void **addrs = (void **) args; + for (i = 0; i < 10000; ++i) + addrs[i % 1024] = dlsym (NULL, "does_not_exist"); + + return addrs; +} + + +static int +do_test (void) +{ + pthread_t tid1, tid2, tid3; + + void *addrs1[1024]; + void *addrs2[1024]; + void *addrs3[1024]; + + if (pthread_create (&tid1, NULL, start_routine, addrs1) != 0) + { + puts ("1st create failed"); + exit (1); + } + if (pthread_create (&tid2, NULL, start_routine, addrs2) != 0) + { + puts ("2nd create failed"); + exit (1); + } + if (pthread_create (&tid3, NULL, start_routine, addrs3) != 0) + { + puts ("3rd create failed"); + exit (1); + } + + if (pthread_join (tid1, NULL) != 0) + { + puts ("1st join failed"); + exit (1); + } + if (pthread_join (tid2, NULL) != 0) + { + puts ("2nd join failed"); + exit (1); + } + if (pthread_join (tid3, NULL) != 0) + { + puts ("2rd join failed"); + exit (1); + } + + return 0; +} + + +#define TEST_FUNCTION do_test () +#include "../test-skeleton.c" |