drm/scheduler: Add stopped flag to drm_sched_entity
The flag will prevent another thread from same process to reinsert the entity queue into scheduler's rq after it was already removewd from there by another thread during drm_sched_entity_flush. Signed-off-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com> Reviewed-by: Chunming Zhou <david1.zhou@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
9c70d10ae7
commit
62347a3300
|
@ -177,8 +177,12 @@ long drm_sched_entity_flush(struct drm_sched_entity *entity, long timeout)
|
||||||
/* For killed process disable any more IBs enqueue right now */
|
/* For killed process disable any more IBs enqueue right now */
|
||||||
last_user = cmpxchg(&entity->last_user, current->group_leader, NULL);
|
last_user = cmpxchg(&entity->last_user, current->group_leader, NULL);
|
||||||
if ((!last_user || last_user == current->group_leader) &&
|
if ((!last_user || last_user == current->group_leader) &&
|
||||||
(current->flags & PF_EXITING) && (current->exit_code == SIGKILL))
|
(current->flags & PF_EXITING) && (current->exit_code == SIGKILL)) {
|
||||||
|
spin_lock(&entity->rq_lock);
|
||||||
|
entity->stopped = true;
|
||||||
drm_sched_rq_remove_entity(entity->rq, entity);
|
drm_sched_rq_remove_entity(entity->rq, entity);
|
||||||
|
spin_unlock(&entity->rq_lock);
|
||||||
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -504,6 +508,12 @@ void drm_sched_entity_push_job(struct drm_sched_job *sched_job,
|
||||||
if (first) {
|
if (first) {
|
||||||
/* Add the entity to the run queue */
|
/* Add the entity to the run queue */
|
||||||
spin_lock(&entity->rq_lock);
|
spin_lock(&entity->rq_lock);
|
||||||
|
if (entity->stopped) {
|
||||||
|
spin_unlock(&entity->rq_lock);
|
||||||
|
|
||||||
|
DRM_ERROR("Trying to push to a killed entity\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
drm_sched_rq_add_entity(entity->rq, entity);
|
drm_sched_rq_add_entity(entity->rq, entity);
|
||||||
spin_unlock(&entity->rq_lock);
|
spin_unlock(&entity->rq_lock);
|
||||||
drm_sched_wakeup(entity->rq->sched);
|
drm_sched_wakeup(entity->rq->sched);
|
||||||
|
|
|
@ -70,6 +70,7 @@ enum drm_sched_priority {
|
||||||
* @fini_status: contains the exit status in case the process was signalled.
|
* @fini_status: contains the exit status in case the process was signalled.
|
||||||
* @last_scheduled: points to the finished fence of the last scheduled job.
|
* @last_scheduled: points to the finished fence of the last scheduled job.
|
||||||
* @last_user: last group leader pushing a job into the entity.
|
* @last_user: last group leader pushing a job into the entity.
|
||||||
|
* @stopped: Marks the enity as removed from rq and destined for termination.
|
||||||
*
|
*
|
||||||
* Entities will emit jobs in order to their corresponding hardware
|
* Entities will emit jobs in order to their corresponding hardware
|
||||||
* ring, and the scheduler will alternate between entities based on
|
* ring, and the scheduler will alternate between entities based on
|
||||||
|
@ -92,6 +93,7 @@ struct drm_sched_entity {
|
||||||
atomic_t *guilty;
|
atomic_t *guilty;
|
||||||
struct dma_fence *last_scheduled;
|
struct dma_fence *last_scheduled;
|
||||||
struct task_struct *last_user;
|
struct task_struct *last_user;
|
||||||
|
bool stopped;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue