Commit 24b412b1 authored by Imre Deak's avatar Imre Deak

drm/i915: Disable intel HPD poll after DRM poll init/enable

The only purpose of intel_hpd_poll_disable() during driver loading and
system resume - at which point polling should be disabled anyway, except
for connectors in an IRQ storm, for which the polling will stay enabled -
is to force-detect all the connectors. However this detection in
i915_hpd_poll_init_work() depends on drm.mode_config.poll_enabled, which
will get set in drm_kms_helper_poll_init(), possibly after
i915_hpd_poll_init_work() is scheduled. Hence the initial detection of
connectors during driver loading may not happen.

Fix the above by moving intel_hpd_poll_disable() after
i915_hpd_poll_init_work(), the proper place anyway for doing the above
detection after all the HW initialization steps are complete. Change the
order the same way during system resume as well. The above race
condition shouldn't matter here - as drm.mode_config.poll_enabled will
be set - but the detection should happen here as well after the HW init
steps are done.

Link: https://patchwork.freedesktop.org/patch/msgid/20240104083008.2715733-5-imre.deak@intel.comReviewed-by: default avatarJouni Högander <jouni.hogander@intel.com>
Signed-off-by: default avatarImre Deak <imre.deak@intel.com>
parent a1a0e863
...@@ -374,7 +374,6 @@ int intel_display_driver_probe(struct drm_i915_private *i915) ...@@ -374,7 +374,6 @@ int intel_display_driver_probe(struct drm_i915_private *i915)
/* Only enable hotplug handling once the fbdev is fully set up. */ /* Only enable hotplug handling once the fbdev is fully set up. */
intel_hpd_init(i915); intel_hpd_init(i915);
intel_hpd_poll_disable(i915);
skl_watermark_ipc_init(i915); skl_watermark_ipc_init(i915);
...@@ -412,6 +411,7 @@ void intel_display_driver_register(struct drm_i915_private *i915) ...@@ -412,6 +411,7 @@ void intel_display_driver_register(struct drm_i915_private *i915)
* fbdev->async_cookie. * fbdev->async_cookie.
*/ */
drm_kms_helper_poll_init(&i915->drm); drm_kms_helper_poll_init(&i915->drm);
intel_hpd_poll_disable(i915);
intel_display_device_info_print(DISPLAY_INFO(i915), intel_display_device_info_print(DISPLAY_INFO(i915),
DISPLAY_RUNTIME_INFO(i915), &p); DISPLAY_RUNTIME_INFO(i915), &p);
......
...@@ -1248,9 +1248,9 @@ static int i915_drm_resume(struct drm_device *dev) ...@@ -1248,9 +1248,9 @@ static int i915_drm_resume(struct drm_device *dev)
intel_dp_mst_resume(dev_priv); intel_dp_mst_resume(dev_priv);
intel_display_driver_resume(dev_priv); intel_display_driver_resume(dev_priv);
intel_hpd_poll_disable(dev_priv);
if (HAS_DISPLAY(dev_priv)) if (HAS_DISPLAY(dev_priv))
drm_kms_helper_poll_enable(dev); drm_kms_helper_poll_enable(dev);
intel_hpd_poll_disable(dev_priv);
intel_opregion_resume(dev_priv); intel_opregion_resume(dev_priv);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment