summaryrefslogtreecommitdiff
path: root/nptl/tst-dlsym1.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2003-02-27 04:42:04 +0000
committerUlrich Drepper <drepper@redhat.com>2003-02-27 04:42:04 +0000
commit695799feb3e640323ec86b469517f87ca16e99ff (patch)
treea2a6a206ca9a4986bd5dd584cf60d8b2356a67ab /nptl/tst-dlsym1.c
parentb1531183c5796e3be5aa193e294970ec3fac7d30 (diff)
downloadglibc-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.c66
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"