[PATCH] drm/amdkfd: Fix static checker warning on MES queue type

Sider, Graham Graham.Sider at amd.com
Thu May 12 22:32:47 UTC 2022


[AMD Official Use Only - General]

Thanks for mentioning, yes I'll add a reported-by for Dan on the commit.

Best,
Graham

> -----Original Message-----
> From: Alex Deucher <alexdeucher at gmail.com>
> Sent: Thursday, May 12, 2022 5:33 PM
> To: Sider, Graham <Graham.Sider at amd.com>
> Cc: amd-gfx list <amd-gfx at lists.freedesktop.org>; Joshi, Mukul
> <Mukul.Joshi at amd.com>; Kuehling, Felix <Felix.Kuehling at amd.com>; Dan
> Carpenter <dan.carpenter at oracle.com>
> Subject: Re: [PATCH] drm/amdkfd: Fix static checker warning on MES queue
> type
> 
> [CAUTION: External Email]
> 
> On Thu, May 12, 2022 at 3:17 PM Graham Sider <Graham.Sider at amd.com>
> wrote:
> >
> > convert_to_mes_queue_type return can be negative, but
> > queue_input.queue_type is uint32_t. Put return in integer var and cast
> > to unsigned after negative check.
> >
> > Signed-off-by: Graham Sider <Graham.Sider at amd.com>
> 
> Add a reported-by for Dan's email?
> 
> Reviewed-by: Alex Deucher <alexander.deucher at amd.com>
> 
> > ---
> >  drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c | 7 ++++---
> >  1 file changed, 4 insertions(+), 3 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
> > b/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
> > index e9c9a3a67ab0..e1797657b04c 100644
> > --- a/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
> > +++ b/drivers/gpu/drm/amd/amdkfd/kfd_device_queue_manager.c
> > @@ -176,7 +176,7 @@ static int add_queue_mes(struct
> device_queue_manager *dqm, struct queue *q,
> >         struct amdgpu_device *adev = (struct amdgpu_device *)dqm->dev-
> >adev;
> >         struct kfd_process_device *pdd = qpd_to_pdd(qpd);
> >         struct mes_add_queue_input queue_input;
> > -       int r;
> > +       int r, queue_type;
> >
> >         if (dqm->is_hws_hang)
> >                 return -EIO;
> > @@ -201,12 +201,13 @@ static int add_queue_mes(struct
> device_queue_manager *dqm, struct queue *q,
> >         queue_input.tba_addr = qpd->tba_addr;
> >         queue_input.tma_addr = qpd->tma_addr;
> >
> > -       queue_input.queue_type = convert_to_mes_queue_type(q-
> >properties.type);
> > -       if (queue_input.queue_type < 0) {
> > +       queue_type = convert_to_mes_queue_type(q->properties.type);
> > +       if (queue_type < 0) {
> >                 pr_err("Queue type not supported with MES, queue:%d\n",
> >                                 q->properties.type);
> >                 return -EINVAL;
> >         }
> > +       queue_input.queue_type = (uint32_t)queue_type;
> >
> >         if (q->gws) {
> >                 queue_input.gws_base = 0;
> > --
> > 2.25.1
> >


More information about the amd-gfx mailing list