summary refs log tree commit diff
path: root/linuxthreads/bug-sleep.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2002-07-10 20:50:46 +0000
committerUlrich Drepper <drepper@redhat.com>2002-07-10 20:50:46 +0000
commitf4741da2e730191150e4394237716fb29d61845c (patch)
treeb9059f021264b4165202db41a9513ff02bd321da /linuxthreads/bug-sleep.c
parentd880edc43c82a7a9c9b50c3ad932a9bff35a7e39 (diff)
downloadglibc-f4741da2e730191150e4394237716fb29d61845c.tar.gz
glibc-f4741da2e730191150e4394237716fb29d61845c.tar.xz
glibc-f4741da2e730191150e4394237716fb29d61845c.zip
Update.
	* bug-sleep.c: New file.
	* Makefile (tests): Add bug-sleep.
Diffstat (limited to 'linuxthreads/bug-sleep.c')
-rw-r--r--linuxthreads/bug-sleep.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/linuxthreads/bug-sleep.c b/linuxthreads/bug-sleep.c
new file mode 100644
index 0000000000..f29a6b73c0
--- /dev/null
+++ b/linuxthreads/bug-sleep.c
@@ -0,0 +1,34 @@
+/* PR libc/4005 */
+#include <pthread.h>
+#include <stdio.h>
+#include <unistd.h>
+#include <time.h>
+
+void *
+run_thread (void *a)
+{
+  while (1)
+    {
+      sleep (10);
+    }
+  return 0;
+}
+
+int
+main (void)
+{
+  pthread_t thr;
+  void *result;
+  alarm (4);
+  printf ("Starting thread.\n");
+  pthread_create (&thr, 0, run_thread, 0);
+  sleep (2);
+  printf ("Canceling thread.\n");
+  pthread_cancel (thr);
+  pthread_join (thr, &result);
+  if (result == PTHREAD_CANCELED)
+    printf ("Thread canceled.\n");
+  else
+    printf ("Thread exited.\n");
+  return 0;
+}