From: Theodore Ts'o Date: Sat, 18 Mar 2023 01:53:52 +0000 (-0400) Subject: ext4: fix possible double unlock when moving a directory X-Git-Tag: baikal/mips/sdk5.8.2~122 X-Git-Url: https://git.baikalelectronics.ru/sdk/?a=commitdiff_plain;h=900fdf72b4f1a80c0cec2cda3fc03307d627a028;p=kernel.git ext4: fix possible double unlock when moving a directory commit 70e42feab2e20618ddd0cbfc4ab4b08628236ecd upstream. Fixes: 0813299c586b ("ext4: Fix possible corruption when moving a directory") Link: https://lore.kernel.org/r/5efbe1b9-ad8b-4a4f-b422-24824d2b775c@kili.mountain Reported-by: Dan Carpenter Reported-by: syzbot+0c73d1d8b952c5f3d714@syzkaller.appspotmail.com Signed-off-by: Theodore Ts'o Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/ext4/namei.c b/fs/ext4/namei.c index b708b437b3e36..d3804975e82bb 100644 --- a/fs/ext4/namei.c +++ b/fs/ext4/namei.c @@ -3866,10 +3866,8 @@ static int ext4_rename(struct inode *old_dir, struct dentry *old_dentry, goto end_rename; } retval = ext4_rename_dir_prepare(handle, &old); - if (retval) { - inode_unlock(old.inode); + if (retval) goto end_rename; - } } /* * If we're renaming a file within an inline_data dir and adding or