summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Carpenter <dan.carpenter@oracle.com>2019-12-13 21:50:11 +0300
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-12-31 16:36:28 +0100
commit307afc5d3f03efd7e284b85d3432e21b79384fc9 (patch)
treeaecbd7b3d9944a2272281c2ddd3df2afb65868dc
parent14ccb2b84f5bfe3a9dad63e911bd9d3ab78fe26f (diff)
downloadlinux-stable-307afc5d3f03efd7e284b85d3432e21b79384fc9.tar.gz
linux-stable-307afc5d3f03efd7e284b85d3432e21b79384fc9.tar.bz2
linux-stable-307afc5d3f03efd7e284b85d3432e21b79384fc9.zip
ext4: unlock on error in ext4_expand_extra_isize()
commit 7f420d64a08c1dcd65b27be82a27cf2bdb2e7847 upstream. We need to unlock the xattr before returning on this error path. Cc: stable@kernel.org # 4.13 Fixes: c03b45b853f5 ("ext4, project: expand inode extra size if possible") Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Link: https://lore.kernel.org/r/20191213185010.6k7yl2tck3wlsdkt@kili.mountain Signed-off-by: Theodore Ts'o <tytso@mit.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--fs/ext4/inode.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c
index ab16b7c6068c..215802cbc42b 100644
--- a/fs/ext4/inode.c
+++ b/fs/ext4/inode.c
@@ -6027,7 +6027,7 @@ int ext4_expand_extra_isize(struct inode *inode,
error = ext4_journal_get_write_access(handle, iloc->bh);
if (error) {
brelse(iloc->bh);
- goto out_stop;
+ goto out_unlock;
}
error = __ext4_expand_extra_isize(inode, new_extra_isize, iloc,
@@ -6037,8 +6037,8 @@ int ext4_expand_extra_isize(struct inode *inode,
if (!error)
error = rc;
+out_unlock:
ext4_write_unlock_xattr(inode, &no_expand);
-out_stop:
ext4_journal_stop(handle);
return error;
}