[PATCH] drm/i915/ddi: Sanitize DDI BUF during HW readout
Imre Deak
imre.deak at intel.com
Wed Jan 15 17:55:35 UTC 2025
Signed-off-by: Imre Deak <imre.deak at intel.com>
---
drivers/gpu/drm/i915/display/intel_ddi.c | 41 ++++++++++++++++++-
drivers/gpu/drm/i915/display/intel_ddi.h | 2 +-
.../drm/i915/display/intel_modeset_setup.c | 2 +-
3 files changed, 41 insertions(+), 4 deletions(-)
diff --git a/drivers/gpu/drm/i915/display/intel_ddi.c b/drivers/gpu/drm/i915/display/intel_ddi.c
index acb986bc1f33a..2496e14e64936 100644
--- a/drivers/gpu/drm/i915/display/intel_ddi.c
+++ b/drivers/gpu/drm/i915/display/intel_ddi.c
@@ -192,6 +192,11 @@ static void mtl_wait_ddi_buf_idle(struct drm_i915_private *i915, enum port port)
void intel_wait_ddi_buf_idle(struct drm_i915_private *dev_priv,
enum port port)
{
+ if (DISPLAY_VER(dev_priv) >= 14) {
+ mtl_wait_ddi_buf_idle(dev_priv, port);
+ return;
+ }
+
if (IS_BROXTON(dev_priv)) {
udelay(16);
return;
@@ -2057,7 +2062,37 @@ void intel_ddi_disable_clock(struct intel_encoder *encoder)
encoder->disable_clock(encoder);
}
-void intel_ddi_sanitize_encoder_pll_mapping(struct intel_encoder *encoder)
+
+static void sanitize_ddi_buf(struct intel_encoder *encoder)
+{
+ struct drm_i915_private *i915 = to_i915(encoder->base.dev);
+ enum port port = encoder->port;
+ intel_wakeref_t wakeref;
+ u32 val;
+
+ if (encoder->base.crtc)
+ return;
+
+ wakeref = intel_display_power_get_if_enabled(i915, encoder->power_domain);
+ if (!wakeref)
+ return;
+
+ val = intel_de_read(i915, DDI_BUF_CTL(port));
+ if (val & DDI_BUF_CTL_ENABLE) {
+ drm_dbg_kms(&i915->drm,
+ "[ENCODER:%d:%s] DDI_BUF enabled on an inactive port, disable it\n",
+ encoder->base.base.id, encoder->base.name);
+
+ val &= ~DDI_BUF_CTL_ENABLE;
+ intel_de_write(i915, DDI_BUF_CTL(port), val);
+
+ intel_wait_ddi_buf_idle(i915, port);
+ }
+
+ intel_display_power_put(i915, encoder->power_domain, wakeref);
+}
+
+void intel_ddi_sanitize_encoder(struct intel_encoder *encoder)
{
struct drm_i915_private *i915 = to_i915(encoder->base.dev);
u32 port_mask;
@@ -2070,6 +2105,8 @@ void intel_ddi_sanitize_encoder_pll_mapping(struct intel_encoder *encoder)
if (encoder->type == INTEL_OUTPUT_DP_MST)
return;
+ sanitize_ddi_buf(encoder);
+
if (!encoder->base.crtc && intel_encoder_is_dp(encoder)) {
u8 pipe_mask;
bool is_mst;
@@ -3056,7 +3093,7 @@ static void mtl_disable_ddi_buf(struct intel_encoder *encoder,
intel_de_write(dev_priv, DDI_BUF_CTL(port), val);
/* 3.c Poll for PORT_BUF_CTL Idle Status == 1, timeout after 100us */
- mtl_wait_ddi_buf_idle(dev_priv, port);
+ intel_wait_ddi_buf_idle(dev_priv, port);
}
/* 3.d Disable D2D Link */
diff --git a/drivers/gpu/drm/i915/display/intel_ddi.h b/drivers/gpu/drm/i915/display/intel_ddi.h
index 2faadd1441e2f..6e72720daa620 100644
--- a/drivers/gpu/drm/i915/display/intel_ddi.h
+++ b/drivers/gpu/drm/i915/display/intel_ddi.h
@@ -79,7 +79,7 @@ void intel_ddi_compute_min_voltage_level(struct intel_crtc_state *crtc_state);
int intel_ddi_toggle_hdcp_bits(struct intel_encoder *intel_encoder,
enum transcoder cpu_transcoder,
bool enable, u32 hdcp_mask);
-void intel_ddi_sanitize_encoder_pll_mapping(struct intel_encoder *encoder);
+void intel_ddi_sanitize_encoder(struct intel_encoder *encoder);
int intel_ddi_level(struct intel_encoder *encoder,
const struct intel_crtc_state *crtc_state,
int lane);
diff --git a/drivers/gpu/drm/i915/display/intel_modeset_setup.c b/drivers/gpu/drm/i915/display/intel_modeset_setup.c
index 9a2bea19f17b7..9cb73deb1d37d 100644
--- a/drivers/gpu/drm/i915/display/intel_modeset_setup.c
+++ b/drivers/gpu/drm/i915/display/intel_modeset_setup.c
@@ -662,7 +662,7 @@ static void intel_sanitize_encoder(struct intel_encoder *encoder)
intel_opregion_notify_encoder(encoder, connector && has_active_crtc);
if (HAS_DDI(i915))
- intel_ddi_sanitize_encoder_pll_mapping(encoder);
+ intel_ddi_sanitize_encoder(encoder);
}
/* FIXME read out full plane state for all planes */
--
2.44.2
More information about the Intel-gfx-trybot
mailing list