Received: by 2002:a5d:925a:0:0:0:0:0 with SMTP id e26csp1379810iol; Sun, 12 Jun 2022 14:41:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz9FNa0Ij5EEfbDSGWwQppMr4eD6YgsNBe2iwE0DySApejZHoVKuMWcMQyA7ohNcLIAVyoZ X-Received: by 2002:a05:6402:405:b0:433:426d:7d59 with SMTP id q5-20020a056402040500b00433426d7d59mr19743165edv.122.1655070084326; Sun, 12 Jun 2022 14:41:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655070084; cv=none; d=google.com; s=arc-20160816; b=ay3rWQkKRL5BjX+GOQD3DH3gDbMiuHBG2QRWBUZEgHoYRLrpl1PPYsj4EQXDWQrYOc YXVLOmnWPMyXM9UqTZgvLkhk3+3k6psH9yCTjmGC89tm9f3sIh2M2bL56HmoLQ4RFx0u lY8h/c/aRLOp8/juIRnZuJcGAoyhEX5FpFFnFAPkY+wJbnzeg9JTOD3umMJEsKpYp6+t qLme2JWVagv8bmEEIkL3eq7H9lSZkqgRzeyIeUB5P8xexygX7nL9FRTYmhzWyMi1RVnR 4fOBbwl4Vioa7VhGWWwJ4Zo2lmOY78Y5XGUqNp0onFjzIVitEv/rXo+rYavd46W58n4N aAnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:reply-to:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-filter; bh=iPLieafcLxFjlmmLhb05zN+YoGOcztOQ4Ix4vfZZjm8=; b=Ynxq5+kXtsaZ+w1RDsj2VI17ozI+f3/LM3H7hvoPrKIQkmHpxNIH7pc93Zg+nyiqtt O3LekqR9ZxvNb8afg5s0xZBozWyPr8tnhKlrzcAI3fiB6tqwe+v0NkrTGEL/ZzvSZzRz druAFwEerYI1EUki9a9eBpdz21pOKJXdoaAt/ENXIWMug4ik7muIHV0AfKEmz/dntGhn N324W8w/uAUlYQM00bbYAxJJxQXZoDF+DTXJ9iLYOy/6F9qGW+0MarFQfY5hNz5SQ8Yl 11Ma4e2pMR/EoNGby+fWmL6VChJ8qJeHirmuEHTAVtMQuEhVc1Lh7bpDymr8ZtNag7h5 siSw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxonhyperv.com header.s=default header.b=SN8BosHK; 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=NONE sp=NONE dis=NONE) header.from=linuxonhyperv.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hs40-20020a1709073ea800b00711e7f20a57si6413804ejc.809.2022.06.12.14.40.59; Sun, 12 Jun 2022 14:41:24 -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=@linuxonhyperv.com header.s=default header.b=SN8BosHK; 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=NONE sp=NONE dis=NONE) header.from=linuxonhyperv.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235941AbiFLVPx (ORCPT + 99 others); Sun, 12 Jun 2022 17:15:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35064 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235585AbiFLVPS (ORCPT ); Sun, 12 Jun 2022 17:15:18 -0400 Received: from linux.microsoft.com (linux.microsoft.com [13.77.154.182]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 291E2590B3; Sun, 12 Jun 2022 14:15:15 -0700 (PDT) Received: by linux.microsoft.com (Postfix, from userid 1004) id F31D920C14C5; Sun, 12 Jun 2022 14:15:14 -0700 (PDT) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com F31D920C14C5 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linuxonhyperv.com; s=default; t=1655068515; bh=iPLieafcLxFjlmmLhb05zN+YoGOcztOQ4Ix4vfZZjm8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:Reply-To:From; b=SN8BosHK+buYJOFw4sCV73d1u9NUVp1GDyYdbc53EKhJRlKuRXpwjcVoVESk6ZVfL YODYZ6JIdnHy/g0pmt7dpK5d5EL7+1vHXOhfJAZqB4hHF3qucWdSJsDOF2zNjCTgGi F4BjvJgBggtIM+CAjVfgdck+44R8cWj/4a6O3rsU= From: longli@linuxonhyperv.com To: "K. Y. Srinivasan" , Haiyang Zhang , Stephen Hemminger , Wei Liu , Dexuan Cui , "David S. Miller" , Jakub Kicinski , Paolo Abeni , Jason Gunthorpe , Leon Romanovsky , edumazet@google.com, shiraz.saleem@intel.com, Ajay Sharma Cc: linux-hyperv@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-rdma@vger.kernel.org, Long Li Subject: [Patch v3 10/12] net: mana: Define max values for SGL entries Date: Sun, 12 Jun 2022 14:14:52 -0700 Message-Id: <1655068494-16440-11-git-send-email-longli@linuxonhyperv.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1655068494-16440-1-git-send-email-longli@linuxonhyperv.com> References: <1655068494-16440-1-git-send-email-longli@linuxonhyperv.com> Reply-To: longli@microsoft.com X-Spam-Status: No, score=-11.6 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_MED,SPF_HELO_PASS,SPF_PASS,T_SCC_BODY_TEXT_LINE, USER_IN_DEF_SPF_WL 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 From: Long Li The number of maximum SGl entries should be computed from the maximum WQE size for the intended queue type and the corresponding OOB data size. This guarantees the hardware queue can successfully queue requests up to the queue depth exposed to the upper layer. Signed-off-by: Long Li --- drivers/net/ethernet/microsoft/mana/mana_en.c | 2 +- include/net/mana/gdma.h | 7 +++++++ include/net/mana/mana.h | 4 +--- 3 files changed, 9 insertions(+), 4 deletions(-) diff --git a/drivers/net/ethernet/microsoft/mana/mana_en.c b/drivers/net/ethernet/microsoft/mana/mana_en.c index e7e99ba77673..b8d2e155bffc 100644 --- a/drivers/net/ethernet/microsoft/mana/mana_en.c +++ b/drivers/net/ethernet/microsoft/mana/mana_en.c @@ -187,7 +187,7 @@ int mana_start_xmit(struct sk_buff *skb, struct net_device *ndev) pkg.wqe_req.client_data_unit = 0; pkg.wqe_req.num_sge = 1 + skb_shinfo(skb)->nr_frags; - WARN_ON_ONCE(pkg.wqe_req.num_sge > 30); + WARN_ON_ONCE(pkg.wqe_req.num_sge > MAX_TX_WQE_SGL_ENTRIES); if (pkg.wqe_req.num_sge <= ARRAY_SIZE(pkg.sgl_array)) { pkg.wqe_req.sgl = pkg.sgl_array; diff --git a/include/net/mana/gdma.h b/include/net/mana/gdma.h index b1bec8ab5695..ef5de92dd98d 100644 --- a/include/net/mana/gdma.h +++ b/include/net/mana/gdma.h @@ -436,6 +436,13 @@ struct gdma_wqe { #define MAX_TX_WQE_SIZE 512 #define MAX_RX_WQE_SIZE 256 +#define MAX_TX_WQE_SGL_ENTRIES ((GDMA_MAX_SQE_SIZE - \ + sizeof(struct gdma_sge) - INLINE_OOB_SMALL_SIZE) / \ + sizeof(struct gdma_sge)) + +#define MAX_RX_WQE_SGL_ENTRIES ((GDMA_MAX_RQE_SIZE - \ + sizeof(struct gdma_sge)) / sizeof(struct gdma_sge)) + struct gdma_cqe { u32 cqe_data[GDMA_COMP_DATA_SIZE / 4]; diff --git a/include/net/mana/mana.h b/include/net/mana/mana.h index e7719c861395..a58e86b0aebe 100644 --- a/include/net/mana/mana.h +++ b/include/net/mana/mana.h @@ -264,8 +264,6 @@ struct mana_cq { int budget; }; -#define GDMA_MAX_RQE_SGES 15 - struct mana_recv_buf_oob { /* A valid GDMA work request representing the data buffer. */ struct gdma_wqe_request wqe_req; @@ -275,7 +273,7 @@ struct mana_recv_buf_oob { /* SGL of the buffer going to be sent has part of the work request. */ u32 num_sge; - struct gdma_sge sgl[GDMA_MAX_RQE_SGES]; + struct gdma_sge sgl[MAX_RX_WQE_SGL_ENTRIES]; /* Required to store the result of mana_gd_post_work_request. * gdma_posted_wqe_info.wqe_size_in_bu is required for progressing the -- 2.17.1