[Intel-gfx] [PATCH] drm/i915: Display WA #1185 WaDisableDARBFClkGating:cnl, glk

Ville Syrjälä ville.syrjala at linux.intel.com
Fri Nov 10 20:44:01 UTC 2017


On Fri, Nov 10, 2017 at 12:24:24PM -0800, Rodrigo Vivi wrote:
> On Fri, Nov 10, 2017 at 08:13:44PM +0000, Ville Syrjälä wrote:
> > On Thu, Nov 09, 2017 at 02:26:32PM -0800, Rodrigo Vivi wrote:
> > > Display is not sending a PMRsp when a PMReq is received
> > > at the same time that all planes are turned off.
> > > State machine in the dcprunit is stuck in the WAIT4DONE
> > > state which means that there is no fill_done.
> > > 
> > > WA: disable arbiter clock gating, set bit [27] of 0x46530
> > > 
> > > v2: As Ville pointed out, based on the description the issue
> > >     can happen when disabling the planes, similar to
> > >     WaRsPkgCStateDisplayPMReq:hsw
> > >     Also description of the issue was updated on commit
> > >     message to make it more clear that we need this
> > >     earlier.
> > 
> > I guess we don't know exactly if this has the same ordering requirements
> > as WaRsPkgCStateDisplayPMReq:hsw. But playing it safe can't hurt I
> > suppose.
> > 
> > > 
> > > Cc: Radhakrishna Sripada <radhakrishna.sripada at intel.com>
> > > Cc: Imre Deak <imre.deak at intel.com>
> > > Cc: Ville Syrjälä <ville.syrjala at linux.intel.com>
> > > Signed-off-by: Rodrigo Vivi <rodrigo.vivi at intel.com>
> > > ---
> > >  drivers/gpu/drm/i915/i915_reg.h      |  1 +
> > >  drivers/gpu/drm/i915/intel_display.c | 24 +++++++++++++++---------
> > >  2 files changed, 16 insertions(+), 9 deletions(-)
> > > 
> > > diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h
> > > index 6ef33422f762..fc8c5f8260f6 100644
> > > --- a/drivers/gpu/drm/i915/i915_reg.h
> > > +++ b/drivers/gpu/drm/i915/i915_reg.h
> > > @@ -3819,6 +3819,7 @@ enum {
> > >   * GEN9 clock gating regs
> > >   */
> > >  #define GEN9_CLKGATE_DIS_0		_MMIO(0x46530)
> > > +#define   DARBF_GATING_DIS		(1 << 27)
> > >  #define   PWM2_GATING_DIS		(1 << 14)
> > >  #define   PWM1_GATING_DIS		(1 << 13)
> > >  
> > > diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
> > > index 84817ccc5305..a038610b66cc 100644
> > > --- a/drivers/gpu/drm/i915/intel_display.c
> > > +++ b/drivers/gpu/drm/i915/intel_display.c
> > > @@ -15080,6 +15080,20 @@ get_encoder_power_domains(struct drm_i915_private *dev_priv)
> > >  	}
> > >  }
> > >  
> > > +/* System hang if this isn't done before disabling all planes! */
> > > +static void intel_early_display_was(struct drm_i915_private *dev_priv)
> > > +{
> > > +	/* Display WA #1185 WaDisableDARBFClkGating:cnl,glk */
> > > +	if (IS_CANNONLAKE(dev_priv) || IS_GEMINILAKE(dev_priv))
> > 
> > Bspec says GLK isn't affected.
> 
> Bspec refers to GLK as Gen10 display...
> so GEN10:All is also GLK...
> but if you look 2 columns ahead you see this:
> GEN:BUG:1947072 [CNL, GLK]

Ah. And the hsd does indeed list glk as well.

> 
> > 
> > > +		I915_WRITE(GEN9_CLKGATE_DIS_0, I915_READ(GEN9_CLKGATE_DIS_0) |
> > > +			   DARBF_GATING_DIS);
> > > +
> > > +	/* WaRsPkgCStateDisplayPMReq:hsw */
> > 
> > Please keep the comment about the hsw system hangs here. The next guy to
> > touch this code is probably not going to be aware of it, or may simply
> > have forgotten it already.
> 
> makes sense...
> should I keep the one in the function comment as well? and duplicate
> the comment on the new one or since we are not that sure we just leave
> the comment close to the hsw one?

I'd just keep it on the hsw one since we know that's how it works
on hsw. Having it on the cnl/glk one would be more speculation at
this point.

> 
> > 
> > With that those addresses this is
> > Reviewed-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
> 
> thanks
> 
> > 
> > > +	if (IS_HASWELL(dev_priv))
> > > +		I915_WRITE(CHICKEN_PAR1_1,
> > > +			   I915_READ(CHICKEN_PAR1_1) | FORCE_ARB_IDLE_PLANES);
> > > +}
> > > +
> > >  /* Scan out the current hw modeset state,
> > >   * and sanitizes it to the current state
> > >   */
> > > @@ -15093,15 +15107,7 @@ intel_modeset_setup_hw_state(struct drm_device *dev,
> > >  	struct intel_encoder *encoder;
> > >  	int i;
> > >  
> > > -	if (IS_HASWELL(dev_priv)) {
> > > -		/*
> > > -		 * WaRsPkgCStateDisplayPMReq:hsw
> > > -		 * System hang if this isn't done before disabling all planes!
> > > -		 */
> > > -		I915_WRITE(CHICKEN_PAR1_1,
> > > -			   I915_READ(CHICKEN_PAR1_1) | FORCE_ARB_IDLE_PLANES);
> > > -	}
> > > -
> > > +	intel_early_display_was(dev_priv);
> > >  	intel_modeset_readout_hw_state(dev);
> > >  
> > >  	/* HW state is read out, now we need to sanitize this mess. */
> > > -- 
> > > 2.13.6
> > 
> > -- 
> > Ville Syrjälä
> > Intel OTC

-- 
Ville Syrjälä
Intel OTC


More information about the Intel-gfx mailing list