[Intel-gfx] [PATCH] drm/i915: Split a setting of MSA to MST and SST

Saarinen, Jani jani.saarinen at intel.com
Mon Nov 11 15:31:41 UTC 2019


Hi, 

> -----Original Message-----
> From: Mun, Gwan-gyeong <gwan-gyeong.mun at intel.com>
> Sent: maanantai 11. marraskuuta 2019 17.04
> To: Saarinen, Jani <jani.saarinen at intel.com>; Nikula, Jani <jani.nikula at intel.com>;
> intel-gfx at lists.freedesktop.org; Souza, Jose <jose.souza at intel.com>
> Subject: Re: [Intel-gfx] [PATCH] drm/i915: Split a setting of MSA to MST and SST
> 
> On Mon, 2019-11-11 at 11:46 +0000, Saarinen, Jani wrote:
> > Hi,
> >
> > > -----Original Message-----
> > > From: Intel-gfx <intel-gfx-bounces at lists.freedesktop.org> On Behalf
> > > Of Souza, Jose
> > > Sent: torstai 7. marraskuuta 2019 23.16
> > > To: Mun, Gwan-gyeong <gwan-gyeong.mun at intel.com>; intel-
> > > gfx at lists.freedesktop.org
> > > Subject: Re: [Intel-gfx] [PATCH] drm/i915: Split a setting of MSA to
> > > MST and SST
> > >
> > > On Wed, 2019-11-06 at 23:26 +0200, Gwan-gyeong Mun wrote:
> > > > 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.
> > >
> > > Reviewed-by: José Roberto de Souza <jose.souza at intel.com>
> > Also Tested-by: Jani Saarinen <jani.saarinen at intel.com> On Dell XPS
> > without patch even booting with console (runlevel 3) screen black on
> > second monitor after DP MST monitor.
> > Dell XPS  (KBL) > TypeC-to DP tp Dell 4K MST monitor and from that to
> > DP monitor (Dell) and this last in the chain black.
> > But with patched kernel screen visible.
> >
> > GG, is issues seen in Shards real or can this be merged now?
> Hi Jani Saarinen,
> IMHO, the reported possible regression seemed not related to this patch.
> I commented and replied to the regression report mail of Rev 3.
> 
> Jani N, if you are available, could you review and merge the patch?
Ville already did 😉 

> 
> Br,
> 
> G.G.
> > > > Cc: Ville Syrjälä <ville.syrjala at linux.intel.com>
> > > > Cc: Stanislav Lisovskiy <stanislav.lisovskiy at 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 at 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,
> > > _______________________________________________
> > > Intel-gfx mailing list
> > > Intel-gfx at lists.freedesktop.org
> > > https://lists.freedesktop.org/mailman/listinfo/intel-gfx


More information about the Intel-gfx mailing list