From: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
To: Jan Beulich <JBeulich@suse.com>
Cc: Dongxiao Xu <dongxiao.xu@intel.com>,
"xen-devel@lists.xen.org" <xen-devel@lists.xen.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [Xen-devel] [PATCH] xen/swiotlb: Exchange to contiguous memory for map_sg hook
Date: Wed, 19 Dec 2012 15:09:04 -0500 [thread overview]
Message-ID: <20121219200904.GG15037@phenom.dumpdata.com> (raw)
In-Reply-To: <50C85E9F02000078000AFD65@nat28.tlf.novell.com>
On Wed, Dec 12, 2012 at 09:38:23AM +0000, Jan Beulich wrote:
> >>> On 12.12.12 at 02:03, "Xu, Dongxiao" <dongxiao.xu@intel.com> wrote:
> >> From: Konrad Rzeszutek Wilk [mailto:konrad.wilk@oracle.com]
> >> On Tue, Dec 11, 2012 at 06:39:35AM +0000, Xu, Dongxiao wrote:
> >> > > From: Konrad Rzeszutek Wilk [mailto:konrad.wilk@oracle.com]
> >> > > What if this check was done in the routines that provide the
> >> > > software static buffers and there try to provide a nice DMA contingous
> >> swatch of pages?
> >> >
> >> > Yes, this approach also came to our mind, which needs to modify the driver
> >> itself.
> >> > If so, it requires driver not using such static buffers (e.g., from
> > kmalloc) to do
> >> DMA even if the buffer is continuous in native.
> >>
> >> I am bit loss here.
> >>
> >> Is the issue you found only with drivers that do not use DMA API?
> >> Can you perhaps point me to the code that triggered this fix in the first
> > place?
> >
> > Yes, we met this issue on a specific SAS device/driver, and it calls into
> > libata-core code, you can refer to function ata_dev_read_id() called from
> > ata_dev_reread_id() in drivers/ata/libata-core.c.
> >
> > In the above function, the target buffer is (void *)dev->link->ap->sector_buf,
> > which is 512 bytes static buffer and unfortunately it across the page
> > boundary.
>
> I wonder whether such use of sg_init_one()/sg_set_buf() is correct
> in the first place. While there aren't any restrictions documented for
> its use, one clearly can't pass in whatever one wants (a pointer into
> vmalloc()-ed memory, for instance, won't work afaict).
>
> I didn't go through all other users of it, but quite a few of the uses
> elsewhere look similarly questionable.
>
> >> I am still not completely clear on what you had in mind. The one method I
> >> thought about that might help in this is to have Xen-SWIOTLB track which
> >> memory ranges were exchanged (so xen_swiotlb_fixup would save the *buf
> >> and the size for each call to xen_create_contiguous_region in a list or
> > array).
> >>
> >> When xen_swiotlb_map/xen_swiotlb_map_sg_attrs care called they would
> >> consult said array/list to see if the region they retrieved crosses said 2MB
> >> chunks. If so.. and here I am unsure of what would be the best way to
> > proceed.
And from finally looking at the code I misunderstood your initial description.
> >
> > We thought we can solve the issue in several ways:
> >
> > 1) Like the previous patch I sent out, we check the DMA region in
> > xen_swiotlb_map_page() and xen_swiotlb_map_sg_attr(), and if DMA region
> > crosses page boundary, we exchange the memory and copy the content. However
> > it has race condition that when copying the memory content (we introduced two
> > memory copies in the patch), some other code may also visit the page, which
> > may encounter incorrect values.
>
> That's why, after mapping a buffer (or SG list) one has to call the
> sync functions before looking at data. Any race as described by
> you is therefore a programming error.
I am with Jan here. It looks like the libata is depending on the dma_unmap
to do this. But it is unclear to me when the ata_qc_complete is actually
called to unmap the buffer (and hence sync it).
>
> Jan
>
>
next prev parent reply other threads:[~2012-12-19 20:09 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-12-06 13:08 [PATCH] xen/swiotlb: Exchange to contiguous memory for map_sg hook Dongxiao Xu
2012-12-06 13:37 ` [Xen-devel] " Jan Beulich
2012-12-07 14:11 ` Konrad Rzeszutek Wilk
2012-12-07 14:08 ` Konrad Rzeszutek Wilk
2012-12-11 6:39 ` Xu, Dongxiao
2012-12-11 17:06 ` Konrad Rzeszutek Wilk
2012-12-12 1:03 ` Xu, Dongxiao
2012-12-12 9:38 ` [Xen-devel] " Jan Beulich
2012-12-19 20:09 ` Konrad Rzeszutek Wilk [this message]
2012-12-20 1:23 ` Xu, Dongxiao
2012-12-20 8:56 ` Jan Beulich
2013-01-07 7:17 ` Xu, Dongxiao
2013-01-07 8:46 ` Jan Beulich
2013-01-07 15:55 ` Konrad Rzeszutek Wilk
2012-12-13 16:34 ` Konrad Rzeszutek Wilk
-- strict thread matches above, loose matches on Subject: below --
2012-12-11 6:27 [Xen-devel] " Xu, Dongxiao
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=20121219200904.GG15037@phenom.dumpdata.com \
--to=konrad.wilk@oracle.com \
--cc=JBeulich@suse.com \
--cc=dongxiao.xu@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=xen-devel@lists.xen.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;
as well as URLs for NNTP newsgroup(s).