All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] drm/i915: Split a setting of MSA to MST and SST
@ 2019-11-06 21:26 ` Gwan-gyeong Mun
  0 siblings, 0 replies; 24+ messages in thread
From: Gwan-gyeong Mun @ 2019-11-06 21:26 UTC (permalink / raw)
  To: intel-gfx

The setting of MSA is done by the DDI .pre_enable() hook. And when we are
using MST, the MSA is only set to first mst stream by calling of
DDI .pre_eanble() hook. It raies issues to non-first mst streams.
Wrong MSA or missed MSA packets might show scrambled screen or wrong
screen.

This splits a setting of MSA to MST and SST cases. And In the MST case it
will call a setting of MSA after an allocating of Virtual Channel from
MST encoder pre_enable callback.

Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Cc: Stanislav Lisovskiy <stanislav.lisovskiy@intel.com>
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=112212
Fixes: 0c06fa156006 ("drm/i915/dp: Add support of BT.2020 Colorimetry to DP MSA")
Fixes: d4a415dcda35 ("drm/i915: Fix MST oops due to MSA changes")
Signed-off-by: Gwan-gyeong Mun <gwan-gyeong.mun@intel.com>
---
 drivers/gpu/drm/i915/display/intel_ddi.c    | 10 ++++++----
 drivers/gpu/drm/i915/display/intel_dp_mst.c |  3 +++
 2 files changed, 9 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_ddi.c b/drivers/gpu/drm/i915/display/intel_ddi.c
index c91521bcf06a..ef41fa0f77f0 100644
--- a/drivers/gpu/drm/i915/display/intel_ddi.c
+++ b/drivers/gpu/drm/i915/display/intel_ddi.c
@@ -1794,10 +1794,8 @@ void intel_ddi_set_dp_msa(const struct intel_crtc_state *crtc_state,
 	 * of Color Encoding Format and Content Color Gamut] while sending
 	 * YCBCR 420, HDR BT.2020 signals we should program MSA MISC1 fields
 	 * which indicate VSC SDP for the Pixel Encoding/Colorimetry Format.
-	 *
-	 * FIXME MST doesn't pass in the conn_state
 	 */
-	if (conn_state && intel_dp_needs_vsc_sdp(crtc_state, conn_state))
+	if (intel_dp_needs_vsc_sdp(crtc_state, conn_state))
 		temp |= DP_MSA_MISC_COLOR_VSC_SDP;
 
 	I915_WRITE(TRANS_MSA_MISC(cpu_transcoder), temp);
@@ -3606,7 +3604,11 @@ static void intel_ddi_pre_enable_dp(struct intel_encoder *encoder,
 	else
 		hsw_ddi_pre_enable_dp(encoder, crtc_state, conn_state);
 
-	intel_ddi_set_dp_msa(crtc_state, conn_state);
+	/* MST will call a setting of MSA after an allocating of Virtual Channel
+	 * from MST encoder pre_enable callback.
+	 */
+	if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST))
+		intel_ddi_set_dp_msa(crtc_state, conn_state);
 }
 
 static void intel_ddi_pre_enable_hdmi(struct intel_encoder *encoder,
diff --git a/drivers/gpu/drm/i915/display/intel_dp_mst.c b/drivers/gpu/drm/i915/display/intel_dp_mst.c
index 5e267c5b4c20..cb77f8072820 100644
--- a/drivers/gpu/drm/i915/display/intel_dp_mst.c
+++ b/drivers/gpu/drm/i915/display/intel_dp_mst.c
@@ -345,6 +345,9 @@ static void intel_mst_pre_enable_dp(struct intel_encoder *encoder,
 	 */
 	if (INTEL_GEN(dev_priv) < 12 || !first_mst_stream)
 		intel_ddi_enable_pipe_clock(pipe_config);
+
+	intel_ddi_set_dp_msa(pipe_config, conn_state);
+
 }
 
 static void intel_mst_enable_dp(struct intel_encoder *encoder,
-- 
2.23.0

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

^ permalink raw reply related	[flat|nested] 24+ messages in thread

end of thread, other threads:[~2019-11-11 15:31 UTC | newest]

Thread overview: 24+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-11-06 21:26 [PATCH] drm/i915: Split a setting of MSA to MST and SST Gwan-gyeong Mun
2019-11-06 21:26 ` [Intel-gfx] " Gwan-gyeong Mun
2019-11-06 23:59 ` ✗ Fi.CI.BAT: failure for " Patchwork
2019-11-06 23:59   ` [Intel-gfx] " Patchwork
2019-11-07 17:11 ` ✗ Fi.CI.BAT: failure for drm/i915: Split a setting of MSA to MST and SST (rev2) Patchwork
2019-11-07 17:11   ` [Intel-gfx] " Patchwork
2019-11-07 21:16 ` [PATCH] drm/i915: Split a setting of MSA to MST and SST Souza, Jose
2019-11-07 21:16   ` [Intel-gfx] " Souza, Jose
2019-11-11 11:46   ` Saarinen, Jani
2019-11-11 11:46     ` [Intel-gfx] " Saarinen, Jani
2019-11-11 15:04     ` Mun, Gwan-gyeong
2019-11-11 15:04       ` [Intel-gfx] " Mun, Gwan-gyeong
2019-11-11 15:31       ` Saarinen, Jani
2019-11-11 15:31         ` [Intel-gfx] " Saarinen, Jani
2019-11-07 21:46 ` ✓ Fi.CI.BAT: success for drm/i915: Split a setting of MSA to MST and SST (rev3) Patchwork
2019-11-07 21:46   ` [Intel-gfx] " Patchwork
2019-11-07 23:22 ` [PATCH] drm/i915: Split a setting of MSA to MST and SST Lucas De Marchi
2019-11-07 23:22   ` [Intel-gfx] " Lucas De Marchi
2019-11-11 14:27   ` Ville Syrjälä
2019-11-11 14:27     ` [Intel-gfx] " Ville Syrjälä
2019-11-09  5:16 ` ✗ Fi.CI.IGT: failure for drm/i915: Split a setting of MSA to MST and SST (rev3) Patchwork
2019-11-09  5:16   ` [Intel-gfx] " Patchwork
2019-11-11 14:57   ` Mun, Gwan-gyeong
2019-11-11 14:57     ` [Intel-gfx] " Mun, Gwan-gyeong

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.