提交 5a90e53e 编写于 作者: D Dave Chinner 提交者: Dave Chinner

xfs: xfs_iflush_cluster has range issues

xfs_iflush_cluster() does a gang lookup on the radix tree, meaning
it can find inodes beyond the current cluster if there is sparse
cache population. gang lookups return results in ascending index
order, so stop trying to cluster inodes once the first inode outside
the cluster mask is detected.
Signed-off-by: NDave Chinner <dchinner@redhat.com>
Reviewed-by: NBrian Foster <bfoster@redhat.com>
Reviewed-by: NChristoph Hellwig <hch@lst.de>
Signed-off-by: NDave Chinner <david@fromorbit.com>
上级 8a17d7dd
...@@ -3207,11 +3207,20 @@ xfs_iflush_cluster( ...@@ -3207,11 +3207,20 @@ xfs_iflush_cluster(
*/ */
spin_lock(&iq->i_flags_lock); spin_lock(&iq->i_flags_lock);
if (!iq->i_ino || if (!iq->i_ino ||
__xfs_iflags_test(iq, XFS_ISTALE) || __xfs_iflags_test(iq, XFS_ISTALE)) {
(XFS_INO_TO_AGINO(mp, iq->i_ino) & mask) != first_index) {
spin_unlock(&iq->i_flags_lock); spin_unlock(&iq->i_flags_lock);
continue; continue;
} }
/*
* Once we fall off the end of the cluster, no point checking
* any more inodes in the list because they will also all be
* outside the cluster.
*/
if ((XFS_INO_TO_AGINO(mp, iq->i_ino) & mask) != first_index) {
spin_unlock(&iq->i_flags_lock);
break;
}
spin_unlock(&iq->i_flags_lock); spin_unlock(&iq->i_flags_lock);
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册