drm: allow loading an EDID as firmware to override broken monitor
authorCarsten Emde <C.Emde@osadl.org>
Sun, 18 Mar 2012 21:37:33 +0000 (22:37 +0100)
committerDave Airlie <airlied@redhat.com>
Tue, 20 Mar 2012 10:09:28 +0000 (10:09 +0000)
commitda0df92b57311aa1b26a2a90599ed16e1e968b90
tree428ccd98d8c7cb3b1436a649109cdaa70b64b16c
parent3e148baf464e5b5690ba68f3c310b06024bb862b
drm: allow loading an EDID as firmware to override broken monitor

Broken monitors and/or broken graphic boards may send erroneous or no
EDID data. This also applies to broken KVM devices that are unable to
correctly forward the EDID data of the connected monitor but invent
their own fantasy data.

This patch allows to specify an EDID data set to be used instead of
probing the monitor for it. It contains built-in data sets of frequently
used screen resolutions. In addition, a particular EDID data set may be
provided in the /lib/firmware directory and loaded via the firmware
interface. The name is passed to the kernel as module parameter of the
drm_kms_helper module either when loaded
  options drm_kms_helper edid_firmware=edid/1280x1024.bin
or as kernel commandline parameter
  drm_kms_helper.edid_firmware=edid/1280x1024.bin

It is also possible to restrict the usage of a specified EDID data set
to a particular connector. This is done by prepending the name of the
connector to the name of the EDID data set using the syntax
  edid_firmware=[<connector>:]<edid>
such as, for example,
  edid_firmware=DVI-I-1:edid/1920x1080.bin
in which case no other connector will be affected.

The built-in data sets are
Resolution    Name
--------------------------------
1024x768      edid/1024x768.bin
1280x1024     edid/1280x1024.bin
1680x1050     edid/1680x1050.bin
1920x1080     edid/1920x1080.bin

They are ignored, if a file with the same name is available in the
/lib/firmware directory.

The built-in EDID data sets are based on standard timings that may not
apply to a particular monitor and even crash it. Ideally, EDID data of
the connected monitor should be used. They may be obtained through the
drm/cardX/cardX-<connector>/edid entry in the /sys/devices PCI directory
of a correctly working graphics adapter.

It is even possible to specify the name of an EDID data set on-the-fly
via the /sys/module interface, e.g.
echo edid/myedid.bin >/sys/module/drm_kms_helper/parameters/edid_firmware
The new screen mode is considered when the related kernel function is
called for the first time after the change. Such calls are made when the
X server is started or when the display settings dialog is opened in an
already running X server.

Signed-off-by: Carsten Emde <C.Emde@osadl.org>
Signed-off-by: Dave Airlie <airlied@redhat.com>
16 files changed:
Documentation/EDID/1024x768.S [new file with mode: 0644]
Documentation/EDID/1280x1024.S [new file with mode: 0644]
Documentation/EDID/1680x1050.S [new file with mode: 0644]
Documentation/EDID/1920x1080.S [new file with mode: 0644]
Documentation/EDID/HOWTO.txt [new file with mode: 0644]
Documentation/EDID/Makefile [new file with mode: 0644]
Documentation/EDID/edid.S [new file with mode: 0644]
Documentation/EDID/hex [new file with mode: 0644]
Documentation/kernel-parameters.txt
drivers/gpu/drm/Kconfig
drivers/gpu/drm/Makefile
drivers/gpu/drm/drm_crtc_helper.c
drivers/gpu/drm/drm_edid.c
drivers/gpu/drm/drm_edid_load.c [new file with mode: 0644]
include/drm/drm_crtc.h
include/drm/drm_edid.h