Update.
authorUlrich Drepper <drepper@redhat.com>
Wed, 10 Jul 2002 20:50:46 +0000 (20:50 +0000)
committerUlrich Drepper <drepper@redhat.com>
Wed, 10 Jul 2002 20:50:46 +0000 (20:50 +0000)
* bug-sleep.c: New file.
* Makefile (tests): Add bug-sleep.

linuxthreads/ChangeLog
linuxthreads/Makefile
linuxthreads/bug-sleep.c [new file with mode: 0644]

index 6430132..de23984 100644 (file)
@@ -2,6 +2,8 @@
 
        * wrapsyscall.c: Add __nanosleep alias.
        * Versions (GLIBC_2.2.6): Add __nanosleep.
+       * bug-sleep.c: New file.
+       * Makefile (tests): Add bug-sleep.
 
 2002-06-19  Steven Munroe  <sjmunroe@vnet.ibm.com>
 
index 4143284..a44b9bb 100644 (file)
@@ -60,7 +60,7 @@ endif
 librt-tests = ex10 ex11
 tests = ex1 ex2 ex3 ex4 ex5 ex6 ex7 ex8 ex9 $(librt-tests) ex12 ex13 joinrace \
        tststack $(tests-nodelete-$(have-z-nodelete)) ecmutex ex14 ex15 ex16 \
-       ex17 ex18 tst-cancel tst-context
+       ex17 ex18 tst-cancel tst-context bug-sleep
 test-srcs = tst-signal
 
 ifeq (yes,$(build-shared))
diff --git a/linuxthreads/bug-sleep.c b/linuxthreads/bug-sleep.c
new file mode 100644 (file)
index 0000000..f29a6b7
--- /dev/null
@@ -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;
+}