[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20190925213904.12128-1-navid.emamdoost@gmail.com>
Date: Wed, 25 Sep 2019 16:39:03 -0500
From: Navid Emamdoost <navid.emamdoost@...il.com>
To: unlisted-recipients:; (no To-header on input)
Cc: emamd001@....edu, kjlu@....edu, smccaman@....edu,
Navid Emamdoost <navid.emamdoost@...il.com>,
Jan Kara <jack@...e.com>, linux-kernel@...r.kernel.org
Subject: [PATCH] udf: prevent memory leak in udf_new_inode
In udf_new_inode if either udf_new_block or insert_inode_locked fials
the allocated memory for iinfo->i_ext.i_data should be released.
Signed-off-by: Navid Emamdoost <navid.emamdoost@...il.com>
---
fs/udf/ialloc.c | 2 ++
1 file changed, 2 insertions(+)
diff --git a/fs/udf/ialloc.c b/fs/udf/ialloc.c
index 0adb40718a5d..b8ab3acab6b6 100644
--- a/fs/udf/ialloc.c
+++ b/fs/udf/ialloc.c
@@ -86,6 +86,7 @@ struct inode *udf_new_inode(struct inode *dir, umode_t mode)
dinfo->i_location.partitionReferenceNum,
start, &err);
if (err) {
+ kfree(iinfo->i_ext.i_data);
iput(inode);
return ERR_PTR(err);
}
@@ -130,6 +131,7 @@ struct inode *udf_new_inode(struct inode *dir, umode_t mode)
inode->i_mtime = inode->i_atime = inode->i_ctime = current_time(inode);
iinfo->i_crtime = inode->i_mtime;
if (unlikely(insert_inode_locked(inode) < 0)) {
+ kfree(iinfo->i_ext.i_data);
make_bad_inode(inode);
iput(inode);
return ERR_PTR(-EIO);
--
2.17.1
Powered by blists - more mailing lists