chiark / gitweb /
main: try a bit harder to find an init process to execute after reexec/switch-root
authorLennart Poettering <lennart@poettering.net>
Mon, 21 May 2012 15:26:19 +0000 (17:26 +0200)
committerLennart Poettering <lennart@poettering.net>
Mon, 21 May 2012 15:26:19 +0000 (17:26 +0200)
src/core/main.c

index 8c25819a120e1870cad9ea84dff23d2316487a11..a51d1be45bc3de8794fa5e1d13cb70f85d085bf4 100644 (file)
@@ -1684,22 +1684,36 @@ finish:
                  * getopt() in argv[], and some cleanups in envp[],
                  * but let's hope that doesn't matter.) */
 
-                if (serialization)
+                if (serialization) {
                         fclose(serialization);
+                        serialization = NULL;
+                }
 
-                if (fds)
+                if (fds) {
                         fdset_free(fds);
+                        fds = NULL;
+                }
 
-                i = 0;
-                args[i++] = switch_root_init ? switch_root_init : "/sbin/init";
-                for (j = 1; j < argc; j++)
+                for (j = 1, i = 1; j < argc; j++)
                         args[i++] = argv[j];
                 args[i++] = NULL;
-
                 assert(i <= args_size);
+
+                if (switch_root_init) {
+                        args[0] = switch_root_init;
+                        execv(args[0], (char* const*) args);
+                        log_warning("Failed to execute configured init, trying fallback: %m");
+                }
+
+                args[0] = "/sbin/init";
                 execv(args[0], (char* const*) args);
 
-                log_error("Failed to reexecute: %m");
+                log_warning("Failed to execute /sbin/init, trying fallback: %m");
+
+                args[0] = "/bin/sh";
+                args[1] = NULL;
+                execv(args[0], (char* const*) args);
+                log_error("Failed to execute /bin/sh, giving up: %m");
         }
 
         if (serialization)