On 13.01.2025 11:33, Tvrtko Ursulin wrote: > Lets isolate scheduler internals from drivers such as pvr which currently > walks the dependency array to look for fences. > > Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@xxxxxxxxxx> > Cc: Christian König <christian.koenig@xxxxxxx> > Cc: Danilo Krummrich <dakr@xxxxxxxxxx> > Cc: Matthew Brost <matthew.brost@xxxxxxxxx> > Cc: Philipp Stanner <pstanner@xxxxxxxxxx> > Reviewed-by: Matt Coster <matt.coster@xxxxxxxxxx> Acked-by: Danilo Krummrich <dakr@xxxxxxxxxx> > --- > drivers/gpu/drm/scheduler/sched_main.c | 23 +++++++++++++++++++++++ > include/drm/gpu_scheduler.h | 3 ++- > 2 files changed, 25 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/scheduler/sched_main.c b/drivers/gpu/drm/scheduler/sched_main.c > index 57da84908752..e6f1f2a8e033 100644 > --- a/drivers/gpu/drm/scheduler/sched_main.c > +++ b/drivers/gpu/drm/scheduler/sched_main.c > @@ -997,6 +997,29 @@ int drm_sched_job_add_implicit_dependencies(struct drm_sched_job *job, > } > EXPORT_SYMBOL(drm_sched_job_add_implicit_dependencies); > > +/** > + * drm_sched_job_has_dependency - check whether fence is the job's dependency > + * @job: scheduler job to check > + * @fence: fence to look for > + * > + * Returns: > + * True if @fence is found within the job's dependencies, or otherwise false. > + */ > +bool drm_sched_job_has_dependency(struct drm_sched_job *job, > + struct dma_fence *fence) > +{ > + struct dma_fence *f; > + unsigned long index; > + > + xa_for_each(&job->dependencies, index, f) { > + if (f == fence) > + return true; > + } > + > + return false; > +} > +EXPORT_SYMBOL(drm_sched_job_has_dependency); > + > /** > * drm_sched_job_cleanup - clean up scheduler job resources > * @job: scheduler job to clean up > diff --git a/include/drm/gpu_scheduler.h b/include/drm/gpu_scheduler.h > index 95e17504e46a..d118a0a57ab1 100644 > --- a/include/drm/gpu_scheduler.h > +++ b/include/drm/gpu_scheduler.h > @@ -577,7 +577,8 @@ int drm_sched_job_add_resv_dependencies(struct drm_sched_job *job, > int drm_sched_job_add_implicit_dependencies(struct drm_sched_job *job, > struct drm_gem_object *obj, > bool write); > - > +bool drm_sched_job_has_dependency(struct drm_sched_job *job, > + struct dma_fence *fence); > > void drm_sched_entity_modify_sched(struct drm_sched_entity *entity, > struct drm_gpu_scheduler **sched_list,