提交 939c7feb 编写于 作者: N Naohiro Aota 提交者: David Sterba

btrfs: zoned: fix ordered extent boundary calculation

btrfs_lookup_ordered_extent() is supposed to query the offset in a file
instead of the logical address. Pass the file offset from
submit_extent_page() to calc_bio_boundaries().

Also, calc_bio_boundaries() relies on the bio's operation flag, so move
the call site after setting it.

Fixes: 390ed29b ("btrfs: refactor submit_extent_page() to make bio and its flag tracing easier")
Reviewed-by: NQu Wenruo <wqu@suse.com>
Signed-off-by: NNaohiro Aota <naohiro.aota@wdc.com>
Reviewed-by: NDavid Sterba <dsterba@suse.com>
Signed-off-by: NDavid Sterba <dsterba@suse.com>
上级 11462397
...@@ -3241,7 +3241,7 @@ static int btrfs_bio_add_page(struct btrfs_bio_ctrl *bio_ctrl, ...@@ -3241,7 +3241,7 @@ static int btrfs_bio_add_page(struct btrfs_bio_ctrl *bio_ctrl,
} }
static int calc_bio_boundaries(struct btrfs_bio_ctrl *bio_ctrl, static int calc_bio_boundaries(struct btrfs_bio_ctrl *bio_ctrl,
struct btrfs_inode *inode) struct btrfs_inode *inode, u64 file_offset)
{ {
struct btrfs_fs_info *fs_info = inode->root->fs_info; struct btrfs_fs_info *fs_info = inode->root->fs_info;
struct btrfs_io_geometry geom; struct btrfs_io_geometry geom;
...@@ -3283,7 +3283,7 @@ static int calc_bio_boundaries(struct btrfs_bio_ctrl *bio_ctrl, ...@@ -3283,7 +3283,7 @@ static int calc_bio_boundaries(struct btrfs_bio_ctrl *bio_ctrl,
} }
/* Ordered extent not yet created, so we're good */ /* Ordered extent not yet created, so we're good */
ordered = btrfs_lookup_ordered_extent(inode, logical); ordered = btrfs_lookup_ordered_extent(inode, file_offset);
if (!ordered) { if (!ordered) {
bio_ctrl->len_to_oe_boundary = U32_MAX; bio_ctrl->len_to_oe_boundary = U32_MAX;
return 0; return 0;
...@@ -3300,7 +3300,7 @@ static int alloc_new_bio(struct btrfs_inode *inode, ...@@ -3300,7 +3300,7 @@ static int alloc_new_bio(struct btrfs_inode *inode,
struct writeback_control *wbc, struct writeback_control *wbc,
unsigned int opf, unsigned int opf,
bio_end_io_t end_io_func, bio_end_io_t end_io_func,
u64 disk_bytenr, u32 offset, u64 disk_bytenr, u32 offset, u64 file_offset,
unsigned long bio_flags) unsigned long bio_flags)
{ {
struct btrfs_fs_info *fs_info = inode->root->fs_info; struct btrfs_fs_info *fs_info = inode->root->fs_info;
...@@ -3317,13 +3317,13 @@ static int alloc_new_bio(struct btrfs_inode *inode, ...@@ -3317,13 +3317,13 @@ static int alloc_new_bio(struct btrfs_inode *inode,
bio = btrfs_bio_alloc(disk_bytenr + offset); bio = btrfs_bio_alloc(disk_bytenr + offset);
bio_ctrl->bio = bio; bio_ctrl->bio = bio;
bio_ctrl->bio_flags = bio_flags; bio_ctrl->bio_flags = bio_flags;
ret = calc_bio_boundaries(bio_ctrl, inode);
if (ret < 0)
goto error;
bio->bi_end_io = end_io_func; bio->bi_end_io = end_io_func;
bio->bi_private = &inode->io_tree; bio->bi_private = &inode->io_tree;
bio->bi_write_hint = inode->vfs_inode.i_write_hint; bio->bi_write_hint = inode->vfs_inode.i_write_hint;
bio->bi_opf = opf; bio->bi_opf = opf;
ret = calc_bio_boundaries(bio_ctrl, inode, file_offset);
if (ret < 0)
goto error;
if (wbc) { if (wbc) {
struct block_device *bdev; struct block_device *bdev;
...@@ -3398,6 +3398,7 @@ static int submit_extent_page(unsigned int opf, ...@@ -3398,6 +3398,7 @@ static int submit_extent_page(unsigned int opf,
if (!bio_ctrl->bio) { if (!bio_ctrl->bio) {
ret = alloc_new_bio(inode, bio_ctrl, wbc, opf, ret = alloc_new_bio(inode, bio_ctrl, wbc, opf,
end_io_func, disk_bytenr, offset, end_io_func, disk_bytenr, offset,
page_offset(page) + cur,
bio_flags); bio_flags);
if (ret < 0) if (ret < 0)
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册