Skip to content

Commit aa8a950

Browse files
jwrdegoederafaeljw
authored andcommitted
ACPI: video: Stop trying to use vendor backlight control on laptops from after ~2012
There have been 2 separate reports now about a non working "dell_backlight" device getting registered under /sys/class/backlight 1 report for a Raptor Lake based Dell and 1 report for a Meteor Lake (development) platform. On hw from the last 10 years dell-laptop will not register "dell_backlight" because acpi_video_get_backlight_type() will return acpi_backlight_video there if called before the GPU/kms driver loads. So it does not matter if the GPU driver's native backlight is registered after dell-laptop loads. But it seems that on the latest generation laptops the ACPI tables no longer contain acpi_video backlight control support which causes acpi_video_get_backlight_type() to return acpi_backlight_vendor causing "dell_backlight" to get registered if the dell-laptop module is loaded before the GPU/kms driver. Vendor specific backlight control like the "dell_backlight" device is only necessary on quite old hw (from before acpi_video backlight control was introduced). Work around "dell_backlight" registering on very new hw (where acpi_video backlight control seems to be no more) by making acpi_video_get_backlight_type() return acpi_backlight_none instead of acpi_backlight_vendor as final fallback when the ACPI tables have support for Windows 8 or later (laptops from after ~2012). Suggested-by: Matthew Garrett <[email protected]> Reported-by: AceLan Kao <[email protected]> Closes: https://lore.kernel.org/platform-driver-x86/[email protected]/ Signed-off-by: Hans de Goede <[email protected]> Signed-off-by: Rafael J. Wysocki <[email protected]>
1 parent bd5d93d commit aa8a950

File tree

1 file changed

+21
-0
lines changed

1 file changed

+21
-0
lines changed

drivers/acpi/video_detect.c

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -844,6 +844,27 @@ enum acpi_backlight_type __acpi_video_get_backlight_type(bool native, bool *auto
844844
if (native_available)
845845
return acpi_backlight_native;
846846

847+
/*
848+
* The vendor specific BIOS interfaces are only necessary for
849+
* laptops from before ~2008.
850+
*
851+
* For laptops from ~2008 till ~2023 this point is never reached
852+
* because on those (video_caps & ACPI_VIDEO_BACKLIGHT) above is true.
853+
*
854+
* Laptops from after ~2023 no longer support ACPI_VIDEO_BACKLIGHT,
855+
* if this point is reached on those, this likely means that
856+
* the GPU kms driver which sets native_available has not loaded yet.
857+
*
858+
* Returning acpi_backlight_vendor in this case is known to sometimes
859+
* cause a non working vendor specific /sys/class/backlight device to
860+
* get registered.
861+
*
862+
* Return acpi_backlight_none on laptops with ACPI tables written
863+
* for Windows 8 (laptops from after ~2012) to avoid this problem.
864+
*/
865+
if (acpi_osi_is_win8())
866+
return acpi_backlight_none;
867+
847868
/* No ACPI video/native (old hw), use vendor specific fw methods. */
848869
return acpi_backlight_vendor;
849870
}

0 commit comments

Comments
 (0)