Received: by 10.192.165.148 with SMTP id m20csp2250318imm; Thu, 3 May 2018 13:02:48 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoJjJ1Lprc4h9D33qJcIYSazJUGbzQlpAXiVaT31RHvFJXU1qw6hNjjStHpa+JH+pXF8AnV X-Received: by 2002:a17:902:7782:: with SMTP id o2-v6mr25829928pll.247.1525377768680; Thu, 03 May 2018 13:02:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525377768; cv=none; d=google.com; s=arc-20160816; b=g9EZtULpgHA3prqvgC6ebtvT5BksfolDFDNHMhZa7nhFR5owIUjwPRQEYiDTJHubp3 fEoOMFjQhl+Sz4rs9TotE0oN0rrL0iJmtsL6c4iq+I6/3qa2gUgHeqnNw7L3NjpjyV9d rEmC1l/T9YJAd/hIrbSRDc9S7B4fbdDKfuhaogSU9P4P0Ze5IeSsefhPaQKa6Z5wOTE0 ekBNLXWF967low3AnzaFyqXRMsXAnmF1KyqQQHosl6F4kNtCppGLzae1DGZPwdCXY2Jq XqMBbOIKSB6N0LTjmXuK+E2IP5sD+nI5hUcuO14dqqK0d3O8qFNJlCAtJkKyKY8dkYt0 JbNw== 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:dkim-signature:arc-authentication-results; bh=DoBo1pbe8jJB/W4V9acWThy0AraapJGQnfWMOfL7evg=; b=VgG3RsS1h1AbOcJtIZ/lV7rh3D9CshPNLmQ+Wwev22IZZqO67m98kohKDIdyMrOCJ6 Duuz4BVyqp0jRJn38Q1d69Kf6ldL9aR3FOyepLp7Cu56ZnQJy6DTACJOszrCI1c14e2E QT23aUB542tkr9b0tNYv0WHs/gl7ZHzxx2osO26YYefxu47NQYWdm1JJ0UqjKKDMaTnQ vMJQ4TzF7OTVfAqxcaCbEMzki1rrYWs5D3oDbOZp7+xBz8q098IVwY5bgAu9WKrLrC2e 5OuydLCnvcMQzxIxOJBemFqAZsJd1idkH+ZDMx98IEcsy4+L4aa3OpEbT4aCJoBa6yiL P3wA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Dh7IF3jm; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x3-v6si14036611plb.478.2018.05.03.13.02.10; Thu, 03 May 2018 13:02:48 -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; dkim=pass header.i=@kernel.org header.s=default header.b=Dh7IF3jm; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751392AbeECUA2 (ORCPT + 99 others); Thu, 3 May 2018 16:00:28 -0400 Received: from mail.kernel.org ([198.145.29.99]:33668 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750823AbeECUAY (ORCPT ); Thu, 3 May 2018 16:00:24 -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 9BC402176D; Thu, 3 May 2018 20:00:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1525377624; bh=mS3UNwjQYLylw/r1t5R04sSRHZehsdhqAY5HZss6vrE=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=Dh7IF3jmwN6X+9QS2nLR8wcBwejiuVPdVq4plKTcq4bDNB3mzuT2USo4x3r/cYsUD dhhD92f3KkbXWOK4QZ0Zrl6wvkBoRuYgA2+tangndfompFy25vF7uR+flTXidzakUs 3OC9DnQP1SrKCO1XCvwzLKVgLTz1dAWnuuMnfSOU= Subject: [PATCH v6 2/5] bnxt_en: Report PCIe link properties with pcie_print_link_status() From: Bjorn Helgaas To: Jeff Kirsher , Ganesh Goudar , Michael Chan , Ariel Elior Cc: linux-pci@vger.kernel.org, everest-linux-l2@cavium.com, intel-wired-lan@lists.osuosl.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Tal Gilboa , Tariq Toukan , Jacob Keller , Jakub Kicinski Date: Thu, 03 May 2018 15:00:22 -0500 Message-ID: <152537762239.62474.691804492516629751.stgit@bhelgaas-glaptop.roam.corp.google.com> In-Reply-To: <152537719056.62474.2571390812509425478.stgit@bhelgaas-glaptop.roam.corp.google.com> References: <152537719056.62474.2571390812509425478.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: Bjorn Helgaas Previously the driver used pcie_get_minimum_link() to warn when the NIC is in a slot that can't supply as much bandwidth as the NIC could use. pcie_get_minimum_link() can be misleading because it finds the slowest link and the narrowest link (which may be different links) without considering the total bandwidth of each link. For a path with a 16 GT/s x1 link and a 2.5 GT/s x16 link, it returns 2.5 GT/s x1, which corresponds to 250 MB/s of bandwidth, not the true available bandwidth of about 1969 MB/s for a 16 GT/s x1 link. Use pcie_print_link_status() to report PCIe link speed and possible limitations instead of implementing this in the driver itself. This finds the slowest link in the path to the device by computing the total bandwidth of each link and compares that with the capabilities of the device. The dmesg change is: - PCIe: Speed %s Width x%d + %u.%03u Gb/s available PCIe bandwidth (%s x%d link) Signed-off-by: Bjorn Helgaas --- drivers/net/ethernet/broadcom/bnxt/bnxt.c | 19 +------------------ 1 file changed, 1 insertion(+), 18 deletions(-) diff --git a/drivers/net/ethernet/broadcom/bnxt/bnxt.c b/drivers/net/ethernet/broadcom/bnxt/bnxt.c index f83769d8047b..34fddb48fecc 100644 --- a/drivers/net/ethernet/broadcom/bnxt/bnxt.c +++ b/drivers/net/ethernet/broadcom/bnxt/bnxt.c @@ -8621,22 +8621,6 @@ static int bnxt_init_mac_addr(struct bnxt *bp) return rc; } -static void bnxt_parse_log_pcie_link(struct bnxt *bp) -{ - enum pcie_link_width width = PCIE_LNK_WIDTH_UNKNOWN; - enum pci_bus_speed speed = PCI_SPEED_UNKNOWN; - - if (pcie_get_minimum_link(pci_physfn(bp->pdev), &speed, &width) || - speed == PCI_SPEED_UNKNOWN || width == PCIE_LNK_WIDTH_UNKNOWN) - netdev_info(bp->dev, "Failed to determine PCIe Link Info\n"); - else - netdev_info(bp->dev, "PCIe: Speed %s Width x%d\n", - speed == PCIE_SPEED_2_5GT ? "2.5GT/s" : - speed == PCIE_SPEED_5_0GT ? "5.0GT/s" : - speed == PCIE_SPEED_8_0GT ? "8.0GT/s" : - "Unknown", width); -} - static int bnxt_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) { static int version_printed; @@ -8851,8 +8835,7 @@ static int bnxt_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) netdev_info(dev, "%s found at mem %lx, node addr %pM\n", board_info[ent->driver_data].name, (long)pci_resource_start(pdev, 0), dev->dev_addr); - - bnxt_parse_log_pcie_link(bp); + pcie_print_link_status(pdev); return 0;