aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>2018-03-14 01:48:25 -0400
committerJoonas Lahtinen <joonas.lahtinen@linux.intel.com>2018-03-27 04:19:49 -0400
commit7a7d58dc2997b6ca5bc1eaa4bd8d019cf7c4a148 (patch)
tree1818c56e9370227cdb8c092c8c5ad089097548b0
parent33d009cd889490838c5db9b9339856c9e3d3facc (diff)
drm/i915/dp: Write to SET_POWER dpcd to enable MST hub.
If bios sets up an MST output and hardware state readout code sees this is an SST configuration, when disabling the encoder we end up calling ->post_disable_dp() hook instead of the MST version. Consequently, we write to the DP_SET_POWER dpcd to set it D3 state. Further along when we try enable the encoder in MST mode, POWER_UP_PHY transaction fails to power up the MST hub. This results in continuous link training failures which keep the system busy delaying boot. We could identify bios MST boot discrepancy and handle it accordingly but a simple way to solve this is to write to the DP_SET_POWER dpcd for MST too. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=105470 Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Cc: Jani Nikula <jani.nikula@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Reported-by: Laura Abbott <labbott@redhat.com> Cc: stable@vger.kernel.org Fixes: 5ea2355a100a ("drm/i915/mst: Use MST sideband message transactions for dpms control") Tested-by: Laura Abbott <labbott@redhat.com> Signed-off-by: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com> Signed-off-by: Jani Nikula <jani.nikula@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20180314054825.1718-1-dhinakaran.pandiyan@intel.com (cherry picked from commit ad260ab32a4d94fa974f58262f8000472d34fd5b) Signed-off-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
-rw-r--r--drivers/gpu/drm/i915/intel_ddi.c7
1 files changed, 2 insertions, 5 deletions
diff --git a/drivers/gpu/drm/i915/intel_ddi.c b/drivers/gpu/drm/i915/intel_ddi.c
index dbcf1a0586f9..8c2d778560f0 100644
--- a/drivers/gpu/drm/i915/intel_ddi.c
+++ b/drivers/gpu/drm/i915/intel_ddi.c
@@ -2205,8 +2205,7 @@ static void intel_ddi_pre_enable_dp(struct intel_encoder *encoder,
2205 intel_prepare_dp_ddi_buffers(encoder, crtc_state); 2205 intel_prepare_dp_ddi_buffers(encoder, crtc_state);
2206 2206
2207 intel_ddi_init_dp_buf_reg(encoder); 2207 intel_ddi_init_dp_buf_reg(encoder);
2208 if (!is_mst) 2208 intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
2209 intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
2210 intel_dp_start_link_train(intel_dp); 2209 intel_dp_start_link_train(intel_dp);
2211 if (port != PORT_A || INTEL_GEN(dev_priv) >= 9) 2210 if (port != PORT_A || INTEL_GEN(dev_priv) >= 9)
2212 intel_dp_stop_link_train(intel_dp); 2211 intel_dp_stop_link_train(intel_dp);
@@ -2304,14 +2303,12 @@ static void intel_ddi_post_disable_dp(struct intel_encoder *encoder,
2304 struct drm_i915_private *dev_priv = to_i915(encoder->base.dev); 2303 struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2305 struct intel_digital_port *dig_port = enc_to_dig_port(&encoder->base); 2304 struct intel_digital_port *dig_port = enc_to_dig_port(&encoder->base);
2306 struct intel_dp *intel_dp = &dig_port->dp; 2305 struct intel_dp *intel_dp = &dig_port->dp;
2307 bool is_mst = intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_DP_MST);
2308 2306
2309 /* 2307 /*
2310 * Power down sink before disabling the port, otherwise we end 2308 * Power down sink before disabling the port, otherwise we end
2311 * up getting interrupts from the sink on detecting link loss. 2309 * up getting interrupts from the sink on detecting link loss.
2312 */ 2310 */
2313 if (!is_mst) 2311 intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
2314 intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
2315 2312
2316 intel_disable_ddi_buf(encoder); 2313 intel_disable_ddi_buf(encoder);
2317 2314