[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