Commit 9c2ba265 authored by Christian König's avatar Christian König

drm/scheduler: use new iterator in drm_sched_job_add_implicit_dependencies v2

Simplifying the code a bit.

v2: use dma_resv_for_each_fence
Signed-off-by: default avatarChristian König <christian.koenig@amd.com>
Reviewed-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20211005113742.1101-17-christian.koenig@amd.com
parent dbcae3bf
...@@ -699,30 +699,16 @@ int drm_sched_job_add_implicit_dependencies(struct drm_sched_job *job, ...@@ -699,30 +699,16 @@ int drm_sched_job_add_implicit_dependencies(struct drm_sched_job *job,
struct drm_gem_object *obj, struct drm_gem_object *obj,
bool write) bool write)
{ {
struct dma_resv_iter cursor;
struct dma_fence *fence;
int ret; int ret;
struct dma_fence **fences;
unsigned int i, fence_count;
if (!write) {
struct dma_fence *fence = dma_resv_get_excl_unlocked(obj->resv);
return drm_sched_job_add_dependency(job, fence);
}
ret = dma_resv_get_fences(obj->resv, NULL, &fence_count, &fences);
if (ret || !fence_count)
return ret;
for (i = 0; i < fence_count; i++) { dma_resv_for_each_fence(&cursor, obj->resv, write, fence) {
ret = drm_sched_job_add_dependency(job, fences[i]); ret = drm_sched_job_add_dependency(job, fence);
if (ret) if (ret)
break; return ret;
} }
return 0;
for (; i < fence_count; i++)
dma_fence_put(fences[i]);
kfree(fences);
return ret;
} }
EXPORT_SYMBOL(drm_sched_job_add_implicit_dependencies); EXPORT_SYMBOL(drm_sched_job_add_implicit_dependencies);
......
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