[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20180305074555.23368-1-jeffy.chen@rock-chips.com>
Date: Mon, 5 Mar 2018 15:45:55 +0800
From: Jeffy Chen <jeffy.chen@...k-chips.com>
To: linux-kernel@...r.kernel.org
Cc: Jeffy Chen <jeffy.chen@...k-chips.com>,
Andrzej Hajda <a.hajda@...sung.com>,
Romain Perier <romain.perier@...labora.com>,
Archit Taneja <architt@...eaurora.org>,
dri-devel@...ts.freedesktop.org,
Russell King <rmk+kernel@...linux.org.uk>,
Neil Armstrong <narmstrong@...libre.com>,
David Airlie <airlied@...ux.ie>,
Hans Verkuil <hverkuil@...all.nl>,
Jose Abreu <Jose.Abreu@...opsys.com>,
Jernej Skrabec <jernej.skrabec@...l.net>,
Laurent Pinchart <Laurent.pinchart@...asonboard.com>
Subject: [PATCH] drm/bridge/synopsys: dw-hdmi: Fix memleak in __dw_hdmi_remove
The platform_device_register_full() will allocate dma_mask for
hdmi->audio, so we should free before platform_device_unregister().
Reported by kmemleak:
unreferenced object 0xffffffc0ef70ff00 (size 128):
comm "kworker/4:1", pid 123, jiffies 4294670080 (age 189.604s)
hex dump (first 32 bytes):
ff ff ff ff 00 00 00 00 00 00 00 00 00 00 00 00 ................
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
backtrace:
[<0000000021946f44>] kmemleak_alloc+0x58/0x8c
[<000000009c43890d>] kmem_cache_alloc_memcg_trace+0x18c/0x25c
[<000000000e17cd06>] platform_device_register_full+0x64/0x108
[<00000000418a0882>] __dw_hdmi_probe+0xb9c/0xcc0
[<00000000e0b720fd>] dw_hdmi_bind+0x30/0x88
[<000000009af347f6>] dw_hdmi_rockchip_bind+0x260/0x2e8
Signed-off-by: Jeffy Chen <jeffy.chen@...k-chips.com>
---
drivers/gpu/drm/bridge/synopsys/dw-hdmi.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
index f9802399cc0d..d9afdc59d4f4 100644
--- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
+++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
@@ -2567,8 +2567,10 @@ __dw_hdmi_probe(struct platform_device *pdev,
static void __dw_hdmi_remove(struct dw_hdmi *hdmi)
{
- if (hdmi->audio && !IS_ERR(hdmi->audio))
+ if (hdmi->audio && !IS_ERR(hdmi->audio)) {
+ kfree(hdmi->audio->dev.dma_mask);
platform_device_unregister(hdmi->audio);
+ }
if (!IS_ERR(hdmi->cec))
platform_device_unregister(hdmi->cec);
--
2.11.0
Powered by blists - more mailing lists