Received: by 10.213.65.68 with SMTP id h4csp54432imn; Fri, 30 Mar 2018 14:07:40 -0700 (PDT) X-Google-Smtp-Source: AIpwx48ax3usMcXKg7kjREeIQHJ1IwcFlgX9BnyK/AJRVidMBbuCnJlU7icyz7aeIq6IdNhcFMdd X-Received: by 10.99.52.11 with SMTP id b11mr326407pga.377.1522444060425; Fri, 30 Mar 2018 14:07:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522444060; cv=none; d=google.com; s=arc-20160816; b=eIQrONJYfSTwlO/eJ5AuNMi028JEsDxKBhsJiK2HthlcRpJaOc60jbD422zQX0Hsvm vJIjSMXsia96B+5vBFmZglS8h5wddZa9BN3HWbnVYgpJqY40hl2Aa+pyA/Eb9M/LiXFp uGsrV7FHGJLrT3ui7nyLZ0J2WX7948AEvCP5SHn4M+aOFJ3/aul8IPBpbPtfpGvAOlkS HHJMFdWBDzlaQX5ti9Y1GMyI0B8UfClsaX8Ex7J+SDfFecTjYroPwdk2HrfjqfwZBafF bhnD8B0zUXuDSlTBKVWxaN5M+iDrZMjCDlLUuzu666DlNjv6NwYI1DKovkjTbB4hrhqo 1mvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:cc:to:from :subject:dmarc-filter:arc-authentication-results; bh=BJMSOzz8p7zvnBR347Lsv4DTc/NF1UrKqiMx938DA0w=; b=rC4aITPVelXeT1VohJOJ7UxqlPjLZ8BPgbgv8iYAysptwSuOFOEs51gSdEM9j+sFLP 88lpGtviK3lUcxx+PlGAdjGODivKxhwVb5qTw2wycnTd0vtU8mnCgxKgEXoRCEdlgwOv HQZkHqLCQnkl7cdh6gB+hZa+VGGzRfArRWv3ufr3QyKToH8U985Vsc/lw+VC5NM27vd6 DMuTNL3PjbiWumTAm70Fu3vNO5mdHVFWOAInG7wp5xG/LaaTiI+SRFXlutCcHEcHzHlz xb+N864EpZ1GEvivbxGzN9ZfHxCm193fRPBY1ke5DaMkiL/SDuUTVa0CdB1Xnk8jMzjR jiSw== 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 c5-v6si9457593plo.461.2018.03.30.14.07.27; Fri, 30 Mar 2018 14:07:40 -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 S1753119AbeC3VFq (ORCPT + 99 others); Fri, 30 Mar 2018 17:05:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:33768 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753090AbeC3VFn (ORCPT ); Fri, 30 Mar 2018 17:05:43 -0400 Received: from localhost (unknown [69.71.5.252]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 34A6121777; Fri, 30 Mar 2018 21:05:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 34A6121777 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=helgaas@kernel.org Subject: [PATCH v5 08/14] net/mlx5e: Use pcie_bandwidth_available() to compute bandwidth From: Bjorn Helgaas To: Tal Gilboa Cc: Tariq Toukan , Jacob Keller , Ariel Elior , Ganesh Goudar , Jeff Kirsher , everest-linux-l2@cavium.com, intel-wired-lan@lists.osuosl.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org Date: Fri, 30 Mar 2018 16:05:41 -0500 Message-ID: <152244394162.135666.4917184975514407800.stgit@bhelgaas-glaptop.roam.corp.google.com> In-Reply-To: <152244269202.135666.3064353823697623332.stgit@bhelgaas-glaptop.roam.corp.google.com> References: <152244269202.135666.3064353823697623332.stgit@bhelgaas-glaptop.roam.corp.google.com> User-Agent: StGit/0.18 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tal Gilboa Use the new pci_bandwidth_available() function to calculate maximum available bandwidth through the PCI chain instead of computing it ourselves with mlx5e_get_pci_bw(). This is used to detect when the device is capable of more bandwidth than is available in the current slot. The driver may adjust compression settings accordingly. Note that pci_bandwidth_available() accounts for PCIe encoding overhead, so it is more accurate than mlx5e_get_pci_bw() was. Signed-off-by: Tal Gilboa [bhelgaas: remove mlx5e_get_pci_bw() wrapper altogether] Signed-off-by: Bjorn Helgaas Reviewed-by: Tariq Toukan --- drivers/net/ethernet/mellanox/mlx5/core/en_main.c | 32 +-------------------- 1 file changed, 1 insertion(+), 31 deletions(-) diff --git a/drivers/net/ethernet/mellanox/mlx5/core/en_main.c b/drivers/net/ethernet/mellanox/mlx5/core/en_main.c index 47bab842c5ee..93291ec4a3d1 100644 --- a/drivers/net/ethernet/mellanox/mlx5/core/en_main.c +++ b/drivers/net/ethernet/mellanox/mlx5/core/en_main.c @@ -3864,36 +3864,6 @@ void mlx5e_build_default_indir_rqt(u32 *indirection_rqt, int len, indirection_rqt[i] = i % num_channels; } -static int mlx5e_get_pci_bw(struct mlx5_core_dev *mdev, u32 *pci_bw) -{ - enum pcie_link_width width; - enum pci_bus_speed speed; - int err = 0; - - err = pcie_get_minimum_link(mdev->pdev, &speed, &width); - if (err) - return err; - - if (speed == PCI_SPEED_UNKNOWN || width == PCIE_LNK_WIDTH_UNKNOWN) - return -EINVAL; - - switch (speed) { - case PCIE_SPEED_2_5GT: - *pci_bw = 2500 * width; - break; - case PCIE_SPEED_5_0GT: - *pci_bw = 5000 * width; - break; - case PCIE_SPEED_8_0GT: - *pci_bw = 8000 * width; - break; - default: - return -EINVAL; - } - - return 0; -} - static bool cqe_compress_heuristic(u32 link_speed, u32 pci_bw) { return (link_speed && pci_bw && @@ -3979,7 +3949,7 @@ void mlx5e_build_nic_params(struct mlx5_core_dev *mdev, params->num_tc = 1; mlx5e_get_max_linkspeed(mdev, &link_speed); - mlx5e_get_pci_bw(mdev, &pci_bw); + pci_bw = pcie_bandwidth_available(mdev->pdev, NULL, NULL, NULL); mlx5_core_dbg(mdev, "Max link speed = %d, PCI BW = %d\n", link_speed, pci_bw);