btrfs: have submit_one_bio users use bio op accessors
This patch has btrfs's submit_one_bio users set the bio op using bio_set_op_attrs and get the op using bio_op. The next patches will continue to convert btrfs, so submit_bio_hook and merge_bio_hook related code will be modified to take only the bio. I did not do it in this patch to try and keep it smaller. Signed-off-by: Mike Christie <mchristi@redhat.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Hannes Reinecke <hare@suse.com> Signed-off-by: Jens Axboe <axboe@fb.com>
This commit is contained in:
parent
8a4c1e42e0
commit
1f7ad75b13
|
@ -2387,7 +2387,7 @@ static int bio_readpage_error(struct bio *failed_bio, u64 phy_offset,
|
||||||
int read_mode;
|
int read_mode;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
BUG_ON(failed_bio->bi_rw & REQ_WRITE);
|
BUG_ON(bio_op(failed_bio) == REQ_OP_WRITE);
|
||||||
|
|
||||||
ret = btrfs_get_io_failure_record(inode, start, end, &failrec);
|
ret = btrfs_get_io_failure_record(inode, start, end, &failrec);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -2413,6 +2413,7 @@ static int bio_readpage_error(struct bio *failed_bio, u64 phy_offset,
|
||||||
free_io_failure(inode, failrec);
|
free_io_failure(inode, failrec);
|
||||||
return -EIO;
|
return -EIO;
|
||||||
}
|
}
|
||||||
|
bio_set_op_attrs(bio, REQ_OP_READ, read_mode);
|
||||||
|
|
||||||
pr_debug("Repair Read Error: submitting new read[%#x] to this_mirror=%d, in_validation=%d\n",
|
pr_debug("Repair Read Error: submitting new read[%#x] to this_mirror=%d, in_validation=%d\n",
|
||||||
read_mode, failrec->this_mirror, failrec->in_validation);
|
read_mode, failrec->this_mirror, failrec->in_validation);
|
||||||
|
@ -2724,8 +2725,8 @@ struct bio *btrfs_io_bio_alloc(gfp_t gfp_mask, unsigned int nr_iovecs)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int __must_check submit_one_bio(int rw, struct bio *bio,
|
static int __must_check submit_one_bio(struct bio *bio, int mirror_num,
|
||||||
int mirror_num, unsigned long bio_flags)
|
unsigned long bio_flags)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
struct bio_vec *bvec = bio->bi_io_vec + bio->bi_vcnt - 1;
|
struct bio_vec *bvec = bio->bi_io_vec + bio->bi_vcnt - 1;
|
||||||
|
@ -2736,12 +2737,12 @@ static int __must_check submit_one_bio(int rw, struct bio *bio,
|
||||||
start = page_offset(page) + bvec->bv_offset;
|
start = page_offset(page) + bvec->bv_offset;
|
||||||
|
|
||||||
bio->bi_private = NULL;
|
bio->bi_private = NULL;
|
||||||
bio->bi_rw = rw;
|
|
||||||
bio_get(bio);
|
bio_get(bio);
|
||||||
|
|
||||||
if (tree->ops && tree->ops->submit_bio_hook)
|
if (tree->ops && tree->ops->submit_bio_hook)
|
||||||
ret = tree->ops->submit_bio_hook(page->mapping->host, rw, bio,
|
ret = tree->ops->submit_bio_hook(page->mapping->host,
|
||||||
mirror_num, bio_flags, start);
|
bio->bi_rw, bio, mirror_num,
|
||||||
|
bio_flags, start);
|
||||||
else
|
else
|
||||||
btrfsic_submit_bio(bio);
|
btrfsic_submit_bio(bio);
|
||||||
|
|
||||||
|
@ -2749,20 +2750,20 @@ static int __must_check submit_one_bio(int rw, struct bio *bio,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int merge_bio(int rw, struct extent_io_tree *tree, struct page *page,
|
static int merge_bio(struct extent_io_tree *tree, struct page *page,
|
||||||
unsigned long offset, size_t size, struct bio *bio,
|
unsigned long offset, size_t size, struct bio *bio,
|
||||||
unsigned long bio_flags)
|
unsigned long bio_flags)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
if (tree->ops && tree->ops->merge_bio_hook)
|
if (tree->ops && tree->ops->merge_bio_hook)
|
||||||
ret = tree->ops->merge_bio_hook(rw, page, offset, size, bio,
|
ret = tree->ops->merge_bio_hook(bio_op(bio), page, offset, size,
|
||||||
bio_flags);
|
bio, bio_flags);
|
||||||
BUG_ON(ret < 0);
|
BUG_ON(ret < 0);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int submit_extent_page(int rw, struct extent_io_tree *tree,
|
static int submit_extent_page(int op, int op_flags, struct extent_io_tree *tree,
|
||||||
struct writeback_control *wbc,
|
struct writeback_control *wbc,
|
||||||
struct page *page, sector_t sector,
|
struct page *page, sector_t sector,
|
||||||
size_t size, unsigned long offset,
|
size_t size, unsigned long offset,
|
||||||
|
@ -2790,10 +2791,9 @@ static int submit_extent_page(int rw, struct extent_io_tree *tree,
|
||||||
|
|
||||||
if (prev_bio_flags != bio_flags || !contig ||
|
if (prev_bio_flags != bio_flags || !contig ||
|
||||||
force_bio_submit ||
|
force_bio_submit ||
|
||||||
merge_bio(rw, tree, page, offset, page_size, bio, bio_flags) ||
|
merge_bio(tree, page, offset, page_size, bio, bio_flags) ||
|
||||||
bio_add_page(bio, page, page_size, offset) < page_size) {
|
bio_add_page(bio, page, page_size, offset) < page_size) {
|
||||||
ret = submit_one_bio(rw, bio, mirror_num,
|
ret = submit_one_bio(bio, mirror_num, prev_bio_flags);
|
||||||
prev_bio_flags);
|
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
*bio_ret = NULL;
|
*bio_ret = NULL;
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -2814,6 +2814,7 @@ static int submit_extent_page(int rw, struct extent_io_tree *tree,
|
||||||
bio_add_page(bio, page, page_size, offset);
|
bio_add_page(bio, page, page_size, offset);
|
||||||
bio->bi_end_io = end_io_func;
|
bio->bi_end_io = end_io_func;
|
||||||
bio->bi_private = tree;
|
bio->bi_private = tree;
|
||||||
|
bio_set_op_attrs(bio, op, op_flags);
|
||||||
if (wbc) {
|
if (wbc) {
|
||||||
wbc_init_bio(wbc, bio);
|
wbc_init_bio(wbc, bio);
|
||||||
wbc_account_io(wbc, page, page_size);
|
wbc_account_io(wbc, page, page_size);
|
||||||
|
@ -2822,7 +2823,7 @@ static int submit_extent_page(int rw, struct extent_io_tree *tree,
|
||||||
if (bio_ret)
|
if (bio_ret)
|
||||||
*bio_ret = bio;
|
*bio_ret = bio;
|
||||||
else
|
else
|
||||||
ret = submit_one_bio(rw, bio, mirror_num, bio_flags);
|
ret = submit_one_bio(bio, mirror_num, bio_flags);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -2886,7 +2887,7 @@ static int __do_readpage(struct extent_io_tree *tree,
|
||||||
get_extent_t *get_extent,
|
get_extent_t *get_extent,
|
||||||
struct extent_map **em_cached,
|
struct extent_map **em_cached,
|
||||||
struct bio **bio, int mirror_num,
|
struct bio **bio, int mirror_num,
|
||||||
unsigned long *bio_flags, int rw,
|
unsigned long *bio_flags, int read_flags,
|
||||||
u64 *prev_em_start)
|
u64 *prev_em_start)
|
||||||
{
|
{
|
||||||
struct inode *inode = page->mapping->host;
|
struct inode *inode = page->mapping->host;
|
||||||
|
@ -3069,8 +3070,8 @@ static int __do_readpage(struct extent_io_tree *tree,
|
||||||
}
|
}
|
||||||
|
|
||||||
pnr -= page->index;
|
pnr -= page->index;
|
||||||
ret = submit_extent_page(rw, tree, NULL, page,
|
ret = submit_extent_page(REQ_OP_READ, read_flags, tree, NULL,
|
||||||
sector, disk_io_size, pg_offset,
|
page, sector, disk_io_size, pg_offset,
|
||||||
bdev, bio, pnr,
|
bdev, bio, pnr,
|
||||||
end_bio_extent_readpage, mirror_num,
|
end_bio_extent_readpage, mirror_num,
|
||||||
*bio_flags,
|
*bio_flags,
|
||||||
|
@ -3101,7 +3102,7 @@ static inline void __do_contiguous_readpages(struct extent_io_tree *tree,
|
||||||
get_extent_t *get_extent,
|
get_extent_t *get_extent,
|
||||||
struct extent_map **em_cached,
|
struct extent_map **em_cached,
|
||||||
struct bio **bio, int mirror_num,
|
struct bio **bio, int mirror_num,
|
||||||
unsigned long *bio_flags, int rw,
|
unsigned long *bio_flags,
|
||||||
u64 *prev_em_start)
|
u64 *prev_em_start)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
|
@ -3122,7 +3123,7 @@ static inline void __do_contiguous_readpages(struct extent_io_tree *tree,
|
||||||
|
|
||||||
for (index = 0; index < nr_pages; index++) {
|
for (index = 0; index < nr_pages; index++) {
|
||||||
__do_readpage(tree, pages[index], get_extent, em_cached, bio,
|
__do_readpage(tree, pages[index], get_extent, em_cached, bio,
|
||||||
mirror_num, bio_flags, rw, prev_em_start);
|
mirror_num, bio_flags, 0, prev_em_start);
|
||||||
put_page(pages[index]);
|
put_page(pages[index]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3132,7 +3133,7 @@ static void __extent_readpages(struct extent_io_tree *tree,
|
||||||
int nr_pages, get_extent_t *get_extent,
|
int nr_pages, get_extent_t *get_extent,
|
||||||
struct extent_map **em_cached,
|
struct extent_map **em_cached,
|
||||||
struct bio **bio, int mirror_num,
|
struct bio **bio, int mirror_num,
|
||||||
unsigned long *bio_flags, int rw,
|
unsigned long *bio_flags,
|
||||||
u64 *prev_em_start)
|
u64 *prev_em_start)
|
||||||
{
|
{
|
||||||
u64 start = 0;
|
u64 start = 0;
|
||||||
|
@ -3154,7 +3155,7 @@ static void __extent_readpages(struct extent_io_tree *tree,
|
||||||
index - first_index, start,
|
index - first_index, start,
|
||||||
end, get_extent, em_cached,
|
end, get_extent, em_cached,
|
||||||
bio, mirror_num, bio_flags,
|
bio, mirror_num, bio_flags,
|
||||||
rw, prev_em_start);
|
prev_em_start);
|
||||||
start = page_start;
|
start = page_start;
|
||||||
end = start + PAGE_SIZE - 1;
|
end = start + PAGE_SIZE - 1;
|
||||||
first_index = index;
|
first_index = index;
|
||||||
|
@ -3165,7 +3166,7 @@ static void __extent_readpages(struct extent_io_tree *tree,
|
||||||
__do_contiguous_readpages(tree, &pages[first_index],
|
__do_contiguous_readpages(tree, &pages[first_index],
|
||||||
index - first_index, start,
|
index - first_index, start,
|
||||||
end, get_extent, em_cached, bio,
|
end, get_extent, em_cached, bio,
|
||||||
mirror_num, bio_flags, rw,
|
mirror_num, bio_flags,
|
||||||
prev_em_start);
|
prev_em_start);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3173,7 +3174,7 @@ static int __extent_read_full_page(struct extent_io_tree *tree,
|
||||||
struct page *page,
|
struct page *page,
|
||||||
get_extent_t *get_extent,
|
get_extent_t *get_extent,
|
||||||
struct bio **bio, int mirror_num,
|
struct bio **bio, int mirror_num,
|
||||||
unsigned long *bio_flags, int rw)
|
unsigned long *bio_flags, int read_flags)
|
||||||
{
|
{
|
||||||
struct inode *inode = page->mapping->host;
|
struct inode *inode = page->mapping->host;
|
||||||
struct btrfs_ordered_extent *ordered;
|
struct btrfs_ordered_extent *ordered;
|
||||||
|
@ -3193,7 +3194,7 @@ static int __extent_read_full_page(struct extent_io_tree *tree,
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = __do_readpage(tree, page, get_extent, NULL, bio, mirror_num,
|
ret = __do_readpage(tree, page, get_extent, NULL, bio, mirror_num,
|
||||||
bio_flags, rw, NULL);
|
bio_flags, read_flags, NULL);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3205,9 +3206,9 @@ int extent_read_full_page(struct extent_io_tree *tree, struct page *page,
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = __extent_read_full_page(tree, page, get_extent, &bio, mirror_num,
|
ret = __extent_read_full_page(tree, page, get_extent, &bio, mirror_num,
|
||||||
&bio_flags, READ);
|
&bio_flags, 0);
|
||||||
if (bio)
|
if (bio)
|
||||||
ret = submit_one_bio(READ, bio, mirror_num, bio_flags);
|
ret = submit_one_bio(bio, mirror_num, bio_flags);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3441,8 +3442,8 @@ static noinline_for_stack int __extent_writepage_io(struct inode *inode,
|
||||||
page->index, cur, end);
|
page->index, cur, end);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = submit_extent_page(write_flags, tree, wbc, page,
|
ret = submit_extent_page(REQ_OP_WRITE, write_flags, tree, wbc,
|
||||||
sector, iosize, pg_offset,
|
page, sector, iosize, pg_offset,
|
||||||
bdev, &epd->bio, max_nr,
|
bdev, &epd->bio, max_nr,
|
||||||
end_bio_extent_writepage,
|
end_bio_extent_writepage,
|
||||||
0, 0, 0, false);
|
0, 0, 0, false);
|
||||||
|
@ -3481,13 +3482,11 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc,
|
||||||
size_t pg_offset = 0;
|
size_t pg_offset = 0;
|
||||||
loff_t i_size = i_size_read(inode);
|
loff_t i_size = i_size_read(inode);
|
||||||
unsigned long end_index = i_size >> PAGE_SHIFT;
|
unsigned long end_index = i_size >> PAGE_SHIFT;
|
||||||
int write_flags;
|
int write_flags = 0;
|
||||||
unsigned long nr_written = 0;
|
unsigned long nr_written = 0;
|
||||||
|
|
||||||
if (wbc->sync_mode == WB_SYNC_ALL)
|
if (wbc->sync_mode == WB_SYNC_ALL)
|
||||||
write_flags = WRITE_SYNC;
|
write_flags = WRITE_SYNC;
|
||||||
else
|
|
||||||
write_flags = WRITE;
|
|
||||||
|
|
||||||
trace___extent_writepage(page, inode, wbc);
|
trace___extent_writepage(page, inode, wbc);
|
||||||
|
|
||||||
|
@ -3731,7 +3730,7 @@ static noinline_for_stack int write_one_eb(struct extent_buffer *eb,
|
||||||
u64 offset = eb->start;
|
u64 offset = eb->start;
|
||||||
unsigned long i, num_pages;
|
unsigned long i, num_pages;
|
||||||
unsigned long bio_flags = 0;
|
unsigned long bio_flags = 0;
|
||||||
int rw = (epd->sync_io ? WRITE_SYNC : WRITE) | REQ_META;
|
int write_flags = (epd->sync_io ? WRITE_SYNC : 0) | REQ_META;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
clear_bit(EXTENT_BUFFER_WRITE_ERR, &eb->bflags);
|
clear_bit(EXTENT_BUFFER_WRITE_ERR, &eb->bflags);
|
||||||
|
@ -3745,9 +3744,10 @@ static noinline_for_stack int write_one_eb(struct extent_buffer *eb,
|
||||||
|
|
||||||
clear_page_dirty_for_io(p);
|
clear_page_dirty_for_io(p);
|
||||||
set_page_writeback(p);
|
set_page_writeback(p);
|
||||||
ret = submit_extent_page(rw, tree, wbc, p, offset >> 9,
|
ret = submit_extent_page(REQ_OP_WRITE, write_flags, tree, wbc,
|
||||||
PAGE_SIZE, 0, bdev, &epd->bio,
|
p, offset >> 9, PAGE_SIZE, 0, bdev,
|
||||||
-1, end_bio_extent_buffer_writepage,
|
&epd->bio, -1,
|
||||||
|
end_bio_extent_buffer_writepage,
|
||||||
0, epd->bio_flags, bio_flags, false);
|
0, epd->bio_flags, bio_flags, false);
|
||||||
epd->bio_flags = bio_flags;
|
epd->bio_flags = bio_flags;
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -4057,13 +4057,12 @@ retry:
|
||||||
static void flush_epd_write_bio(struct extent_page_data *epd)
|
static void flush_epd_write_bio(struct extent_page_data *epd)
|
||||||
{
|
{
|
||||||
if (epd->bio) {
|
if (epd->bio) {
|
||||||
int rw = WRITE;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (epd->sync_io)
|
bio_set_op_attrs(epd->bio, REQ_OP_WRITE,
|
||||||
rw = WRITE_SYNC;
|
epd->sync_io ? WRITE_SYNC : 0);
|
||||||
|
|
||||||
ret = submit_one_bio(rw, epd->bio, 0, epd->bio_flags);
|
ret = submit_one_bio(epd->bio, 0, epd->bio_flags);
|
||||||
BUG_ON(ret < 0); /* -ENOMEM */
|
BUG_ON(ret < 0); /* -ENOMEM */
|
||||||
epd->bio = NULL;
|
epd->bio = NULL;
|
||||||
}
|
}
|
||||||
|
@ -4190,19 +4189,19 @@ int extent_readpages(struct extent_io_tree *tree,
|
||||||
if (nr < ARRAY_SIZE(pagepool))
|
if (nr < ARRAY_SIZE(pagepool))
|
||||||
continue;
|
continue;
|
||||||
__extent_readpages(tree, pagepool, nr, get_extent, &em_cached,
|
__extent_readpages(tree, pagepool, nr, get_extent, &em_cached,
|
||||||
&bio, 0, &bio_flags, READ, &prev_em_start);
|
&bio, 0, &bio_flags, &prev_em_start);
|
||||||
nr = 0;
|
nr = 0;
|
||||||
}
|
}
|
||||||
if (nr)
|
if (nr)
|
||||||
__extent_readpages(tree, pagepool, nr, get_extent, &em_cached,
|
__extent_readpages(tree, pagepool, nr, get_extent, &em_cached,
|
||||||
&bio, 0, &bio_flags, READ, &prev_em_start);
|
&bio, 0, &bio_flags, &prev_em_start);
|
||||||
|
|
||||||
if (em_cached)
|
if (em_cached)
|
||||||
free_extent_map(em_cached);
|
free_extent_map(em_cached);
|
||||||
|
|
||||||
BUG_ON(!list_empty(pages));
|
BUG_ON(!list_empty(pages));
|
||||||
if (bio)
|
if (bio)
|
||||||
return submit_one_bio(READ, bio, 0, bio_flags);
|
return submit_one_bio(bio, 0, bio_flags);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5228,7 +5227,7 @@ int read_extent_buffer_pages(struct extent_io_tree *tree,
|
||||||
err = __extent_read_full_page(tree, page,
|
err = __extent_read_full_page(tree, page,
|
||||||
get_extent, &bio,
|
get_extent, &bio,
|
||||||
mirror_num, &bio_flags,
|
mirror_num, &bio_flags,
|
||||||
READ | REQ_META);
|
REQ_META);
|
||||||
if (err)
|
if (err)
|
||||||
ret = err;
|
ret = err;
|
||||||
} else {
|
} else {
|
||||||
|
@ -5237,8 +5236,7 @@ int read_extent_buffer_pages(struct extent_io_tree *tree,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bio) {
|
if (bio) {
|
||||||
err = submit_one_bio(READ | REQ_META, bio, mirror_num,
|
err = submit_one_bio(bio, mirror_num, bio_flags);
|
||||||
bio_flags);
|
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue