Commit a6889caf authored by Filipe Manana's avatar Filipe Manana Committed by David Sterba

btrfs: do not start readahead for csum tree when scrubbing non-data block groups

When scrubbing a stripe of a block group we always start readahead for the
checksums btree and wait for it to complete, however when the blockgroup is
not a data block group (or a mixed block group) it is a waste of time to do
it, since there are no checksums for metadata extents in that btree.

So skip that when the block group does not have the data flag set, saving
some time doing memory allocations, queueing a job in the readahead work
queue, waiting for it to complete and potentially avoiding some IO as well
(when csum tree extents are not in memory already).
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Reviewed-by: default avatarJosef Bacik <josef@toxicpanda.com>
Signed-off-by: default avatarFilipe Manana <fdmanana@suse.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent a57ad681
...@@ -3084,17 +3084,21 @@ static noinline_for_stack int scrub_stripe(struct scrub_ctx *sctx, ...@@ -3084,17 +3084,21 @@ static noinline_for_stack int scrub_stripe(struct scrub_ctx *sctx,
key_end.offset = (u64)-1; key_end.offset = (u64)-1;
reada1 = btrfs_reada_add(root, &key, &key_end); reada1 = btrfs_reada_add(root, &key, &key_end);
key.objectid = BTRFS_EXTENT_CSUM_OBJECTID; if (cache->flags & BTRFS_BLOCK_GROUP_DATA) {
key.type = BTRFS_EXTENT_CSUM_KEY; key.objectid = BTRFS_EXTENT_CSUM_OBJECTID;
key.offset = logical; key.type = BTRFS_EXTENT_CSUM_KEY;
key_end.objectid = BTRFS_EXTENT_CSUM_OBJECTID; key.offset = logical;
key_end.type = BTRFS_EXTENT_CSUM_KEY; key_end.objectid = BTRFS_EXTENT_CSUM_OBJECTID;
key_end.offset = logic_end; key_end.type = BTRFS_EXTENT_CSUM_KEY;
reada2 = btrfs_reada_add(csum_root, &key, &key_end); key_end.offset = logic_end;
reada2 = btrfs_reada_add(csum_root, &key, &key_end);
} else {
reada2 = NULL;
}
if (!IS_ERR(reada1)) if (!IS_ERR(reada1))
btrfs_reada_wait(reada1); btrfs_reada_wait(reada1);
if (!IS_ERR(reada2)) if (!IS_ERR_OR_NULL(reada2))
btrfs_reada_wait(reada2); btrfs_reada_wait(reada2);
......
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