]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/psr: Don't enable Panel Replay on sink if globally disabled
authorJouni Högander <jouni.hogander@intel.com>
Thu, 15 Jan 2026 07:00:39 +0000 (09:00 +0200)
committerJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
Mon, 19 Jan 2026 09:55:31 +0000 (11:55 +0200)
With some panels informing support for Panel Replay we are observing
problems if having Panel Replay enable bit set on sink when forced to use
PSR instead of Panel Replay. Avoid these problems by not setting Panel
Replay enable bit in sink when Panel Replay is globally disabled during
link training. I.e. disabled by module parameter.

The enable bit is still set when disabling Panel Replay via debugfs
interface. Added note comment about this.

Fixes: 68f3a505b367 ("drm/i915/psr: Enable Panel Replay on sink always when it's supported")
Cc: Mika Kahola <mika.kahola@intel.com>
Cc: Jani Nikula <jani.nikula@linux.intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Cc: <stable@vger.kernel.org> # v6.15+
Signed-off-by: Jouni Högander <jouni.hogander@intel.com>
Reviewed-by: Mika Kahola <mika.kahola@intel.com>
Link: https://patch.msgid.link/20260115070039.368965-1-jouni.hogander@intel.com
(cherry picked from commit c5a52cd04e24f0ae53fda26f74ab027b8c548e0e)
Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
drivers/gpu/drm/i915/display/intel_psr.c

index 91f4ac86c7ad7dfdee5bb0d91d13bc6c5b076c3a..62208ffc510164a36fd6ff8e7edaadfb63523ea3 100644 (file)
@@ -842,7 +842,12 @@ static void intel_psr_enable_sink(struct intel_dp *intel_dp,
 
 void intel_psr_panel_replay_enable_sink(struct intel_dp *intel_dp)
 {
-       if (CAN_PANEL_REPLAY(intel_dp))
+       /*
+        * NOTE: We might want to trigger mode set when
+        * disabling/enabling Panel Replay via debugfs interface to
+        * ensure this bit is cleared/set accordingly.
+        */
+       if (CAN_PANEL_REPLAY(intel_dp) && panel_replay_global_enabled(intel_dp))
                drm_dp_dpcd_writeb(&intel_dp->aux, PANEL_REPLAY_CONFIG,
                                   DP_PANEL_REPLAY_ENABLE);
 }