summaryrefslogtreecommitdiff
path: root/libpthread/tests/test-3.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-3.c
parent5b293b7099ab66c8c60529655df513ce2e640c3c (diff)
parent68567b88ee8f9e395e0c1f0a565affe8a1d4d68b (diff)
Merge tag 'upstream/libpthread/20090404' into upstream-merged
Diffstat (limited to 'libpthread/tests/test-3.c')
-rw-r--r--libpthread/tests/test-3.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/libpthread/tests/test-3.c b/libpthread/tests/test-3.c
new file mode 100644
index 00000000..7db2e43f
--- /dev/null
+++ b/libpthread/tests/test-3.c
@@ -0,0 +1,55 @@
+/* Test the thread attribute get and set methods. */
+
+#define _GNU_SOURCE
+
+#include <pthread.h>
+#include <sched.h>
+#include <assert.h>
+#include <errno.h>
+
+int
+main (int argc, char *argv[])
+{
+ error_t err;
+ pthread_attr_t attr;
+
+ int i;
+ struct sched_param sp;
+ void *p;
+ size_t sz;
+
+ err = pthread_attr_init (&attr);
+ assert_perror (err);
+
+ err = pthread_attr_destroy (&attr);
+ assert_perror (err);
+
+ err = pthread_attr_init (&attr);
+ assert_perror (err);
+
+#define TEST1(foo, rv, v) \
+ err = pthread_attr_get##foo (&attr, rv); \
+ assert_perror (err); \
+ \
+ err = pthread_attr_set##foo (&attr, v); \
+ assert_perror (err);
+
+#define TEST(foo, rv, v) TEST1(foo, rv, v)
+
+ TEST(inheritsched, &i, i);
+ TEST(schedparam, &sp, &sp);
+ TEST(schedpolicy, &i, i);
+ TEST(scope, &i, i);
+ TEST(stackaddr, &p, p);
+ TEST(detachstate, &i, i);
+ TEST(guardsize, &sz, sz);
+ TEST(stacksize, &sz, sz);
+
+ err = pthread_attr_getstack (&attr, &p, &sz);
+ assert_perror (err);
+
+ err = pthread_attr_setstack (&attr, p, sz);
+ assert_perror (err);
+
+ return 0;
+}