From: Jens Axboe <axboe@suse.de>
To: Christophe Saout <christophe@saout.de>
Cc: Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
DM-Devel <dm-devel@sistina.com>
Subject: Re: question about BIO/request ordering / barriers
Date: Fri, 2 Jan 2004 11:44:19 +0100 [thread overview]
Message-ID: <20040102104419.GM5523@suse.de> (raw)
In-Reply-To: <1072886889.4395.7.camel@leto.cs.pocnet.net>
On Wed, Dec 31 2003, Christophe Saout wrote:
> Am Mi, den 31.12.2003 schrieb Jens Axboe um 16:56:
>
> [Sorry for quoting the whole thing again, but I think the DM developers
> might know about the issue too]
>
> > On Wed, Dec 31 2003, Christophe Saout wrote:
> > > Hi!
> > >
> > > I'm just digging through the device-mapper code and a question came up:
> > >
> > > Are "intermediate block device drivers" (like device-mapper) allowed to
> > > reorder BIOs?
> > >
> > > I'm not talking about BIOs submitted from different threads at the same
> > > time but BIOs submitted from the same thread sequentially, especially
> > > writes.
> > >
> > > That would mean that BIOs might be reordered around barriers which would
> > > break potential users.
> >
> > That would not be a good idea. Reordering around a barrier is forbidden,
> > you may reorder as you please otherwise. Consider yourself the io
> > scheduler, that is essentially the function you are performing. The io
> > scheduler will honor the barrier as well.
> >
> > > At the moment I suppose this shouldn't be an issue because I didn't find
> > > a single user in the whole kernel that actually submits BIOs with
> > > BIO_RW_BARRIER set via submit_bio/generic_make_request (journaling
> > > filesystems are simply waiting until all writes are finished before
> > > continueing, right?).
> >
> > Right, there are some missing bits still.
>
> Ah, ok. So things are probably going to break in the future if they
> aren't fixed now. That's what I wanted do know.
Yep
> > > There are same cases (in device-mapper) where
> > >
> > > a) writes get get suspended and queued for later submission where it is
> > > not ensured that those writes are submitted before any other writes that
> > > could possibly occur after the device gets resumed (generic dm code)
> > > b) a stack (instead of a fifo) is used to queue requests and submit them
> > > later (not yet included code)
> > > c) writes can get queued but reads are directly passed through
> > > (snapshotting code too)
> > >
> > > Also, if DM recevices a barrier shouldn't this barrier be somehow sent
> > > to all real devices instead of the one that the request is actually sent
> > > to?
> >
> > Yes, the driver must take whatever precautions necessary...
>
> Ok, thanks. Let's see what can be done about that.
>
> Is it possible to create empty BIOs that just act as barrier?
Unfortunately no, the barrier bit currently has to be tied to a bio with
content. I'd be willing to accept a patch to send down empty barrier
bio's though, it's a useful feature in this context.
> Because I think when device-mapper encounters a BIO with BIO_RW_BARRIER
> set it then should also create barriers for the other devices.
It's pretty tricky. Search the list archives for past discussions on
this.
--
Jens Axboe
prev parent reply other threads:[~2004-01-02 10:44 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-12-31 14:01 question about BIO/request ordering / barriers Christophe Saout
2003-12-31 15:56 ` Jens Axboe
2003-12-31 16:08 ` Christophe Saout
2004-01-02 10:44 ` Jens Axboe [this message]
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=20040102104419.GM5523@suse.de \
--to=axboe@suse.de \
--cc=christophe@saout.de \
--cc=dm-devel@sistina.com \
--cc=linux-kernel@vger.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox