From: Philip Withnall Date: Wed, 1 Feb 2017 13:36:16 +0000 (+0000) Subject: nspawn: Print attempted execv() path on failure (#5199) X-Git-Tag: v233~189 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1a68e1e543fd8f899503bec00585a16ada296ef7;p=thirdparty%2Fsystemd.git nspawn: Print attempted execv() path on failure (#5199) The failure message is typically currently: execv() failed: No such file or directory which is not very useful because it doesn’t tell you which file or directory it was trying to exec. --- diff --git a/src/nspawn/nspawn.c b/src/nspawn/nspawn.c index 4913907b69d..0474f61d437 100644 --- a/src/nspawn/nspawn.c +++ b/src/nspawn/nspawn.c @@ -2130,6 +2130,7 @@ static int inner_child( NULL, /* NOTIFY_SOCKET */ NULL }; + const char *exec_target; _cleanup_strv_free_ char **env_use = NULL; int r; @@ -2316,28 +2317,32 @@ static int inner_child( memcpy_safe(a + 1, arg_parameters, m * sizeof(char*)); a[1 + m] = NULL; - a[0] = (char*) "/usr/lib/systemd/systemd"; + exec_target = a[0] = (char*) "/usr/lib/systemd/systemd"; execve(a[0], a, env_use); - a[0] = (char*) "/lib/systemd/systemd"; + exec_target = a[0] = (char*) "/lib/systemd/systemd"; execve(a[0], a, env_use); - a[0] = (char*) "/sbin/init"; + exec_target = a[0] = (char*) "/sbin/init"; execve(a[0], a, env_use); - } else if (!strv_isempty(arg_parameters)) + } else if (!strv_isempty(arg_parameters)) { + exec_target = arg_parameters[0]; execvpe(arg_parameters[0], arg_parameters, env_use); - else { + } else { if (!arg_chdir) /* If we cannot change the directory, we'll end up in /, that is expected. */ (void) chdir(home ?: "/root"); + exec_target = "/bin/bash"; execle("/bin/bash", "-bash", NULL, env_use); + + exec_target = "/bin/sh"; execle("/bin/sh", "-sh", NULL, env_use); } r = -errno; (void) log_open(); - return log_error_errno(r, "execv() failed: %m"); + return log_error_errno(r, "execv(%s) failed: %m", exec_target); } static int setup_sd_notify_child(void) {