]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/commitdiff
xfs: ignore leaf attr ichdr.count in verifier during log replay
authorEric Sandeen <sandeen@redhat.com>
Tue, 10 Jan 2017 02:18:50 +0000 (20:18 -0600)
committerEric Sandeen <sandeen@redhat.com>
Tue, 10 Jan 2017 02:18:50 +0000 (20:18 -0600)
Source kernel commit: 2e1d23370e75d7d89350d41b4ab58c7f6a0e26b2

When we create a new attribute, we first create a shortform
attribute, and try to fit the new attribute into it.
If that fails, we copy the (empty) attribute into a leaf attribute,
and do the copy again.  Thus there can be a transient state where
we have an empty leaf attribute.

If we encounter this during log replay, the verifier will fail.
So add a test to ignore this part of the leaf attr verification
during log replay.

Thanks as usual to dchinner for spotting the problem.

Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Dave Chinner <david@fromorbit.com>
Signed-off-by: Eric Sandeen <sandeen@sandeen.net>
libxfs/xfs_attr_leaf.c

index 0ca034729a5ef8a779a93a032bc9aecdfb70f830..246d5b45b9e2a5dda27abd023483feec0569722c 100644 (file)
@@ -248,6 +248,7 @@ xfs_attr3_leaf_verify(
 {
        struct xfs_mount        *mp = bp->b_target->bt_mount;
        struct xfs_attr_leafblock *leaf = bp->b_addr;
+       struct xfs_perag *pag = bp->b_pag;
        struct xfs_attr3_icleaf_hdr ichdr;
 
        xfs_attr3_leaf_hdr_from_disk(mp->m_attr_geo, &ichdr, leaf);
@@ -268,7 +269,12 @@ xfs_attr3_leaf_verify(
                if (ichdr.magic != XFS_ATTR_LEAF_MAGIC)
                        return false;
        }
-       if (ichdr.count == 0)
+       /*
+        * In recovery there is a transient state where count == 0 is valid
+        * because we may have transitioned an empty shortform attr to a leaf
+        * if the attr didn't fit in shortform.
+        */
+       if (pag && pag->pagf_init && ichdr.count == 0)
                return false;
 
        /* XXX: need to range check rest of attr header values */