]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfs: check for unknown v5 feature bits in superblock write verifier
authorDarrick J. Wong <darrick.wong@oracle.com>
Fri, 5 Oct 2018 02:36:11 +0000 (21:36 -0500)
committerEric Sandeen <sandeen@redhat.com>
Fri, 5 Oct 2018 02:36:11 +0000 (21:36 -0500)
Source kernel commit: 9e037cb7972fab5a9f55bca4ebe6e4dbf7e160bc

Make sure we never try to write the superblock with unknown feature bits
set.  We checked those at mount time, so if they're set now then memory
is corrupt.

Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Eric Sandeen <sandeen@sandeen.net>
libxfs/xfs_sb.c

index 37207d9c5806c5a05c6f94281b3c661722aed978..93584fac2a210f2174cc71c0c40e56813c182998 100644 (file)
@@ -169,7 +169,40 @@ xfs_validate_sb_write(
        if (XFS_SB_VERSION_NUM(sbp) != XFS_SB_VERSION_5)
                return 0;
 
-       /* XXX: For write validation, we don't need to check feature masks?? */
+       /*
+        * Version 5 superblock feature mask validation. Reject combinations
+        * the kernel cannot support since we checked for unsupported bits in
+        * the read verifier, which means that memory is corrupt.
+        */
+       if (xfs_sb_has_compat_feature(sbp, XFS_SB_FEAT_COMPAT_UNKNOWN)) {
+               xfs_warn(mp,
+"Corruption detected in superblock compatible features (0x%x)!",
+                       (sbp->sb_features_compat & XFS_SB_FEAT_COMPAT_UNKNOWN));
+               return -EFSCORRUPTED;
+       }
+
+       if (xfs_sb_has_ro_compat_feature(sbp, XFS_SB_FEAT_RO_COMPAT_UNKNOWN)) {
+               xfs_alert(mp,
+"Corruption detected in superblock read-only compatible features (0x%x)!",
+                       (sbp->sb_features_ro_compat &
+                                       XFS_SB_FEAT_RO_COMPAT_UNKNOWN));
+               return -EFSCORRUPTED;
+       }
+       if (xfs_sb_has_incompat_feature(sbp, XFS_SB_FEAT_INCOMPAT_UNKNOWN)) {
+               xfs_warn(mp,
+"Corruption detected in superblock incompatible features (0x%x)!",
+                       (sbp->sb_features_incompat &
+                                       XFS_SB_FEAT_INCOMPAT_UNKNOWN));
+               return -EFSCORRUPTED;
+       }
+       if (xfs_sb_has_incompat_log_feature(sbp,
+                       XFS_SB_FEAT_INCOMPAT_LOG_UNKNOWN)) {
+               xfs_warn(mp,
+"Corruption detected in superblock incompatible log features (0x%x)!",
+                       (sbp->sb_features_log_incompat &
+                                       XFS_SB_FEAT_INCOMPAT_LOG_UNKNOWN));
+               return -EFSCORRUPTED;
+       }
 
        /*
         * We can't read verify the sb LSN because the read verifier is called