try without wcontinued for borked systems

master
Marc Alexander Lehmann 16 years ago
parent c20c072486
commit 95b3cecca5

28
ev.c

@ -717,10 +717,6 @@ static ev_child *childs [PID_HASHSIZE];
static ev_signal childev;
#ifndef WCONTINUED
# define WCONTINUED 0
#endif
void inline_speed
child_reap (EV_P_ ev_signal *sw, int chain, int pid, int status)
{
@ -736,20 +732,28 @@ child_reap (EV_P_ ev_signal *sw, int chain, int pid, int status)
}
}
#ifndef WCONTINUED
# define WCONTINUED 0
#endif
static void
childcb (EV_P_ ev_signal *sw, int revents)
{
int pid, status;
if (0 < (pid = waitpid (-1, &status, WNOHANG | WUNTRACED | WCONTINUED)))
{
/* make sure we are called again until all childs have been reaped */
/* we need to do it this way so that the callback gets called before we continue */
ev_feed_event (EV_A_ (W)sw, EV_SIGNAL);
/* some systems define WCONTINUED but then fail to support it (linux 2.4) */
if (0 >= (pid = waitpid (-1, &status, WNOHANG | WUNTRACED | WCONTINUED)))
if (!WCONTINUED
|| errno != EINVAL
|| 0 >= (pid = waitpid (-1, &status, WNOHANG | WUNTRACED)))
return;
child_reap (EV_A_ sw, pid, pid, status);
child_reap (EV_A_ sw, 0, pid, status); /* this might trigger a watcher twice, but feed_event catches that */
}
/* make sure we are called again until all childs have been reaped */
/* we need to do it this way so that the callback gets called before we continue */
ev_feed_event (EV_A_ (W)sw, EV_SIGNAL);
child_reap (EV_A_ sw, pid, pid, status);
child_reap (EV_A_ sw, 0, pid, status); /* this might trigger a watcher twice, but feed_event catches that */
}
#endif

Loading…
Cancel
Save