Hi, > -----Original Message----- > From: Mun, Gwan-gyeong <gwan-gyeong.mun@xxxxxxxxx> > Sent: maanantai 11. marraskuuta 2019 17.04 > To: Saarinen, Jani <jani.saarinen@xxxxxxxxx>; Nikula, Jani <jani.nikula@xxxxxxxxx>; > intel-gfx@xxxxxxxxxxxxxxxxxxxxx; Souza, Jose <jose.souza@xxxxxxxxx> > Subject: Re: [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@xxxxxxxxxxxxxxxxxxxxx> On Behalf > > > Of Souza, Jose > > > Sent: torstai 7. marraskuuta 2019 23.16 > > > To: Mun, Gwan-gyeong <gwan-gyeong.mun@xxxxxxxxx>; intel- > > > gfx@xxxxxxxxxxxxxxxxxxxxx > > > Subject: Re: [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@xxxxxxxxx> > > Also Tested-by: Jani Saarinen <jani.saarinen@xxxxxxxxx> 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@xxxxxxxxxxxxxxx> > > > > Cc: Stanislav Lisovskiy <stanislav.lisovskiy@xxxxxxxxx> > > > > 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@xxxxxxxxx> > > > > --- > > > > 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@xxxxxxxxxxxxxxxxxxxxx > > > https://lists.freedesktop.org/mailman/listinfo/intel-gfx _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx