Commit 78a213a0 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by David Sterba

btrfs: optimize simple reads in btrfsic_map_block

Pass a smap into __btrfs_map_block so that the usual case of a read that
doesn't require parity raid recovery doesn't need an extra memory
allocation for the btrfs_io_context.
Reviewed-by: default avatarQu Wenruo <wqu@suse.com>
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 3965a4c7
...@@ -1459,13 +1459,13 @@ static int btrfsic_map_block(struct btrfsic_state *state, u64 bytenr, u32 len, ...@@ -1459,13 +1459,13 @@ static int btrfsic_map_block(struct btrfsic_state *state, u64 bytenr, u32 len,
struct btrfs_fs_info *fs_info = state->fs_info; struct btrfs_fs_info *fs_info = state->fs_info;
int ret; int ret;
u64 length; u64 length;
struct btrfs_io_context *multi = NULL; struct btrfs_io_context *bioc = NULL;
struct btrfs_io_stripe smap, *map;
struct btrfs_device *device; struct btrfs_device *device;
length = len; length = len;
ret = btrfs_map_block(fs_info, BTRFS_MAP_READ, ret = __btrfs_map_block(fs_info, BTRFS_MAP_READ, bytenr, &length, &bioc,
bytenr, &length, &multi, mirror_num); NULL, &mirror_num, 0);
if (ret) { if (ret) {
block_ctx_out->start = 0; block_ctx_out->start = 0;
block_ctx_out->dev_bytenr = 0; block_ctx_out->dev_bytenr = 0;
...@@ -1478,21 +1478,26 @@ static int btrfsic_map_block(struct btrfsic_state *state, u64 bytenr, u32 len, ...@@ -1478,21 +1478,26 @@ static int btrfsic_map_block(struct btrfsic_state *state, u64 bytenr, u32 len,
return ret; return ret;
} }
device = multi->stripes[0].dev; if (bioc)
map = &bioc->stripes[0];
else
map = &smap;
device = map->dev;
if (test_bit(BTRFS_DEV_STATE_MISSING, &device->dev_state) || if (test_bit(BTRFS_DEV_STATE_MISSING, &device->dev_state) ||
!device->bdev || !device->name) !device->bdev || !device->name)
block_ctx_out->dev = NULL; block_ctx_out->dev = NULL;
else else
block_ctx_out->dev = btrfsic_dev_state_lookup( block_ctx_out->dev = btrfsic_dev_state_lookup(
device->bdev->bd_dev); device->bdev->bd_dev);
block_ctx_out->dev_bytenr = multi->stripes[0].physical; block_ctx_out->dev_bytenr = map->physical;
block_ctx_out->start = bytenr; block_ctx_out->start = bytenr;
block_ctx_out->len = len; block_ctx_out->len = len;
block_ctx_out->datav = NULL; block_ctx_out->datav = NULL;
block_ctx_out->pagev = NULL; block_ctx_out->pagev = NULL;
block_ctx_out->mem_to_free = NULL; block_ctx_out->mem_to_free = NULL;
kfree(multi); kfree(bioc);
if (NULL == block_ctx_out->dev) { if (NULL == block_ctx_out->dev) {
ret = -ENXIO; ret = -ENXIO;
pr_info("btrfsic: error, cannot lookup dev (#1)!\n"); pr_info("btrfsic: error, cannot lookup dev (#1)!\n");
......
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