drm/i915: Hold a ref to the ring while retiring
As the final request on a ring may hold the reference to this ring (via retiring the last pinned context), we may find ourselves chasing a dangling pointer on completion of the list. A quick solution is to hold a reference to the ring itself as we retire along it so that we only free it after we stop dereferencing it. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20190318095204.9913-4-chris@chris-wilson.co.uk
This commit is contained in:
@@ -1230,7 +1230,7 @@ static void execlists_submit_request(struct i915_request *request)
|
||||
|
||||
static void __execlists_context_fini(struct intel_context *ce)
|
||||
{
|
||||
intel_ring_free(ce->ring);
|
||||
intel_ring_put(ce->ring);
|
||||
|
||||
GEM_BUG_ON(i915_gem_object_is_active(ce->state->obj));
|
||||
i915_gem_object_put(ce->state->obj);
|
||||
@@ -2867,7 +2867,7 @@ static int execlists_context_deferred_alloc(struct intel_context *ce,
|
||||
return 0;
|
||||
|
||||
error_ring_free:
|
||||
intel_ring_free(ring);
|
||||
intel_ring_put(ring);
|
||||
error_deref_obj:
|
||||
i915_gem_object_put(ctx_obj);
|
||||
return ret;
|
||||
|
Reference in New Issue
Block a user