Commit f86a802b authored by Chris Wilson's avatar Chris Wilson

dma-fence: Avoid list_del during fence->cb_list iteration

Before we notify the fence signal callback, we remove the cb from the
list. However, since we are processing the entire list from underneath
the spinlock, we do not need to individual delete each element, but can
simply reset the link and the entire list.
Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: Christian König <christian.koenig@amd.com>
Reviewed-by: default avatarChristian König <christian.koenig@amd.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190817144736.7826-4-chris@chris-wilson.co.uk
parent 4fe3997a
...@@ -149,9 +149,12 @@ int dma_fence_signal_locked(struct dma_fence *fence) ...@@ -149,9 +149,12 @@ int dma_fence_signal_locked(struct dma_fence *fence)
trace_dma_fence_signaled(fence); trace_dma_fence_signaled(fence);
} }
list_for_each_entry_safe(cur, tmp, &fence->cb_list, node) { if (!list_empty(&fence->cb_list)) {
list_del_init(&cur->node); list_for_each_entry_safe(cur, tmp, &fence->cb_list, node) {
cur->func(fence, cur); INIT_LIST_HEAD(&cur->node);
cur->func(fence, cur);
}
INIT_LIST_HEAD(&fence->cb_list);
} }
return ret; return ret;
} }
......
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