Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp124476rwl; Thu, 23 Mar 2023 13:38:52 -0700 (PDT) X-Google-Smtp-Source: AKy350ZkFvYfEn6yJ++2KCkzNH3blbwAQKUYWbSogVj2Hle1w+Gmo6kRG0SNYT2UUi8fpCN9po3k X-Received: by 2002:a05:6402:1044:b0:4fa:eccd:9849 with SMTP id e4-20020a056402104400b004faeccd9849mr716446edu.9.1679603932408; Thu, 23 Mar 2023 13:38:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1679603932; cv=none; d=google.com; s=arc-20160816; b=lBodL4W87ph4JMhdT6sanIeLSyfTs4gdm65MkD+EhQbf4BScO6D/FkLqzaKTOxdcCv 9jfXWWbzqaHnXUchXCqoulpGRZQgkPTZe6+Oh+uVYKv+dI2r0kI3rtI66AkNc0ekUvev eb635TXuXxzRSAVI6TGxv3kO8OdqJFzcIE+mOpFPz7qYMqtzDYD7+lIx22qgv7vDdIYA zJZbJcwtMIC8Pn+mHLK4mG6huaq5tF4O9bG8b2ffB5i7rktPaQU6UAPR45Jx2+F1JQUF ICwO5TmuYqu1tZ/GZyNTDX3sZ/TbKjFgr1JZYh3Zzq4VinrlxEZCNvIkoSzAhFvj1rFj xBEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=sJS1VMRs4nHPaI7UqQ2eYjD/zRoqmB8dlm9OvrdS33c=; b=il2a4Jk1bpEgsyQMyz9c38tTMivITbJBudnLCRYgBnJgzL0NtrO63TWE5SXM556xk2 t7pZUMfcH6cLVfwviRGyFdYe4d8HnjalrigcO1iUhX7Y1nwxHjb9WAiYU7ubxAdVjf/m j4lY4j7d4kfrIFFcPXlY+683UnmvRt5RIYPjEW/jP1RiCr6fvax6g8aCT7A7W/TxlbzB LwaPaaeeLLWmQC/UdDjhdCMJeHmSJWschji0bt4d7wIkW2n2wAGkD6k2HsxdsUh/NyyB kf/BOCPRDqYTSI/lotsHLJViKUesCl9glpvE2lG6E65lKLyqhWkkEb7SIgpR/PFSeiCY +kig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@vmware.com header.s=s1024 header.b=nSbQ3HE6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=vmware.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id y11-20020aa7c24b000000b005021f0d576csi92372edo.691.2023.03.23.13.38.04; Thu, 23 Mar 2023 13:38:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@vmware.com header.s=s1024 header.b=nSbQ3HE6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=vmware.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231452AbjCWUHc (ORCPT + 99 others); Thu, 23 Mar 2023 16:07:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46996 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229600AbjCWUHb (ORCPT ); Thu, 23 Mar 2023 16:07:31 -0400 Received: from EX-PRD-EDGE01.vmware.com (EX-PRD-EDGE01.vmware.com [208.91.3.33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C208622DEA; Thu, 23 Mar 2023 13:07:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; s=s1024; d=vmware.com; h=from:to:cc:subject:date:message-id:mime-version:content-type; bh=sJS1VMRs4nHPaI7UqQ2eYjD/zRoqmB8dlm9OvrdS33c=; b=nSbQ3HE6AE2cUSHWaEHtQH0QQharoUyJZccWFnsWsYUIDveg8GVMjXyMEED0Wr Uyc7XwJji5i5F9+mZ25p+tQg2H1JDEfFSgW4hoLqGt4b2z7HEKRqqnc6VpbTJn FJ/ZSlkGu7OXYHjj0HZRWhtp+MJV+eKftoZgHnlSFgyDF7w= Received: from sc9-mailhost1.vmware.com (10.113.161.71) by EX-PRD-EDGE01.vmware.com (10.188.245.6) with Microsoft SMTP Server id 15.1.2375.34; Thu, 23 Mar 2023 13:07:20 -0700 Received: from htb-1n-eng-dhcp122.eng.vmware.com (unknown [10.20.114.216]) by sc9-mailhost1.vmware.com (Postfix) with ESMTP id 015A620165; Thu, 23 Mar 2023 13:07:23 -0700 (PDT) Received: by htb-1n-eng-dhcp122.eng.vmware.com (Postfix, from userid 0) id DAD79A838E; Thu, 23 Mar 2023 13:07:22 -0700 (PDT) From: Ronak Doshi To: CC: Ronak Doshi , , VMware PV-Drivers Reviewers , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Guolin Yang , open list Subject: [PATCH net v2] vmxnet3: use gro callback when UPT is enabled Date: Thu, 23 Mar 2023 13:07:21 -0700 Message-ID: <20230323200721.27622-1-doshir@vmware.com> X-Mailer: git-send-email 2.11.0 MIME-Version: 1.0 Content-Type: text/plain Received-SPF: None (EX-PRD-EDGE01.vmware.com: doshir@vmware.com does not designate permitted sender hosts) X-Spam-Status: No, score=-5.2 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, vmxnet3 uses GRO callback only if LRO is disabled. However, on smartNic based setups where UPT is supported, LRO can be enabled from guest VM but UPT devicve does not support LRO as of now. In such cases, there can be performance degradation as GRO is not being done. This patch fixes this issue by calling GRO API when UPT is enabled. We use updateRxProd to determine if UPT mode is active or not. To clarify few things discussed over the thread: The patch is not neglecting any feature bits nor disabling GRO. It uses GRO callback when UPT is active as LRO is not available in UPT. GRO callback cannot be used as default for all cases as it degrades performance for non-UPT cases or for cases when LRO is already done in ESXi. Cc: stable@vger.kernel.org Fixes: 6f91f4ba046e ("vmxnet3: add support for capability registers") Signed-off-by: Ronak Doshi Reviewed-by: Simon Horman -- v1->v2: split if check on multiple lines --- drivers/net/vmxnet3/vmxnet3_drv.c | 4 +++- 1 files changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index 682987040ea8..da488cbb0542 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c @@ -1688,7 +1688,9 @@ vmxnet3_rq_rx_complete(struct vmxnet3_rx_queue *rq, if (unlikely(rcd->ts)) __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rcd->tci); - if (adapter->netdev->features & NETIF_F_LRO) + /* Use GRO callback if UPT is enabled */ + if ((adapter->netdev->features & NETIF_F_LRO) && + !rq->shared->updateRxProd) netif_receive_skb(skb); else napi_gro_receive(&rq->napi, skb); -- 2.11.0