Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752097AbaAJRiX (ORCPT ); Fri, 10 Jan 2014 12:38:23 -0500 Received: from mga14.intel.com ([143.182.124.37]:56933 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751172AbaAJRiV (ORCPT ); Fri, 10 Jan 2014 12:38:21 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.95,639,1384329600"; d="scan'208";a="456802884" Message-ID: <52D02FF4.3020105@intel.com> Date: Fri, 10 Jan 2014 09:37:56 -0800 From: John Fastabend User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130801 Thunderbird/17.0.8 MIME-Version: 1.0 To: Jason Wang CC: davem@davemloft.net, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, mst@redhat.com, Neil Horman , e1000-devel@lists.sourceforge.net Subject: Re: [PATCH net V3 2/2] net: core: explicitly select a txq before doing l2 forwarding References: <1389341906-2367-1-git-send-email-jasowang@redhat.com> <1389341906-2367-2-git-send-email-jasowang@redhat.com> In-Reply-To: <1389341906-2367-2-git-send-email-jasowang@redhat.com> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/10/2014 12:18 AM, 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 > > --- > Changes from V2: > - Reuse dev_queue_xmit() instead of re-inventing dfwd_direct_xmit() > - remove the unnecessary braces > Changes from V1: > - Adding a new parameter to ndo_select_queue instead of a new method to select > queue for l2 forwarding. > - Remove the unnecessary ndo_dfwd_start_xmit() since txq was selected > explicitly. > - Keep NETIF_F_LLTX when netdev feature is changed. > - Shape the commit log > --- Looks good to me thanks, I tested my macvlan use cases and everything works as expected. Acked-by: John Fastabend -- 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/