Received: by 10.192.165.148 with SMTP id m20csp2248330imm; Thu, 3 May 2018 13:01:05 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrbtsEv25YHo3LNARbOk/C3GAJ+o7784VwIIztI4BZjw0gyblq4iMaHoVmkYGKtdryMlyJH X-Received: by 2002:a17:902:9a9:: with SMTP id 38-v6mr25510767pln.114.1525377665358; Thu, 03 May 2018 13:01:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525377665; cv=none; d=google.com; s=arc-20160816; b=ufGWCPWwun75moacC86TC9rRSbdejRtZHoUfTQXP3YALehTY0P/Cya69kUtbTwEpIz YxjxkSiRI5fagsdLkKIZQ2PLxIfy2cyxi5HYBL6c7rdyK1cs0TyhLZ59SHWqhMzWrRhT zA+UYTZXnJbpIr6TsGjZcRxrwuZMqN3X28EUwJQxxd1W2YnqUZh1HWfDAf2oR+yAApX4 aJamzTLP2cIjRU9ks52/lWIFBxy+gFrVRRaQEUcqEVjBfeOCoSbyzVZvx9ethEWI/p5K 1qTOXAwATjOg4l7WJED5sTXqVsBOO3DJa+ZKQXfLBjK1LqBmSgfg7n9jhVGTicqR/mnK DSZg== 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=NNyxTwaecwRZlgmcQWXFB481WTzrZGayz6bZXDBrKFs=; b=roJ4Jf5T++pSuu5jjcYpVA0Pt8agO/FNnAS7lmppc41gq+YxPzEQNqJKezaOteyVD/ fEhsaS6r5jcf5Wo5l+udoRf//JlPlp3NfsqzmrsRbkDYIqPi0vSvNQiinNkVzVYh/9dI FGqbsM17wYeUStY+hXHLEmjT0kLyqoMvBYnbKbDLuUtef7r6zIklNnvK8VDP/n0FqAWy 5ToDVc7fh5mdn6kReMDWIvoyTq7UamyPBvwsnSZFjQgYlEC5Vi3e3eRKWkXe9ivrQZWI EbA9v8f2MU+P+WLBWM5yYE1dqZw/J9KunoKCnxrotlliGn4d75rCmMrgwdAPuMy0nd4h LZtg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=D1lnOyzQ; 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 v4si2342216pff.281.2018.05.03.13.00.47; Thu, 03 May 2018 13:01:05 -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=D1lnOyzQ; 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 S1751316AbeECUAV (ORCPT + 99 others); Thu, 3 May 2018 16:00:21 -0400 Received: from mail.kernel.org ([198.145.29.99]:33468 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750823AbeECUAR (ORCPT ); Thu, 3 May 2018 16:00:17 -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 E867D21770; Thu, 3 May 2018 20:00:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1525377617; bh=WC/VF6BmLNs8GcKZevzlmmda/jz4RLNRwgTWQwWVMRk=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=D1lnOyzQx8Zg0iblwtOClCqvWLKZrrSgTQUeO74Kj+w76xaednndOO922ssZNSxnG pL5Xxpc4YMQCWIRqXEbxCS6QKZVi5RaV/fxbnx09Xhe5Mvfs350MjU4ECdmip93BQl xlSMhGwadwulvQrzon856oSsgn4yCKo5TTi6LVPo= Subject: [PATCH v6 1/5] bnx2x: 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:15 -0500 Message-ID: <152537761536.62474.4071016337645118753.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: - %s (%c%d) PCI-E x%d %s found at mem %lx, IRQ %d, node addr %pM + %s (%c%d) PCI-E found at mem %lx, IRQ %d, node addr %pM + %u.%03u Gb/s available PCIe bandwidth (%s x%d link) Signed-off-by: Bjorn Helgaas --- drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c | 23 ++++++---------------- 1 file changed, 6 insertions(+), 17 deletions(-) diff --git a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c index c766ae23bc74..5b1ed240bf18 100644 --- a/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c +++ b/drivers/net/ethernet/broadcom/bnx2x/bnx2x_main.c @@ -13922,8 +13922,6 @@ static int bnx2x_init_one(struct pci_dev *pdev, { struct net_device *dev = NULL; struct bnx2x *bp; - enum pcie_link_width pcie_width; - enum pci_bus_speed pcie_speed; int rc, max_non_def_sbs; int rx_count, tx_count, rss_count, doorbell_size; int max_cos_est; @@ -14091,21 +14089,12 @@ static int bnx2x_init_one(struct pci_dev *pdev, dev_addr_add(bp->dev, bp->fip_mac, NETDEV_HW_ADDR_T_SAN); rtnl_unlock(); } - if (pcie_get_minimum_link(bp->pdev, &pcie_speed, &pcie_width) || - pcie_speed == PCI_SPEED_UNKNOWN || - pcie_width == PCIE_LNK_WIDTH_UNKNOWN) - BNX2X_DEV_INFO("Failed to determine PCI Express Bandwidth\n"); - else - BNX2X_DEV_INFO( - "%s (%c%d) PCI-E x%d %s found at mem %lx, IRQ %d, node addr %pM\n", - board_info[ent->driver_data].name, - (CHIP_REV(bp) >> 12) + 'A', (CHIP_METAL(bp) >> 4), - pcie_width, - pcie_speed == PCIE_SPEED_2_5GT ? "2.5GHz" : - pcie_speed == PCIE_SPEED_5_0GT ? "5.0GHz" : - pcie_speed == PCIE_SPEED_8_0GT ? "8.0GHz" : - "Unknown", - dev->base_addr, bp->pdev->irq, dev->dev_addr); + BNX2X_DEV_INFO( + "%s (%c%d) PCI-E found at mem %lx, IRQ %d, node addr %pM\n", + board_info[ent->driver_data].name, + (CHIP_REV(bp) >> 12) + 'A', (CHIP_METAL(bp) >> 4), + dev->base_addr, bp->pdev->irq, dev->dev_addr); + pcie_print_link_status(bp->pdev); bnx2x_register_phc(bp);