From: Kay Sievers Date: Tue, 22 May 2012 17:11:10 +0000 (+0200) Subject: main: only fall back to /bin/sh in case /sbin/init does not exist X-Git-Tag: v183~38 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=745e2fb79ab20f3e98310d5e889a161ffe8b492c main: only fall back to /bin/sh in case /sbin/init does not exist --- diff --git a/src/core/main.c b/src/core/main.c index b66ae0e03..4d9a2d453 100644 --- a/src/core/main.c +++ b/src/core/main.c @@ -1749,12 +1749,15 @@ finish: args[0] = "/sbin/init"; execv(args[0], (char* const*) args); - log_warning("Failed to execute /sbin/init, trying fallback: %m"); + if (errno == ENOENT) { + log_warning("No /sbin/init, trying fallback"); - args[0] = "/bin/sh"; - args[1] = NULL; - execv(args[0], (char* const*) args); - log_error("Failed to execute /bin/sh, giving up: %m"); + args[0] = "/bin/sh"; + args[1] = NULL; + execv(args[0], (char* const*) args); + log_error("Failed to execute /bin/sh, giving up: %m"); + } else + log_warning("Failed to execute /sbin/init, giving up: %m"); } if (serialization)