[Intel-gfx] [PATCH] drm/i915: handle faked missed interrupts as simulated hangs, too

Daniel Vetter daniel at ffwll.ch
Wed Oct 30 10:36:46 CET 2013


On Mon, Oct 28, 2013 at 09:24:13AM +0100, Daniel Vetter wrote:
> Otherwise QA will report this as a real hang when running igt
> ZZ_missed_irq.
> 
> v2: Actually test the right stuff and really shut up the DRM_ERROR
> output ...
> 
> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=70747
> Tested-by: lu hua <huax.lu at intel.com>
> Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch>

Merged with Chris' irc-ack.
-Daniel

> ---
>  drivers/gpu/drm/i915/i915_irq.c | 8 ++++++--
>  1 file changed, 6 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
> index 1a7dc7754e2f..68936da7c25d 100644
> --- a/drivers/gpu/drm/i915/i915_irq.c
> +++ b/drivers/gpu/drm/i915/i915_irq.c
> @@ -2258,8 +2258,12 @@ static void i915_hangcheck_elapsed(unsigned long data)
>  				if (waitqueue_active(&ring->irq_queue)) {
>  					/* Issue a wake-up to catch stuck h/w. */
>  					if (!test_and_set_bit(ring->id, &dev_priv->gpu_error.missed_irq_rings)) {
> -						DRM_ERROR("Hangcheck timer elapsed... %s idle\n",
> -							  ring->name);
> +						if (!(dev_priv->gpu_error.test_irq_rings & intel_ring_flag(ring)))
> +							DRM_ERROR("Hangcheck timer elapsed... %s idle\n",
> +								  ring->name);
> +						else
> +							DRM_INFO("Fake missed irq on %s\n",
> +								 ring->name);
>  						wake_up_all(&ring->irq_queue);
>  					}
>  					/* Safeguard against driver failure */
> -- 
> 1.8.4.rc3
> 

-- 
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch



More information about the Intel-gfx mailing list