]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
drm/i915: reinit GT power save during resume
authorImre Deak <imre.deak@intel.com>
Tue, 22 Apr 2014 17:21:07 +0000 (20:21 +0300)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Fri, 25 Apr 2014 13:43:27 +0000 (15:43 +0200)
During runtime suspend there can be a last pending rps.work, so make
sure it's canceled. Note that in the runtime suspend callback we can't
get any RPS interrupts since it's called only after the GPU goes idle
and we set the minimum RPS frequency. The next possibility for an RPS
interrupt is only after getting an RPM ref (for example because of a new
GPU command) and calling the RPM resume callback.

v2:
- patch introduced in v2 of the patchset
v3:
- Change the order of canceling the rps.work and disabling interrupts to
  avoid the race between interrupt disabling and the the rps.work. Race
  spotted by Ville.

Signed-off-by: Imre Deak <imre.deak@intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/i915_drv.c

index aa11995c023c50ce84a0ae8169f6a0750865e7f5..72e25e477c269d7cf974e2d153a0b2e867cc0eb0 100644 (file)
@@ -942,6 +942,12 @@ static int intel_runtime_suspend(struct device *device)
 
        DRM_DEBUG_KMS("Suspending device\n");
 
+       /*
+        * rps.work can't be rearmed here, since we get here only after making
+        * sure the GPU is idle and the RPS freq is set to the minimum. See
+        * intel_mark_idle().
+        */
+       cancel_work_sync(&dev_priv->rps.work);
        intel_runtime_pm_disable_interrupts(dev);
 
        if (IS_GEN6(dev))
@@ -993,6 +999,7 @@ static int intel_runtime_resume(struct device *device)
        gen6_update_ring_freq(dev);
 
        intel_runtime_pm_restore_interrupts(dev);
+       intel_reset_gt_powersave(dev);
 
        DRM_DEBUG_KMS("Device resumed\n");
        return 0;