|  | > OS = DIGITAL UNIX V4.0, the thread code is compiled using the -threads
> switch of the compiler (old pthread interface).
Thanks for answering the question ;-) Or at least, providing enough
information for me to answer it trivially, which is almost the same thing.
The sigwait() function is implemented in the kernel. Prior to Digital UNIX
4.0, the kernel did not support cancellation of blocking functions, and,
therefore, sigwait() could not be a cancellation point.
In Digital UNIX 4.0, this is no longer a problem, and sigwait() IS a
cancellation point. BUT... inevitably, people rely on bugs and restrictions,
and we are aware of many products (& customers) who rely on kernel blocking
functions NOT being cancellation points. There was no easy way to resolve
this quandary.
Thus, we fixed the problem AND maintained binary compatibility by allowing
"system cancellation" only in threads created using the POSIX threads
interface. Threads created using the obsolete CMA interface or the retired
DCE threads interface have "system cancellation" disabled. There's no
interface to change this -- after all, if you don't want compatibility with
the old version, you should port to POSIX threads anyway.
The fact that you are building with "-threads" means that you are using
either the CMA or DCE threads interface rather than POSIX threads, so you
cannot cancel any blocking system call -- including sigwait().
	/dave
 |