xfs: create a new buf_ops pointer to verify structure metadata
Expose all metadata structure buffer verifier functions via buf_ops. These will be used by the online scrub mechanism to look for problems with buffers that are already sitting around in memory. Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Reviewed-by: Dave Chinner <dchinner@redhat.com>
This commit is contained in:
@@ -528,6 +528,15 @@ xfs_agfl_verify(
|
|||||||
struct xfs_agfl *agfl = XFS_BUF_TO_AGFL(bp);
|
struct xfs_agfl *agfl = XFS_BUF_TO_AGFL(bp);
|
||||||
int i;
|
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))
|
if (!uuid_equal(&agfl->agfl_uuid, &mp->m_sb.sb_meta_uuid))
|
||||||
return __this_address;
|
return __this_address;
|
||||||
if (be32_to_cpu(agfl->agfl_magicnum) != XFS_AGFL_MAGIC)
|
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",
|
.name = "xfs_agfl",
|
||||||
.verify_read = xfs_agfl_read_verify,
|
.verify_read = xfs_agfl_read_verify,
|
||||||
.verify_write = xfs_agfl_write_verify,
|
.verify_write = xfs_agfl_write_verify,
|
||||||
|
.verify_struct = xfs_agfl_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -2402,10 +2412,10 @@ xfs_alloc_put_freelist(
|
|||||||
|
|
||||||
static xfs_failaddr_t
|
static xfs_failaddr_t
|
||||||
xfs_agf_verify(
|
xfs_agf_verify(
|
||||||
struct xfs_mount *mp,
|
struct xfs_buf *bp)
|
||||||
struct xfs_buf *bp)
|
{
|
||||||
{
|
struct xfs_mount *mp = bp->b_target->bt_mount;
|
||||||
struct xfs_agf *agf = XFS_BUF_TO_AGF(bp);
|
struct xfs_agf *agf = XFS_BUF_TO_AGF(bp);
|
||||||
|
|
||||||
if (xfs_sb_version_hascrc(&mp->m_sb)) {
|
if (xfs_sb_version_hascrc(&mp->m_sb)) {
|
||||||
if (!uuid_equal(&agf->agf_uuid, &mp->m_sb.sb_meta_uuid))
|
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_buf_verify_cksum(bp, XFS_AGF_CRC_OFF))
|
||||||
xfs_verifier_error(bp, -EFSBADCRC, __this_address);
|
xfs_verifier_error(bp, -EFSBADCRC, __this_address);
|
||||||
else {
|
else {
|
||||||
fa = xfs_agf_verify(mp, bp);
|
fa = xfs_agf_verify(bp);
|
||||||
if (XFS_TEST_ERROR(fa, mp, XFS_ERRTAG_ALLOC_READ_AGF))
|
if (XFS_TEST_ERROR(fa, mp, XFS_ERRTAG_ALLOC_READ_AGF))
|
||||||
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
||||||
}
|
}
|
||||||
@@ -2481,7 +2491,7 @@ xfs_agf_write_verify(
|
|||||||
struct xfs_buf_log_item *bip = bp->b_fspriv;
|
struct xfs_buf_log_item *bip = bp->b_fspriv;
|
||||||
xfs_failaddr_t fa;
|
xfs_failaddr_t fa;
|
||||||
|
|
||||||
fa = xfs_agf_verify(mp, bp);
|
fa = xfs_agf_verify(bp);
|
||||||
if (fa) {
|
if (fa) {
|
||||||
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
||||||
return;
|
return;
|
||||||
@@ -2500,6 +2510,7 @@ const struct xfs_buf_ops xfs_agf_buf_ops = {
|
|||||||
.name = "xfs_agf",
|
.name = "xfs_agf",
|
||||||
.verify_read = xfs_agf_read_verify,
|
.verify_read = xfs_agf_read_verify,
|
||||||
.verify_write = xfs_agf_write_verify,
|
.verify_write = xfs_agf_write_verify,
|
||||||
|
.verify_struct = xfs_agf_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -400,6 +400,7 @@ const struct xfs_buf_ops xfs_allocbt_buf_ops = {
|
|||||||
.name = "xfs_allocbt",
|
.name = "xfs_allocbt",
|
||||||
.verify_read = xfs_allocbt_read_verify,
|
.verify_read = xfs_allocbt_read_verify,
|
||||||
.verify_write = xfs_allocbt_write_verify,
|
.verify_write = xfs_allocbt_write_verify,
|
||||||
|
.verify_struct = xfs_allocbt_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -339,6 +339,7 @@ const struct xfs_buf_ops xfs_attr3_leaf_buf_ops = {
|
|||||||
.name = "xfs_attr3_leaf",
|
.name = "xfs_attr3_leaf",
|
||||||
.verify_read = xfs_attr3_leaf_read_verify,
|
.verify_read = xfs_attr3_leaf_read_verify,
|
||||||
.verify_write = xfs_attr3_leaf_write_verify,
|
.verify_write = xfs_attr3_leaf_write_verify,
|
||||||
|
.verify_struct = xfs_attr3_leaf_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|||||||
@@ -116,20 +116,21 @@ xfs_attr3_rmt_verify(
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static int
|
||||||
xfs_attr3_rmt_read_verify(
|
__xfs_attr3_rmt_read_verify(
|
||||||
struct xfs_buf *bp)
|
struct xfs_buf *bp,
|
||||||
|
bool check_crc,
|
||||||
|
xfs_failaddr_t *failaddr)
|
||||||
{
|
{
|
||||||
struct xfs_mount *mp = bp->b_target->bt_mount;
|
struct xfs_mount *mp = bp->b_target->bt_mount;
|
||||||
char *ptr;
|
char *ptr;
|
||||||
xfs_failaddr_t fa;
|
|
||||||
int len;
|
int len;
|
||||||
xfs_daddr_t bno;
|
xfs_daddr_t bno;
|
||||||
int blksize = mp->m_attr_geo->blksize;
|
int blksize = mp->m_attr_geo->blksize;
|
||||||
|
|
||||||
/* no verification of non-crc buffers */
|
/* no verification of non-crc buffers */
|
||||||
if (!xfs_sb_version_hascrc(&mp->m_sb))
|
if (!xfs_sb_version_hascrc(&mp->m_sb))
|
||||||
return;
|
return 0;
|
||||||
|
|
||||||
ptr = bp->b_addr;
|
ptr = bp->b_addr;
|
||||||
bno = bp->b_bn;
|
bno = bp->b_bn;
|
||||||
@@ -137,22 +138,48 @@ xfs_attr3_rmt_read_verify(
|
|||||||
ASSERT(len >= blksize);
|
ASSERT(len >= blksize);
|
||||||
|
|
||||||
while (len > 0) {
|
while (len > 0) {
|
||||||
if (!xfs_verify_cksum(ptr, blksize, XFS_ATTR3_RMT_CRC_OFF)) {
|
if (check_crc &&
|
||||||
xfs_verifier_error(bp, -EFSBADCRC, __this_address);
|
!xfs_verify_cksum(ptr, blksize, XFS_ATTR3_RMT_CRC_OFF)) {
|
||||||
return;
|
*failaddr = __this_address;
|
||||||
}
|
return -EFSBADCRC;
|
||||||
fa = xfs_attr3_rmt_verify(mp, ptr, blksize, bno);
|
|
||||||
if (fa) {
|
|
||||||
xfs_verifier_error(bp, -EFSCORRUPTED, fa);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
*failaddr = xfs_attr3_rmt_verify(mp, ptr, blksize, bno);
|
||||||
|
if (*failaddr)
|
||||||
|
return -EFSCORRUPTED;
|
||||||
len -= blksize;
|
len -= blksize;
|
||||||
ptr += blksize;
|
ptr += blksize;
|
||||||
bno += BTOBB(blksize);
|
bno += BTOBB(blksize);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (len != 0)
|
if (len != 0) {
|
||||||
xfs_verifier_error(bp, -EFSCORRUPTED, __this_address);
|
*failaddr = __this_address;
|
||||||
|
return -EFSCORRUPTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
xfs_attr3_rmt_read_verify(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
xfs_failaddr_t fa;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
error = __xfs_attr3_rmt_read_verify(bp, true, &fa);
|
||||||
|
if (error)
|
||||||
|
xfs_verifier_error(bp, error, fa);
|
||||||
|
}
|
||||||
|
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_attr3_rmt_verify_struct(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
xfs_failaddr_t fa;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
error = __xfs_attr3_rmt_read_verify(bp, false, &fa);
|
||||||
|
return error ? fa : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -207,6 +234,7 @@ const struct xfs_buf_ops xfs_attr3_rmt_buf_ops = {
|
|||||||
.name = "xfs_attr3_rmt",
|
.name = "xfs_attr3_rmt",
|
||||||
.verify_read = xfs_attr3_rmt_read_verify,
|
.verify_read = xfs_attr3_rmt_read_verify,
|
||||||
.verify_write = xfs_attr3_rmt_write_verify,
|
.verify_write = xfs_attr3_rmt_write_verify,
|
||||||
|
.verify_struct = xfs_attr3_rmt_verify_struct,
|
||||||
};
|
};
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
|
|||||||
@@ -501,6 +501,7 @@ const struct xfs_buf_ops xfs_bmbt_buf_ops = {
|
|||||||
.name = "xfs_bmbt",
|
.name = "xfs_bmbt",
|
||||||
.verify_read = xfs_bmbt_read_verify,
|
.verify_read = xfs_bmbt_read_verify,
|
||||||
.verify_write = xfs_bmbt_write_verify,
|
.verify_write = xfs_bmbt_write_verify,
|
||||||
|
.verify_struct = xfs_bmbt_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -243,10 +243,35 @@ xfs_da3_node_read_verify(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Verify the structure of a da3 block. */
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_da3_node_verify_struct(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
struct xfs_da_blkinfo *info = bp->b_addr;
|
||||||
|
|
||||||
|
switch (be16_to_cpu(info->magic)) {
|
||||||
|
case XFS_DA3_NODE_MAGIC:
|
||||||
|
case XFS_DA_NODE_MAGIC:
|
||||||
|
return xfs_da3_node_verify(bp);
|
||||||
|
case XFS_ATTR_LEAF_MAGIC:
|
||||||
|
case XFS_ATTR3_LEAF_MAGIC:
|
||||||
|
bp->b_ops = &xfs_attr3_leaf_buf_ops;
|
||||||
|
return bp->b_ops->verify_struct(bp);
|
||||||
|
case XFS_DIR2_LEAFN_MAGIC:
|
||||||
|
case XFS_DIR3_LEAFN_MAGIC:
|
||||||
|
bp->b_ops = &xfs_dir3_leafn_buf_ops;
|
||||||
|
return bp->b_ops->verify_struct(bp);
|
||||||
|
default:
|
||||||
|
return __this_address;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const struct xfs_buf_ops xfs_da3_node_buf_ops = {
|
const struct xfs_buf_ops xfs_da3_node_buf_ops = {
|
||||||
.name = "xfs_da3_node",
|
.name = "xfs_da3_node",
|
||||||
.verify_read = xfs_da3_node_read_verify,
|
.verify_read = xfs_da3_node_read_verify,
|
||||||
.verify_write = xfs_da3_node_write_verify,
|
.verify_write = xfs_da3_node_write_verify,
|
||||||
|
.verify_struct = xfs_da3_node_verify_struct,
|
||||||
};
|
};
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|||||||
@@ -126,6 +126,7 @@ const struct xfs_buf_ops xfs_dir3_block_buf_ops = {
|
|||||||
.name = "xfs_dir3_block",
|
.name = "xfs_dir3_block",
|
||||||
.verify_read = xfs_dir3_block_read_verify,
|
.verify_read = xfs_dir3_block_read_verify,
|
||||||
.verify_write = xfs_dir3_block_write_verify,
|
.verify_write = xfs_dir3_block_write_verify,
|
||||||
|
.verify_struct = xfs_dir3_block_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|||||||
@@ -334,6 +334,7 @@ const struct xfs_buf_ops xfs_dir3_data_buf_ops = {
|
|||||||
.name = "xfs_dir3_data",
|
.name = "xfs_dir3_data",
|
||||||
.verify_read = xfs_dir3_data_read_verify,
|
.verify_read = xfs_dir3_data_read_verify,
|
||||||
.verify_write = xfs_dir3_data_write_verify,
|
.verify_write = xfs_dir3_data_write_verify,
|
||||||
|
.verify_struct = xfs_dir3_data_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct xfs_buf_ops xfs_dir3_data_reada_buf_ops = {
|
static const struct xfs_buf_ops xfs_dir3_data_reada_buf_ops = {
|
||||||
|
|||||||
@@ -227,6 +227,13 @@ __write_verify(
|
|||||||
xfs_buf_update_cksum(bp, XFS_DIR3_LEAF_CRC_OFF);
|
xfs_buf_update_cksum(bp, XFS_DIR3_LEAF_CRC_OFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_dir3_leaf1_verify(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
return xfs_dir3_leaf_verify(bp, XFS_DIR2_LEAF1_MAGIC);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xfs_dir3_leaf1_read_verify(
|
xfs_dir3_leaf1_read_verify(
|
||||||
struct xfs_buf *bp)
|
struct xfs_buf *bp)
|
||||||
@@ -241,6 +248,13 @@ xfs_dir3_leaf1_write_verify(
|
|||||||
__write_verify(bp, XFS_DIR2_LEAF1_MAGIC);
|
__write_verify(bp, XFS_DIR2_LEAF1_MAGIC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_dir3_leafn_verify(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
return xfs_dir3_leaf_verify(bp, XFS_DIR2_LEAFN_MAGIC);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xfs_dir3_leafn_read_verify(
|
xfs_dir3_leafn_read_verify(
|
||||||
struct xfs_buf *bp)
|
struct xfs_buf *bp)
|
||||||
@@ -259,12 +273,14 @@ const struct xfs_buf_ops xfs_dir3_leaf1_buf_ops = {
|
|||||||
.name = "xfs_dir3_leaf1",
|
.name = "xfs_dir3_leaf1",
|
||||||
.verify_read = xfs_dir3_leaf1_read_verify,
|
.verify_read = xfs_dir3_leaf1_read_verify,
|
||||||
.verify_write = xfs_dir3_leaf1_write_verify,
|
.verify_write = xfs_dir3_leaf1_write_verify,
|
||||||
|
.verify_struct = xfs_dir3_leaf1_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct xfs_buf_ops xfs_dir3_leafn_buf_ops = {
|
const struct xfs_buf_ops xfs_dir3_leafn_buf_ops = {
|
||||||
.name = "xfs_dir3_leafn",
|
.name = "xfs_dir3_leafn",
|
||||||
.verify_read = xfs_dir3_leafn_read_verify,
|
.verify_read = xfs_dir3_leafn_read_verify,
|
||||||
.verify_write = xfs_dir3_leafn_write_verify,
|
.verify_write = xfs_dir3_leafn_write_verify,
|
||||||
|
.verify_struct = xfs_dir3_leafn_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|||||||
@@ -164,6 +164,7 @@ const struct xfs_buf_ops xfs_dir3_free_buf_ops = {
|
|||||||
.name = "xfs_dir3_free",
|
.name = "xfs_dir3_free",
|
||||||
.verify_read = xfs_dir3_free_read_verify,
|
.verify_read = xfs_dir3_free_read_verify,
|
||||||
.verify_write = xfs_dir3_free_write_verify,
|
.verify_write = xfs_dir3_free_write_verify,
|
||||||
|
.verify_struct = xfs_dir3_free_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Everything ok in the free block header? */
|
/* Everything ok in the free block header? */
|
||||||
|
|||||||
@@ -242,6 +242,17 @@ xfs_dquot_buf_verify(
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static xfs_failaddr_t
|
||||||
|
xfs_dquot_buf_verify_struct(
|
||||||
|
struct xfs_buf *bp)
|
||||||
|
{
|
||||||
|
struct xfs_mount *mp = bp->b_target->bt_mount;
|
||||||
|
|
||||||
|
if (!xfs_dquot_buf_verify(mp, bp, 0))
|
||||||
|
return __this_address;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
xfs_dquot_buf_read_verify(
|
xfs_dquot_buf_read_verify(
|
||||||
struct xfs_buf *bp)
|
struct xfs_buf *bp)
|
||||||
@@ -294,6 +305,7 @@ const struct xfs_buf_ops xfs_dquot_buf_ops = {
|
|||||||
.name = "xfs_dquot",
|
.name = "xfs_dquot",
|
||||||
.verify_read = xfs_dquot_buf_read_verify,
|
.verify_read = xfs_dquot_buf_read_verify,
|
||||||
.verify_write = xfs_dquot_buf_write_verify,
|
.verify_write = xfs_dquot_buf_write_verify,
|
||||||
|
.verify_struct = xfs_dquot_buf_verify_struct,
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct xfs_buf_ops xfs_dquot_buf_ra_ops = {
|
const struct xfs_buf_ops xfs_dquot_buf_ra_ops = {
|
||||||
|
|||||||
@@ -2579,6 +2579,7 @@ const struct xfs_buf_ops xfs_agi_buf_ops = {
|
|||||||
.name = "xfs_agi",
|
.name = "xfs_agi",
|
||||||
.verify_read = xfs_agi_read_verify,
|
.verify_read = xfs_agi_read_verify,
|
||||||
.verify_write = xfs_agi_write_verify,
|
.verify_write = xfs_agi_write_verify,
|
||||||
|
.verify_struct = xfs_agi_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|||||||
@@ -329,6 +329,7 @@ const struct xfs_buf_ops xfs_inobt_buf_ops = {
|
|||||||
.name = "xfs_inobt",
|
.name = "xfs_inobt",
|
||||||
.verify_read = xfs_inobt_read_verify,
|
.verify_read = xfs_inobt_read_verify,
|
||||||
.verify_write = xfs_inobt_write_verify,
|
.verify_write = xfs_inobt_write_verify,
|
||||||
|
.verify_struct = xfs_inobt_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
|
|||||||
@@ -290,6 +290,7 @@ const struct xfs_buf_ops xfs_refcountbt_buf_ops = {
|
|||||||
.name = "xfs_refcountbt",
|
.name = "xfs_refcountbt",
|
||||||
.verify_read = xfs_refcountbt_read_verify,
|
.verify_read = xfs_refcountbt_read_verify,
|
||||||
.verify_write = xfs_refcountbt_write_verify,
|
.verify_write = xfs_refcountbt_write_verify,
|
||||||
|
.verify_struct = xfs_refcountbt_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
|
|||||||
@@ -382,6 +382,7 @@ const struct xfs_buf_ops xfs_rmapbt_buf_ops = {
|
|||||||
.name = "xfs_rmapbt",
|
.name = "xfs_rmapbt",
|
||||||
.verify_read = xfs_rmapbt_read_verify,
|
.verify_read = xfs_rmapbt_read_verify,
|
||||||
.verify_write = xfs_rmapbt_write_verify,
|
.verify_write = xfs_rmapbt_write_verify,
|
||||||
|
.verify_struct = xfs_rmapbt_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
|
|||||||
@@ -173,6 +173,7 @@ const struct xfs_buf_ops xfs_symlink_buf_ops = {
|
|||||||
.name = "xfs_symlink",
|
.name = "xfs_symlink",
|
||||||
.verify_read = xfs_symlink_read_verify,
|
.verify_read = xfs_symlink_read_verify,
|
||||||
.verify_write = xfs_symlink_write_verify,
|
.verify_write = xfs_symlink_write_verify,
|
||||||
|
.verify_struct = xfs_symlink_verify,
|
||||||
};
|
};
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
@@ -140,6 +140,7 @@ struct xfs_buf_ops {
|
|||||||
char *name;
|
char *name;
|
||||||
void (*verify_read)(struct xfs_buf *);
|
void (*verify_read)(struct xfs_buf *);
|
||||||
void (*verify_write)(struct xfs_buf *);
|
void (*verify_write)(struct xfs_buf *);
|
||||||
|
xfs_failaddr_t (*verify_struct)(struct xfs_buf *bp);
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct xfs_buf {
|
typedef struct xfs_buf {
|
||||||
|
|||||||
Reference in New Issue
Block a user