Commit b9f78d67 authored by Tvrtko Ursulin's avatar Tvrtko Ursulin

drm/i915/selftests: Fix live_workarounds to actually do resets

The test was missing some magic ingredients to actually trigger the
resets.

In case of the full reset we need the I915_RESET_HANDOFF flag set, and in
case of engine reset we need a busy request.

Thanks to Chris for helping with reset magic.

v2:
 * Grab RPM ref over reset.
Signed-off-by: default avatarTvrtko Ursulin <tvrtko.ursulin@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20181130095211.23849-1-tvrtko.ursulin@linux.intel.com
parent 8d2f6e2f
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#include "../i915_selftest.h" #include "../i915_selftest.h"
#include "igt_spinner.h"
#include "igt_wedge_me.h" #include "igt_wedge_me.h"
#include "mock_context.h" #include "mock_context.h"
...@@ -159,35 +160,57 @@ static int check_whitelist(const struct whitelist *w, ...@@ -159,35 +160,57 @@ static int check_whitelist(const struct whitelist *w,
static int do_device_reset(struct intel_engine_cs *engine) static int do_device_reset(struct intel_engine_cs *engine)
{ {
i915_reset(engine->i915, ENGINE_MASK(engine->id), NULL); set_bit(I915_RESET_HANDOFF, &engine->i915->gpu_error.flags);
i915_reset(engine->i915, ENGINE_MASK(engine->id), "live_workarounds");
return 0; return 0;
} }
static int do_engine_reset(struct intel_engine_cs *engine) static int do_engine_reset(struct intel_engine_cs *engine)
{ {
return i915_reset_engine(engine, NULL); return i915_reset_engine(engine, "live_workarounds");
} }
static int switch_to_scratch_context(struct intel_engine_cs *engine) static int
switch_to_scratch_context(struct intel_engine_cs *engine,
struct igt_spinner *spin)
{ {
struct i915_gem_context *ctx; struct i915_gem_context *ctx;
struct i915_request *rq; struct i915_request *rq;
int err = 0;
ctx = kernel_context(engine->i915); ctx = kernel_context(engine->i915);
if (IS_ERR(ctx)) if (IS_ERR(ctx))
return PTR_ERR(ctx); return PTR_ERR(ctx);
intel_runtime_pm_get(engine->i915); intel_runtime_pm_get(engine->i915);
if (spin)
rq = igt_spinner_create_request(spin, ctx, engine, MI_NOOP);
else
rq = i915_request_alloc(engine, ctx); rq = i915_request_alloc(engine, ctx);
intel_runtime_pm_put(engine->i915); intel_runtime_pm_put(engine->i915);
kernel_context_close(ctx); kernel_context_close(ctx);
if (IS_ERR(rq))
return PTR_ERR(rq); if (IS_ERR(rq)) {
spin = NULL;
err = PTR_ERR(rq);
goto err;
}
i915_request_add(rq); i915_request_add(rq);
return 0; if (spin && !igt_wait_for_spinner(spin, rq)) {
pr_err("Spinner failed to start\n");
err = -ETIMEDOUT;
}
err:
if (err && spin)
igt_spinner_end(spin);
return err;
} }
static int check_whitelist_across_reset(struct intel_engine_cs *engine, static int check_whitelist_across_reset(struct intel_engine_cs *engine,
...@@ -195,10 +218,22 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine, ...@@ -195,10 +218,22 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine,
const struct whitelist *w, const struct whitelist *w,
const char *name) const char *name)
{ {
struct drm_i915_private *i915 = engine->i915;
bool want_spin = reset == do_engine_reset;
struct i915_gem_context *ctx; struct i915_gem_context *ctx;
struct igt_spinner spin;
int err; int err;
ctx = kernel_context(engine->i915); pr_info("Checking %d whitelisted registers (RING_NONPRIV) [%s]\n",
w->count, name);
if (want_spin) {
err = igt_spinner_init(&spin, i915);
if (err)
return err;
}
ctx = kernel_context(i915);
if (IS_ERR(ctx)) if (IS_ERR(ctx))
return PTR_ERR(ctx); return PTR_ERR(ctx);
...@@ -208,11 +243,19 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine, ...@@ -208,11 +243,19 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine,
goto out; goto out;
} }
err = switch_to_scratch_context(engine); err = switch_to_scratch_context(engine, want_spin ? &spin : NULL);
if (err) if (err)
goto out; goto out;
intel_runtime_pm_get(i915);
err = reset(engine); err = reset(engine);
intel_runtime_pm_put(i915);
if (want_spin) {
igt_spinner_end(&spin);
igt_spinner_fini(&spin);
}
if (err) { if (err) {
pr_err("%s reset failed\n", name); pr_err("%s reset failed\n", name);
goto out; goto out;
...@@ -227,7 +270,7 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine, ...@@ -227,7 +270,7 @@ static int check_whitelist_across_reset(struct intel_engine_cs *engine,
kernel_context_close(ctx); kernel_context_close(ctx);
ctx = kernel_context(engine->i915); ctx = kernel_context(i915);
if (IS_ERR(ctx)) if (IS_ERR(ctx))
return PTR_ERR(ctx); return PTR_ERR(ctx);
...@@ -259,8 +302,6 @@ static int live_reset_whitelist(void *arg) ...@@ -259,8 +302,6 @@ static int live_reset_whitelist(void *arg)
if (!whitelist_build(engine, &w)) if (!whitelist_build(engine, &w))
return 0; return 0;
pr_info("Checking %d whitelisted registers (RING_NONPRIV)\n", w.count);
set_bit(I915_RESET_BACKOFF, &error->flags); set_bit(I915_RESET_BACKOFF, &error->flags);
set_bit(I915_RESET_ENGINE + engine->id, &error->flags); set_bit(I915_RESET_ENGINE + engine->id, &error->flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment