summaryrefslogtreecommitdiff
path: root/libpthread/tests/test-1.c
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2010-08-01 01:52:54 +0200
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2010-08-01 01:52:54 +0200
commitd3c289d5867fefd5340328b7bd8cec32ca726d92 (patch)
treeabd01dcff720ad69b0d5c105b4ea78b9fb9a9db5 /libpthread/tests/test-1.c
parent5b293b7099ab66c8c60529655df513ce2e640c3c (diff)
parent68567b88ee8f9e395e0c1f0a565affe8a1d4d68b (diff)
Merge tag 'upstream/libpthread/20090404' into upstream-merged
Diffstat (limited to 'libpthread/tests/test-1.c')
-rw-r--r--libpthread/tests/test-1.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/libpthread/tests/test-1.c b/libpthread/tests/test-1.c
new file mode 100644
index 00000000..318fd6e9
--- /dev/null
+++ b/libpthread/tests/test-1.c
@@ -0,0 +1,49 @@
+#define _GNU_SOURCE
+
+#include <pthread.h>
+#include <unistd.h>
+#include <error.h>
+#include <errno.h>
+#include <stdio.h>
+
+#define THREADS 500
+
+void *
+foo (void *arg)
+{
+ pthread_mutex_t *mutex = arg;
+ pthread_mutex_lock (mutex);
+ pthread_mutex_unlock (mutex);
+ return mutex;
+}
+
+int
+main (int argc, char **argv)
+{
+ int i;
+ error_t err;
+ pthread_t tid[THREADS];
+ pthread_mutex_t mutex[THREADS];
+
+ for (i = 0; i < THREADS; i ++)
+ {
+ pthread_mutex_init (&mutex[i], 0);
+ pthread_mutex_lock (&mutex[i]);
+ err = pthread_create (&tid[i], 0, foo, &mutex[i]);
+ if (err)
+ error (1, err, "pthread_create");
+ sched_yield ();
+ }
+
+ for (i = THREADS - 1; i >= 0; i --)
+ {
+ void *ret;
+ pthread_mutex_unlock (&mutex[i]);
+ err = pthread_join (tid[i], &ret);
+ if (err)
+ error (1, err, "pthread_join");
+ assert (ret == &mutex[i]);
+ }
+
+ return 0;
+}