]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
drm/i915: Detect potential i915_reset_trylock() lockups
authorChris Wilson <chris@chris-wilson.co.uk>
Tue, 12 Feb 2019 13:08:31 +0000 (13:08 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Tue, 12 Feb 2019 16:41:35 +0000 (16:41 +0000)
Use lockdep to warn before we wait indefinitely in case we may be
waiting indefinitely.

Suggested-by: Mika Kuoppala <mika.kuoppala@intel.com>
References: 2caffbf11762 ("drm/i915: Revoke mmaps and prevent access to fence registers across reset")
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Mika Kuoppala <mika.kuoppala@intel.com>
Reviewed-by: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190212130831.14425-2-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/i915_reset.c

index c1b53533ada60ab53d94499dcc3fb7bcf4007efb..12e74decd7a2895fa8c764db66844aec75f3cc7d 100644 (file)
@@ -1305,6 +1305,9 @@ int i915_reset_trylock(struct drm_i915_private *i915)
        struct i915_gpu_error *error = &i915->gpu_error;
        int srcu;
 
        struct i915_gpu_error *error = &i915->gpu_error;
        int srcu;
 
+       might_lock(&error->reset_backoff_srcu);
+       might_sleep();
+
        rcu_read_lock();
        while (test_bit(I915_RESET_BACKOFF, &error->flags)) {
                rcu_read_unlock();
        rcu_read_lock();
        while (test_bit(I915_RESET_BACKOFF, &error->flags)) {
                rcu_read_unlock();