Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4586751rwd; Sun, 11 Jun 2023 10:24:15 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6xxLkJ1GxeXgcNYffAHW6xwytV1Av6UUVJ9Nf1ABCWsSR7ceo9dPzc8g9F4umwBa3W9k5T X-Received: by 2002:a17:906:fd86:b0:977:ecff:3367 with SMTP id xa6-20020a170906fd8600b00977ecff3367mr7406521ejb.40.1686504255612; Sun, 11 Jun 2023 10:24:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686504255; cv=none; d=google.com; s=arc-20160816; b=YBrNR5fCATQ8zjon8tjPnEPxZIdy1Akha7C91QNVhY7me6dLQIFAx37Magpo6a77VG Vb6KUAAgrsq8AVUSPIcdN9X5dty5qKHumV1fyLz6bwRvoxTASuh6WZ5wcIqx4YMFCbh+ 3VcxPa05AbLsPDBu+oDhFAjZcDwxhogKhLJJKEoeLpnn1hOzRJsyhc47E2RDou/1fndW H5wX8cKqFfmRPltPLA2MMZmf5w4SUZ1xbPZwAZiQPaKAbmoKyW+P/KVPUGnQ8nHSmfSX Spmjz8KjRtNdU2o2Ahck7MTBpeMaHMjjJ7EV16a3gkvZSt13BHvMkNhN5FK6cyNsZluq UC5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:message-id :in-reply-to:subject:cc:to:from:date; bh=TtoebyDSQynbZwaTjWw9DshX614kVJzhpuRqO3AvTMs=; b=s2eRiogfD/EfUghimVjyJFnJ64tsqzY28ggjxccEen49q/BCS8YLozZgmy8Ev8tyR0 jyoWodh/yAO3nIM+JZaE4yZn1yJjejPmqP5qXpgNL6XLKw7CxdYx/FHhzCr8YPgVsBBE 9SU70TD4E33M5Cw0sYItQE6eJIrPCZVVwLvKSetu3EHooPnyfAHpB9f227O+DcHl8hZE Qsorz2SNCnNG0yr652XOYHJzXfoWeBhFCw6lp0evLE+Rg8K3dknP4jNkedaiA+XcMKDK 0qxQ5uuqljfAycw1dCNp6RTYbVM4wozvMeW4oy9PFC6GPG0Wk+WHezgahvgUdRMsOETQ QZ9g== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id gl16-20020a170906e0d000b0096f8b640d66si589870ejb.104.2023.06.11.10.23.51; Sun, 11 Jun 2023 10:24:15 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233990AbjFKRVC (ORCPT + 99 others); Sun, 11 Jun 2023 13:21:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45280 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230156AbjFKRUz (ORCPT ); Sun, 11 Jun 2023 13:20:55 -0400 Received: from angie.orcam.me.uk (angie.orcam.me.uk [IPv6:2001:4190:8020::34]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 21BFFE6F; Sun, 11 Jun 2023 10:20:30 -0700 (PDT) Received: by angie.orcam.me.uk (Postfix, from userid 500) id 529979200C9; Sun, 11 Jun 2023 19:20:02 +0200 (CEST) Received: from localhost (localhost [127.0.0.1]) by angie.orcam.me.uk (Postfix) with ESMTP id 4E1479200C0; Sun, 11 Jun 2023 18:20:02 +0100 (BST) Date: Sun, 11 Jun 2023 18:20:02 +0100 (BST) From: "Maciej W. Rozycki" To: Bjorn Helgaas , Mahesh J Salgaonkar , Oliver O'Halloran , Michael Ellerman , Nicholas Piggin , Christophe Leroy , Saeed Mahameed , Leon Romanovsky , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni cc: Alex Williamson , Lukas Wunner , Mika Westerberg , Stefan Roese , Jim Wilson , David Abdurachmanov , =?UTF-8?Q?Pali_Roh=C3=A1r?= , linux-pci@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, linux-rdma@vger.kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v9 12/14] PCI: Provide stub failed link recovery for device probing and hot plug In-Reply-To: Message-ID: References: User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,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 This now fails unconditionally and will be always optimised away, but provides for quirks to implement recovery for failed links detected in device probing and device hot plug events. Signed-off-by: Maciej W. Rozycki --- New change in v9, factored out from 7/7: - Rename `pcie_downstream_link_retrain' to `pcie_failed_link_retrain'. - Add stub implementation in "pci.h". --- drivers/pci/pci.c | 2 ++ drivers/pci/pci.h | 4 ++++ drivers/pci/probe.c | 2 ++ 3 files changed, 8 insertions(+) linux-pcie-failed-link-retrain.diff Index: linux-macro/drivers/pci/pci.c =================================================================== --- linux-macro.orig/drivers/pci/pci.c +++ linux-macro/drivers/pci/pci.c @@ -4912,6 +4912,8 @@ static bool pcie_wait_for_link_delay(str if (active) msleep(20); ret = pcie_wait_for_link_status(pdev, false, active); + if (active && !ret) + ret = pcie_failed_link_retrain(pdev); if (active && ret) msleep(delay); Index: linux-macro/drivers/pci/pci.h =================================================================== --- linux-macro.orig/drivers/pci/pci.h +++ linux-macro/drivers/pci/pci.h @@ -554,6 +554,10 @@ static inline int pci_dev_specific_disab return -ENOTTY; } #endif +static inline bool pcie_failed_link_retrain(struct pci_dev *dev) +{ + return false; +} /* PCI error reporting and recovery */ pci_ers_result_t pcie_do_recovery(struct pci_dev *dev, Index: linux-macro/drivers/pci/probe.c =================================================================== --- linux-macro.orig/drivers/pci/probe.c +++ linux-macro/drivers/pci/probe.c @@ -2549,6 +2549,8 @@ void pci_device_add(struct pci_dev *dev, dma_set_max_seg_size(&dev->dev, 65536); dma_set_seg_boundary(&dev->dev, 0xffffffff); + pcie_failed_link_retrain(dev); + /* Fix up broken headers */ pci_fixup_device(pci_fixup_header, dev);