[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1302242642.23016855.1524762824836.JavaMail.zimbra@redhat.com>
Date: Thu, 26 Apr 2018 13:13:44 -0400 (EDT)
From: Pankaj Gupta <pagupta@...hat.com>
To: Dan Williams <dan.j.williams@...el.com>
Cc: Stefan Hajnoczi <stefanha@...il.com>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
KVM list <kvm@...r.kernel.org>,
Qemu Developers <qemu-devel@...gnu.org>,
linux-nvdimm <linux-nvdimm@...1.01.org>,
Linux MM <linux-mm@...ck.org>, Jan Kara <jack@...e.cz>,
Stefan Hajnoczi <stefanha@...hat.com>,
Rik van Riel <riel@...riel.com>,
haozhong zhang <haozhong.zhang@...el.com>,
Nitesh Narayan Lal <nilal@...hat.com>,
Kevin Wolf <kwolf@...hat.com>,
Paolo Bonzini <pbonzini@...hat.com>,
ross zwisler <ross.zwisler@...el.com>,
David Hildenbrand <david@...hat.com>,
xiaoguangrong eric <xiaoguangrong.eric@...il.com>,
Christoph Hellwig <hch@...radead.org>,
Marcel Apfelbaum <marcel@...hat.com>,
"Michael S. Tsirkin" <mst@...hat.com>,
niteshnarayanlal@...mail.com, Igor Mammedov <imammedo@...hat.com>,
lcapitulino@...hat.com
Subject: Re: [RFC v2 2/2] pmem: device flush over VIRTIO
> >
> >>
> >> On Wed, Apr 25, 2018 at 04:54:14PM +0530, Pankaj Gupta wrote:
> >> > This patch adds functionality to perform
> >> > flush from guest to hosy over VIRTIO
> >> > when 'ND_REGION_VIRTIO'flag is set on
> >> > nd_negion. Flag is set by 'virtio-pmem'
> >> > driver.
> >> >
> >> > Signed-off-by: Pankaj Gupta <pagupta@...hat.com>
> >> > ---
> >> > drivers/nvdimm/region_devs.c | 7 +++++++
> >> > 1 file changed, 7 insertions(+)
> >> >
> >> > diff --git a/drivers/nvdimm/region_devs.c b/drivers/nvdimm/region_devs.c
> >> > index a612be6..6c6454e 100644
> >> > --- a/drivers/nvdimm/region_devs.c
> >> > +++ b/drivers/nvdimm/region_devs.c
> >> > @@ -20,6 +20,7 @@
> >> > #include <linux/nd.h>
> >> > #include "nd-core.h"
> >> > #include "nd.h"
> >> > +#include <linux/virtio_pmem.h>
> >> >
> >> > /*
> >> > * For readq() and writeq() on 32-bit builds, the hi-lo, lo-hi order is
> >> > @@ -1074,6 +1075,12 @@ void nvdimm_flush(struct nd_region *nd_region)
> >> > struct nd_region_data *ndrd = dev_get_drvdata(&nd_region->dev);
> >> > int i, idx;
> >> >
> >> > + /* call PV device flush */
> >> > + if (test_bit(ND_REGION_VIRTIO, &nd_region->flags)) {
> >> > + virtio_pmem_flush(&nd_region->dev);
> >> > + return;
> >> > + }
> >>
> >> How does libnvdimm know when flush has completed?
> >>
> >> Callers expect the flush to be finished when nvdimm_flush() returns but
> >> the virtio driver has only queued the request, it hasn't waited for
> >> completion!
> >
> > I tried to implement what nvdimm does right now. It just writes to
> > flush hint address to make sure data persists.
>
> nvdimm_flush() is currently expected to be synchronous. Currently it
> is sfence(); write to special address; sfence(). By the time the
> second sfence returns the data is flushed. So you would need to make
> this virtio flush interface synchronous as well, but that appears
> problematic to stop the guest for unbounded amounts of time. Instead,
> you need to rework nvdimm_flush() and the pmem driver to make these
> flush requests asynchronous and add the plumbing for completion
> callbacks via bio_endio().
o.k.
>
> > I just did not want to block guest write requests till host side
> > fsync completes.
>
> You must complete the flush before bio_endio(), otherwise you're
> violating the expectations of the guest filesystem/block-layer.
sure!
>
> >
> > be worse for operations on different guest files because all these
> > operations would happen
> > ultimately on same file at host.
> >
> > I think with current way, we can achieve an asynchronous queuing mechanism
> > on cost of not
> > 100% sure when fsync would complete but it is assured it will happen. Also,
> > its entire block
> > flush.
>
> No, again, that's broken. We need to add the plumbing for
> communicating the fsync() completion relative the WRITE_{FLUSH,FUA}
> bio in the guest.
Sure. Thanks Dan & Stefan for the explanation and review.
Best regards,
Pankaj
Powered by blists - more mailing lists