forked from Minki/linux
drm/amdkfd: Limit queue number per process and device to 127
HWS uses bit 7 in the queue number of the map process packet for an undocumented feature. Therefore the queue number per process and device must be 127 or less. 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
bc920fd4f4
commit
36c2d7eb5e
@ -150,6 +150,7 @@ int pqm_create_queue(struct process_queue_manager *pqm,
|
|||||||
struct process_queue_node *pqn;
|
struct process_queue_node *pqn;
|
||||||
struct kernel_queue *kq;
|
struct kernel_queue *kq;
|
||||||
enum kfd_queue_type type = properties->type;
|
enum kfd_queue_type type = properties->type;
|
||||||
|
unsigned int max_queues = 127; /* HWS limit */
|
||||||
|
|
||||||
q = NULL;
|
q = NULL;
|
||||||
kq = NULL;
|
kq = NULL;
|
||||||
@ -166,10 +167,11 @@ int pqm_create_queue(struct process_queue_manager *pqm,
|
|||||||
* If we are just about to create DIQ, the is_debug flag is not set yet
|
* If we are just about to create DIQ, the is_debug flag is not set yet
|
||||||
* Hence we also check the type as well
|
* Hence we also check the type as well
|
||||||
*/
|
*/
|
||||||
if ((pdd->qpd.is_debug) || (type == KFD_QUEUE_TYPE_DIQ)) {
|
if ((pdd->qpd.is_debug) || (type == KFD_QUEUE_TYPE_DIQ))
|
||||||
if (pdd->qpd.queue_count >= dev->device_info->max_no_of_hqd/2)
|
max_queues = dev->device_info->max_no_of_hqd/2;
|
||||||
return -ENOSPC;
|
|
||||||
}
|
if (pdd->qpd.queue_count >= max_queues)
|
||||||
|
return -ENOSPC;
|
||||||
|
|
||||||
retval = find_available_queue_slot(pqm, qid);
|
retval = find_available_queue_slot(pqm, qid);
|
||||||
if (retval != 0)
|
if (retval != 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user