1.7.15-1: pthread_cancel and pthread_kill not working as expected

Otto Meta otto.meta@sister-shadow.de
Fri May 18 10:23:00 GMT 2012


Greetings,

as I got no response to my first question, I tried two older Cygwin
versions to narrow down the problem. Maybe thisÂ’ll help someone to
figure out the cause.

I tried 1.7.9 and 1.7.12-1, with the results of 1.7.12-1 being exactly
like the ones from 1.7.14-2 and 1.7.15-1. Unfortunately I couldnÂ’t dig
up any versions between 1.7.9 and 1.7.12-1.

Results from 1.7.12-1 (for semaphores, detailed results in my last mail):
Test 1: Main thread hangs on pthread_cancel() (PTHREAD_CANCEL_DEFERRED)
Test 2: Threads ignore pthread_cancel() (PTHREAD_CANCEL_ASYNCHRONOUS)
Test 3: Signals often wake the wrong thread
Test 4: Wrong thread wakes up once, then nothing
Test 5: Some threads exit, depending on whether the signal reached the
        right thread
Test 6: Thread isn't cancelled even after a waking it with a signal

On 1.7.9 things are a bit different:
Test 1: PTHREAD_CANCEL_DEFERRED
        semaphore/pause: All threads are cancelled via pthread_cancel()
        read: No thread is cancelled
Test 2: PTHREAD_CANCEL_ASYNCHRONOUS
        Threads ignore pthread_cancel()
Test 3: semaphore/read: No thread wakes up or executes the signal handler,
          sleep() doesn't sleep any more after the first signal (returns
          immediately)
        pause: All threads wake up on every signal, correct thread
          executes signal handler
Test 4: semaphore/read: No thread wakes up or executes the signal handler,
          sleep() doesn't sleep any more after the first signal (returns
          immediately)
        pause: All threads wake up on every signal, correct thread
          executes signal handler
Test 5: semaphore: No thread is killed, sleep() doesn't sleep any more
        pause: First thread cancelled, other threads won't pause()
          any more and run amok
        read: Some threads are killed, sleep() doesn't sleep any more
Test 6: semaphore/pause: No thread is killed, sleep() doesn't sleep
          any more
        pause: First thread cancelled, other threads won't pause()
          any more and run amok

Sorry if IÂ’m mixing two (or three?) problems, but they all seem
pthreads-related.

pthread_cancel deferred:
Worked on threads blocked in sem_wait() and pause() in 1.7.9, doesnÂ’t work
any more in 1.7.12-1 and newer and instead hangs calling thread. IÂ’d
consider this one a regression. DidnÂ’t work on threads blocked in read()
in any tested version.

pthread_cancel asynchronous:
No thread is cancelled in any tested version. Calling thread doesnÂ’t hang,
though.

pthread_kill:
In 1.7.9 a signal to any thread wakes up all threads blocked in pause()
and the correct thread executes the signal handler. DoesnÂ’t wake threads
blocked in sem_wait() or read(). After delivering a signal, pause() and
sleep() donÂ’t block any more and return immediately.
In 1.7.12-1 and newer sleep() and pause() wonÂ’t break and not all threads
are woken up. Instead only one thread is woken, but unfortunately not
always the correct one.

While signal handling mostly seems to have improved, cancelling
got worse. Especially the fact that the calling thread blocks in
pthread_cancel can be quite a show-stopper.

Any suggestions or ideas?

Cheers,
Otto

--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple



More information about the Cygwin mailing list