On Tue, Aug 03, 2021 at 01:19:12PM -0700, Souza, Jose wrote: > On Fri, 2021-07-09 at 22:41 -0700, Matt Roper wrote: > > On Thu, Jul 08, 2021 at 02:18:26PM -0700, José Roberto de Souza wrote: > > > Alderlake-P have different values for MBUS DBOX A credits depending > > > if MBUS join is enabled or not. > > > > > > BSpec: 50343 > > > BSpec: 54369 > > > Cc: Matt Atwood <matthew.s.atwood@xxxxxxxxx> > > > Signed-off-by: José Roberto de Souza <jose.souza@xxxxxxxxx> > > > --- > > > drivers/gpu/drm/i915/display/intel_display.c | 16 ++++++++++++---- > > > 1 file changed, 12 insertions(+), 4 deletions(-) > > > > > > diff --git a/drivers/gpu/drm/i915/display/intel_display.c b/drivers/gpu/drm/i915/display/intel_display.c > > > index 65ddb6ca16e67..fe380896eb99e 100644 > > > --- a/drivers/gpu/drm/i915/display/intel_display.c > > > +++ b/drivers/gpu/drm/i915/display/intel_display.c > > > @@ -3400,13 +3400,17 @@ static void glk_pipe_scaler_clock_gating_wa(struct drm_i915_private *dev_priv, > > > intel_de_write(dev_priv, CLKGATE_DIS_PSL(pipe), val); > > > } > > > > > > -static void icl_pipe_mbus_enable(struct intel_crtc *crtc) > > > +static void icl_pipe_mbus_enable(struct intel_crtc *crtc, bool joined_mbus) > > > { > > > struct drm_i915_private *dev_priv = to_i915(crtc->base.dev); > > > enum pipe pipe = crtc->pipe; > > > u32 val; > > > > > > - val = MBUS_DBOX_A_CREDIT(2); > > > + /* Wa_22010947358:adl-p */ > > > + if (IS_ALDERLAKE_P(dev_priv)) > > > + val = joined_mbus ? MBUS_DBOX_A_CREDIT(6) : MBUS_DBOX_A_CREDIT(4); > > > + else > > > + val = MBUS_DBOX_A_CREDIT(2); > > > > If we're in single-pipe / joined-mbus mode, then we'll program the > > credits to 6. If we later turn on another pipe, reallocate the DDB, and > > turn off joined-mbus mode, we'll set that other pipe's credits to 4 > > during the sequence of hsw_crtc_enable() -> icl_pipe_mbus_enable(). But > > don't we also need to go back re-program the credits down to 4 on the > > first pipe too (which is already enabled and won't be re-calling > > hsw_crtc_enable())? > > > > I might be missing something; it's been a while since I really looked at > > any of the dbuf stuff... > > skl_compute_ddb() is handling this cases, it will force a modeset in all pipes in cases like this. > Ah, that's right. Reviewed-by: Matt Roper <matthew.d.roper@xxxxxxxxx> > > > > > > Matt > > > > > > > > if (DISPLAY_VER(dev_priv) >= 12) { > > > val |= MBUS_DBOX_BW_CREDIT(2); > > > @@ -3561,8 +3565,12 @@ static void hsw_crtc_enable(struct intel_atomic_state *state, > > > if (dev_priv->display.initial_watermarks) > > > dev_priv->display.initial_watermarks(state, crtc); > > > > > > - if (DISPLAY_VER(dev_priv) >= 11) > > > - icl_pipe_mbus_enable(crtc); > > > + if (DISPLAY_VER(dev_priv) >= 11) { > > > + const struct intel_dbuf_state *dbuf_state = > > > + intel_atomic_get_new_dbuf_state(state); > > > + > > > + icl_pipe_mbus_enable(crtc, dbuf_state->joined_mbus); > > > + } > > > > > > if (new_crtc_state->bigjoiner_slave) > > > intel_crtc_vblank_on(new_crtc_state); > > > -- > > > 2.32.0 > > > > > > _______________________________________________ > > > Intel-gfx mailing list > > > Intel-gfx@xxxxxxxxxxxxxxxxxxxxx > > > https://lists.freedesktop.org/mailman/listinfo/intel-gfx > > > -- Matt Roper Graphics Software Engineer VTT-OSGC Platform Enablement Intel Corporation (916) 356-2795