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@xxxxxxx> > Fixes: fb91065851cd ("drm/amdkfd: Refactor queue wptr_bo GART mapping") Reviewed-by: Felix Kuehling <felix.kuehling@xxxxxxx> > --- > 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;