From: NeilBrown <neilb@suse.de>
To: Ming Lin <mlin@kernel.org>
Cc: Christoph Hellwig <hch@lst.de>,
lkml <linux-kernel@vger.kernel.org>,
Kent Overstreet <kent.overstreet@gmail.com>,
Jens Axboe <axboe@kernel.dk>, Dongsu Park <dpark@posteo.net>,
linux-raid@vger.kernel.org
Subject: Re: [PATCH v4 06/11] md/raid5: get rid of bio_fits_rdev()
Date: Wed, 27 May 2015 09:03:09 +1000 [thread overview]
Message-ID: <20150527090309.2cddf33b@notabene.brown> (raw)
In-Reply-To: <CAF1ivSYxfE+bZrPD7vpHPsU+XAD+S2Lkz=h84vA9yCy86h40ow@mail.gmail.com>
[-- Attachment #1: Type: text/plain, Size: 3302 bytes --]
On Tue, 26 May 2015 15:32:38 -0700 Ming Lin <mlin@kernel.org> wrote:
> On Tue, May 26, 2015 at 7:33 AM, Ming Lin <mlin@kernel.org> wrote:
> > On Mon, May 25, 2015 at 7:17 AM, Christoph Hellwig <hch@lst.de> wrote:
> >> On Mon, May 25, 2015 at 05:54:14PM +1000, NeilBrown wrote:
> >>> Did I write that? I guess I did :-(
> >>> I meant *after*. Don't get rid of bio_fits_rdev until split_bio is in
> >>> chunk_aligned_read().
> >>
> >> I suspect the whole series could use some reordering.
> >
> > Nice reordering.
> > I'll do this.
>
> Here is the reordering.
> https://git.kernel.org/cgit/linux/kernel/git/mlin/linux.git/log/?h=block-generic-req
>
> I'll post it if you are OK.
>
> [PATCH 01/15] block: add blk_queue_split()
> [PATCH 02/15] md: remove ->merge_bvec_fn
> [PATCH 03/15] dm: remov merge functions
> [PATCH 04/15] drbd: remove ->merge_bvec_fn
> [PATCH 05/15] pktcdvd: remove ->merge_bvec_fn
> [PATCH 06/15] rbd: remove ->merge_bvec_fn
> [PATCH 07/15] bcache: remove driver private bio splitting code
> [PATCH 08/15] btrfs: remove bio splitting and merge_bvec_fn() calls
> [PATCH 09/15] block: call blk_queue_split() in make_request functions
> [PATCH 10/15] block: kill ->merge_bvec_fn and simplify bio_add_page
> [PATCH 11/15] block: remove split code in blkdev_issue_discard
> [PATCH 12/15] md/raid5: get rid of bio_fits_rdev()
> [PATCH 13/15] block: remove bio_get_nr_vecs()
> [PATCH 14/15] fs: use helper bio_add_page() instead of open coding on
> [PATCH 15/15] Documentation: update notes in biovecs about
The changes to dm.c and dm.h should be in the "dm:" patch, not "md:".
But I don't think the sequence is right.
You cannot remove ->merge_bvec_fn for *any* stacked device until *all* devices
make use of blk_queue_split() (or otherwise handle arbitrarily large bios).
I think it would be easiest to:
- add blk_queue_split() and call it from common code before ->make_request_fn
is called. The ensure all devices can accept arbitrarily large bios.
- driver-by-driver remove merge_bvec_fn and make sure the the driver can cope
with arbitrary bios themselve, calling blk_queue_split in the make_request
function only if needed
- finally remove the call to blk_queue_split from the common code.
Does that make sense to others?
Thanks,
NeilBrown
>
> >
> > Thanks.
> >
> >>
> >> patch 1:
> >>
> >> add ->bio_split and blk_queue_split
> >>
> >> patch 2..n:
> >>
> >> one for each non-trivial driver that implements ->merge_bvec_fn to
> >> remove it and instead split bios in ->make_request. The md patch
> >> to do the right thing in chunk_aligned_read goes into the general
> >> md patch here. The bcache patch also goes into this series.
> >>
> >> patch n+1:
> >>
> >> - add blk_queue_split calls for remaining trivial drivers
> >>
> >> patch n+2:
> >>
> >> - remove ->merge_bvec_fn and checking of max_sectors a for all
> >> drivers, simplify bio_add_page
> >>
> >> patch n+2:
> >>
> >> - remove splitting in blkdev_issue_discard
> >>
> >> patch n+3
> >>
> >> - remove bio_fits_rdev
> >>
> >> patch n+4
> >>
> >> - remove bio_get_nr_vecs
> >>
> >> patch n+4
> >>
> >> - use bio_add_page
> >>
> >> patch n+5
> >>
> >> - update documentation
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 811 bytes --]
next prev parent reply other threads:[~2015-05-26 23:03 UTC|newest]
Thread overview: 111+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-05-22 18:18 [PATCH v4 00/11] simplify block layer based on immutable biovecs Ming Lin
2015-05-22 18:18 ` [PATCH v4 01/11] block: make generic_make_request handle arbitrarily sized bios Ming Lin
2015-05-22 18:18 ` [Drbd-dev] " Ming Lin
2015-05-25 5:46 ` NeilBrown
2015-05-25 5:46 ` [Drbd-dev] " NeilBrown
2015-05-26 14:36 ` Mike Snitzer
2015-05-26 14:36 ` [Drbd-dev] " Mike Snitzer
2015-05-26 15:02 ` Ming Lin
2015-05-26 15:02 ` [Drbd-dev] " Ming Lin
2015-05-26 15:34 ` Alasdair G Kergon
2015-05-26 15:34 ` Alasdair G Kergon
2015-05-26 15:34 ` [Drbd-dev] " Alasdair G Kergon
2015-05-26 23:06 ` NeilBrown
2015-05-26 23:06 ` [Drbd-dev] " NeilBrown
2015-05-27 0:40 ` [dm-devel] " Alasdair G Kergon
2015-05-27 0:40 ` [Drbd-dev] " Alasdair G Kergon
2015-05-27 8:20 ` Christoph Hellwig
2015-05-27 8:20 ` Christoph Hellwig
2015-05-27 8:20 ` [Drbd-dev] " Christoph Hellwig
2015-05-26 16:04 ` Mike Snitzer
2015-05-26 16:04 ` [Drbd-dev] " Mike Snitzer
2015-05-26 17:17 ` Ming Lin
2015-05-26 17:17 ` [Drbd-dev] " Ming Lin
[not found] ` <20150526160400.GB4715-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2015-05-27 23:42 ` Ming Lin
2015-05-27 23:42 ` Ming Lin
2015-05-27 23:42 ` [Drbd-dev] " Ming Lin
2015-05-28 0:36 ` Alasdair G Kergon
2015-05-28 0:36 ` [Drbd-dev] " Alasdair G Kergon
[not found] ` <20150528003627.GD32216-FDJ95KluN3Z0klwcnFlA1dvLeJWuRmrY@public.gmane.org>
2015-05-28 5:54 ` Ming Lin
2015-05-28 5:54 ` Ming Lin
2015-05-28 5:54 ` [Drbd-dev] " Ming Lin
2015-05-29 7:05 ` Ming Lin
2015-05-29 7:05 ` Ming Lin
2015-05-29 7:05 ` [Drbd-dev] " Ming Lin
2015-05-29 15:15 ` Mike Snitzer
2015-05-29 15:15 ` [Drbd-dev] " Mike Snitzer
2015-06-01 6:02 ` Ming Lin
2015-06-01 6:02 ` Ming Lin
2015-06-01 6:02 ` [Drbd-dev] " Ming Lin
2015-06-02 20:59 ` Ming Lin
2015-06-02 20:59 ` Ming Lin
2015-06-02 20:59 ` [Drbd-dev] " Ming Lin
[not found] ` <CAF1ivSY_7M1OhrMuXg0OKu7BPy=SbTHSHCk+2q6vfEVgvJL8YA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-06-04 21:06 ` Mike Snitzer
2015-06-04 21:06 ` Mike Snitzer
2015-06-04 21:06 ` [Drbd-dev] " Mike Snitzer
2015-06-04 22:21 ` Ming Lin
2015-06-04 22:21 ` [Drbd-dev] " Ming Lin
2015-06-05 0:06 ` Mike Snitzer
2015-06-05 0:06 ` [Drbd-dev] " Mike Snitzer
[not found] ` <20150605000636.GA24611-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2015-06-05 5:21 ` Ming Lin
2015-06-05 5:21 ` Ming Lin
2015-06-05 5:21 ` [Drbd-dev] " Ming Lin
[not found] ` <20150604210617.GA23710-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2015-06-09 6:09 ` Ming Lin
2015-06-09 6:09 ` Ming Lin
2015-06-09 6:09 ` [Drbd-dev] " Ming Lin
2015-06-10 21:20 ` Ming Lin
2015-06-10 21:20 ` Ming Lin
2015-06-10 21:20 ` [Drbd-dev] " Ming Lin
[not found] ` <CAF1ivSbo456n+1JxDp7eAHAgKs5qBOcomN4N9hhCEXmy8i4nPQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-06-10 21:46 ` Mike Snitzer
2015-06-10 21:46 ` Mike Snitzer
2015-06-10 21:46 ` [Drbd-dev] " Mike Snitzer
[not found] ` <20150610214611.GA744-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2015-06-10 22:06 ` Ming Lin
2015-06-10 22:06 ` Ming Lin
2015-06-10 22:06 ` [Drbd-dev] " Ming Lin
[not found] ` <CAF1ivSbvX1HooUBk-vB3vXGFbocKYimr=YSkLivAV_nSSMHxzg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-06-12 5:49 ` Ming Lin
2015-06-12 5:49 ` Ming Lin
2015-06-12 5:49 ` [Drbd-dev] " Ming Lin
2015-06-18 5:27 ` Ming Lin
2015-06-18 5:27 ` Ming Lin
2015-06-18 5:27 ` [Drbd-dev] " Ming Lin
2015-05-22 18:18 ` [PATCH v4 02/11] block: simplify bio_add_page() Ming Lin
2015-05-22 18:18 ` [PATCH v4 03/11] bcache: remove driver private bio splitting code Ming Lin
2015-05-22 18:18 ` [PATCH v4 04/11] btrfs: remove bio splitting and merge_bvec_fn() calls Ming Lin
2015-05-22 18:18 ` [PATCH v4 05/11] block: remove split code in blkdev_issue_discard Ming Lin
2015-05-22 18:18 ` [PATCH v4 06/11] md/raid5: get rid of bio_fits_rdev() Ming Lin
2015-05-25 5:48 ` NeilBrown
2015-05-25 7:03 ` Ming Lin
2015-05-25 7:54 ` NeilBrown
2015-05-25 14:17 ` Christoph Hellwig
2015-05-26 14:33 ` Ming Lin
2015-05-26 22:32 ` Ming Lin
2015-05-26 23:03 ` NeilBrown [this message]
2015-05-26 23:42 ` Ming Lin
2015-05-27 0:38 ` NeilBrown
2015-05-27 8:15 ` Christoph Hellwig
2015-05-22 18:18 ` [PATCH v4 07/11] md/raid5: split bio for chunk_aligned_read Ming Lin
2015-05-22 18:18 ` [PATCH v4 08/11] block: kill merge_bvec_fn() completely Ming Lin
2015-05-22 18:18 ` [Drbd-dev] " Ming Lin
2015-05-25 5:49 ` NeilBrown
2015-05-25 5:49 ` [Drbd-dev] " NeilBrown
2015-05-25 14:04 ` Christoph Hellwig
2015-05-25 14:04 ` [Drbd-dev] " Christoph Hellwig
2015-05-25 15:02 ` Ilya Dryomov
2015-05-25 15:02 ` [Drbd-dev] " Ilya Dryomov
2015-05-25 15:08 ` Christoph Hellwig
2015-05-25 15:08 ` [Drbd-dev] " Christoph Hellwig
2015-05-25 15:19 ` Ilya Dryomov
2015-05-25 15:19 ` [Drbd-dev] " Ilya Dryomov
2015-05-25 15:35 ` Alex Elder
2015-05-25 15:35 ` [Drbd-dev] " Alex Elder
2015-05-22 18:18 ` [PATCH v4 09/11] fs: use helper bio_add_page() instead of open coding on bi_io_vec Ming Lin
2015-05-22 18:18 ` [PATCH v4 10/11] block: remove bio_get_nr_vecs() Ming Lin
2015-05-22 18:18 ` [PATCH v4 11/11] Documentation: update notes in biovecs about arbitrarily sized bios Ming Lin
2015-05-23 14:15 ` [PATCH v4 00/11] simplify block layer based on immutable biovecs Christoph Hellwig
2015-05-24 7:37 ` Ming Lin
2015-05-25 13:51 ` Christoph Hellwig
2015-05-29 6:39 ` Ming Lin
2015-06-01 6:15 ` Ming Lin
2015-06-03 6:57 ` Christoph Hellwig
2015-06-03 13:28 ` Jeff Moyer
2015-06-03 17:06 ` Ming Lin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150527090309.2cddf33b@notabene.brown \
--to=neilb@suse.de \
--cc=axboe@kernel.dk \
--cc=dpark@posteo.net \
--cc=hch@lst.de \
--cc=kent.overstreet@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-raid@vger.kernel.org \
--cc=mlin@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.