Commit 638a7174 authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: don't iunlock unlocked inodes

Don't iunlock an unlocked inode, which can happen if the parent pointer
scrubber bails out with sc->ip unlocked while trying to grab the parent
directory inode.
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
parent cf1b0b8b
...@@ -159,7 +159,8 @@ xfs_scrub_teardown( ...@@ -159,7 +159,8 @@ xfs_scrub_teardown(
sc->tp = NULL; sc->tp = NULL;
} }
if (sc->ip) { if (sc->ip) {
xfs_iunlock(sc->ip, sc->ilock_flags); if (sc->ilock_flags)
xfs_iunlock(sc->ip, sc->ilock_flags);
if (sc->ip != ip_in && if (sc->ip != ip_in &&
!xfs_internal_inum(sc->mp, sc->ip->i_ino)) !xfs_internal_inum(sc->mp, sc->ip->i_ino))
iput(VFS_I(sc->ip)); iput(VFS_I(sc->ip));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment