xfs: don't treat unknown di_flags2 as corruption in scrub
authorEric Sandeen <sandeen@sandeen.net>
Sat, 29 Sep 2018 03:49:00 +0000 (13:49 +1000)
committerDave Chinner <david@fromorbit.com>
Sat, 29 Sep 2018 03:49:00 +0000 (13:49 +1000)
xchk_inode_flags2() currently treats any di_flags2 values that the
running kernel doesn't recognize as corruption, and calls
xchk_ino_set_corrupt() if they are set.  However, it's entirely possible
that these flags were set in some newer kernel and are quite valid,
but ignored in this kernel.

(Validators don't care one bit about unknown di_flags2.)

Call xchk_ino_set_warning instead, because this may or may not actually
indicate a problem.

Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
fs/xfs/libxfs/xfs_format.h
fs/xfs/scrub/inode.c

index 059bc44c27e83edf3cb1fe2c494490e65f93c5d8..afbe336600e165e2fe475ebcf6683e3f677c1cc4 100644 (file)
@@ -1016,6 +1016,8 @@ static inline void xfs_dinode_put_rdev(struct xfs_dinode *dip, xfs_dev_t rdev)
 #define XFS_DIFLAG_EXTSZINHERIT_BIT 12 /* inherit inode extent size */
 #define XFS_DIFLAG_NODEFRAG_BIT     13 /* do not reorganize/defragment */
 #define XFS_DIFLAG_FILESTREAM_BIT   14  /* use filestream allocator */
+/* Do not use bit 15, di_flags is legacy and unchanging now */
+
 #define XFS_DIFLAG_REALTIME      (1 << XFS_DIFLAG_REALTIME_BIT)
 #define XFS_DIFLAG_PREALLOC      (1 << XFS_DIFLAG_PREALLOC_BIT)
 #define XFS_DIFLAG_NEWRTBM       (1 << XFS_DIFLAG_NEWRTBM_BIT)
index 5b3b177c0fc908fa9527b3a35302e91993027c9c..e386c9b0b4ab7de6bc2d42fddcf204539d8d2a28 100644 (file)
@@ -126,6 +126,7 @@ xchk_inode_flags(
 {
        struct xfs_mount        *mp = sc->mp;
 
+       /* di_flags are all taken, last bit cannot be used */
        if (flags & ~XFS_DIFLAG_ANY)
                goto bad;
 
@@ -172,8 +173,9 @@ xchk_inode_flags2(
 {
        struct xfs_mount        *mp = sc->mp;
 
+       /* Unknown di_flags2 could be from a future kernel */
        if (flags2 & ~XFS_DIFLAG2_ANY)
-               goto bad;
+               xchk_ino_set_warning(sc, ino);
 
        /* reflink flag requires reflink feature */
        if ((flags2 & XFS_DIFLAG2_REFLINK) &&