alaurie / rpms / plymouth

Forked from rpms/plymouth 4 days ago
Clone

Blame SOURCES/fix-ask-password-race.patch

e22087
From e0e098f6b1240979f7da473f8966cd8043bce576 Mon Sep 17 00:00:00 2001
e22087
From: Ray Strode <rstrode@redhat.com>
e22087
Date: Thu, 6 Mar 2014 10:02:21 -0500
e22087
Subject: [PATCH] main: call update_display when splash is shown
e22087
e22087
we need to call update display any time a splash is shown,
e22087
because there may be a pending password request.
e22087
e22087
The code attempted to do this in show_splash, but did it before
e22087
the splash was assigned to running state, so function was a noop.
e22087
e22087
This commit moves it a little later in code after the splash is
e22087
properly assigned.
e22087
---
e22087
 src/main.c | 4 +++-
e22087
 1 file changed, 3 insertions(+), 1 deletion(-)
e22087
e22087
diff --git a/src/main.c b/src/main.c
e22087
index ccb8b63..fb91bf2 100644
e22087
--- a/src/main.c
e22087
+++ b/src/main.c
e22087
@@ -294,60 +294,61 @@ load_settings (state_t     *state,
e22087
           ply_trace ("Splash delay is set to %lf", state->splash_delay);
e22087
           state->splash_delay = atof (delay_string);
e22087
         }
e22087
     }
e22087
 
e22087
   settings_loaded = true;
e22087
 out:
e22087
   ply_key_file_free (key_file);
e22087
 
e22087
   return settings_loaded;
e22087
 }
e22087
 
e22087
 static void
e22087
 show_detailed_splash (state_t *state)
e22087
 {
e22087
   ply_boot_splash_t *splash;
e22087
 
e22087
   if (state->boot_splash != NULL)
e22087
     return;
e22087
 
e22087
   ply_trace ("Showing detailed splash screen");
e22087
   splash = show_theme (state, NULL);
e22087
 
e22087
   if (splash == NULL)
e22087
     {
e22087
       ply_trace ("Could not start detailed splash screen, this could be a problem.");
e22087
       return;
e22087
     }
e22087
 
e22087
   state->boot_splash = splash;
e22087
+  update_display (state);
e22087
 }
e22087
 
e22087
 static const char *
e22087
 command_line_get_string_after_prefix (const char *command_line,
e22087
                                       const char *prefix)
e22087
 {
e22087
   char *argument;
e22087
 
e22087
   argument = strstr (command_line, prefix);
e22087
 
e22087
   if (argument == NULL)
e22087
     return NULL;
e22087
 
e22087
   if (argument == command_line ||
e22087
       argument[-1] == ' ')
e22087
     return argument + strlen (prefix);
e22087
 
e22087
   return NULL;
e22087
 }
e22087
 
e22087
 static bool
e22087
 command_line_has_argument (const char *command_line,
e22087
                            const char *argument)
e22087
 {
e22087
     const char *string;
e22087
 
e22087
     string = command_line_get_string_after_prefix (command_line, argument);
e22087
 
e22087
     if (string == NULL)
e22087
       return false;
e22087
@@ -450,60 +451,62 @@ show_default_splash (state_t *state)
e22087
     {
e22087
       ply_trace ("Trying distribution default splash");
e22087
       state->boot_splash = show_theme (state, state->distribution_default_splash_path);
e22087
     }
e22087
 
e22087
   if (state->boot_splash == NULL)
e22087
     {
e22087
       ply_trace ("Trying old scheme for default splash");
e22087
       state->boot_splash = show_theme (state, PLYMOUTH_THEME_PATH "default.plymouth");
e22087
     }
e22087
 
e22087
   if (state->boot_splash == NULL)
e22087
     {
e22087
       ply_trace ("Could not start default splash screen,"
e22087
                  "showing text splash screen");
e22087
       state->boot_splash = show_theme (state, PLYMOUTH_THEME_PATH "text/text.plymouth");
e22087
     }
e22087
 
e22087
   if (state->boot_splash == NULL)
e22087
     {
e22087
       ply_trace ("Could not start text splash screen,"
e22087
                  "showing built-in splash screen");
e22087
       state->boot_splash = show_theme (state, NULL);
e22087
     }
e22087
 
e22087
   if (state->boot_splash == NULL)
e22087
     {
e22087
       ply_error ("plymouthd: could not start boot splash: %m");
e22087
       return;
e22087
     }
e22087
+
e22087
+  update_display (state);
e22087
 }
e22087
 
e22087
 static void
e22087
 cancel_pending_delayed_show (state_t *state)
e22087
 {
e22087
   if (isnan (state->splash_delay))
e22087
     return;
e22087
 
e22087
   ply_event_loop_stop_watching_for_timeout (state->loop,
e22087
                                             (ply_event_loop_timeout_handler_t)
e22087
                                             show_splash,
e22087
                                             state);
e22087
   state->splash_delay = NAN;
e22087
 }
e22087
 
e22087
 static void
e22087
 on_ask_for_password (state_t      *state,
e22087
                      const char   *prompt,
e22087
                      ply_trigger_t *answer)
e22087
 {
e22087
   ply_entry_trigger_t *entry_trigger;
e22087
 
e22087
   if (state->boot_splash == NULL)
e22087
     {
e22087
       /* Waiting to be shown, boot splash will
e22087
        * arrive shortly so just sit tight
e22087
        */
e22087
       if (state->is_shown)
e22087
         {
e22087
           bool has_open_seats;
e22087
@@ -1671,61 +1674,60 @@ show_theme (state_t           *state,
e22087
     splash = load_theme (state, theme_path);
e22087
   else
e22087
     splash = load_built_in_theme (state);
e22087
 
e22087
   if (splash == NULL)
e22087
     return NULL;
e22087
 
e22087
   attach_splash_to_seats (state, splash);
e22087
   ply_device_manager_activate_renderers (state->device_manager);
e22087
 
e22087
   if (state->mode == PLY_MODE_SHUTDOWN)
e22087
     splash_mode = PLY_BOOT_SPLASH_MODE_SHUTDOWN;
e22087
   else
e22087
     splash_mode = PLY_BOOT_SPLASH_MODE_BOOT_UP;
e22087
 
e22087
   if (!ply_boot_splash_show (splash, splash_mode))
e22087
     {
e22087
       ply_save_errno ();
e22087
       ply_boot_splash_free (splash);
e22087
       ply_restore_errno ();
e22087
       return NULL;
e22087
     }
e22087
 
e22087
 #ifdef PLY_ENABLE_SYSTEMD_INTEGRATION
e22087
   if (state->is_attached)
e22087
     tell_systemd_to_print_details (state);
e22087
 #endif
e22087
 
e22087
   ply_device_manager_activate_keyboards (state->device_manager);
e22087
   show_messages (state);
e22087
-  update_display (state);
e22087
 
e22087
   return splash;
e22087
 }
e22087
 
e22087
 static bool
e22087
 attach_to_running_session (state_t *state)
e22087
 {
e22087
   ply_terminal_session_t *session;
e22087
   ply_terminal_session_flags_t flags;
e22087
   bool should_be_redirected;
e22087
 
e22087
   flags = 0;
e22087
 
e22087
   should_be_redirected = !state->no_boot_log;
e22087
 
e22087
   if (should_be_redirected)
e22087
     flags |= PLY_TERMINAL_SESSION_FLAGS_REDIRECT_CONSOLE;
e22087
 
e22087
  if (state->session == NULL)
e22087
    {
e22087
      ply_trace ("creating new terminal session");
e22087
      session = ply_terminal_session_new (NULL);
e22087
 
e22087
      ply_terminal_session_attach_to_event_loop (session, state->loop);
e22087
    }
e22087
  else
e22087
    {
e22087
      session = state->session;
e22087
      ply_trace ("session already created");
e22087
    }
e22087
-- 
e22087
1.8.3.1
e22087