Received: by 10.213.65.68 with SMTP id h4csp557093imn; Tue, 13 Mar 2018 12:59:29 -0700 (PDT) X-Google-Smtp-Source: AG47ELsPpUH0xafJhOI2fyr9B/NWHkv4REZVEfjquiAHDTq3PRp/l2CHCq2oOX+syVGF/n4lnmFc X-Received: by 10.99.188.2 with SMTP id q2mr1476712pge.101.1520971169139; Tue, 13 Mar 2018 12:59:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520971169; cv=none; d=google.com; s=arc-20160816; b=zqa9045jIFvf3GQsaSci7P30nPJzMilPHGQfLAqzB+ndK3bPWLT5vHFWcWwxfU1uPy yGgiHJ0Wagrb7XHaKbg1AtdJCjXAPYB2rdOB6z9RpnLIuHBVgQf4orn2AylD1b7dd/UO aPahihHeEB+sQUB4PxvnOTMRT4JAt2zVCnuN45/pOgqs/jGIIqD5kMOb4rKudB4SlIXz b8d/FnCGbjpDeHQ7vnrRclnNON5WS/Q3bgkwTvW/TaWUx7DyoXPurKp4WvhxWCOzrAN2 Tv8x5+LMr80i7Ar0fwkAYuWKF/hGj/lSgdOBr6Jrmqg0fFl1MKygOsftlqjR5tmnDtMK svfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from:arc-authentication-results; bh=r25dNtIpq2kruLV6TCEn/LQ0XU9+JR+O8i/Rqy4kpGw=; b=AFKgKSXdB4NbCwSQ3lGU71/66IVvfy23smjo12eTmgHieCmZJSHiOwWlnXUOhtbbeS hmxmY5hm6tuWolPCj4V05Y8A4jrrynNNb83nxxxq9vfSg03/QMFjUACSP66Spmgq35BM tVW4yGsQrsB2Tx+5VJtvNqRMwbOZKlYwWruolzG5KN94QSUNyJc3RQsybKBYaMPlZPJF QHrLR7cb3PWnBhb/Ls5eoLHEmW0UAAotNr42aJO+6bw40K9IFuTaVoyFYwph1Sf+kah/ tQEIc0lwLye3uz8t6Vb2mp10RiyX3YbKPB7dv3WIFQKzQ18CQpMMqXmQgfw6XGZV1rM1 KazA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r65si664054pfa.79.2018.03.13.12.59.14; Tue, 13 Mar 2018 12:59:29 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932528AbeCMT5h (ORCPT + 99 others); Tue, 13 Mar 2018 15:57:37 -0400 Received: from ex13-edg-ou-002.vmware.com ([208.91.0.190]:16488 "EHLO EX13-EDG-OU-002.vmware.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932448AbeCMT5g (ORCPT ); Tue, 13 Mar 2018 15:57:36 -0400 Received: from sc9-mailhost3.vmware.com (10.113.161.73) by EX13-EDG-OU-002.vmware.com (10.113.208.156) with Microsoft SMTP Server id 15.0.1156.6; Tue, 13 Mar 2018 12:42:22 -0700 Received: from ubuntu.eng.vmware.com (unknown [10.33.74.215]) by sc9-mailhost3.vmware.com (Postfix) with ESMTP id 15CAA40BFF; Tue, 13 Mar 2018 12:42:35 -0700 (PDT) From: Ronak Doshi To: CC: , Ronak Doshi , Shrikrishna Khare , "VMware, Inc." , open list Subject: [PATCH net 2/2] vmxnet3: use correct flag to indicate LRO feature Date: Tue, 13 Mar 2018 12:41:41 -0700 Message-ID: <20180313194141.12913-1-doshir@vmware.com> X-Mailer: git-send-email 2.11.0 MIME-Version: 1.0 Content-Type: text/plain Received-SPF: None (EX13-EDG-OU-002.vmware.com: doshir@vmware.com does not designate permitted sender hosts) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 'Commit 45dac1d6ea04 ("vmxnet3: Changes for vmxnet3 adapter version 2 (fwd)")' introduced a flag "lro" in structure vmxnet3_adapter which is used to indicate whether LRO is enabled or not. However, the patch did not set the flag and hence it was never exercised. So, when LRO is enabled, it resulted in poor TCP performance due to delayed acks. This issue is seen with packets which are larger than the mss getting a delayed ack rather than an immediate ack, thus resulting in high latency. This patch removes the lro flag and directly uses device features against NETIF_F_LRO to check if lro is enabled. Reported-by: Rachel Lunnon Signed-off-by: Ronak Doshi Acked-by: Shrikrishna Khare --- drivers/net/vmxnet3/vmxnet3_drv.c | 3 ++- drivers/net/vmxnet3/vmxnet3_int.h | 5 ++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index 052eef2f729f..86c4d6e4dfaa 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c @@ -1473,7 +1473,8 @@ vmxnet3_rq_rx_complete(struct vmxnet3_rx_queue *rq, vmxnet3_rx_csum(adapter, skb, (union Vmxnet3_GenericDesc *)rcd); skb->protocol = eth_type_trans(skb, adapter->netdev); - if (!rcd->tcp || !adapter->lro) + if (!rcd->tcp || + !(adapter->netdev->features & NETIF_F_LRO)) goto not_lro; if (segCnt != 0 && mss != 0) { diff --git a/drivers/net/vmxnet3/vmxnet3_int.h b/drivers/net/vmxnet3/vmxnet3_int.h index b94fdfd0b6f1..99387a4a20a8 100644 --- a/drivers/net/vmxnet3/vmxnet3_int.h +++ b/drivers/net/vmxnet3/vmxnet3_int.h @@ -69,10 +69,10 @@ /* * Version numbers */ -#define VMXNET3_DRIVER_VERSION_STRING "1.4.12.0-k" +#define VMXNET3_DRIVER_VERSION_STRING "1.4.13.0-k" /* a 32-bit int, each byte encode a verion number in VMXNET3_DRIVER_VERSION */ -#define VMXNET3_DRIVER_VERSION_NUM 0x01040c00 +#define VMXNET3_DRIVER_VERSION_NUM 0x01040d00 #if defined(CONFIG_PCI_MSI) /* RSS only makes sense if MSI-X is supported. */ @@ -343,7 +343,6 @@ struct vmxnet3_adapter { u8 version; bool rxcsum; - bool lro; #ifdef VMXNET3_RSS struct UPT1_RSSConf *rss_conf; -- 2.11.0