diff options
Diffstat (limited to 'drivers/gpu/drm/i915/i915_irq.c')
-rw-r--r-- | drivers/gpu/drm/i915/i915_irq.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c index 77e42e719d7d..2a042bc173fe 100644 --- a/drivers/gpu/drm/i915/i915_irq.c +++ b/drivers/gpu/drm/i915/i915_irq.c | |||
@@ -482,6 +482,14 @@ static void i915_handle_error(struct drm_device *dev) | |||
482 | I915_WRITE(IIR, I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT); | 482 | I915_WRITE(IIR, I915_RENDER_COMMAND_PARSER_ERROR_INTERRUPT); |
483 | } | 483 | } |
484 | 484 | ||
485 | if (dev_priv->mm.wedged) { | ||
486 | /* | ||
487 | * Wakeup waiting processes so they don't hang | ||
488 | */ | ||
489 | printk("i915: Waking up sleeping processes\n"); | ||
490 | DRM_WAKEUP(&dev_priv->irq_queue); | ||
491 | } | ||
492 | |||
485 | queue_work(dev_priv->wq, &dev_priv->error_work); | 493 | queue_work(dev_priv->wq, &dev_priv->error_work); |
486 | } | 494 | } |
487 | 495 | ||