[PATCH 8/9] drm/amdkfd: Limit queue number per process and device to 127

Oded Gabbay oded.gabbay at gmail.com
Sun Oct 8 12:39:08 UTC 2017


On Wed, Sep 27, 2017 at 7:09 AM, Felix Kuehling <Felix.Kuehling at amd.com> wrote:
> 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 at amd.com>
> ---
>  drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c | 10 ++++++----
>  1 file changed, 6 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c b/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
> index 88ad178..5129dc1 100644
> --- a/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
> +++ b/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
> @@ -150,6 +150,7 @@ int pqm_create_queue(struct process_queue_manager *pqm,
>         struct process_queue_node *pqn;
>         struct kernel_queue *kq;
>         enum kfd_queue_type type = properties->type;
> +       unsigned int max_queues = 127; /* HWS limit */
>
>         q = 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
>          * Hence we also check the type as well
>          */
> -       if ((pdd->qpd.is_debug) || (type == KFD_QUEUE_TYPE_DIQ)) {
> -               if (pdd->qpd.queue_count >= dev->device_info->max_no_of_hqd/2)
> -                       return -ENOSPC;
> -       }
> +       if ((pdd->qpd.is_debug) || (type == KFD_QUEUE_TYPE_DIQ))
> +               max_queues = dev->device_info->max_no_of_hqd/2;
> +
> +       if (pdd->qpd.queue_count >= max_queues)
> +               return -ENOSPC;
>
>         retval = find_available_queue_slot(pqm, qid);
>         if (retval != 0)
> --
> 2.7.4
>
This patch is:
Reviewed-by: Oded Gabbay <oded.gabbay at gmail.com>


More information about the amd-gfx mailing list