Message ID | 1392829166-25341-1-git-send-email-mika.kuoppala@intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Wed, Feb 19, 2014 at 06:59:25PM +0200, mika.kuoppala@intel.com wrote: > From: Mika Kuoppala <mika.kuoppala@intel.com> > > When we get control from BIOS there might be mt forcewake > bits already set. Apparently double write into mt forcewake > without proper clear/ack sequence in between will cause > system hang. > I'd remove the bit about the hang, since we can't really explain it, and while I am at it, I'd remove it from the previous patch I reviewed to, but whatever. > Fix this by clearing mt forcewake register on init, > like we do with older gens. > > Signed-off-by: Mika Kuoppala <mika.kuoppala@intel.com> Either way: Reviewed-by: Ben Widawsky <ben@bwidawsk.net> > --- > drivers/gpu/drm/i915/intel_uncore.c | 10 +++++----- > 1 file changed, 5 insertions(+), 5 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_uncore.c b/drivers/gpu/drm/i915/intel_uncore.c > index c628414..25ceac4 100644 > --- a/drivers/gpu/drm/i915/intel_uncore.c > +++ b/drivers/gpu/drm/i915/intel_uncore.c > @@ -305,13 +305,13 @@ static void intel_uncore_forcewake_reset(struct drm_device *dev) > { > struct drm_i915_private *dev_priv = dev->dev_private; > > - if (IS_VALLEYVIEW(dev)) { > + if (IS_VALLEYVIEW(dev)) > vlv_force_wake_reset(dev_priv); > - } else if (INTEL_INFO(dev)->gen >= 6) { > + else if (IS_GEN6(dev) || IS_GEN7(dev)) > __gen6_gt_force_wake_reset(dev_priv); > - if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev)) > - __gen6_gt_force_wake_mt_reset(dev_priv); > - } > + > + if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev) || IS_GEN8(dev)) > + __gen6_gt_force_wake_mt_reset(dev_priv); > } > > void intel_uncore_early_sanitize(struct drm_device *dev) > -- > 1.7.9.5 > > --------------------------------------------------------------------- > Intel Finland Oy > Registered Address: PL 281, 00181 Helsinki > Business Identity Code: 0357606 - 4 > Domiciled in Helsinki > > This e-mail and any attachments may contain confidential material for > the sole use of the intended recipient(s). Any review or distribution > by others is strictly prohibited. If you are not the intended > recipient, please contact the sender and delete all copies. > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/intel-gfx
diff --git a/drivers/gpu/drm/i915/intel_uncore.c b/drivers/gpu/drm/i915/intel_uncore.c index c628414..25ceac4 100644 --- a/drivers/gpu/drm/i915/intel_uncore.c +++ b/drivers/gpu/drm/i915/intel_uncore.c @@ -305,13 +305,13 @@ static void intel_uncore_forcewake_reset(struct drm_device *dev) { struct drm_i915_private *dev_priv = dev->dev_private; - if (IS_VALLEYVIEW(dev)) { + if (IS_VALLEYVIEW(dev)) vlv_force_wake_reset(dev_priv); - } else if (INTEL_INFO(dev)->gen >= 6) { + else if (IS_GEN6(dev) || IS_GEN7(dev)) __gen6_gt_force_wake_reset(dev_priv); - if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev)) - __gen6_gt_force_wake_mt_reset(dev_priv); - } + + if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev) || IS_GEN8(dev)) + __gen6_gt_force_wake_mt_reset(dev_priv); } void intel_uncore_early_sanitize(struct drm_device *dev)