diff options
author | Ulrich Drepper <drepper@redhat.com> | 2002-07-10 20:50:46 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2002-07-10 20:50:46 +0000 |
commit | f4741da2e730191150e4394237716fb29d61845c (patch) | |
tree | b9059f021264b4165202db41a9513ff02bd321da /linuxthreads/bug-sleep.c | |
parent | d880edc43c82a7a9c9b50c3ad932a9bff35a7e39 (diff) | |
download | glibc-f4741da2e730191150e4394237716fb29d61845c.tar.gz |
Update.
* bug-sleep.c: New file.
* Makefile (tests): Add bug-sleep.
Diffstat (limited to 'linuxthreads/bug-sleep.c')
-rw-r--r-- | linuxthreads/bug-sleep.c | 34 |
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; +} |