From ece70a1400120c0e5678815423b62770be85bc62 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Tue, 7 Nov 2000 16:49:35 +0000 Subject: Update. 2000-11-07 Kazumoto Kojima * sysdeps/sh/bits/setjmp.h: Move to... * sysdeps/sh/sh4/bits/setjmp.h: ...here. * sysdeps/sh/sh3/bits/setjmp.h: New file. --- linuxthreads/cancel.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'linuxthreads') 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 -- cgit v1.1