drm/amdkfd: Register/Deregister process on qpd resolution
Process registration needs to happen on each device. So use per-device queue lists to determine when to register/deregister the process. Signed-off-by: Ben Goz <ben.goz@amd.com> Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com> Reviewed-by: Oded Gabbay <oded.gabbay@gmail.com> Signed-off-by: Oded Gabbay <oded.gabbay@gmail.com>
This commit is contained in:
parent
062c5672d5
commit
5a29ad6b9e
@ -177,7 +177,8 @@ int pqm_create_queue(struct process_queue_manager *pqm,
|
||||
if (retval != 0)
|
||||
return retval;
|
||||
|
||||
if (list_empty(&pqm->queues)) {
|
||||
if (list_empty(&pdd->qpd.queues_list) &&
|
||||
list_empty(&pdd->qpd.priv_queue_list)) {
|
||||
pdd->qpd.pqm = pqm;
|
||||
dev->dqm->ops.register_process(dev->dqm, &pdd->qpd);
|
||||
}
|
||||
@ -248,7 +249,8 @@ err_create_queue:
|
||||
err_allocate_pqn:
|
||||
/* check if queues list is empty unregister process from device */
|
||||
clear_bit(*qid, pqm->queue_slot_bitmap);
|
||||
if (list_empty(&pqm->queues))
|
||||
if (list_empty(&pdd->qpd.queues_list) &&
|
||||
list_empty(&pdd->qpd.priv_queue_list))
|
||||
dev->dqm->ops.unregister_process(dev->dqm, &pdd->qpd);
|
||||
return retval;
|
||||
}
|
||||
@ -302,7 +304,8 @@ int pqm_destroy_queue(struct process_queue_manager *pqm, unsigned int qid)
|
||||
kfree(pqn);
|
||||
clear_bit(qid, pqm->queue_slot_bitmap);
|
||||
|
||||
if (list_empty(&pqm->queues))
|
||||
if (list_empty(&pdd->qpd.queues_list) &&
|
||||
list_empty(&pdd->qpd.priv_queue_list))
|
||||
dqm->ops.unregister_process(dqm, &pdd->qpd);
|
||||
|
||||
return retval;
|
||||
|
Loading…
x
Reference in New Issue
Block a user