On 08/01/2025 18:35, 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> -- Matt Coster E: matt.coster@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 64cd79e1793a..f07b19c97d0f 100644 > --- a/drivers/gpu/drm/scheduler/sched_main.c > +++ b/drivers/gpu/drm/scheduler/sched_main.c > @@ -968,6 +968,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 e2e6af8849c6..a0ff08123f07 100644 > --- a/include/drm/gpu_scheduler.h > +++ b/include/drm/gpu_scheduler.h > @@ -564,7 +564,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, -- Matt Coster E: matt.coster@xxxxxxxxxx
Attachment:
OpenPGP_signature.asc
Description: OpenPGP digital signature