On Tue, Sep 25, 2012 at 10:16:12AM +0100, Chris Wilson wrote: > Finishes commit 02d719562ef40483648b2cc46899d4a2ff5953bb > Author: Daniel Vetter <daniel.vetter at ffwll.ch> > Date: Thu Aug 9 16:44:54 2012 +0200 > > drm/i915: properly guard ilk ips state > > The core functions were annotated with their locking requirements, but > we overlooked that they were exported, without any control over the > locking, to debugfs. So in order to enable debugfs to read the registers > without triggering sanity checks, we change the exported entry points to > properly take the required locks before calling the core routines. > > Reported-by: yangguang <guang.a.yang at intel.com> > Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=55304 > Signed-off-by: Chris Wilson <chris at chris-wilson.co.uk> Merged, thanks for the patch. -Daniel > --- > drivers/gpu/drm/i915/intel_pm.c | 40 +++++++++++++++++++++++++++++++++++---- > 1 file changed, 36 insertions(+), 4 deletions(-) > > diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c > index 4e16cc1..f459e30 100644 > --- a/drivers/gpu/drm/i915/intel_pm.c > +++ b/drivers/gpu/drm/i915/intel_pm.c > @@ -2735,7 +2735,7 @@ static const struct cparams { > { 0, 800, 231, 23784 }, > }; > > -unsigned long i915_chipset_val(struct drm_i915_private *dev_priv) > +static unsigned long __i915_chipset_val(struct drm_i915_private *dev_priv) > { > u64 total_count, diff, ret; > u32 count1, count2, count3, m = 0, c = 0; > @@ -2789,6 +2789,22 @@ unsigned long i915_chipset_val(struct drm_i915_private *dev_priv) > return ret; > } > > +unsigned long i915_chipset_val(struct drm_i915_private *dev_priv) > +{ > + unsigned long val; > + > + if (dev_priv->info->gen != 5) > + return 0; > + > + spin_lock_irq(&mchdev_lock); > + > + val = __i915_chipset_val(dev_priv); > + > + spin_unlock_irq(&mchdev_lock); > + > + return val; > +} > + > unsigned long i915_mch_val(struct drm_i915_private *dev_priv) > { > unsigned long m, x, b; > @@ -2992,7 +3008,7 @@ void i915_update_gfx_val(struct drm_i915_private *dev_priv) > spin_unlock_irq(&mchdev_lock); > } > > -unsigned long i915_gfx_val(struct drm_i915_private *dev_priv) > +static unsigned long __i915_gfx_val(struct drm_i915_private *dev_priv) > { > unsigned long t, corr, state1, corr2, state2; > u32 pxvid, ext_v; > @@ -3029,6 +3045,22 @@ unsigned long i915_gfx_val(struct drm_i915_private *dev_priv) > return dev_priv->ips.gfx_power + state2; > } > > +unsigned long i915_gfx_val(struct drm_i915_private *dev_priv) > +{ > + unsigned long val; > + > + if (dev_priv->info->gen != 5) > + return 0; > + > + spin_lock_irq(&mchdev_lock); > + > + val = __i915_gfx_val(dev_priv); > + > + spin_unlock_irq(&mchdev_lock); > + > + return val; > +} > + > /** > * i915_read_mch_val - return value for IPS use > * > @@ -3045,8 +3077,8 @@ unsigned long i915_read_mch_val(void) > goto out_unlock; > dev_priv = i915_mch_dev; > > - chipset_val = i915_chipset_val(dev_priv); > - graphics_val = i915_gfx_val(dev_priv); > + chipset_val = __i915_chipset_val(dev_priv); > + graphics_val = __i915_gfx_val(dev_priv); > > ret = chipset_val + graphics_val; > > -- > 1.7.10.4 > > _______________________________________________ > Intel-gfx mailing list > Intel-gfx at lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/intel-gfx -- Daniel Vetter Software Engineer, Intel Corporation +41 (0) 79 365 57 48 - http://blog.ffwll.ch