aboutsummaryrefslogtreecommitdiff
path: root/linuxthreads/cancel.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-11-07 16:49:35 +0000
committerUlrich Drepper <drepper@redhat.com>2000-11-07 16:49:35 +0000
commitece70a1400120c0e5678815423b62770be85bc62 (patch)
tree58401c1e15f97c3da083f837e64f59e6460ab4a9 /linuxthreads/cancel.c
parent632b6761c348150e018c42ee06265794668d9180 (diff)
downloadglibc-ece70a1400120c0e5678815423b62770be85bc62.zip
glibc-ece70a1400120c0e5678815423b62770be85bc62.tar.gz
glibc-ece70a1400120c0e5678815423b62770be85bc62.tar.bz2
Update.
2000-11-07 Kazumoto Kojima <kkojima@rr.iij4u.or.jp> * sysdeps/sh/bits/setjmp.h: Move to... * sysdeps/sh/sh4/bits/setjmp.h: ...here. * sysdeps/sh/sh3/bits/setjmp.h: New file.
Diffstat (limited to 'linuxthreads/cancel.c')
-rw-r--r--linuxthreads/cancel.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/linuxthreads/cancel.c b/linuxthreads/cancel.c
index 40f9db5..b05d8bf 100644
--- a/linuxthreads/cancel.c
+++ b/linuxthreads/cancel.c
@@ -55,6 +55,7 @@ int pthread_cancel(pthread_t thread)
int dorestart = 0;
pthread_descr th;
pthread_extricate_if *pextricate;
+ int already_canceled;
__pthread_lock(&handle->h_lock, NULL);
if (invalid_handle(handle, thread)) {
@@ -64,14 +65,15 @@ int pthread_cancel(pthread_t thread)
th = handle->h_descr;
- if (th->p_cancelstate == PTHREAD_CANCEL_DISABLE || th->p_canceled) {
- th->p_canceled = 1;
+ already_canceled = th->p_canceled;
+ th->p_canceled = 1;
+
+ if (th->p_cancelstate == PTHREAD_CANCEL_DISABLE || already_canceled) {
__pthread_unlock(&handle->h_lock);
return 0;
}
pextricate = th->p_extricate;
- th->p_canceled = 1;
pid = th->p_pid;
/* If the thread has registered an extrication interface, then