]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
isofs: release buffer head before return
authorPan Bian <bianpan2016@163.com>
Mon, 18 Jan 2021 12:04:55 +0000 (04:04 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 3 Mar 2021 15:44:18 +0000 (16:44 +0100)
[ Upstream commit 0a6dc67a6aa45f19bd4ff89b4f468fc50c4b8daa ]

Release the buffer_head before returning error code in
do_isofs_readdir() and isofs_find_entry().

Fixes: 2deb1acc653c ("isofs: fix access to unallocated memory when reading corrupted filesystem")
Link: https://lore.kernel.org/r/20210118120455.118955-1-bianpan2016@163.com
Signed-off-by: Pan Bian <bianpan2016@163.com>
Signed-off-by: Jan Kara <jack@suse.cz>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/isofs/dir.c
fs/isofs/namei.c

index b943cbd963bb98c9ba89edc814cfe4c3223e8c3a..2e7d74c7beed888939454cd7fc5590a1239e1c7b 100644 (file)
@@ -151,6 +151,7 @@ static int do_isofs_readdir(struct inode *inode, struct file *file,
                        printk(KERN_NOTICE "iso9660: Corrupted directory entry"
                               " in block %lu of inode %lu\n", block,
                               inode->i_ino);
+                       brelse(bh);
                        return -EIO;
                }
 
index 7b543e6b6526dc8ceebe9bd09aaa07e2d7045236..696f255d153251bf68a4efc3662f706c02ebd98d 100644 (file)
@@ -101,6 +101,7 @@ isofs_find_entry(struct inode *dir, struct dentry *dentry,
                        printk(KERN_NOTICE "iso9660: Corrupted directory entry"
                               " in block %lu of inode %lu\n", block,
                               dir->i_ino);
+                       brelse(bh);
                        return 0;
                }