|
@@ -528,6 +528,15 @@ xfs_agfl_verify(
|
|
|
struct xfs_agfl *agfl = XFS_BUF_TO_AGFL(bp);
|
|
|
int i;
|
|
|
|
|
|
+ /*
|
|
|
+ * There is no verification of non-crc AGFLs because mkfs does not
|
|
|
+ * initialise the AGFL to zero or NULL. Hence the only valid part of the
|
|
|
+ * AGFL is what the AGF says is active. We can't get to the AGF, so we
|
|
|
+ * can't verify just those entries are valid.
|
|
|
+ */
|
|
|
+ if (!xfs_sb_version_hascrc(&mp->m_sb))
|
|
|
+ return NULL;
|
|
|
+
|
|
|
if (!uuid_equal(&agfl->agfl_uuid, &mp->m_sb.sb_meta_uuid))
|
|
|
return __this_address;
|
|
|
if (be32_to_cpu(agfl->agfl_magicnum) != XFS_AGFL_MAGIC)
|
|
@@ -605,6 +614,7 @@ const struct xfs_buf_ops xfs_agfl_buf_ops = {
|
|
|
.name = "xfs_agfl",
|
|
|
.verify_read = xfs_agfl_read_verify,
|
|
|
.verify_write = xfs_agfl_write_verify,
|
|
|
+ .verify_struct = xfs_agfl_verify,
|
|
|
};
|
|
|
|
|
|
/*
|
|
@@ -2402,10 +2412,10 @@ xfs_alloc_put_freelist(
|
|
|
|
|
|
static xfs_failaddr_t
|
|
|
xfs_agf_verify(
|
|
|
- struct xfs_mount *mp,
|
|
|
- struct xfs_buf *bp)
|
|
|
- {
|
|
|
- struct xfs_agf *agf = XFS_BUF_TO_AGF(bp);
|
|
|
+ struct xfs_buf *bp)
|
|
|
+{
|
|
|
+ struct xfs_mount *mp = bp->b_target->bt_mount;
|
|
|
+ struct xfs_agf *agf = XFS_BUF_TO_AGF(bp);
|
|
|
|
|
|
if (xfs_sb_version_hascrc(&mp->m_sb)) {
|
|
|
if (!uuid_equal(&agf->agf_uuid, &mp->m_sb.sb_meta_uuid))
|
|
@@ -2467,7 +2477,7 @@ xfs_agf_read_verify(
|
|
|
!xfs_buf_verify_cksum(bp, XFS_AGF_CRC_OFF))
|
|
|
xfs_verifier_error(bp, -EFSBADCRC, __this_address);
|
|
|
else {
|
|
|
- fa = xfs_agf_verify(mp, bp);
|
|
|
+ fa = xfs_agf_verify(bp);
|
|
|
if (XFS_TEST_ERROR(fa, mp, XFS_ERRTAG_ALLOC_READ_AGF))
|
|
|
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
|
|
}
|
|
@@ -2481,7 +2491,7 @@ xfs_agf_write_verify(
|
|
|
struct xfs_buf_log_item *bip = bp->b_fspriv;
|
|
|
xfs_failaddr_t fa;
|
|
|
|
|
|
- fa = xfs_agf_verify(mp, bp);
|
|
|
+ fa = xfs_agf_verify(bp);
|
|
|
if (fa) {
|
|
|
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
|
|
return;
|
|
@@ -2500,6 +2510,7 @@ const struct xfs_buf_ops xfs_agf_buf_ops = {
|
|
|
.name = "xfs_agf",
|
|
|
.verify_read = xfs_agf_read_verify,
|
|
|
.verify_write = xfs_agf_write_verify,
|
|
|
+ .verify_struct = xfs_agf_verify,
|
|
|
};
|
|
|
|
|
|
/*
|