[<prev] [next>] [day] [month] [year] [list]
Message-Id: <1505650478-4638-1-git-send-email-sudipm.mukherjee@gmail.com>
Date: Sun, 17 Sep 2017 13:14:38 +0100
From: Sudip Mukherjee <sudipm.mukherjee@...il.com>
To: Ohad Ben-Cohen <ohad@...ery.com>,
Bjorn Andersson <bjorn.andersson@...aro.org>
Cc: linux-kernel@...r.kernel.org, linux-remoteproc@...r.kernel.org,
Sudip Mukherjee <sudipm.mukherjee@...il.com>
Subject: [PATCH] rpmsg: glink: fix memory leak
We missed freeing intent and intent->data on error conditions.
Signed-off-by: Sudip Mukherjee <sudipm.mukherjee@...il.com>
---
drivers/rpmsg/qcom_glink_native.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/drivers/rpmsg/qcom_glink_native.c b/drivers/rpmsg/qcom_glink_native.c
index 5a5e927..2e64c4d 100644
--- a/drivers/rpmsg/qcom_glink_native.c
+++ b/drivers/rpmsg/qcom_glink_native.c
@@ -640,13 +640,17 @@ qcom_glink_alloc_intent(struct qcom_glink *glink,
return NULL;
intent->data = kzalloc(size, GFP_KERNEL);
- if (!intent->data)
+ if (!intent->data) {
+ kfree(intent);
return NULL;
+ }
spin_lock_irqsave(&channel->intent_lock, flags);
ret = idr_alloc_cyclic(&channel->liids, intent, 1, -1, GFP_ATOMIC);
if (ret < 0) {
spin_unlock_irqrestore(&channel->intent_lock, flags);
+ kfree(intent->data);
+ kfree(intent);
return NULL;
}
spin_unlock_irqrestore(&channel->intent_lock, flags);
--
2.7.4
Powered by blists - more mailing lists