mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-08 12:52:40 -04:00
drm/amdgpu: Fix double free in amdgpu_userq_fence_driver_alloc()
The goto frees "fence_drv" so this is a double free bug. There is no
need to call amdgpu_seq64_free(adev, fence_drv->va) since the seq64
allocation failed so change the goto to goto free_fence_drv. Also
propagate the error code from amdgpu_seq64_alloc() instead of hard coding
it to -ENOMEM.
Fixes: e7cf21fbb2 ("drm/amdgpu: Few optimization and fixes for userq fence driver")
Reviewed-by: Arvind Yadav <arvind.yadav@amd.com>
Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
committed by
Alex Deucher
parent
987718c559
commit
8ff7c78bae
@@ -84,11 +84,8 @@ int amdgpu_userq_fence_driver_alloc(struct amdgpu_device *adev,
|
||||
/* Acquire seq64 memory */
|
||||
r = amdgpu_seq64_alloc(adev, &fence_drv->va, &fence_drv->gpu_addr,
|
||||
&fence_drv->cpu_addr);
|
||||
if (r) {
|
||||
kfree(fence_drv);
|
||||
r = -ENOMEM;
|
||||
goto free_seq64;
|
||||
}
|
||||
if (r)
|
||||
goto free_fence_drv;
|
||||
|
||||
memset(fence_drv->cpu_addr, 0, sizeof(u64));
|
||||
|
||||
|
||||
Reference in New Issue
Block a user