From: Michel Normand Date: Thu, 25 Jun 2009 09:21:56 +0000 (+0200) Subject: lxc-execute to return exit code of its child not others X-Git-Tag: lxc_0_6_3~35 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=37c3dfc9c974a6c42716c66e8d3c286f2441da44;p=thirdparty%2Flxc.git lxc-execute to return exit code of its child not others lxc-execute has to return the exit code of it's child not others as today's code would return the exit code of the last child. We need to track the first process we launched and store its exit status when it exits. In order to avoid to detect the exit of this pid several time if the pids number wrap, we put an extra flag saying the process group is orhpan. Signed-off-by: Michel Normand Signed-off-by: Daniel Lezcano --- diff --git a/src/lxc/lxc_init.c b/src/lxc/lxc_init.c index 964730706..3ed99b620 100644 --- a/src/lxc/lxc_init.c +++ b/src/lxc/lxc_init.c @@ -106,8 +106,10 @@ int main(int argc, char *argv[]) exit(err); } + err = 0; for (;;) { int status; + int orphan = 0; pid_t waited_pid; waited_pid = wait(&status); @@ -118,9 +120,16 @@ int main(int argc, char *argv[]) continue; ERROR("failed to wait child : %s", strerror(errno)); goto out; - } else { - err = lxc_error_set_and_log(waited_pid, status); } + + /* + * keep the exit code of started application (not wrapped pid) + * and continue to wait for the end of the orphan group. + */ + if ((waited_pid != pid) || (orphan ==1)) + continue; + orphan = 1; + err = lxc_error_set_and_log(waited_pid, status); } out: return err;