From: Shirley Ma <mashirle@us.ibm.com>
To: "Michael S. Tsirkin" <mst@redhat.com>
Cc: "Michał Mirosław" <mirqus@gmail.com>,
"Ben Hutchings" <bhutchings@solarflare.com>,
"David Miller" <davem@davemloft.net>,
"Eric Dumazet" <eric.dumazet@gmail.com>,
"Avi Kivity" <avi@redhat.com>, "Arnd Bergmann" <arnd@arndb.de>,
netdev@vger.kernel.org, kvm@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH V5 2/6 net-next] netdevice.h: Add zero-copy flag in netdevice
Date: Thu, 26 May 2011 08:27:46 -0700 [thread overview]
Message-ID: <1306423666.5180.8.camel@localhost.localdomain> (raw)
In-Reply-To: <20110526084916.GA17928@redhat.com>
On Thu, 2011-05-26 at 11:49 +0300, Michael S. Tsirkin wrote:
> On Wed, May 25, 2011 at 03:49:40PM -0700, Shirley Ma wrote:
> > On Fri, 2011-05-20 at 02:41 +0300, Michael S. Tsirkin wrote:
> > > So the requirements are
> > > - data must be released in a timely fashion (e.g. unlike
> virtio-net
> > > tun or bridge)
> > The current patch doesn't enable tun zero-copy. tun will copy data
> It's
> > not an issue now.
> > We can disallow macvtap attach to bridge when
> > zero-copy is enabled.
>
> Attach macvtap to a tun device though. Or e.g. veth device ...
> So there should be so generic way to disable zerocopy.
> It can either be a whitelist or a blacklist.
> >
> > > - SG support
> > > - HIGHDMA support (on arches where this makes sense)
> >
> > This can be checked by device flags.
>
> OK, but pls note that SG can get turned off dynamically.
>
> > > - no filtering based on data (data is mapped in guest)
> >
> > > - on fast path no calls to skb_copy, skb_clone, pskb_copy,
> > > pskb_expand_head as these are slow
> >
> > Any calls to skb_copy, skb_clone, pskb_copy, pskb_expand_head will
> do a
> > copy. The performance should be the same as none zero-copy case
> before.
>
> I'm guessing a copy is cheaper than get_user_pages+copy+put_page.
> But maybe not by much. Care checking that?
That's I have done already. Patch is going out for review.
> > I have done/tested the patch V6, will send it out for review
> tomorrow.
> >
> > I am looking at where there are some cases, skb remains the same for
> > filtering.
>
> To reliably filter on data I think we'll need to copy it first,
> otherwise
> guest can change it. Most filters only look at the header though.
>
> > > First 2 requirements are a must, all other requirements
> > > are just dependencies to make sure zero copy will be faster
> > > than non zero copy.
> > > Using a new feature bit is probably the simplest approach to
> > > this. macvtap on top of most physical NICs most likely works
> > > correctly so it seems a bit more work than it needs to be,
> > > but it's also the safest one I think ...
> >
> > For "macvtap/vhost zero-copy" we can use SG & HIGHDMA to enable it,
> it
> > looks safe to me once patching skb_copy, skb_clone, pskb_copy,
> > pskb_expand_head.
> >
> > To extend zero-copy in other usages, we can have a new feature bit
> > later.
> >
> > Is that reasonable?
> >
> > Thanks
> > Shirley
>
> Is the problem is extra work needed to extend feature bits?
There is no problem to use it, Mahesh is working on this patch. I just
want to remove macvtap/vhost zero-copy patch dependency.
Thanks
Shirley
next prev parent reply other threads:[~2011-05-26 15:27 UTC|newest]
Thread overview: 38+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-05-16 19:28 [PATCH V5 2/6 net-next] netdevice.h: Add zero-copy flag in netdevice Shirley Ma
2011-05-16 19:35 ` Ben Hutchings
2011-05-16 19:38 ` Shirley Ma
2011-05-16 19:47 ` Ben Hutchings
2011-05-16 21:14 ` Michael S. Tsirkin
2011-05-16 23:32 ` Shirley Ma
2011-05-17 6:21 ` Michael S. Tsirkin
2011-05-17 20:53 ` Shirley Ma
2011-05-17 21:48 ` Michał Mirosław
2011-05-17 22:28 ` Shirley Ma
2011-05-17 22:58 ` Michał Mirosław
2011-05-17 23:44 ` Shirley Ma
2011-05-18 9:06 ` Michał Mirosław
2011-05-18 10:38 ` Michael S. Tsirkin
2011-05-18 11:10 ` Michał Mirosław
2011-05-18 11:17 ` Michael S. Tsirkin
2011-05-18 11:40 ` Michał Mirosław
2011-05-18 11:47 ` Michael S. Tsirkin
2011-05-18 14:38 ` Shirley Ma
2011-05-18 15:47 ` Michael S. Tsirkin
2011-05-18 16:07 ` Shirley Ma
2011-05-18 16:36 ` Michael S. Tsirkin
2011-05-18 16:45 ` Shirley Ma
2011-05-18 16:51 ` Michael S. Tsirkin
2011-05-18 17:00 ` Shirley Ma
2011-05-19 19:42 ` Shirley Ma
2011-05-19 23:41 ` Michael S. Tsirkin
2011-05-25 22:49 ` Shirley Ma
2011-05-26 8:49 ` Michael S. Tsirkin
2011-05-26 15:27 ` Shirley Ma [this message]
2011-05-26 19:11 ` Shirley Ma
2011-05-18 16:02 ` Shirley Ma
2011-05-18 16:23 ` Michael S. Tsirkin
2011-05-18 16:50 ` Michael S. Tsirkin
2011-05-18 11:47 ` Michał Mirosław
2011-05-18 11:56 ` Michael S. Tsirkin
2011-05-18 12:48 ` Michał Mirosław
2011-05-18 13:19 ` Michael S. Tsirkin
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=1306423666.5180.8.camel@localhost.localdomain \
--to=mashirle@us.ibm.com \
--cc=arnd@arndb.de \
--cc=avi@redhat.com \
--cc=bhutchings@solarflare.com \
--cc=davem@davemloft.net \
--cc=eric.dumazet@gmail.com \
--cc=kvm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mirqus@gmail.com \
--cc=mst@redhat.com \
--cc=netdev@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 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.