提交 d9e600b2 编写于 作者: C Chris Wilson 提交者: Daniel Vetter

drm/i915: Only call mod_timer() if not already pending

The final arrangement of updating timer->expires and calling mod_timer()
used in

commit 672e7b7c
Author: Chris Wilson <chris@chris-wilson.co.uk>
Date:   Wed Nov 19 09:47:19 2014 +0000

    drm/i915: Don't continually defer the hangcheck

turns out to be very unsafe. Try again.
Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
Cc: Mika Kuoppala <mika.kuoppala@intel.com>
Signed-off-by: NDaniel Vetter <daniel.vetter@ffwll.ch>
上级 bbd440fb
...@@ -3067,9 +3067,10 @@ void i915_queue_hangcheck(struct drm_device *dev) ...@@ -3067,9 +3067,10 @@ void i915_queue_hangcheck(struct drm_device *dev)
return; return;
/* Don't continually defer the hangcheck, but make sure it is active */ /* Don't continually defer the hangcheck, but make sure it is active */
if (!timer_pending(timer)) if (timer_pending(timer))
timer->expires = round_jiffies_up(jiffies + DRM_I915_HANGCHECK_JIFFIES); return;
mod_timer(timer, timer->expires); mod_timer(timer,
round_jiffies_up(jiffies + DRM_I915_HANGCHECK_JIFFIES));
} }
static void ibx_irq_reset(struct drm_device *dev) static void ibx_irq_reset(struct drm_device *dev)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册