@@ -337,22 +337,42 @@ static inline void btrfs_inode_resume_unlocked_dio(struct btrfs_inode *inode)
clear_bit(BTRFS_INODE_READDIO_NEED_LOCK, &inode->runtime_flags);
}
+static inline void btrfs_csum_format(struct btrfs_super_block *sb,
+ u32 csum, u8 *cbuf)
+{
+ size_t size = btrfs_super_csum_size(sb) * 8;
+
+ switch (btrfs_super_csum_type(sb)) {
+ case BTRFS_CSUM_TYPE_CRC32:
+ snprintf(cbuf, size, "0x%08x", csum);
+ break;
+ default: /* can't happen - csum type is validated at mount time */
+ break;
+ }
+}
+
static inline void btrfs_print_data_csum_error(struct btrfs_inode *inode,
u64 logical_start, u32 csum, u32 csum_expected, int mirror_num)
{
struct btrfs_root *root = inode->root;
+ struct btrfs_super_block *sb = root->fs_info->super_copy;
+ u8 cbuf[BTRFS_CSUM_SIZE];
+ u8 ecbuf[BTRFS_CSUM_SIZE];
+
+ btrfs_csum_format(sb, csum, cbuf);
+ btrfs_csum_format(sb, csum_expected, ecbuf);
/* Output minus objectid, which is more meaningful */
if (root->root_key.objectid >= BTRFS_LAST_FREE_OBJECTID)
btrfs_warn_rl(root->fs_info,
- "csum failed root %lld ino %lld off %llu csum 0x%08x expected csum 0x%08x mirror %d",
+ "csum failed root %lld ino %lld off %llu csum %s expected csum %s mirror %d",
root->root_key.objectid, btrfs_ino(inode),
- logical_start, csum, csum_expected, mirror_num);
+ logical_start, cbuf, ecbuf, mirror_num);
else
btrfs_warn_rl(root->fs_info,
- "csum failed root %llu ino %llu off %llu csum 0x%08x expected csum 0x%08x mirror %d",
+ "csum failed root %llu ino %llu off %llu csum %s expected csum %s mirror %d",
root->root_key.objectid, btrfs_ino(inode),
- logical_start, csum, csum_expected, mirror_num);
+ logical_start, cbuf, ecbuf, mirror_num);
}
#endif