drm/i915: Issue engine resets onto idle engines
authorChris Wilson <chris@chris-wilson.co.uk>
Fri, 25 Jan 2019 13:22:30 +0000 (13:22 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Fri, 25 Jan 2019 14:27:30 +0000 (14:27 +0000)
Always perform the requested reset, even if we believe the engine is
idle. Presumably there was a reason the caller wanted the reset, and in
the near future we lose the easy tracking for whether the engine is
idle.

Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: John Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190125132230.22221-5-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/i915_reset.c
drivers/gpu/drm/i915/selftests/intel_hangcheck.c

index 68af017ee54864cc26c967600ca5e7be885ace4e..99bd3bc336b30437d6e31d3f7ecb953c9ba8ce2e 100644 (file)
@@ -1076,10 +1076,6 @@ int i915_reset_engine(struct intel_engine_cs *engine, const char *msg)
        GEM_TRACE("%s flags=%lx\n", engine->name, error->flags);
        GEM_BUG_ON(!test_bit(I915_RESET_ENGINE + engine->id, &error->flags));
 
-       if (i915_seqno_passed(intel_engine_get_seqno(engine),
-                             intel_engine_last_submit(engine)))
-               return 0;
-
        reset_prepare_engine(engine);
 
        if (msg)
index 8025c7e0bf6c4cc182353f7706d65ac3d84088ce..2c38ea5892d95f9bac5ed8a4b6d18948372c3dbf 100644 (file)
@@ -449,8 +449,6 @@ static int __igt_reset_engine(struct drm_i915_private *i915, bool active)
 
                set_bit(I915_RESET_ENGINE + id, &i915->gpu_error.flags);
                do {
-                       u32 seqno = intel_engine_get_seqno(engine);
-
                        if (active) {
                                struct i915_request *rq;
 
@@ -479,8 +477,6 @@ static int __igt_reset_engine(struct drm_i915_private *i915, bool active)
                                        break;
                                }
 
-                               GEM_BUG_ON(!rq->global_seqno);
-                               seqno = rq->global_seqno - 1;
                                i915_request_put(rq);
                        }
 
@@ -496,11 +492,10 @@ static int __igt_reset_engine(struct drm_i915_private *i915, bool active)
                                break;
                        }
 
-                       reset_engine_count += active;
                        if (i915_reset_engine_count(&i915->gpu_error, engine) !=
-                           reset_engine_count) {
-                               pr_err("%s engine reset %srecorded!\n",
-                                      engine->name, active ? "not " : "");
+                           ++reset_engine_count) {
+                               pr_err("%s engine reset not recorded!\n",
+                                      engine->name);
                                err = -EINVAL;
                                break;
                        }
@@ -728,7 +723,6 @@ static int __igt_reset_engines(struct drm_i915_private *i915,
 
                set_bit(I915_RESET_ENGINE + id, &i915->gpu_error.flags);
                do {
-                       u32 seqno = intel_engine_get_seqno(engine);
                        struct i915_request *rq = NULL;
 
                        if (flags & TEST_ACTIVE) {
@@ -756,9 +750,6 @@ static int __igt_reset_engines(struct drm_i915_private *i915,
                                        err = -EIO;
                                        break;
                                }
-
-                               GEM_BUG_ON(!rq->global_seqno);
-                               seqno = rq->global_seqno - 1;
                        }
 
                        err = i915_reset_engine(engine, NULL);
@@ -795,10 +786,9 @@ static int __igt_reset_engines(struct drm_i915_private *i915,
 
                reported = i915_reset_engine_count(&i915->gpu_error, engine);
                reported -= threads[engine->id].resets;
-               if (reported != (flags & TEST_ACTIVE ? count : 0)) {
-                       pr_err("i915_reset_engine(%s:%s): reset %lu times, but reported %lu, expected %lu reported\n",
-                              engine->name, test_name, count, reported,
-                              (flags & TEST_ACTIVE ? count : 0));
+               if (reported != count) {
+                       pr_err("i915_reset_engine(%s:%s): reset %lu times, but reported %lu\n",
+                              engine->name, test_name, count, reported);
                        if (!err)
                                err = -EINVAL;
                }