aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--nptl/ChangeLog3
-rw-r--r--nptl/tst-attr1.c120
2 files changed, 123 insertions, 0 deletions
diff --git a/nptl/ChangeLog b/nptl/ChangeLog
index 1fb37806e1..654c46264a 100644
--- a/nptl/ChangeLog
+++ b/nptl/ChangeLog
@@ -1,5 +1,8 @@
2003-02-16 Ulrich Drepper <drepper@redhat.com>
+ * tst-attr1.c (do_test): Add tests for pthread_setcanceltype,
+ pthread_setcancelstate, and pthread_rwlock_setpshared.
+
* tst-cancel7.c (do_test): Make sure the pid file exists before
canceling the thread.
diff --git a/nptl/tst-attr1.c b/nptl/tst-attr1.c
index c5870beb5b..13b62a69de 100644
--- a/nptl/tst-attr1.c
+++ b/nptl/tst-attr1.c
@@ -17,6 +17,7 @@
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
+#include <errno.h>
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
@@ -43,6 +44,14 @@ do_test (void)
exit (1);
}
+ pthread_rwlockattr_t rwa;
+
+ if (pthread_rwlockattr_init (&rwa) != 0)
+ {
+ puts ("rwlockattr_init failed");
+ exit (1);
+ }
+
/* XXX Remove if default value is clear. */
pthread_attr_setinheritsched (&a, PTHREAD_INHERIT_SCHED);
pthread_attr_setschedpolicy (&a, SCHED_OTHER);
@@ -61,6 +70,11 @@ do_test (void)
printf ("attr_setdetachstate with value %ld succeeded\n", r);
exit (1);
}
+ if (e != EINVAL)
+ {
+ puts ("attr_setdetachstate didn't return EINVAL");
+ exit (1);
+ }
int s;
if (pthread_attr_getdetachstate (&a, &s) != 0)
@@ -86,6 +100,11 @@ detach state changed to %d by invalid setdetachstate call\n", s);
printf ("attr_setinheritsched with value %ld succeeded\n", r);
exit (1);
}
+ if (e != EINVAL)
+ {
+ puts ("attr_setinheritsched didn't return EINVAL");
+ exit (1);
+ }
int s;
if (pthread_attr_getinheritsched (&a, &s) != 0)
@@ -111,6 +130,11 @@ inheritsched changed to %d by invalid setinheritsched call\n", s);
printf ("attr_setschedpolicy with value %ld succeeded\n", r);
exit (1);
}
+ if (e != EINVAL)
+ {
+ puts ("attr_setschedpolicy didn't return EINVAL");
+ exit (1);
+ }
int s;
if (pthread_attr_getschedpolicy (&a, &s) != 0)
@@ -136,6 +160,11 @@ schedpolicy changed to %d by invalid setschedpolicy call\n", s);
printf ("attr_setscope with value %ld succeeded\n", r);
exit (1);
}
+ if (e != EINVAL)
+ {
+ puts ("attr_setscope didn't return EINVAL");
+ exit (1);
+ }
int s;
if (pthread_attr_getscope (&a, &s) != 0)
@@ -161,6 +190,11 @@ contentionscope changed to %d by invalid setscope call\n", s);
printf ("mutexattr_setpshared with value %ld succeeded\n", r);
exit (1);
}
+ if (e != EINVAL)
+ {
+ puts ("mutexattr_setpshared didn't return EINVAL");
+ exit (1);
+ }
int s;
if (pthread_mutexattr_getpshared (&ma, &s) != 0)
@@ -175,6 +209,92 @@ contentionscope changed to %d by invalid setscope call\n", s);
pshared changed to %d by invalid mutexattr_setpshared call\n", s);
exit (1);
}
+
+ e = pthread_rwlockattr_setpshared (&rwa, r);
+
+ if (e == 0)
+ {
+ printf ("rwlockattr_setpshared with value %ld succeeded\n", r);
+ exit (1);
+ }
+ if (e != EINVAL)
+ {
+ puts ("rwlockattr_setpshared didn't return EINVAL");
+ exit (1);
+ }
+
+ if (pthread_rwlockattr_getpshared (&rwa, &s) != 0)
+ {
+ puts ("rwlockattr_getpshared failed");
+ exit (1);
+ }
+
+ if (s != PTHREAD_PROCESS_PRIVATE)
+ {
+ printf ("\
+pshared changed to %d by invalid rwlockattr_setpshared call\n", s);
+ exit (1);
+ }
+ }
+
+ if (r != PTHREAD_CANCEL_ENABLE && r != PTHREAD_CANCEL_DISABLE)
+ {
+ int e = pthread_setcancelstate (r, NULL);
+
+ if (e == 0)
+ {
+ printf ("setcancelstate with value %ld succeeded\n", r);
+ exit (1);
+ }
+
+ if (e != EINVAL)
+ {
+ puts ("setcancelstate didn't return EINVAL");
+ exit (1);
+ }
+
+ int s;
+ if (pthread_setcancelstate (PTHREAD_CANCEL_ENABLE, &s) != 0)
+ {
+ puts ("setcancelstate failed for PTHREAD_CANCEL_ENABLE");
+ exit (1);
+ }
+
+ if (s != PTHREAD_CANCEL_ENABLE)
+ {
+ puts ("invalid setcancelstate changed state");
+ exit (1);
+ }
+ }
+
+ if (r != PTHREAD_CANCEL_DEFERRED && r != PTHREAD_CANCEL_ASYNCHRONOUS)
+ {
+ int e = pthread_setcanceltype (r, NULL);
+
+ if (e == 0)
+ {
+ printf ("setcanceltype with value %ld succeeded\n", r);
+ exit (1);
+ }
+
+ if (e != EINVAL)
+ {
+ puts ("setcanceltype didn't return EINVAL");
+ exit (1);
+ }
+
+ int s;
+ if (pthread_setcanceltype (PTHREAD_CANCEL_DEFERRED, &s) != 0)
+ {
+ puts ("setcanceltype failed for PTHREAD_CANCEL_DEFERRED");
+ exit (1);
+ }
+
+ if (s != PTHREAD_CANCEL_DEFERRED)
+ {
+ puts ("invalid setcanceltype changed state");
+ exit (1);
+ }
}
}