Sergey's latest cygwin.dll and pdksh

Sergey Okhapkin sos@prospect.com.ru
Mon Jun 16 23:02:00 GMT 1997


Chris Faylor wrote:
>
> #ifdef POSIX_SIGNALS
>     struct sigaction act;
>
>     act.sa_handler = (SIGNAL_HANDTYPE) handler;
>     sigemptyset(&act.sa_mask);        /* only block sig while in handler 
*/
>     act.sa_flags = 0;
> # ifdef SA_INTERRUPT                  /* SunOS 4.x */
>     if (interact)
>         act.sa_flags |= SA_INTERRUPT; /* make sure system calls are not 
restarte
> d */
> # endif
>     sigaction(sig, &act, (struct sigaction *)NULL);
>
> ----
>
> Where the 'sig' is 'SIGCHLD'.
>
> It appears that 'sig' is blocked while within the handler.  Could that be
> what is going wrong?

Cygwin.dll blocks the signal while executing signal's handler. If arrived 
signal is blocked, it will be added to process's sig_pending mask. On exit 
from any handler all pending signals are raised again. See exceptions.cc 
for details. Probably, we have to change sig_pending from a bit mask to an 
array of counters to avoid possible losts of a signals. What do you think 
about?

--
Sergey Okhapkin, http://www.lexa.ru/sos
Moscow, Russia
Looking for a job.


-
For help on using this list (especially unsubscribing), send a message to
"gnu-win32-request@cygnus.com" with one line of text: "help".



More information about the Cygwin mailing list