On Fri, Nov 10, 2017 at 09:11:01PM +0000, Ville Syrjälä wrote: > On Fri, Nov 10, 2017 at 12:58:50PM -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. > > v3: Restore comment about possibility to system hang > > to where we are sure about it, without speculation. (Ville). > > > > Cc: Radhakrishna Sripada <radhakrishna.sripada@xxxxxxxxx> > > Cc: Imre Deak <imre.deak@xxxxxxxxx> > > Cc: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> > > Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> > > Reviewed-by: Ville Syrjälä <ville.syrjala@xxxxxxxxxxxxxxx> > > Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> > > ^ double sob > > The dangers of adding tags below your sob line and using -s... exactly! thanks a lot for noticing that... I will remove when merging... > > > --- > > 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 5c7540f3f5dc..282a4664a517 100644 > > --- a/drivers/gpu/drm/i915/intel_display.c > > +++ b/drivers/gpu/drm/i915/intel_display.c > > @@ -15081,6 +15081,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)) > > + I915_WRITE(GEN9_CLKGATE_DIS_0, I915_READ(GEN9_CLKGATE_DIS_0) | > > + DARBF_GATING_DIS); > > + > > + /* WaRsPkgCStateDisplayPMReq:hsw */ > > + 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 > > */ > > @@ -15094,15 +15108,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 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx