]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/psr: Read Intel DPCD workaround register
authorJouni Högander <jouni.hogander@intel.com>
Fri, 15 May 2026 09:57:54 +0000 (12:57 +0300)
committerJouni Högander <jouni.hogander@intel.com>
Mon, 18 May 2026 06:06:39 +0000 (09:06 +0300)
Read Intel DPCD workaround register and store it into
intel_connector->dp.psr_caps. psr_caps was chosen as currently it contains
only PSR workaround for PSR2 SDP on prior scanline implementation.

Signed-off-by: Jouni Högander <jouni.hogander@intel.com>
Reviewed-by: Suraj Kandpal <suraj.kandpal@intel.com>
Link: https://patch.msgid.link/20260515095756.2799483-3-jouni.hogander@intel.com
drivers/gpu/drm/i915/display/intel_display_types.h
drivers/gpu/drm/i915/display/intel_psr.c

index b7bcf8fefa3e6fbe296e5f35daee464ab95776d7..f44be5c689aefb20db9570e0553e8d6b632b9118 100644 (file)
@@ -584,6 +584,7 @@ struct intel_connector {
 
                struct {
                        u8 dpcd[EDP_PSR_RECEIVER_CAP_SIZE];
+                       u8 intel_wa_dpcd;
 
                        bool support;
                        bool su_support;
index 892d209dce1b85aa312983202548a83678e8dcec..03a2377c315c0424dd34b8befea2adc2b8c8c1f4 100644 (file)
@@ -44,6 +44,7 @@
 #include "intel_display_wa.h"
 #include "intel_dmc.h"
 #include "intel_dp.h"
+#include "intel_dpcd.h"
 #include "intel_dp_aux.h"
 #include "intel_dp_tunnel.h"
 #include "intel_dsb.h"
@@ -720,8 +721,14 @@ static void _psr_init_dpcd(struct intel_dp *intel_dp, struct intel_connector *co
                            connector->dp.psr_caps.su_support ? "" : "not ");
        }
 
-       if (connector->dp.psr_caps.su_support)
+       if (connector->dp.psr_caps.su_support) {
+               ret = drm_dp_dpcd_read_byte(&intel_dp->aux,
+                                           INTEL_DPCD_INTEL_WA_REGISTER_CAPS,
+                                           &connector->dp.psr_caps.intel_wa_dpcd);
+               if (ret < 0)
+                       return;
                _psr_compute_su_granularity(intel_dp, connector);
+       }
 }
 
 void intel_psr_init_dpcd(struct intel_dp *intel_dp, struct intel_connector *connector)