Browse Source

subd: if a required daemon exits, wait instead of killing it.

Otherwise we always say it died because we killed it, so we don't get
the exit status.

Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
ppa-0.6.1
Rusty Russell 7 years ago
parent
commit
b83ac58a98
  1. 9
      lightningd/subd.c

9
lightningd/subd.c

@ -523,8 +523,13 @@ static void destroy_subd(struct subd *sd)
switch (waitpid(sd->pid, &status, WNOHANG)) { switch (waitpid(sd->pid, &status, WNOHANG)) {
case 0: case 0:
log_debug(sd->log, "Status closed, but not exited. Killing"); /* If it's an essential daemon, don't kill: we want the
kill(sd->pid, SIGKILL); * exit status */
if (!sd->must_not_exit) {
log_debug(sd->log,
"Status closed, but not exited. Killing");
kill(sd->pid, SIGKILL);
}
waitpid(sd->pid, &status, 0); waitpid(sd->pid, &status, 0);
fail_if_subd_fails = false; fail_if_subd_fails = false;
break; break;

Loading…
Cancel
Save