From: Paulo Zanoni <[email protected]>

Just a missing register. There is no problem to run this code when the
output is HDMI.

Signed-off-by: Paulo Zanoni <[email protected]>
---
 drivers/gpu/drm/i915/intel_ddi.c | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/i915/intel_ddi.c b/drivers/gpu/drm/i915/intel_ddi.c
index dd28e35..fed7856 100644
--- a/drivers/gpu/drm/i915/intel_ddi.c
+++ b/drivers/gpu/drm/i915/intel_ddi.c
@@ -961,15 +961,25 @@ static void intel_ddi_disable_port(struct 
drm_i915_private *dev_priv,
                                   enum port port)
 {
        uint32_t reg, val;
+       bool wait = false;
 
        reg = DDI_BUF_CTL(port);
        val = I915_READ(reg);
        if (val & DDI_BUF_CTL_ENABLE) {
                val &= ~DDI_BUF_CTL_ENABLE;
                I915_WRITE(reg, val);
-               intel_wait_ddi_buf_idle(dev_priv, port);
+               wait = true;
        }
 
+       reg = DP_TP_CTL(port);
+       val = I915_READ(reg);
+       val &= ~(DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_MASK);
+       val |= DP_TP_CTL_LINK_TRAIN_PAT1;
+       I915_WRITE(reg, val);
+
+       if (wait)
+               intel_wait_ddi_buf_idle(dev_priv, port);
+
        switch (I915_READ(PORT_CLK_SEL(port))) {
        case PORT_CLK_SEL_WRPLL1:
                reg = WRPLL_CTL1;
-- 
1.7.11.2

_______________________________________________
Intel-gfx mailing list
[email protected]
http://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to