Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756746AbaAJOaw (ORCPT ); Fri, 10 Jan 2014 09:30:52 -0500 Received: from charlotte.tuxdriver.com ([70.61.120.58]:53248 "EHLO smtp.tuxdriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751329AbaAJOas (ORCPT ); Fri, 10 Jan 2014 09:30:48 -0500 Date: Fri, 10 Jan 2014 09:30:38 -0500 From: Neil Horman To: Jason Wang Cc: davem@davemloft.net, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, mst@redhat.com, John Fastabend , e1000-devel@lists.sourceforge.net Subject: Re: [PATCH net V3 2/2] net: core: explicitly select a txq before doing l2 forwarding Message-ID: <20140110143038.GC10111@neilslaptop.think-freely.org> References: <1389341906-2367-1-git-send-email-jasowang@redhat.com> <1389341906-2367-2-git-send-email-jasowang@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1389341906-2367-2-git-send-email-jasowang@redhat.com> User-Agent: Mutt/1.5.21 (2010-09-15) X-Spam-Score: -2.9 (--) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jan 10, 2014 at 04:18:26PM +0800, Jason Wang wrote: > Currently, the tx queue were selected implicitly in ndo_dfwd_start_xmit(). The > will cause several issues: > > - NETIF_F_LLTX were removed for macvlan, so txq lock were done for macvlan > instead of lower device which misses the necessary txq synchronization for > lower device such as txq stopping or frozen required by dev watchdog or > control path. > - dev_hard_start_xmit() was called with NULL txq which bypasses the net device > watchdog. > - dev_hard_start_xmit() does not check txq everywhere which will lead a crash > when tso is disabled for lower device. > > Fix this by explicitly introducing a new param for .ndo_select_queue() for just > selecting queues in the case of l2 forwarding offload. netdev_pick_tx() was also > extended to accept this parameter and dev_queue_xmit_accel() was used to do l2 > forwarding transmission. > > With this fixes, NETIF_F_LLTX could be preserved for macvlan and there's no need > to check txq against NULL in dev_hard_start_xmit(). Also there's no need to keep > a dedicated ndo_dfwd_start_xmit() and we can just reuse the code of > dev_queue_xmit() to do the transmission. > > In the future, it was also required for macvtap l2 forwarding support since it > provides a necessary synchronization method. > > Cc: John Fastabend > Cc: Neil Horman > Cc: e1000-devel@lists.sourceforge.net > Signed-off-by: Jason Wang > Acked-by: Neil Horman -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/