提交 2d5ac130 编写于 作者: C Christoph Hellwig 提交者: David Sterba

btrfs: don't use bio->bi_private to pass the inode to submit_one_bio

submit_one_bio is only used for page cache I/O, so the inode can be
trivially derived from the first page in the bio.
Reviewed-by: NQu Wenruo <wqu@suse.com>
Signed-off-by: NChristoph Hellwig <hch@lst.de>
Reviewed-by: NDavid Sterba <dsterba@suse.com>
Signed-off-by: NDavid Sterba <dsterba@suse.com>
上级 234fdd28
...@@ -181,10 +181,7 @@ static int add_extent_changeset(struct extent_state *state, u32 bits, ...@@ -181,10 +181,7 @@ static int add_extent_changeset(struct extent_state *state, u32 bits,
static void submit_one_bio(struct bio *bio, int mirror_num, static void submit_one_bio(struct bio *bio, int mirror_num,
enum btrfs_compression_type compress_type) enum btrfs_compression_type compress_type)
{ {
struct extent_io_tree *tree = bio->bi_private; struct inode *inode = bio_first_page_all(bio)->mapping->host;
struct inode *inode = tree->private_data;
bio->bi_private = NULL;
/* Caller should ensure the bio has at least some range added */ /* Caller should ensure the bio has at least some range added */
ASSERT(bio->bi_iter.bi_size); ASSERT(bio->bi_iter.bi_size);
...@@ -3362,7 +3359,6 @@ static int alloc_new_bio(struct btrfs_inode *inode, ...@@ -3362,7 +3359,6 @@ static int alloc_new_bio(struct btrfs_inode *inode,
bio_ctrl->bio = bio; bio_ctrl->bio = bio;
bio_ctrl->compress_type = compress_type; bio_ctrl->compress_type = compress_type;
bio->bi_end_io = end_io_func; bio->bi_end_io = end_io_func;
bio->bi_private = &inode->io_tree;
bio->bi_opf = opf; bio->bi_opf = opf;
ret = calc_bio_boundaries(bio_ctrl, inode, file_offset); ret = calc_bio_boundaries(bio_ctrl, inode, file_offset);
if (ret < 0) if (ret < 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册