mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 09:34:17 +00:00
ocfs2: unlock inode if deleting inode from orphan fails
When doing append direct io cleanup, if deleting inode fails, it goes out without unlocking inode, which will cause the inode deadlock. This issue was introduced by commit cf1776a9e834 ("ocfs2: fix a tiny race when truncate dio orohaned entry"). Signed-off-by: Guozhonghua <guozhonghua@h3c.com> Signed-off-by: Joseph Qi <joseph.qi@huawei.com> Reviewed-by: Gang He <ghe@suse.com> Cc: Mark Fasheh <mfasheh@suse.de> Cc: Joel Becker <jlbec@evilplan.org> Cc: Junxiao Bi <junxiao.bi@oracle.com> Cc: <stable@vger.kernel.org> [4.2+] Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
5ef11c35ce
commit
a4a8481ff6
@ -956,6 +956,7 @@ clean_orphan:
|
|||||||
tmp_ret = ocfs2_del_inode_from_orphan(osb, inode, di_bh,
|
tmp_ret = ocfs2_del_inode_from_orphan(osb, inode, di_bh,
|
||||||
update_isize, end);
|
update_isize, end);
|
||||||
if (tmp_ret < 0) {
|
if (tmp_ret < 0) {
|
||||||
|
ocfs2_inode_unlock(inode, 1);
|
||||||
ret = tmp_ret;
|
ret = tmp_ret;
|
||||||
mlog_errno(ret);
|
mlog_errno(ret);
|
||||||
brelse(di_bh);
|
brelse(di_bh);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user