summaryrefslogtreecommitdiffstats
path: root/fs/xfs
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2016-05-18 05:54:23 +0200
committerDave Chinner <david@fromorbit.com>2016-05-18 05:54:23 +0200
commit7d3aa7fe970791f1a674b14572a411accf2f4d4e (patch)
tree1648ba722ac8d92f79717ccc4c412c862c031748 /fs/xfs
parentxfs: fix inode validity check in xfs_iflush_cluster (diff)
downloadlinux-7d3aa7fe970791f1a674b14572a411accf2f4d4e.tar.xz
linux-7d3aa7fe970791f1a674b14572a411accf2f4d4e.zip
xfs: skip stale inodes in xfs_iflush_cluster
We don't write back stale inodes so we should skip them in xfs_iflush_cluster, too. cc: <stable@vger.kernel.org> # 3.10.x- Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Dave Chinner <david@fromorbit.com>
Diffstat (limited to 'fs/xfs')
-rw-r--r--fs/xfs/xfs_inode.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c
index a955b0212453..3cbc9031731b 100644
--- a/fs/xfs/xfs_inode.c
+++ b/fs/xfs/xfs_inode.c
@@ -3207,6 +3207,7 @@ xfs_iflush_cluster(
*/
spin_lock(&iq->i_flags_lock);
if (!iq->i_ino ||
+ __xfs_iflags_test(iq, XFS_ISTALE) ||
(XFS_INO_TO_AGINO(mp, iq->i_ino) & mask) != first_index) {
spin_unlock(&iq->i_flags_lock);
continue;