On 3/26/26 13:26, Khatri, Sunil wrote:
> 
> On 26-03-2026 05:38 pm, Christian König wrote:
>> On 3/26/26 09:55, Sunil Khatri wrote:
>>> In function amdgpu_userq_evict use the function return
>>> value in the if condition instead.
>>>
>>> Signed-off-by: Sunil Khatri <[email protected]>
>>> ---
>>>  drivers/gpu/drm/amd/amdgpu/amdgpu_userq.c | 8 ++------
>>>  1 file changed, 2 insertions(+), 6 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_userq.c 
>>> b/drivers/gpu/drm/amd/amdgpu/amdgpu_userq.c
>>> index aa0e6eea9436..2a1832fce6d2 100644
>>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_userq.c
>>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_userq.c
>>> @@ -1308,17 +1308,13 @@ void
>>>  amdgpu_userq_evict(struct amdgpu_userq_mgr *uq_mgr)
>>>  {
>>>     struct amdgpu_device *adev = uq_mgr->adev;
>>> -   int ret;
>>>  
>>>     /* Wait for any pending userqueue fence work to finish */
>>> -   ret = amdgpu_userq_wait_for_signal(uq_mgr);
>>> -   if (ret)
>>> +   if (amdgpu_userq_wait_for_signal(uq_mgr))
>>>             dev_err(adev->dev, "Not evicting userqueue, timeout waiting for 
>>> work\n");
>> That actually looks like a pretty bad idea. Instead we should start printing 
>> the error code.
> Sure could add an error code in the logging.
>> But before we do that I would rather like to know why 
>> amdgpu_userq_wait_for_signal() can fail?
> dma_fence_wait_timeout is what could fail and we are returning -ETIMEDOUT. We 
> could totally avoid checking for the error here completely as we are already 
> printing the error in
> the called function below.
> ret=dma_fence_wait_timeout(f, true, msecs_to_jiffies(100));

*sigh* I explicitly NAKed that timeout before. Please change that to the 
maximum.

Additional to that please drop the extra call to dma_fence_is_signaled() before 
the wait, such stuff is completely superfluous.

Then the second parameter to dma_fence_wait_timeout should be false, this way 
we can't be interrupted any more and don't need to check the return value for 
errors.

Thanks for take a look at that,
Christian.

>                 if(ret<=0) {
>                         drm_file_err(uq_mgr->file, "Timed out waiting for 
> fence=%llu:%llu\n",
>                                      f->context, f->seqno);
>         return-ETIMEDOUT;
>                 }
>> That should never happen in the first place.
>>
>> Regards,
>> Christian.
>>
>>>  
>>> -   ret = amdgpu_userq_evict_all(uq_mgr);
>>> -   if (ret)
>>> +   if (amdgpu_userq_evict_all(uq_mgr))
>>>             dev_err(adev->dev, "Failed to evict userqueue\n");
> Here also the below function returns error and printing error too. We could 
> avoid the return value here too as we are already printing the error.
> amdgpu_userq_preempt_helper(queue);
>                 if(r)
>                         ret=r;
> 
> 
> Regards
> Sunil Khatri
> 
>>> -
>>>  }
>>>  
>>>  int amdgpu_userq_mgr_init(struct amdgpu_userq_mgr *userq_mgr, struct 
>>> drm_file *file_priv,

Reply via email to