diff options
author | Zhang Rui <rui.zhang@intel.com> | 2007-09-14 11:46:22 +0800 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2007-09-18 13:37:49 -0400 |
commit | a21101c46ca5b4320e31408853cdcbf7cb1ce4ed (patch) | |
tree | 1a0015c8a8eea64d976c627471067079cf8db4bd /drivers | |
parent | c2f828977ba5d17c13debba374ea252d18e5ccfb (diff) | |
download | kernel_samsung_aries-a21101c46ca5b4320e31408853cdcbf7cb1ce4ed.zip kernel_samsung_aries-a21101c46ca5b4320e31408853cdcbf7cb1ce4ed.tar.gz kernel_samsung_aries-a21101c46ca5b4320e31408853cdcbf7cb1ce4ed.tar.bz2 |
ACPI: video: _DOS=0 by default to prevent hotkey hang
In the past, the Linux/ACPI video driver invoked _DOS
(Display Output Switch) with the parameter 1
to tell the BIOS to switch the video output display for us.
But this conflicts with Linux native graphics drivers,
and can cause all sorts of issues, including hanging the system.
http://bugzilla.kernel.org/show_bug.cgi?id=6001
Here we change the Linux default to evaluate _DOS=0,
which tells the BIOS to simply send us a hotkey event
and not touch the graphics hardware.
The acpi video driver sends the display switch hotkey
event up through the intput layer, and X can interpret
that and use its native graphics driver to switch the display.
For the case where Linux has no native graphics driver running,
or the graphics driver doesn't know how to switch video and
the BIOS (safely) does, the previous behaviour can be restored with:
# echo 1 > /proc/acpi/video/*/DOS
Signed-off-by: Zhang Rui <rui.zhang@intel.com>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/acpi/video.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/acpi/video.c b/drivers/acpi/video.c index 3c9bb85..6cb3e7b1 100644 --- a/drivers/acpi/video.c +++ b/drivers/acpi/video.c @@ -1754,7 +1754,7 @@ static int acpi_video_bus_put_devices(struct acpi_video_bus *video) static int acpi_video_bus_start_devices(struct acpi_video_bus *video) { - return acpi_video_bus_DOS(video, 1, 0); + return acpi_video_bus_DOS(video, 0, 0); } static int acpi_video_bus_stop_devices(struct acpi_video_bus *video) |