Commit 66dbd900 authored by Matthew Brost's avatar Matthew Brost Committed by Dave Airlie

drm/sched: Drain all entities in DRM sched run job worker

All entities must be drained in the DRM scheduler run job worker to
avoid the following case. An entity found that is ready, no job found
ready on entity, and run job worker goes idle with other entities + jobs
ready. Draining all ready entities (i.e. loop over all ready entities)
in the run job worker ensures all job that are ready will be scheduled.

Cc: Thorsten Leemhuis <regressions@leemhuis.info>
Reported-by: default avatarMikhail Gavrilov <mikhail.v.gavrilov@gmail.com>
Closes: https://lore.kernel.org/all/CABXGCsM2VLs489CH-vF-1539-s3in37=bwuOWtoeeE+q26zE+Q@mail.gmail.com/Reported-and-tested-by: default avatarMario Limonciello <mario.limonciello@amd.com>
Closes: https://gitlab.freedesktop.org/drm/amd/-/issues/3124
Link: https://lore.kernel.org/all/20240123021155.2775-1-mario.limonciello@amd.com/Reported-and-tested-by: default avatarVlastimil Babka <vbabka@suse.cz>
Closes: https://lore.kernel.org/dri-devel/05ddb2da-b182-4791-8ef7-82179fd159a8@amd.com/T/#m0c31d4d1b9ae9995bb880974c4f1dbaddc33a48aSigned-off-by: default avatarMatthew Brost <matthew.brost@intel.com>
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240124210811.1639040-1-matthew.brost@intel.com
parent 77fe8f19
...@@ -1178,21 +1178,20 @@ static void drm_sched_run_job_work(struct work_struct *w) ...@@ -1178,21 +1178,20 @@ static void drm_sched_run_job_work(struct work_struct *w)
struct drm_sched_entity *entity; struct drm_sched_entity *entity;
struct dma_fence *fence; struct dma_fence *fence;
struct drm_sched_fence *s_fence; struct drm_sched_fence *s_fence;
struct drm_sched_job *sched_job; struct drm_sched_job *sched_job = NULL;
int r; int r;
if (READ_ONCE(sched->pause_submit)) if (READ_ONCE(sched->pause_submit))
return; return;
entity = drm_sched_select_entity(sched); /* Find entity with a ready job */
while (!sched_job && (entity = drm_sched_select_entity(sched))) {
sched_job = drm_sched_entity_pop_job(entity);
if (!sched_job)
complete_all(&entity->entity_idle);
}
if (!entity) if (!entity)
return;
sched_job = drm_sched_entity_pop_job(entity);
if (!sched_job) {
complete_all(&entity->entity_idle);
return; /* No more work */ return; /* No more work */
}
s_fence = sched_job->s_fence; s_fence = sched_job->s_fence;
......
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