Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 67eabc05 authored by Steve Aarnio's avatar Steve Aarnio Committed by Dave Airlie
Browse files

drm/i915: Don't add panel_fixed_mode to the probed modes list at LVDS init.



In the case where no EDID data is read from the device, adding the
panel_fixed_mode pointer to the probed modes list causes data corruption.

If the panel_fixed_mode pointer is added to the probed modes list at
init time, a copy of the mode is added again at drm_get_modes() request
time.  Then, the panel_fixed_mode pointer is freed because it is seen as
a duplicate mode.  Unfortunately, this pointer is still stored and used
in mode_fixup().

Because the panel_fixed_mode data is copied and returned at
drm_get_modes() time, it is unnecessary to add this information at init
time.

Signed-off-by: default avatarSteve Aarnio <steve.j.aarnio@intel.com>
Signed-off-by: default avatarEric Anholt <eric@anholt.net>
Signed-off-by: default avatarDave Airlie <airlied@linux.ie>
parent ea39f835
Loading
Loading
Loading
Loading
+0 −2
Original line number Diff line number Diff line
@@ -481,8 +481,6 @@ void intel_lvds_init(struct drm_device *dev)
		if (dev_priv->panel_fixed_mode) {
			dev_priv->panel_fixed_mode->type |=
				DRM_MODE_TYPE_PREFERRED;
			drm_mode_probed_add(connector,
					    dev_priv->panel_fixed_mode);
			goto out;
		}
	}