Signal handler of SIGCHLD calls waitpid() which sets errno on error. To

avoid clubbering of errno in normal context, save_errno got introduced.

ok oga
This commit is contained in:
tobias 2008-05-06 15:12:04 +00:00
parent cd0ce46817
commit 458f96936d

View File

@ -300,12 +300,15 @@ static void
_sigchld_cb(int which)
{
pid_t pid;
int save_errno = errno;
int status;
/* Collect dead children. */
while ((pid = waitpid(-1, &status, WNOHANG)) > 0 ||
(pid < 0 && errno == EINTR))
;
errno = save_errno;
}
__dead void