[Intel-gfx] [PATCH] drm/i915/skl: Correct other-pipe watermark update condition check

Ville Syrjälä ville.syrjala at linux.intel.com
Mon Oct 19 06:00:18 PDT 2015


On Mon, Oct 19, 2015 at 11:29:59AM +0200, Daniel Vetter wrote:
> On Mon, Sep 21, 2015 at 11:32:44PM +0530, Kumar, Mahesh wrote:
> > If ddb allocation for planes in current CRTC is changed, that doesn't
> > lead to ddb allocation change for other CRTCs, because our DDB allocation
> > is not dynamic according to plane parameters, ddb is allocated according
> > to number of CRTC enabled, & divided equally among CTRC's.
> > 
> > In current condition check during Watermark calculation, if number of
> > plane/ddb allocation changes for current CRTC, Watermark for other pipes
> > are recalculated. But there is no change in DDB allocation of other pipe
> > so watermark is also not changed, This leads to warning messages.
> > WARN_ON(!wm_changed)
> > 
> > This patch corrects this and check if DDB allocation for pipes is changed,
> > then only recalculate watermarks.
> > 
> > Signed-off-by: Kumar, Mahesh <mahesh1.kumar at intel.com>
> > ---
> >  drivers/gpu/drm/i915/intel_pm.c | 12 +++++-------
> >  1 file changed, 5 insertions(+), 7 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c
> > index 62de97e..a1ed920 100644
> > --- a/drivers/gpu/drm/i915/intel_pm.c
> > +++ b/drivers/gpu/drm/i915/intel_pm.c
> > @@ -3127,14 +3127,12 @@ static bool skl_ddb_allocation_changed(const struct skl_ddb_allocation *new_ddb,
> >  	struct drm_device *dev = intel_crtc->base.dev;
> >  	struct drm_i915_private *dev_priv = dev->dev_private;
> >  	const struct skl_ddb_allocation *cur_ddb = &dev_priv->wm.skl_hw.ddb;
> > -	enum pipe pipe = intel_crtc->pipe;
> > -
> > -	if (memcmp(new_ddb->plane[pipe], cur_ddb->plane[pipe],
> > -		   sizeof(new_ddb->plane[pipe])))
> > -		return true;
> >  
> > -	if (memcmp(&new_ddb->cursor[pipe], &cur_ddb->cursor[pipe],
> > -		    sizeof(new_ddb->cursor[pipe])))
> > +	/*
> > +	 * If ddb allocation of pipes chenged, it may require recalculation of
> > +	 * watermarks
> > +	 */
> > +	if (memcmp(new_ddb->pipe, cur_ddb->pipe, sizeof(new_ddb->pipe)))
> >  		return true;
> 
> I still have the cursor code here, this patch needs to be rebased.

I suppose you mean you have the other cursor code there, cause this one
has it too, just looking a bit different.

-- 
Ville Syrjälä
Intel OTC


More information about the Intel-gfx mailing list