]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/dp: Reset link params after a DPRX capability change
authorImre Deak <imre.deak@intel.com>
Fri, 22 May 2026 16:05:11 +0000 (19:05 +0300)
committerImre Deak <imre.deak@intel.com>
Mon, 25 May 2026 12:07:22 +0000 (15:07 +0300)
There is no reason to distinguish between DPRX capability changes
signaled via a long HPD and via an RX_CAP_CHANGED HPD IRQ.

Both cases result in reading out the DPRX capabilities and updating the
corresponding sink and common capabilities cached in intel_dp, however
only the long HPD resets the link training/recovery state and MST link
probe parameters correspondingly. The link training/recovery state may
contain reduced maximum link rate/lane count values left over from a
previous link training failure.

Based on the above after an RX_CAP_CHANGED increased the link rate, lane
count parameters the maximum link rate/lane count in the link
training/recovery state may remain below these, leaving the newly added
valid configurations unavailable for subsequent modesets in an
inconsistent way.

Handle RX_CAP_CHANGED IRQs the same way as long HPDs and reset the link
recovery state and MST link probe parameters in that case as well.

v2: Set intel_dp::reset_link_params instead of using a helper for this.
    (Ville).

Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Link: https://patch.msgid.link/20260522160514.2628249-2-imre.deak@intel.com
drivers/gpu/drm/i915/display/intel_dp.c

index 1920d2f02666556c5b3ef0d10b442ce38b7c97a4..940e73ad451d7e9275fa82f4e07d96d617f2a433 100644 (file)
@@ -6000,8 +6000,10 @@ static bool intel_dp_handle_link_service_irq(struct intel_dp *intel_dp, u8 irq_m
        drm_WARN_ON(display->drm, irq_mask & ~(INTEL_DP_LINK_SERVICE_IRQ_MASK_SST |
                                               INTEL_DP_LINK_SERVICE_IRQ_MASK_MST));
 
-       if (irq_mask & RX_CAP_CHANGED)
+       if (irq_mask & RX_CAP_CHANGED) {
+               intel_dp->reset_link_params = true;
                reprobe_needed = true;
+       }
 
        if (irq_mask & LINK_STATUS_CHANGED)
                intel_dp_check_link_state(intel_dp);