--- jobs.c +++ jobs.c 2008-01-08 18:10:16.000000000 +0000 @@ -2426,7 +2426,11 @@ wait_for (pid) act.sa_handler = SIG_DFL; sigemptyset (&act.sa_mask); sigemptyset (&oact.sa_mask); +# if defined(MUST_REINSTALL_SIGHANDLERS) act.sa_flags = 0; +# else + act.sa_flags = SA_RESTART; +# endif sigaction (SIGCHLD, &act, &oact); # endif queue_sigchld = 1; --- sig.c +++ sig.c 2010-10-14 12:28:48.004425767 +0000 @@ -658,6 +658,16 @@ set_signal_handler (sig, handler) #else if (sig == SIGCHLD) act.sa_flags |= SA_RESTART; +# if !defined(MUST_REINSTALL_SIGHANDLERS) + if (sig != SIGALRM) + act.sa_flags |= SA_RESTART; /* XXX */ + if (handler == (trap_handler)) + act.sa_flags |= SA_NODEFER; /* XXX */ + if (handler == (termsig_sighandler)) + act.sa_flags |= SA_NODEFER; /* XXX */ + if (sig == SIGTSTP || sig == SIGTTOU || sig == SIGTTIN || sig == SIGCONT) + act.sa_flags |= SA_NODEFER; /* XXX */ +# endif #endif sigemptyset (&act.sa_mask); sigemptyset (&oact.sa_mask);