Commit e16302cb authored by Chris Wilson's avatar Chris Wilson

drm/i915/selftests: Release ctx->engine_mutex after iteration

A lock once taken must be released again.

Fixes: c31c9e82 ("drm/i915/selftests: Teach switch_to_context() to use the context")
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Cc: Matthew Auld <matthew.auld@intel.com>
Reviewed-by: default avatarTvrtko Ursulin <tvrtko.ursulin@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20191022223316.12662-1-chris@chris-wilson.co.uk
parent f79520bb
...@@ -19,18 +19,22 @@ static int switch_to_context(struct i915_gem_context *ctx) ...@@ -19,18 +19,22 @@ static int switch_to_context(struct i915_gem_context *ctx)
{ {
struct i915_gem_engines_iter it; struct i915_gem_engines_iter it;
struct intel_context *ce; struct intel_context *ce;
int err = 0;
for_each_gem_engine(ce, i915_gem_context_lock_engines(ctx), it) { for_each_gem_engine(ce, i915_gem_context_lock_engines(ctx), it) {
struct i915_request *rq; struct i915_request *rq;
rq = intel_context_create_request(ce); rq = intel_context_create_request(ce);
if (IS_ERR(rq)) if (IS_ERR(rq)) {
return PTR_ERR(rq); err = PTR_ERR(rq);
break;
}
i915_request_add(rq); i915_request_add(rq);
} }
i915_gem_context_unlock_engines(ctx);
return 0; return err;
} }
static void trash_stolen(struct drm_i915_private *i915) static void trash_stolen(struct drm_i915_private *i915)
......
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