Received: by 2002:a05:6602:18e:0:0:0:0 with SMTP id m14csp2439323ioo; Sat, 28 May 2022 13:44:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzz8Nipnl9BbSq++vrY+sAUIFET4Ypo69TnNkpG+zOQOaIqME5nRW1tw7LZeHDw0wTTvtbv X-Received: by 2002:a17:902:f54c:b0:163:9c57:2d58 with SMTP id h12-20020a170902f54c00b001639c572d58mr8331156plf.28.1653770698725; Sat, 28 May 2022 13:44:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1653770698; cv=none; d=google.com; s=arc-20160816; b=NYpoAuqIlULBxNsaEukSdGc5C/Rv5gg1Fpn/ABUAftIcOwyDiMxkflMBkkI8UMrVfx cIVOVMjh8ntjZxMB7+p/AiFZQQWocQm3SCF6fmK0ySnGlkfL1LOnaaXjtOCmDIVROnDs mb8MKvr9HLWaROWp2HJCfVG11t9o7woYUTH2TIN2YSKaSO5WQNzHQgqIxrR5oYKM4bPH ZZLjO5jCjwm443UEH4ITShoLANjbEKaDY3Tn1chcEppIEkVyQG5HtUYtqldYIW4PIHb9 3h8+m2Ib36hKHidoWCPkz1fqSJumrlWYVj9VKCXhaZ3Quub29pVyROSi4Kn7X8i72/EZ lLfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=8jUo5ILLnzzIFtft13bYw8jpL7wDw6YblekTQ1WZdNs=; b=WXdPRSWYccLwq3UdPdKz27QnbZe9/CsMh9elepMZPsa+/WB5cfadXeu8XYBKQ5ikbA IET2vgz7ut78EjQY9bm97+rXCVn8zVDw0T0uVIvbLgU+DZjgxDqhMrr8BpsR5vPGOiDA eGxvZ3FFcLxoyF1/UzFxewsa6ZHOb0qJjSCczGapV+LN8yGl/89r89bavkHhyTmLkqqP I0/HoJFrDkhXgx68UcvD2ocgJEdPdKIiTRONp72H3skrkXndZHZhcBhqu4vztIznCliI VgnPouE0nuwW7iESvuiz0/nHiY4HDnJQD3t9z9lttQ0DB/JOx1G79JxSsxEu85SXy+v0 vtug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@vmware.com header.s=s1024 header.b=avBW4saB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 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 lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id c73-20020a624e4c000000b0050759c7a6f2si8771306pfb.376.2022.05.28.13.44.58 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 28 May 2022 13:44:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@vmware.com header.s=s1024 header.b=avBW4saB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=vmware.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id E81BE1B9A5D; Sat, 28 May 2022 12:44:26 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1355541AbiE1BeY (ORCPT + 99 others); Fri, 27 May 2022 21:34:24 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34758 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1355548AbiE1BeS (ORCPT ); Fri, 27 May 2022 21:34:18 -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 CACFA13C1D5; Fri, 27 May 2022 18:34:02 -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:in-reply-to:mime-version: content-type; bh=8jUo5ILLnzzIFtft13bYw8jpL7wDw6YblekTQ1WZdNs=; b=avBW4saBe3A+nwXGFq6SKr+4e49Q2441gb9WVZYMgVOG1sPDVQOrcGo4sXxkf2 AHNd1G3OfbqOXtZU0QN26FTUpRjRMjslIDhDgtImyU2uDyduq+X8NozIvz9rGQ ORbuDuTCNeKLkTBIsM8gxPEDu5Y3uSEBMgEHqgUVia81t2I= Received: from sc9-mailhost2.vmware.com (10.113.161.72) by EX-PRD-EDGE01.vmware.com (10.188.245.6) with Microsoft SMTP Server id 15.1.2308.20; Fri, 27 May 2022 18:18:53 -0700 Received: from htb-1n-eng-dhcp122.eng.vmware.com (unknown [10.20.114.216]) by sc9-mailhost2.vmware.com (Postfix) with ESMTP id CEE1B202C0; Fri, 27 May 2022 18:19:01 -0700 (PDT) Received: by htb-1n-eng-dhcp122.eng.vmware.com (Postfix, from userid 0) id BDD88AA2B9; Fri, 27 May 2022 18:19:01 -0700 (PDT) From: Ronak Doshi To: CC: Ronak Doshi , VMware PV-Drivers Reviewers , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , open list Subject: [PATCH net-next 6/8] vmxnet3: limit number of TXDs used for TSO packet Date: Fri, 27 May 2022 18:17:56 -0700 Message-ID: <20220528011758.7024-7-doshir@vmware.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20220528011758.7024-1-doshir@vmware.com> References: <20220528011758.7024-1-doshir@vmware.com> 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=-2.8 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE 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 does not have a limit on number of descriptors used for a TSO packet. However, with UPT, for hardware performance reasons, this patch limits the number of transmit descriptors to 24 for a TSO packet. Signed-off-by: Ronak Doshi Acked-by: Guolin Yang --- drivers/net/vmxnet3/vmxnet3_defs.h | 2 ++ drivers/net/vmxnet3/vmxnet3_drv.c | 17 +++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/drivers/net/vmxnet3/vmxnet3_defs.h b/drivers/net/vmxnet3/vmxnet3_defs.h index 415e4c9993ef..cb9dc72f2b3d 100644 --- a/drivers/net/vmxnet3/vmxnet3_defs.h +++ b/drivers/net/vmxnet3/vmxnet3_defs.h @@ -400,6 +400,8 @@ union Vmxnet3_GenericDesc { /* max # of tx descs for a non-tso pkt */ #define VMXNET3_MAX_TXD_PER_PKT 16 +/* max # of tx descs for a tso pkt */ +#define VMXNET3_MAX_TSO_TXD_PER_PKT 24 /* Max size of a single rx buffer */ #define VMXNET3_MAX_RX_BUF_SIZE ((1 << 14) - 1) diff --git a/drivers/net/vmxnet3/vmxnet3_drv.c b/drivers/net/vmxnet3/vmxnet3_drv.c index 2ba263966989..6e013ae0b5ea 100644 --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c @@ -1061,6 +1061,23 @@ vmxnet3_tq_xmit(struct sk_buff *skb, struct vmxnet3_tx_queue *tq, } tq->stats.copy_skb_header++; } + if (unlikely(count > VMXNET3_MAX_TSO_TXD_PER_PKT)) { + /* tso pkts must not use more than + * VMXNET3_MAX_TSO_TXD_PER_PKT entries + */ + if (skb_linearize(skb) != 0) { + tq->stats.drop_too_many_frags++; + goto drop_pkt; + } + tq->stats.linearized++; + + /* recalculate the # of descriptors to use */ + count = VMXNET3_TXD_NEEDED(skb_headlen(skb)) + 1; + if (unlikely(count > VMXNET3_MAX_TSO_TXD_PER_PKT)) { + tq->stats.drop_too_many_frags++; + goto drop_pkt; + } + } if (skb->encapsulation) { vmxnet3_prepare_inner_tso(skb, &ctx); } else { -- 2.11.0