All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH -next] drm/amdgpu: double free error and freeing uninitialized null pointer
@ 2022-07-10 13:29 ` Sebin Sebastian
  0 siblings, 0 replies; 17+ messages in thread
From: Sebin Sebastian @ 2022-07-10 13:29 UTC (permalink / raw)
  Cc: Tom St Denis, Lijo Lazar, André Almeida,
	Somalapuram Amaranath, David Airlie, Sebin Sebastian, Pan, Xinhui,
	linux-kernel, amd-gfx, Nirmoy Das, dri-devel, Daniel Vetter,
	Alex Deucher, Evan Quan, Christian König

Fix two coverity warning's double free and and an uninitialized pointer
read. Both tmp and new are pointing at same address and both are freed
which leads to double free. Freeing tmp in the condition after new is
assigned with new address fixes the double free issue. new is not
initialized to null which also leads to a free on an uninitialized
pointer.
Coverity issue: 1518665 (uninitialized pointer read)
		1518679 (double free)

Signed-off-by: Sebin Sebastian <mailmesebin00@gmail.com>
---
 drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c
index f3b3c688e4e7..d82fe0e1b06b 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c
@@ -1660,7 +1660,7 @@ static ssize_t amdgpu_reset_dump_register_list_write(struct file *f,
 {
 	struct amdgpu_device *adev = (struct amdgpu_device *)file_inode(f)->i_private;
 	char reg_offset[11];
-	uint32_t *new, *tmp = NULL;
+	uint32_t *new = NULL, *tmp = NULL;
 	int ret, i = 0, len = 0;
 
 	do {
@@ -1692,17 +1692,19 @@ static ssize_t amdgpu_reset_dump_register_list_write(struct file *f,
 		goto error_free;
 	}
 	ret = down_write_killable(&adev->reset_domain->sem);
-	if (ret)
+	if (ret) {
+		kfree(tmp);
 		goto error_free;
+	}
 
 	swap(adev->reset_dump_reg_list, tmp);
 	swap(adev->reset_dump_reg_value, new);
 	adev->num_regs = i;
 	up_write(&adev->reset_domain->sem);
+	kfree(tmp);
 	ret = size;
 
 error_free:
-	kfree(tmp);
 	kfree(new);
 	return ret;
 }
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 17+ messages in thread

end of thread, other threads:[~2022-07-18  8:05 UTC | newest]

Thread overview: 17+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-07-10 13:29 [PATCH -next] drm/amdgpu: double free error and freeing uninitialized null pointer Sebin Sebastian
2022-07-10 13:29 ` Sebin Sebastian
2022-07-10 13:29 ` Sebin Sebastian
2022-07-12 15:14 ` André Almeida
2022-07-12 15:14   ` André Almeida
2022-07-12 15:14   ` André Almeida
2022-07-14 15:06   ` Sebin Sebastian
2022-07-14 15:06     ` Sebin Sebastian
2022-07-14 15:06     ` Sebin Sebastian
2022-07-14 15:43     ` André Almeida
2022-07-14 15:43       ` André Almeida
2022-07-14 15:43       ` André Almeida
2022-07-15  8:18       ` Somalapuram, Amaranath
2022-07-15  8:18         ` Somalapuram, Amaranath
2022-07-18  7:45         ` Sebin Sebastian
2022-07-18  7:45           ` Sebin Sebastian
2022-07-18  7:45           ` Sebin Sebastian

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.