static int only_lcd = -1;
 module_param(only_lcd, int, 0444);
 
+/*
+ * Display probing is known to take up to 5 seconds, so delay the fallback
+ * backlight registration by 5 seconds + 3 seconds for some extra margin.
+ */
+static int register_backlight_delay = 8;
+module_param(register_backlight_delay, int, 0444);
+MODULE_PARM_DESC(register_backlight_delay,
+       "Delay in seconds before doing fallback (non GPU driver triggered) "
+       "backlight registration, set to 0 to disable.");
+
 static bool may_report_brightness_keys;
 static int register_count;
 static DEFINE_MUTEX(register_count_mutex);
 static int acpi_video_bus_add(struct acpi_device *device);
 static int acpi_video_bus_remove(struct acpi_device *device);
 static void acpi_video_bus_notify(struct acpi_device *device, u32 event);
+static void acpi_video_bus_register_backlight_work(struct work_struct *ignored);
+static DECLARE_DELAYED_WORK(video_bus_register_backlight_work,
+                           acpi_video_bus_register_backlight_work);
 void acpi_video_detect_exit(void);
 
 /*
        if (video->backlight_registered)
                return 0;
 
-       acpi_video_run_bcl_for_osi(video);
-
        if (acpi_video_get_backlight_type() != acpi_backlight_video)
                return 0;
 
        list_add_tail(&video->entry, &video_bus_head);
        mutex_unlock(&video_list_lock);
 
-       acpi_video_bus_register_backlight(video);
+       /*
+        * The userspace visible backlight_device gets registered separately
+        * from acpi_video_register_backlight().
+        */
+       acpi_video_run_bcl_for_osi(video);
        acpi_video_bus_add_notify_handler(video);
 
        return 0;
        return 0;
 }
 
+static void acpi_video_bus_register_backlight_work(struct work_struct *ignored)
+{
+       acpi_video_register_backlight();
+}
+
 static int __init is_i740(struct pci_dev *dev)
 {
        if (dev->device == 0x00D1)
         */
        register_count = 1;
 
+       /*
+        * acpi_video_bus_add() skips registering the userspace visible
+        * backlight_device. The intend is for this to be registered by the
+        * drm/kms driver calling acpi_video_register_backlight() *after* it is
+        * done setting up its own native backlight device. The delayed work
+        * ensures that acpi_video_register_backlight() always gets called
+        * eventually, in case there is no drm/kms driver or it is disabled.
+        */
+       if (register_backlight_delay)
+               schedule_delayed_work(&video_bus_register_backlight_work,
+                                     register_backlight_delay * HZ);
+
 leave:
        mutex_unlock(®ister_count_mutex);
        return ret;
 {
        mutex_lock(®ister_count_mutex);
        if (register_count) {
+               cancel_delayed_work_sync(&video_bus_register_backlight_work);
                acpi_bus_unregister_driver(&acpi_video_bus);
                register_count = 0;
                may_report_brightness_keys = false;
 }
 EXPORT_SYMBOL(acpi_video_unregister);
 
+void acpi_video_register_backlight(void)
+{
+       struct acpi_video_bus *video;
+
+       mutex_lock(&video_list_lock);
+       list_for_each_entry(video, &video_bus_head, entry)
+               acpi_video_bus_register_backlight(video);
+       mutex_unlock(&video_list_lock);
+}
+EXPORT_SYMBOL(acpi_video_register_backlight);
+
 void acpi_video_unregister_backlight(void)
 {
        struct acpi_video_bus *video;
 
 #if IS_ENABLED(CONFIG_ACPI_VIDEO)
 extern int acpi_video_register(void);
 extern void acpi_video_unregister(void);
+extern void acpi_video_register_backlight(void);
 extern int acpi_video_get_edid(struct acpi_device *device, int type,
                               int device_id, void **edid);
 extern enum acpi_backlight_type acpi_video_get_backlight_type(void);
 #else
 static inline int acpi_video_register(void) { return -ENODEV; }
 static inline void acpi_video_unregister(void) { return; }
+static inline void acpi_video_register_backlight(void) { return; }
 static inline int acpi_video_get_edid(struct acpi_device *device, int type,
                                      int device_id, void **edid)
 {