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-3.c | |
| parent | 91beae771a8a09b59376f2f52212771c390ab14a (diff) | |
| parent | d3c289d5867fefd5340328b7bd8cec32ca726d92 (diff) | |
Merge commit 'upstream/20090404'
Diffstat (limited to 'libpthread/tests/test-3.c')
| -rw-r--r-- | libpthread/tests/test-3.c | 55 |
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; +} |
