alaurie / rpms / plymouth

Forked from rpms/plymouth 4 days ago
Clone

Blame SOURCES/fix-init-bin-sh.patch

01552a
From be52bd06949cb2a386fda147d24155581708ef1a Mon Sep 17 00:00:00 2001
01552a
From: Ray Strode <rstrode@redhat.com>
01552a
Date: Fri, 10 Oct 2014 13:30:56 -0400
01552a
Subject: [PATCH] main: show splash when init=/bin/sh
01552a
01552a
but quit after switch root.  The keeps luks
01552a
working.
01552a
---
01552a
 src/main.c | 23 ++++++++++++++++++++---
01552a
 1 file changed, 20 insertions(+), 3 deletions(-)
01552a
01552a
diff --git a/src/main.c b/src/main.c
01552a
index fb91bf2..4101550 100644
01552a
--- a/src/main.c
01552a
+++ b/src/main.c
01552a
@@ -135,60 +135,64 @@ static ply_boot_splash_t *load_theme (state_t    *state,
01552a
 static ply_boot_splash_t *show_theme (state_t    *state,
01552a
                                       const char *theme_path);
01552a
 
01552a
 static void attach_splash_to_seats (state_t           *state,
01552a
                                     ply_boot_splash_t *splash);
01552a
 static bool attach_to_running_session (state_t *state);
01552a
 static void detach_from_running_session (state_t *state);
01552a
 static void on_escape_pressed (state_t *state);
01552a
 static void dump_details_and_quit_splash (state_t *state);
01552a
 static void update_display (state_t *state);
01552a
 
01552a
 static void on_error_message (ply_buffer_t *debug_buffer,
01552a
                               const void   *bytes,
01552a
                               size_t        number_of_bytes);
01552a
 static ply_buffer_t *debug_buffer;
01552a
 static char *debug_buffer_path = NULL;
01552a
 static char *pid_file = NULL;
01552a
 static void toggle_between_splash_and_details (state_t *state);
01552a
 #ifdef PLY_ENABLE_SYSTEMD_INTEGRATION
01552a
 static void tell_systemd_to_print_details (state_t *state);
01552a
 static void tell_systemd_to_stop_printing_details (state_t *state);
01552a
 #endif
01552a
 static const char * get_cache_file_for_mode (ply_mode_t mode);
01552a
 static void on_escape_pressed (state_t *state);
01552a
 static void on_enter (state_t    *state,
01552a
                       const char *line);
01552a
 static void on_keyboard_input (state_t    *state,
01552a
                                const char *keyboard_input,
01552a
                                size_t      character_size);
01552a
 static void on_backspace (state_t *state);
01552a
+static void on_quit (state_t       *state,
01552a
+                     bool           retain_splash,
01552a
+                     ply_trigger_t *quit_trigger);
01552a
+static bool sh_is_init (state_t *state);
01552a
 
01552a
 static void
01552a
 on_session_output (state_t    *state,
01552a
                    const char *output,
01552a
                    size_t      size)
01552a
 {
01552a
   ply_buffer_append_bytes (state->boot_buffer, output, size);
01552a
   if (state->boot_splash != NULL)
01552a
     ply_boot_splash_update_output (state->boot_splash,
01552a
                                    output, size);
01552a
 }
01552a
 
01552a
 static void
01552a
 on_session_hangup (state_t *state)
01552a
 {
01552a
   ply_trace ("got hang up on terminal session fd");
01552a
 }
01552a
 
01552a
 static void
01552a
 on_update (state_t     *state,
01552a
            const char  *status)
01552a
 {
01552a
   ply_trace ("updating status to '%s'", status);
01552a
   ply_progress_status_update (state->progress,
01552a
                                status);
01552a
   if (state->boot_splash != NULL)
01552a
     ply_boot_splash_update_status (state->boot_splash,
01552a
                                    status);
01552a
 }
01552a
 
01552a
@@ -626,60 +630,67 @@ on_ignore_keystroke (state_t      *state,
01552a
     {
01552a
       ply_keystroke_watch_t* keystroke_trigger = ply_list_node_get_data (node);
01552a
       if ((!keystroke_trigger->keys && !keys) ||
01552a
           (keystroke_trigger->keys && keys && strcmp(keystroke_trigger->keys, keys)==0))
01552a
         {
01552a
           ply_trigger_pull (keystroke_trigger->trigger, NULL);
01552a
           ply_list_remove_node (state->keystroke_triggers, node);
01552a
           return;
01552a
         }
01552a
     }
01552a
 }
01552a
 
01552a
 static void
01552a
 on_progress_pause (state_t *state)
01552a
 {
01552a
   ply_trace ("pausing progress");
01552a
   ply_progress_pause (state->progress);
01552a
 }
01552a
 
01552a
 static void
01552a
 on_progress_unpause (state_t *state)
01552a
 {
01552a
   ply_trace ("unpausing progress");
01552a
   ply_progress_unpause (state->progress);
01552a
 }
01552a
 
01552a
 static void
01552a
 on_newroot (state_t    *state,
01552a
             const char *root_dir)
01552a
 {
01552a
+  if (sh_is_init (state))
01552a
+    {
01552a
+      ply_trace ("new root mounted at \"%s\", exiting since init= a shell", root_dir);
01552a
+      on_quit (state, false, ply_trigger_new (NULL));
01552a
+      return;
01552a
+    }
01552a
+
01552a
   ply_trace ("new root mounted at \"%s\", switching to it", root_dir);
01552a
   chdir(root_dir);
01552a
   chroot(".");
01552a
   chdir("/");
01552a
   ply_progress_load_cache (state->progress, get_cache_file_for_mode (state->mode));
01552a
   if (state->boot_splash != NULL)
01552a
     ply_boot_splash_root_mounted (state->boot_splash);
01552a
 }
01552a
 
01552a
 static const char *
01552a
 get_cache_file_for_mode (ply_mode_t mode)
01552a
 {
01552a
   const char *filename;
01552a
 
01552a
   switch ((int)mode)
01552a
     {
01552a
     case PLY_MODE_BOOT:
01552a
       filename = BOOT_DURATION_FILE;
01552a
       break;
01552a
     case PLY_MODE_SHUTDOWN:
01552a
       filename = SHUTDOWN_DURATION_FILE;
01552a
       break;
01552a
     case PLY_MODE_UPDATES:
01552a
       filename = NULL;
01552a
       break;
01552a
     default:
01552a
       ply_error ("Unhandled case in %s line %d\n", __FILE__, __LINE__);
01552a
       abort ();
01552a
       break;
01552a
     }
01552a
@@ -781,70 +792,76 @@ prepare_logging (state_t *state)
01552a
       if (state->number_of_errors > 0)
01552a
         spool_error (state);
01552a
     }
01552a
 }
01552a
 
01552a
 static void
01552a
 on_system_initialized (state_t *state)
01552a
 {
01552a
   ply_trace ("system now initialized, opening log");
01552a
   state->system_initialized = true;
01552a
 
01552a
   prepare_logging (state);
01552a
 }
01552a
 
01552a
 static void
01552a
 on_error (state_t *state)
01552a
 {
01552a
   ply_trace ("encountered error during boot up");
01552a
 
01552a
   if (state->system_initialized && state->number_of_errors == 0)
01552a
     spool_error (state);
01552a
   else
01552a
     ply_trace ("not spooling because number of errors %d", state->number_of_errors);
01552a
 
01552a
   state->number_of_errors++;
01552a
 }
01552a
 
01552a
 static bool
01552a
 plymouth_should_ignore_show_splash_calls (state_t *state)
01552a
 {
01552a
-  const char *init_string;
01552a
-  size_t length;
01552a
-
01552a
   ply_trace ("checking if plymouth should be running");
01552a
   if (state->mode != PLY_MODE_BOOT || command_line_has_argument (state->kernel_command_line, "plymouth.force-splash"))
01552a
       return false;
01552a
 
01552a
   if (command_line_has_argument (state->kernel_command_line, "plymouth.ignore-show-splash"))
01552a
       return true;
01552a
 
01552a
+  return false;
01552a
+}
01552a
+
01552a
+static bool
01552a
+sh_is_init (state_t *state)
01552a
+{
01552a
+  const char *init_string;
01552a
+  size_t length;
01552a
+
01552a
   init_string = command_line_get_string_after_prefix (state->kernel_command_line, "init=");
01552a
 
01552a
   if (init_string)
01552a
     {
01552a
       length = strcspn (init_string, " \n");
01552a
       if (length > 2 && ply_string_has_prefix (init_string + length - 2, "sh"))
01552a
         return true;
01552a
     }
01552a
 
01552a
   return false;
01552a
 }
01552a
 
01552a
 static bool
01552a
 plymouth_should_show_default_splash (state_t *state)
01552a
 {
01552a
   ply_trace ("checking if plymouth should show default splash");
01552a
 
01552a
   const char const *strings[] = {
01552a
       "single", "1", "s", "S", "-S", NULL
01552a
   };
01552a
   int i;
01552a
 
01552a
   if (state->should_force_details)
01552a
     return false;
01552a
 
01552a
   for (i = 0; strings[i] != NULL; i++)
01552a
     {
01552a
       if (command_line_has_argument (state->kernel_command_line, strings[i]))
01552a
         {
01552a
           ply_trace ("no default splash because kernel command line has option \"%s\"", strings[i]);
01552a
-- 
01552a
1.8.3.1
01552a