]> Git Repo - linux.git/commit
drm/i915: Clear breadcrumb node when cancelling signaling
authorChris Wilson <[email protected]>
Wed, 15 Nov 2017 12:14:58 +0000 (12:14 +0000)
committerJani Nikula <[email protected]>
Tue, 21 Nov 2017 09:39:56 +0000 (11:39 +0200)
commit6e068270b7883836e4717e262d96d1c43690862a
treeb2c688b2d592c59c87a184bd0029326e2cb87e80
parentdcd1d8302a06b0a0e5d6f9b6851fa4a5579e79b0
drm/i915: Clear breadcrumb node when cancelling signaling

When we call intel_engine_cancel_signaling() to stop reporting when
a request is completed via an asynchronous signal, we remove that request
from the breadcrumb wait queue. However, we may be concurrently
processing that request in the signaler itself, the actual operations on
the request's node itself are serialised but we do not actually clear the
waiter after removing it from the tree allowing both parties to attempt
to do so and corrupting the rbtree. (Previously removing from the
breadcrumb wait queue could only be done on behalf of i915_wait_request,
so this race could not happen).

Reported-by: "He, Bo" <[email protected]>
Fixes: 9eb143bbec7d ("drm/i915: Allow a request to be cancelled")
Signed-off-by: Chris Wilson <[email protected]>
Cc: "He, Bo" <[email protected]>
Cc: Tvrtko Ursulin <[email protected]>
Cc: MichaƂ Winiarski <[email protected]>
Cc: Joonas Lahtinen <[email protected]>
Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
Reviewed-by: Joonas Lahtinen <[email protected]>
(cherry picked from commit c534612e780c4a2c8ef5bfc11583c7d58436baca)
Signed-off-by: Jani Nikula <[email protected]>
drivers/gpu/drm/i915/intel_breadcrumbs.c
This page took 0.050334 seconds and 4 git commands to generate.