From mboxrd@z Thu Jan 1 00:00:00 1970 From: ebiederm@xmission.com (Eric W. Biederman) Subject: Re: [PATCH v3 2/2] macvtap: restore vlan header on user read Date: Wed, 25 Apr 2012 22:31:25 -0700 Message-ID: References: <1335373316-612-1-git-send-email-basil.gor@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: "David S. Miller" , netdev@vger.kernel.org To: Basil Gor Return-path: Received: from out02.mta.xmission.com ([166.70.13.232]:33659 "EHLO out02.mta.xmission.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752215Ab2DZF1T (ORCPT ); Thu, 26 Apr 2012 01:27:19 -0400 In-Reply-To: <1335373316-612-1-git-send-email-basil.gor@gmail.com> (Basil Gor's message of "Wed, 25 Apr 2012 21:01:56 +0400") Sender: netdev-owner@vger.kernel.org List-ID: Basil Gor writes: > Vlan tag is restored during buffer transmit to a network device (bridge > port) in bridging code in case of tun/tap driver. In case of macvtap it > has to be done explicitly. Otherwise vlan_tci is ignored and user always > gets untagged packets. We could quibble about efficiencies but this looks good except for macvtap_recvmsg which isn't setting the auxdata for the vlan header. Eric > Signed-off-by: Basil Gor > --- > drivers/net/macvtap.c | 11 ++++++++++- > 1 files changed, 10 insertions(+), 1 deletions(-) > > diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c > index 0427c65..28d2678 100644 > --- a/drivers/net/macvtap.c > +++ b/drivers/net/macvtap.c > @@ -1,6 +1,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -753,13 +754,21 @@ static ssize_t macvtap_aio_write(struct kiocb *iocb, const struct iovec *iv, > > /* Put packet to the user space buffer */ > static ssize_t macvtap_put_user(struct macvtap_queue *q, > - const struct sk_buff *skb, > + struct sk_buff *skb, > const struct iovec *iv, int len) > { > struct macvlan_dev *vlan; > int ret; > int vnet_hdr_len = 0; > > + if (vlan_tx_tag_present(skb)) { > + skb = __vlan_put_tag(skb, vlan_tx_tag_get(skb)); > + if (unlikely(!skb)) > + return -ENOMEM; > + > + skb->vlan_tci = 0; > + } > + > if (q->flags & IFF_VNET_HDR) { > struct virtio_net_hdr vnet_hdr; > vnet_hdr_len = q->vnet_hdr_sz;