alaurie / rpms / plymouth

Forked from rpms/plymouth 19 days ago
Clone

Blame SOURCES/0001-device-manager-fall-back-to-text-mode-if-graphical-d.patch

a802d9
From bdfcf889f8cda47190d98fa8a3e401a1db38074c Mon Sep 17 00:00:00 2001
a802d9
From: Ray Strode <rstrode@redhat.com>
a802d9
Date: Tue, 7 Nov 2017 13:49:30 -0500
a802d9
Subject: [PATCH] device-manager: fall back to text mode if graphical devices
a802d9
 fail
a802d9
a802d9
Right now we assume if we find a /dev/dri/card0 that it will work.
a802d9
That may not be true. The proprietary nvidia driver, for instance,
a802d9
provides /dev/dri/card0 but disables modesetting by default.
a802d9
a802d9
This commit makes sure we fall back to text mode if /dev/dri/card0
a802d9
is insufficient for our needs.
a802d9
a802d9
https://bugs.freedesktop.org/show_bug.cgi?id=103612
a802d9
---
a802d9
 src/libply-splash-core/ply-device-manager.c | 26 ++++++++++++---------
a802d9
 1 file changed, 15 insertions(+), 11 deletions(-)
a802d9
a802d9
diff --git a/src/libply-splash-core/ply-device-manager.c b/src/libply-splash-core/ply-device-manager.c
a802d9
index b4c33d4..cf56f4e 100644
a802d9
--- a/src/libply-splash-core/ply-device-manager.c
a802d9
+++ b/src/libply-splash-core/ply-device-manager.c
a802d9
@@ -47,7 +47,7 @@
a802d9
 static void create_devices_from_udev (ply_device_manager_t *manager);
a802d9
 #endif
a802d9
 
a802d9
-static void create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
+static bool create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
                                                            const char           *device_path,
a802d9
                                                            ply_terminal_t       *terminal,
a802d9
                                                            ply_renderer_type_t   renderer_type);
a802d9
@@ -212,11 +212,12 @@ fb_device_has_drm_device (ply_device_manager_t *manager,
a802d9
         return has_drm_device;
a802d9
 }
a802d9
 
a802d9
-static void
a802d9
+static bool
a802d9
 create_devices_for_udev_device (ply_device_manager_t *manager,
a802d9
                                 struct udev_device   *device)
a802d9
 {
a802d9
         const char *device_path;
a802d9
+        bool created = false;
a802d9
 
a802d9
         device_path = udev_device_get_devnode (device);
a802d9
 
a802d9
@@ -245,12 +246,14 @@ create_devices_for_udev_device (ply_device_manager_t *manager,
a802d9
                                 terminal = manager->local_console_terminal;
a802d9
                         }
a802d9
 
a802d9
-                        create_devices_for_terminal_and_renderer_type (manager,
a802d9
-                                                                    device_path,
a802d9
-                                                                    terminal,
a802d9
-                                                                    renderer_type);
a802d9
+                        created = create_devices_for_terminal_and_renderer_type (manager,
a802d9
+                                                                                 device_path,
a802d9
+                                                                                 terminal,
a802d9
+                                                                                 renderer_type);
a802d9
                 }
a802d9
         }
a802d9
+
a802d9
+        return created;
a802d9
 }
a802d9
 
a802d9
 static void
a802d9
@@ -310,8 +313,7 @@ create_devices_for_subsystem (ply_device_manager_t *manager,
a802d9
                                 node = udev_device_get_devnode (device);
a802d9
                                 if (node != NULL) {
a802d9
                                         ply_trace ("found node %s", node);
a802d9
-                                        found_device = true;
a802d9
-                                        create_devices_for_udev_device (manager, device);
a802d9
+                                        found_device = create_devices_for_udev_device (manager, device);
a802d9
                                 }
a802d9
                         } else {
a802d9
                                 ply_trace ("device doesn't have a devices tag");
a802d9
@@ -656,7 +658,7 @@ create_text_displays_for_terminal (ply_device_manager_t *manager,
a802d9
           manager->text_display_added_handler (manager->event_handler_data, display);
a802d9
 }
a802d9
 
a802d9
-static void
a802d9
+static bool
a802d9
 create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
                                                const char           *device_path,
a802d9
                                                ply_terminal_t       *terminal,
a802d9
@@ -670,7 +672,7 @@ create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
 
a802d9
         if (renderer != NULL) {
a802d9
                 ply_trace ("ignoring device %s since it's already managed", device_path);
a802d9
-                return;
a802d9
+                return true;
a802d9
         }
a802d9
 
a802d9
         ply_trace ("creating devices for %s (renderer type: %u) (terminal: %s)",
a802d9
@@ -686,7 +688,7 @@ create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
                         renderer = NULL;
a802d9
 
a802d9
                         if (renderer_type != PLY_RENDERER_TYPE_AUTO)
a802d9
-                                return;
a802d9
+                                return false;
a802d9
                 }
a802d9
 
a802d9
                 if (renderer != NULL) {
a802d9
@@ -743,6 +745,8 @@ create_devices_for_terminal_and_renderer_type (ply_device_manager_t *manager,
a802d9
                 ply_trace ("activating keyboards");
a802d9
                 ply_keyboard_watch_for_input (keyboard);
a802d9
         }
a802d9
+
a802d9
+        return true;
a802d9
 }
a802d9
 
a802d9
 static void
a802d9
-- 
a802d9
2.17.1
a802d9