diff options
| author | Dave Airlie <airlied@redhat.com> | 2015-05-15 01:21:18 -0400 |
|---|---|---|
| committer | Dave Airlie <airlied@redhat.com> | 2015-05-15 01:21:18 -0400 |
| commit | 472313245645661c3bc710f874e660c493d313e1 (patch) | |
| tree | 0e6ac1f69b83c32cd8505d9863801dba7c4cea3f | |
| parent | e52f649e5b7ad61edfe2b7273831fa3b64c76149 (diff) | |
| parent | 364aece01a2dd748fc36a1e8bf52ef639b0857bd (diff) | |
Merge tag 'drm-intel-fixes-2015-05-13' of git://anongit.freedesktop.org/drm-intel into drm-fixes
fix one gpu hang on resume.
* tag 'drm-intel-fixes-2015-05-13' of git://anongit.freedesktop.org/drm-intel:
drm/i915: Avoid GPU hang when coming out of s3 or s4
| -rw-r--r-- | drivers/gpu/drm/i915/i915_drv.c | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c index c302ffb5a168..a19d2c71e205 100644 --- a/drivers/gpu/drm/i915/i915_drv.c +++ b/drivers/gpu/drm/i915/i915_drv.c | |||
| @@ -699,6 +699,16 @@ static int i915_drm_resume(struct drm_device *dev) | |||
| 699 | intel_init_pch_refclk(dev); | 699 | intel_init_pch_refclk(dev); |
| 700 | drm_mode_config_reset(dev); | 700 | drm_mode_config_reset(dev); |
| 701 | 701 | ||
| 702 | /* | ||
| 703 | * Interrupts have to be enabled before any batches are run. If not the | ||
| 704 | * GPU will hang. i915_gem_init_hw() will initiate batches to | ||
| 705 | * update/restore the context. | ||
| 706 | * | ||
| 707 | * Modeset enabling in intel_modeset_init_hw() also needs working | ||
| 708 | * interrupts. | ||
| 709 | */ | ||
| 710 | intel_runtime_pm_enable_interrupts(dev_priv); | ||
| 711 | |||
| 702 | mutex_lock(&dev->struct_mutex); | 712 | mutex_lock(&dev->struct_mutex); |
| 703 | if (i915_gem_init_hw(dev)) { | 713 | if (i915_gem_init_hw(dev)) { |
| 704 | DRM_ERROR("failed to re-initialize GPU, declaring wedged!\n"); | 714 | DRM_ERROR("failed to re-initialize GPU, declaring wedged!\n"); |
| @@ -706,9 +716,6 @@ static int i915_drm_resume(struct drm_device *dev) | |||
| 706 | } | 716 | } |
| 707 | mutex_unlock(&dev->struct_mutex); | 717 | mutex_unlock(&dev->struct_mutex); |
| 708 | 718 | ||
| 709 | /* We need working interrupts for modeset enabling ... */ | ||
| 710 | intel_runtime_pm_enable_interrupts(dev_priv); | ||
| 711 | |||
| 712 | intel_modeset_init_hw(dev); | 719 | intel_modeset_init_hw(dev); |
| 713 | 720 | ||
| 714 | spin_lock_irq(&dev_priv->irq_lock); | 721 | spin_lock_irq(&dev_priv->irq_lock); |
