Commit 624a4c64 authored by Eric Sandeen's avatar Eric Sandeen Committed by Sasha Levin

xfs: print name of verifier if it fails

[ Upstream commit 233135b7 ]

This adds a name to each buf_ops structure, so that if
a verifier fails we can print the type of verifier that
failed it.  Should be a slight debugging aid, I hope.
Signed-off-by: default avatarEric Sandeen <sandeen@redhat.com>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
Signed-off-by: default avatarDave Chinner <david@fromorbit.com>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent be65d29f
...@@ -515,6 +515,7 @@ xfs_agfl_write_verify( ...@@ -515,6 +515,7 @@ xfs_agfl_write_verify(
} }
const struct xfs_buf_ops xfs_agfl_buf_ops = { const struct xfs_buf_ops xfs_agfl_buf_ops = {
.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,
}; };
...@@ -2271,6 +2272,7 @@ xfs_agf_write_verify( ...@@ -2271,6 +2272,7 @@ xfs_agf_write_verify(
} }
const struct xfs_buf_ops xfs_agf_buf_ops = { const struct xfs_buf_ops xfs_agf_buf_ops = {
.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,
}; };
......
...@@ -380,6 +380,7 @@ xfs_allocbt_write_verify( ...@@ -380,6 +380,7 @@ xfs_allocbt_write_verify(
} }
const struct xfs_buf_ops xfs_allocbt_buf_ops = { const struct xfs_buf_ops xfs_allocbt_buf_ops = {
.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,
}; };
......
...@@ -251,6 +251,7 @@ xfs_attr3_leaf_read_verify( ...@@ -251,6 +251,7 @@ xfs_attr3_leaf_read_verify(
} }
const struct xfs_buf_ops xfs_attr3_leaf_buf_ops = { const struct xfs_buf_ops xfs_attr3_leaf_buf_ops = {
.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,
}; };
......
...@@ -198,6 +198,7 @@ xfs_attr3_rmt_write_verify( ...@@ -198,6 +198,7 @@ xfs_attr3_rmt_write_verify(
} }
const struct xfs_buf_ops xfs_attr3_rmt_buf_ops = { const struct xfs_buf_ops xfs_attr3_rmt_buf_ops = {
.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,
}; };
......
...@@ -722,6 +722,7 @@ xfs_bmbt_write_verify( ...@@ -722,6 +722,7 @@ xfs_bmbt_write_verify(
} }
const struct xfs_buf_ops xfs_bmbt_buf_ops = { const struct xfs_buf_ops xfs_bmbt_buf_ops = {
.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,
}; };
......
...@@ -243,6 +243,7 @@ xfs_da3_node_read_verify( ...@@ -243,6 +243,7 @@ xfs_da3_node_read_verify(
} }
const struct xfs_buf_ops xfs_da3_node_buf_ops = { const struct xfs_buf_ops xfs_da3_node_buf_ops = {
.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,
}; };
......
...@@ -123,6 +123,7 @@ xfs_dir3_block_write_verify( ...@@ -123,6 +123,7 @@ xfs_dir3_block_write_verify(
} }
const struct xfs_buf_ops xfs_dir3_block_buf_ops = { const struct xfs_buf_ops xfs_dir3_block_buf_ops = {
.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,
}; };
......
...@@ -302,11 +302,13 @@ xfs_dir3_data_write_verify( ...@@ -302,11 +302,13 @@ xfs_dir3_data_write_verify(
} }
const struct xfs_buf_ops xfs_dir3_data_buf_ops = { const struct xfs_buf_ops xfs_dir3_data_buf_ops = {
.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,
}; };
static const struct xfs_buf_ops xfs_dir3_data_reada_buf_ops = { static const struct xfs_buf_ops xfs_dir3_data_reada_buf_ops = {
.name = "xfs_dir3_data_reada",
.verify_read = xfs_dir3_data_reada_verify, .verify_read = xfs_dir3_data_reada_verify,
.verify_write = xfs_dir3_data_write_verify, .verify_write = xfs_dir3_data_write_verify,
}; };
......
...@@ -244,11 +244,13 @@ xfs_dir3_leafn_write_verify( ...@@ -244,11 +244,13 @@ xfs_dir3_leafn_write_verify(
} }
const struct xfs_buf_ops xfs_dir3_leaf1_buf_ops = { const struct xfs_buf_ops xfs_dir3_leaf1_buf_ops = {
.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,
}; };
const struct xfs_buf_ops xfs_dir3_leafn_buf_ops = { const struct xfs_buf_ops xfs_dir3_leafn_buf_ops = {
.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,
}; };
......
...@@ -149,6 +149,7 @@ xfs_dir3_free_write_verify( ...@@ -149,6 +149,7 @@ xfs_dir3_free_write_verify(
} }
const struct xfs_buf_ops xfs_dir3_free_buf_ops = { const struct xfs_buf_ops xfs_dir3_free_buf_ops = {
.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,
}; };
......
...@@ -303,6 +303,7 @@ xfs_dquot_buf_write_verify( ...@@ -303,6 +303,7 @@ xfs_dquot_buf_write_verify(
} }
const struct xfs_buf_ops xfs_dquot_buf_ops = { const struct xfs_buf_ops xfs_dquot_buf_ops = {
.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,
}; };
......
...@@ -2105,6 +2105,7 @@ xfs_agi_write_verify( ...@@ -2105,6 +2105,7 @@ xfs_agi_write_verify(
} }
const struct xfs_buf_ops xfs_agi_buf_ops = { const struct xfs_buf_ops xfs_agi_buf_ops = {
.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,
}; };
......
...@@ -297,6 +297,7 @@ xfs_inobt_write_verify( ...@@ -297,6 +297,7 @@ xfs_inobt_write_verify(
} }
const struct xfs_buf_ops xfs_inobt_buf_ops = { const struct xfs_buf_ops xfs_inobt_buf_ops = {
.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,
}; };
......
...@@ -141,11 +141,13 @@ xfs_inode_buf_write_verify( ...@@ -141,11 +141,13 @@ xfs_inode_buf_write_verify(
} }
const struct xfs_buf_ops xfs_inode_buf_ops = { const struct xfs_buf_ops xfs_inode_buf_ops = {
.name = "xfs_inode",
.verify_read = xfs_inode_buf_read_verify, .verify_read = xfs_inode_buf_read_verify,
.verify_write = xfs_inode_buf_write_verify, .verify_write = xfs_inode_buf_write_verify,
}; };
const struct xfs_buf_ops xfs_inode_buf_ra_ops = { const struct xfs_buf_ops xfs_inode_buf_ra_ops = {
.name = "xxfs_inode_ra",
.verify_read = xfs_inode_buf_readahead_verify, .verify_read = xfs_inode_buf_readahead_verify,
.verify_write = xfs_inode_buf_write_verify, .verify_write = xfs_inode_buf_write_verify,
}; };
......
...@@ -704,11 +704,13 @@ xfs_sb_write_verify( ...@@ -704,11 +704,13 @@ xfs_sb_write_verify(
} }
const struct xfs_buf_ops xfs_sb_buf_ops = { const struct xfs_buf_ops xfs_sb_buf_ops = {
.name = "xfs_sb",
.verify_read = xfs_sb_read_verify, .verify_read = xfs_sb_read_verify,
.verify_write = xfs_sb_write_verify, .verify_write = xfs_sb_write_verify,
}; };
const struct xfs_buf_ops xfs_sb_quiet_buf_ops = { const struct xfs_buf_ops xfs_sb_quiet_buf_ops = {
.name = "xfs_sb_quiet",
.verify_read = xfs_sb_quiet_read_verify, .verify_read = xfs_sb_quiet_read_verify,
.verify_write = xfs_sb_write_verify, .verify_write = xfs_sb_write_verify,
}; };
......
...@@ -166,6 +166,7 @@ xfs_symlink_write_verify( ...@@ -166,6 +166,7 @@ xfs_symlink_write_verify(
} }
const struct xfs_buf_ops xfs_symlink_buf_ops = { const struct xfs_buf_ops xfs_symlink_buf_ops = {
.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,
}; };
......
...@@ -131,6 +131,7 @@ struct xfs_buf_map { ...@@ -131,6 +131,7 @@ struct xfs_buf_map {
struct xfs_buf_map (map) = { .bm_bn = (blkno), .bm_len = (numblk) }; struct xfs_buf_map (map) = { .bm_bn = (blkno), .bm_len = (numblk) };
struct xfs_buf_ops { struct xfs_buf_ops {
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 *);
}; };
......
...@@ -166,9 +166,9 @@ xfs_verifier_error( ...@@ -166,9 +166,9 @@ xfs_verifier_error(
{ {
struct xfs_mount *mp = bp->b_target->bt_mount; struct xfs_mount *mp = bp->b_target->bt_mount;
xfs_alert(mp, "Metadata %s detected at %pF, block 0x%llx", xfs_alert(mp, "Metadata %s detected at %pF, %s block 0x%llx",
bp->b_error == -EFSBADCRC ? "CRC error" : "corruption", bp->b_error == -EFSBADCRC ? "CRC error" : "corruption",
__return_address, bp->b_bn); __return_address, bp->b_ops->name, bp->b_bn);
xfs_alert(mp, "Unmount and run xfs_repair"); xfs_alert(mp, "Unmount and run xfs_repair");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment