Thread (30 messages) 30 messages, 4 authors, 2021-05-26

Re: [PATCH 8/9] btrfs: simplify eb checksum verification in btrfs_validate_metadata_buffer

From: Qu Wenruo <hidden>
Date: 2021-05-26 23:13:37


On 2021/5/27 上午12:58, David Sterba wrote:
quoted hunk ↗ jump to hunk
On Wed, May 26, 2021 at 06:31:39PM +0200, David Sterba wrote:
quoted
quoted
quoted
+	header = page_address(eb->pages[0]) +
+		 get_eb_offset_in_page(eb, offsetof(struct btrfs_leaf, header));
It takes me near a minute to figure why it's not just
"get_eb_offset_in_page(eb, 0)".

I'm not sure if we really need that explicit way to just get 0,
especially most of us (and even some advanced users) know that csum
comes at the very beginning of a tree block.

And the mention of btrfs_leave can sometimes be confusing, especially
when we could have tree nodes passed in.
Ah right, I wanted to use the offsetof for clarity but that it could be
used with nodes makes it confusing again. What if it's replaced by

	get_eb_offset_in_page(eb, offsetof(struct btrfs_header, csum));

This makes it clear that it's the checksum and from the experience we
know it's at offset 0. I'd rather avoid magic constants and offsets but
you're right that everybody knows that the checksum is at the beginning
of btree block.
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -584,7 +584,7 @@ static int validate_extent_buffer(struct extent_buffer *eb)
         const u32 csum_size = fs_info->csum_size;
         u8 found_level;
         u8 result[BTRFS_CSUM_SIZE];
-       const struct btrfs_header *header;
+       const u8 *header_csum;
         int ret = 0;

         found_start = btrfs_header_bytenr(eb);
@@ -609,14 +609,14 @@ static int validate_extent_buffer(struct extent_buffer *eb)
         }

         csum_tree_block(eb, result);
-       header = page_address(eb->pages[0]) +
-                get_eb_offset_in_page(eb, offsetof(struct btrfs_leaf, header));
+       header_csum = page_address(eb->pages[0]) +
+               get_eb_offset_in_page(eb, offsetof(struct btrfs_header, csum));
This version looks better to me.

THanks,
Qu
-       if (memcmp(result, header->csum, csum_size) != 0) {
+       if (memcmp(result, header_csum, csum_size) != 0) {
                 btrfs_warn_rl(fs_info,
         "checksum verify failed on %llu wanted " CSUM_FMT " found " CSUM_FMT " level %d",
                               eb->start,
-                             CSUM_FMT_VALUE(csum_size, header->csum),
+                             CSUM_FMT_VALUE(csum_size, header_csum),
                               CSUM_FMT_VALUE(csum_size, result),
                               btrfs_header_level(eb));
                 ret = -EUCLEAN;
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help