Commit aa880198 authored by Dave Chinner's avatar Dave Chinner

xfs: don't consider future format versions valid

In commit fe08cc50 we reworked the valid superblock version
checks. If it is a V5 filesystem, it is always valid, then we
checked if the version was less than V4 (reject) and then checked
feature fields in the V4 flags to determine if it was valid.

What we missed was that if the version is not V4 at this point,
we shoudl reject the fs. i.e. the check current treats V6+
filesystems as if it was a v4 filesystem. Fix this.

cc: stable@vger.kernel.org
Fixes: fe08cc50 ("xfs: open code sb verifier feature checks")
Signed-off-by: default avatarDave Chinner <dchinner@redhat.com>
Reviewed-by: default avatarDarrick J. Wong <djwong@kernel.org>
Signed-off-by: default avatarDave Chinner <david@fromorbit.com>
parent 09a9639e
...@@ -72,7 +72,8 @@ xfs_sb_validate_v5_features( ...@@ -72,7 +72,8 @@ xfs_sb_validate_v5_features(
} }
/* /*
* We support all XFS versions newer than a v4 superblock with V2 directories. * We current support XFS v5 formats with known features and v4 superblocks with
* at least V2 directories.
*/ */
bool bool
xfs_sb_good_version( xfs_sb_good_version(
...@@ -86,16 +87,16 @@ xfs_sb_good_version( ...@@ -86,16 +87,16 @@ xfs_sb_good_version(
if (xfs_sb_is_v5(sbp)) if (xfs_sb_is_v5(sbp))
return xfs_sb_validate_v5_features(sbp); return xfs_sb_validate_v5_features(sbp);
/* versions prior to v4 are not supported */
if (XFS_SB_VERSION_NUM(sbp) != XFS_SB_VERSION_4)
return false;
/* We must not have any unknown v4 feature bits set */ /* We must not have any unknown v4 feature bits set */
if ((sbp->sb_versionnum & ~XFS_SB_VERSION_OKBITS) || if ((sbp->sb_versionnum & ~XFS_SB_VERSION_OKBITS) ||
((sbp->sb_versionnum & XFS_SB_VERSION_MOREBITSBIT) && ((sbp->sb_versionnum & XFS_SB_VERSION_MOREBITSBIT) &&
(sbp->sb_features2 & ~XFS_SB_VERSION2_OKBITS))) (sbp->sb_features2 & ~XFS_SB_VERSION2_OKBITS)))
return false; return false;
/* versions prior to v4 are not supported */
if (XFS_SB_VERSION_NUM(sbp) < XFS_SB_VERSION_4)
return false;
/* V4 filesystems need v2 directories and unwritten extents */ /* V4 filesystems need v2 directories and unwritten extents */
if (!(sbp->sb_versionnum & XFS_SB_VERSION_DIRV2BIT)) if (!(sbp->sb_versionnum & XFS_SB_VERSION_DIRV2BIT))
return false; return false;
......
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