|
Thomas Zimmermann |
ebf85e |
From 62e3a3e342af3c313ab38603811ecdb1fcc79edb Mon Sep 17 00:00:00 2001
|
|
Thomas Zimmermann |
ebf85e |
From: Prakash Kamliya <pkamliya@codeaurora.org>
|
|
Thomas Zimmermann |
ebf85e |
Date: Mon, 4 Dec 2017 19:10:15 +0530
|
|
Thomas Zimmermann |
ebf85e |
Subject: [PATCH] drm/msm: fix leak in failed get_pages
|
|
Thomas Zimmermann |
ebf85e |
Git-commit: 62e3a3e342af3c313ab38603811ecdb1fcc79edb
|
|
Thomas Zimmermann |
ebf85e |
Patch-mainline: v4.16-rc1
|
|
Thomas Zimmermann |
ebf85e |
References: bsc#1051510
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
get_pages doesn't keep a reference of the pages allocated
|
|
Thomas Zimmermann |
ebf85e |
when it fails later in the code path. This can lead to
|
|
Thomas Zimmermann |
ebf85e |
a memory leak. Keep reference of the allocated pages so
|
|
Thomas Zimmermann |
ebf85e |
that it can be freed when msm_gem_free_object gets called
|
|
Thomas Zimmermann |
ebf85e |
later during cleanup.
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
Signed-off-by: Prakash Kamliya <pkamliya@codeaurora.org>
|
|
Thomas Zimmermann |
ebf85e |
Signed-off-by: Sharat Masetty <smasetty@codeaurora.org>
|
|
Thomas Zimmermann |
ebf85e |
Signed-off-by: Rob Clark <robdclark@gmail.com>
|
|
Thomas Zimmermann |
ebf85e |
Acked-by: Takashi Iwai <tiwai@suse.de>
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
---
|
|
Thomas Zimmermann |
ebf85e |
drivers/gpu/drm/msm/msm_gem.c | 14 ++++++++++----
|
|
Thomas Zimmermann |
ebf85e |
1 file changed, 10 insertions(+), 4 deletions(-)
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
--- a/drivers/gpu/drm/msm/msm_gem.c
|
|
Thomas Zimmermann |
ebf85e |
+++ b/drivers/gpu/drm/msm/msm_gem.c
|
|
Thomas Zimmermann |
ebf85e |
@@ -90,14 +90,17 @@ static struct page **get_pages(struct dr
|
|
Thomas Zimmermann |
ebf85e |
return p;
|
|
Thomas Zimmermann |
ebf85e |
}
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
+ msm_obj->pages = p;
|
|
Thomas Zimmermann |
ebf85e |
+
|
|
Thomas Zimmermann |
ebf85e |
msm_obj->sgt = drm_prime_pages_to_sg(p, npages);
|
|
Thomas Zimmermann |
ebf85e |
if (IS_ERR(msm_obj->sgt)) {
|
|
Thomas Zimmermann |
ebf85e |
+ void *ptr = ERR_CAST(msm_obj->sgt);
|
|
Thomas Zimmermann |
ebf85e |
+
|
|
Thomas Zimmermann |
ebf85e |
dev_err(dev->dev, "failed to allocate sgt\n");
|
|
Thomas Zimmermann |
ebf85e |
- return ERR_CAST(msm_obj->sgt);
|
|
Thomas Zimmermann |
ebf85e |
+ msm_obj->sgt = NULL;
|
|
Thomas Zimmermann |
ebf85e |
+ return ptr;
|
|
Thomas Zimmermann |
ebf85e |
}
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
- msm_obj->pages = p;
|
|
Thomas Zimmermann |
ebf85e |
-
|
|
Thomas Zimmermann |
ebf85e |
/* For non-cached buffers, ensure the new pages are clean
|
|
Thomas Zimmermann |
ebf85e |
* because display controller, GPU, etc. are not coherent:
|
|
Thomas Zimmermann |
ebf85e |
*/
|
|
Thomas Zimmermann |
ebf85e |
@@ -120,7 +123,10 @@ static void put_pages(struct drm_gem_obj
|
|
Thomas Zimmermann |
ebf85e |
if (msm_obj->flags & (MSM_BO_WC|MSM_BO_UNCACHED))
|
|
Thomas Zimmermann |
ebf85e |
dma_unmap_sg(obj->dev->dev, msm_obj->sgt->sgl,
|
|
Thomas Zimmermann |
ebf85e |
msm_obj->sgt->nents, DMA_BIDIRECTIONAL);
|
|
Thomas Zimmermann |
ebf85e |
- sg_free_table(msm_obj->sgt);
|
|
Thomas Zimmermann |
ebf85e |
+
|
|
Thomas Zimmermann |
ebf85e |
+ if (msm_obj->sgt)
|
|
Thomas Zimmermann |
ebf85e |
+ sg_free_table(msm_obj->sgt);
|
|
Thomas Zimmermann |
ebf85e |
+
|
|
Thomas Zimmermann |
ebf85e |
kfree(msm_obj->sgt);
|
|
Thomas Zimmermann |
ebf85e |
|
|
Thomas Zimmermann |
ebf85e |
if (use_pages(obj))
|