[PATCH] amdkfd: properly free gang_ctx_bo when failed to init user queue

Felix Kuehling felix.kuehling at amd.com
Wed Feb 5 16:49:59 UTC 2025



On 2025-02-05 3:08, Zhu Lingshan wrote:
> The destructor of a gtt bo is declared as
> void amdgpu_amdkfd_free_gtt_mem(struct amdgpu_device *adev, void **mem_obj);
> Which takes void** as the second parameter.
> 
> GCC allows passing void* to the function because void* can be implicitly
> casted to any other types, so it can pass compiling.
> 
> However, passing this void* parameter into the function's
> execution process(which expects void** and dereferencing void**)
> will result in errors.
> 
> Signed-off-by: Zhu Lingshan <lingshan.zhu at amd.com>
> Fixes: fb91065851cd ("drm/amdkfd: Refactor queue wptr_bo GART mapping")

Reviewed-by: Felix Kuehling <felix.kuehling at amd.com>


> ---
>  drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> 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 750f967fecf5..0ce8d49ca16e 100644
> --- a/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
> +++ b/drivers/gpu/drm/amd/amdkfd/kfd_process_queue_manager.c
> @@ -295,7 +295,7 @@ static int init_user_queue(struct process_queue_manager *pqm,
>  	return 0;
>  
>  free_gang_ctx_bo:
> -	amdgpu_amdkfd_free_gtt_mem(dev->adev, (*q)->gang_ctx_bo);
> +	amdgpu_amdkfd_free_gtt_mem(dev->adev, &(*q)->gang_ctx_bo);
>  cleanup:
>  	uninit_queue(*q);
>  	*q = NULL;



More information about the amd-gfx mailing list