Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp765923iof; Mon, 6 Jun 2022 12:05:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwOdX/HrIlKQQSbjUHjMdN81PeeVWjsdUWvpRSU+pYIweU9MfLJgBFHXQvSVRZewV5tEZBl X-Received: by 2002:a17:907:1c06:b0:6df:b257:cbb3 with SMTP id nc6-20020a1709071c0600b006dfb257cbb3mr22880979ejc.631.1654542329430; Mon, 06 Jun 2022 12:05:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654542329; cv=none; d=google.com; s=arc-20160816; b=FT/sXuSbaZSRprf1Qo3DoIM/L/8XfcO+Psy//QDChcveBM/QEqKNoWWUQ24T1pYIBj hnVy6t4oaoEnNcS42ADhaiYLRkhITIM6ndHoEh+hcz6reqv41iu4ypyD1YgT9qituPRY Z2sTIYtvFFsDvoTpwNCD2/Dr2M1geousmcj3PgboHugvdhNGRsI79651rUnx/YRXav6u Hokte0nlhAcLzsXbA5x73Ruev/S1X95nOrRehxYpavp64IwCSdCNp6c7xwTwzwx3cCuY mlcXSdzaOTfDvCBHphQDXJoSrqIP/s5L6N3NbxgYOq3+TIMi39gmOIfWBoynDg8rZ+Mj C3lQ== 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=z7BuZ0AKxfSP0k5d1/eeJ+ounm26gnL3ACZNzJVBFR5L8P7g+bQEd/+HumFeB97HsA Eapwp8m5hvzS+YXuR+ZflCMYGZ2W2323WxUBb6jI5pnE4znd+YyMt/CAAwwk8KasyzzY KGGU+DDqR/qKm2zfCyJzqEBvoEZ8lmnuBexU8kytu7lRLROSLtWyQKpqPTPzc3WVHPuz ZttOPo4ldoqfo5HlHsv8yOPlJhdE8YlNGp4nD7KbFrOFbXTW0Hi99JmrXKenU0Z5RwUO c/+wurY22/chdIJnvGEWzDVQL2gxxSHlP+L6mR2jyQhcDgcIgK2tooRFDyHniGvFcBTD vk0A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@vmware.com header.s=s1024 header.b=WAJJx4CX; 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 z4-20020a05640235c400b0042fb1fc374dsi8912488edc.399.2022.06.06.12.05.01; Mon, 06 Jun 2022 12:05:29 -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=WAJJx4CX; 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 S231162AbiFFSEP (ORCPT + 99 others); Mon, 6 Jun 2022 14:04:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47850 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230428AbiFFSDt (ORCPT ); Mon, 6 Jun 2022 14:03:49 -0400 Received: from EX-PRD-EDGE02.vmware.com (EX-PRD-EDGE02.vmware.com [208.91.3.34]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 231071BF821; Mon, 6 Jun 2022 11:03:49 -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=WAJJx4CXFe3qkeSoT0+k1m2U0BdhWbBfJ2Ku//W0Uh4sNbtFkje28eOsmCM3yK KEKC/iuNs0OQwBSmYR0OtYyf+aZYtJ9RLfrzgJ2yGkIad3KupsJJZhQYhmCMew r1EC8dL6EVK7dcUZUYV8EzVHZkVEQGyPCoTc+VvayQ5gPC0= Received: from sc9-mailhost3.vmware.com (10.113.161.73) by EX-PRD-EDGE02.vmware.com (10.188.245.7) with Microsoft SMTP Server id 15.1.2308.14; Mon, 6 Jun 2022 11:03:38 -0700 Received: from htb-1n-eng-dhcp122.eng.vmware.com (unknown [10.20.114.216]) by sc9-mailhost3.vmware.com (Postfix) with ESMTP id F157A20221; Mon, 6 Jun 2022 11:03:43 -0700 (PDT) Received: by htb-1n-eng-dhcp122.eng.vmware.com (Postfix, from userid 0) id EBB9DAA1E5; Mon, 6 Jun 2022 11:03:43 -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: Mon, 6 Jun 2022 11:03:12 -0700 Message-ID: <20220606180316.27793-7-doshir@vmware.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20220606180316.27793-1-doshir@vmware.com> References: <20220606180316.27793-1-doshir@vmware.com> MIME-Version: 1.0 Content-Type: text/plain Received-SPF: None (EX-PRD-EDGE02.vmware.com: doshir@vmware.com does not designate permitted sender hosts) X-Spam-Status: No, score=-8.3 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham 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