linux-block.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH V2 00/10] block: enable multi-page bvec for passthrough IO
@ 2019-03-17 10:01 Ming Lei
  2019-03-17 10:01 ` [PATCH V2 01/10] block: pass page to xen_biovec_phys_mergeable Ming Lei
                   ` (10 more replies)
  0 siblings, 11 replies; 13+ messages in thread
From: Ming Lei @ 2019-03-17 10:01 UTC (permalink / raw)
  To: Jens Axboe
  Cc: linux-block, Ming Lei, ris Ostrovsky, Juergen Gross, xen-devel,
	Omar Sandoval, Christoph Hellwig

Hi,

Now the whole IO stack is capable of handling multi-page bvec, and it has
been enabled in the normal FS IO path. However, it isn't done for
passthrough IO.

Without enabling multi-bvec for passthough IO, we won't go ahead for
optimizing related IO paths, such as bvec merging, bio_add_pc_page
simplification.

This patch enables multi-page bvec for passthrough IO. Turns out
bio_add_pc_page() is simpliefied a lot, especially the physical segment
number of passthrough bio is always same with bio.bi_vcnt. Also the
bvec merging inside bio is killed.

blktests(block/029) is added for covering passthough IO path, and this
patchset does pass the new block/029 test.

	https://marc.info/?l=linux-block&m=155175063417139&w=2

V2:
	- add new patch of 'block: avoid to break XEN by multi-page bvec'
	- add one new patch to cleanup bio_add_pc_page()
	- add another two new patches for cleanup of mapping bvec to sg
	- most of others are patch style changes

Ming Lei (10):
  block: pass page to xen_biovec_phys_mergeable
  block: avoid to break XEN by multi-page bvec
  block: don't merge adjacent bvecs to one segment in bio
    blk_queue_split
  block: cleanup bio_add_pc_page
  block: check if page is mergeable in one helper
  block: put the same page when adding it to bio
  block: enable multi-page bvec for passthrough IO
  block: remove argument of 'request_queue' from __blk_bvec_map_sg
  block: reuse __blk_bvec_map_sg() for mapping page sized bvec
  block: don't check if adjacent bvecs in one bio can be mergeable

 block/bio.c            | 134 ++++++++++++++++++++++++++++---------------------
 block/blk-merge.c      | 106 +++++++++++++++++++-------------------
 block/blk.h            |   2 +-
 drivers/xen/biomerge.c |   5 +-
 include/linux/bio.h    |   3 ++
 include/xen/xen.h      |   2 +-
 6 files changed, 135 insertions(+), 117 deletions(-)

Cc: ris Ostrovsky <boris.ostrovsky@oracle.com>
Cc: Juergen Gross <jgross@suse.com>
Cc: xen-devel@lists.xenproject.org
Cc: Omar Sandoval <osandov@fb.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>


-- 
2.9.5


^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2019-03-27 15:44 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-03-17 10:01 [PATCH V2 00/10] block: enable multi-page bvec for passthrough IO Ming Lei
2019-03-17 10:01 ` [PATCH V2 01/10] block: pass page to xen_biovec_phys_mergeable Ming Lei
2019-03-17 10:01 ` [PATCH V2 02/10] block: avoid to break XEN by multi-page bvec Ming Lei
2019-03-19  9:18   ` Juergen Gross
2019-03-17 10:01 ` [PATCH V2 03/10] block: don't merge adjacent bvecs to one segment in bio blk_queue_split Ming Lei
2019-03-17 10:01 ` [PATCH V2 04/10] block: cleanup bio_add_pc_page Ming Lei
2019-03-17 10:01 ` [PATCH V2 05/10] block: check if page is mergeable in one helper Ming Lei
2019-03-17 10:01 ` [PATCH V2 06/10] block: put the same page when adding it to bio Ming Lei
2019-03-17 10:01 ` [PATCH V2 07/10] block: enable multi-page bvec for passthrough IO Ming Lei
2019-03-17 10:01 ` [PATCH V2 08/10] block: remove argument of 'request_queue' from __blk_bvec_map_sg Ming Lei
2019-03-17 10:01 ` [PATCH V2 09/10] block: reuse __blk_bvec_map_sg() for mapping page sized bvec Ming Lei
2019-03-17 10:01 ` [PATCH V2 10/10] block: don't check if adjacent bvecs in one bio can be mergeable Ming Lei
2019-03-27 15:44 ` [PATCH V2 00/10] block: enable multi-page bvec for passthrough IO Jens Axboe

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).