From: Dave Airlie Date: Tue, 3 May 2016 02:44:29 +0000 (+1000) Subject: drm/amdgpu: set metadata pointer to NULL after freeing. X-Git-Tag: Ubuntu-snapdragon-4.4.0-1050.54~3587 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=eb939c9690460209a6e5539aa73245a5b5e3eb9f;p=mirror_ubuntu-artful-kernel.git drm/amdgpu: set metadata pointer to NULL after freeing. BugLink: http://bugs.launchpad.net/bugs/1580754 commit 0092d3edcb23fcdb8cbe4159ba94a534290ff982 upstream. Without this there was a double free of the metadata, which ended up freeing the fd table for me here, and taking out the machine more often than not. I reproduced with X.org + modesetting DDX + latest llvm/mesa, also required using dri3. Reviewed-by: Christian König Signed-off-by: Dave Airlie Signed-off-by: Alex Deucher Signed-off-by: Greg Kroah-Hartman Signed-off-by: Tim Gardner Signed-off-by: Kamal Mostafa --- diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c index b8fbbd7699e4..73628c7599e7 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_object.c @@ -540,6 +540,7 @@ int amdgpu_bo_set_metadata (struct amdgpu_bo *bo, void *metadata, if (!metadata_size) { if (bo->metadata_size) { kfree(bo->metadata); + bo->metadata = NULL; bo->metadata_size = 0; } return 0;