Skip to content

Commit b4df463

Browse files
Aaron Lurafaeljw
authored andcommitted
ACPI / video: update the skip case for acpi_video_device_in_dod()
If the firmware has declared more than 8 video output devices, and the one that control the internal panel's backlight is listed after the first 8 output devices, the _DOD will not include it due to the current i915 operation region implementation. As a result, we will not create a backlight device for it while we should. Solve this problem by special case the firmware that has 8+ output devices in that if we see such a firmware, we do not test if the device is in _DOD list. The creation of the backlight device will also enable the firmware to emit events on backlight hotkey press when the acpi_osi= cmdline option is specified on those affected ASUS laptops. Link: https://bugzilla.kernel.org/show_bug.cgi?id=70241 Reported-and-tested-by: Oleksij Rempel <linux@rempel-privat.de> Reported-and-tested-by: Dmitry Tunin <hanipouspilot@gmail.com> Reported-and-tested-by: Jimbo <jaime.91@hotmail.es> Cc: 3.18+ <stable@vger.kernel.org> # 3.18+ Signed-off-by: Aaron Lu <aaron.lu@intel.com> Acked-by: Jani Nikula <jani.nikula@intel.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
1 parent 667ae4e commit b4df463

File tree

1 file changed

+8
-2
lines changed

1 file changed

+8
-2
lines changed

drivers/acpi/video.c

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -155,6 +155,7 @@ struct acpi_video_bus {
155155
u8 dos_setting;
156156
struct acpi_video_enumerated_device *attached_array;
157157
u8 attached_count;
158+
u8 child_count;
158159
struct acpi_video_bus_cap cap;
159160
struct acpi_video_bus_flags flags;
160161
struct list_head video_device_list;
@@ -1159,8 +1160,12 @@ static bool acpi_video_device_in_dod(struct acpi_video_device *device)
11591160
struct acpi_video_bus *video = device->video;
11601161
int i;
11611162

1162-
/* If we have a broken _DOD, no need to test */
1163-
if (!video->attached_count)
1163+
/*
1164+
* If we have a broken _DOD or we have more than 8 output devices
1165+
* under the graphics controller node that we can't proper deal with
1166+
* in the operation region code currently, no need to test.
1167+
*/
1168+
if (!video->attached_count || video->child_count > 8)
11641169
return true;
11651170

11661171
for (i = 0; i < video->attached_count; i++) {
@@ -1413,6 +1418,7 @@ acpi_video_bus_get_devices(struct acpi_video_bus *video,
14131418
dev_err(&dev->dev, "Can't attach device\n");
14141419
break;
14151420
}
1421+
video->child_count++;
14161422
}
14171423
return status;
14181424
}

0 commit comments

Comments
 (0)