Commit 4d8f0d4f authored by Ley Foon Tan's avatar Ley Foon Tan Committed by Stefan Bader

PCI: altera: Check link status before retrain link

BugLink: https://bugs.launchpad.net/bugs/1818237

commit c622032e upstream.

Check the link status before retraining.  If the link is not up, don't
bother trying to retrain it.

[bhelgaas: split code move to separate patch, changelog]
Signed-off-by: default avatarLey Foon Tan <lftan@altera.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Cc: Claudius Heine <claudius.heine.ext@siemens.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarJuerg Haefliger <juergh@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent a80cadee
...@@ -100,6 +100,10 @@ static bool altera_pcie_link_is_up(struct altera_pcie *pcie) ...@@ -100,6 +100,10 @@ static bool altera_pcie_link_is_up(struct altera_pcie *pcie)
static void altera_pcie_retrain(struct pci_dev *dev) static void altera_pcie_retrain(struct pci_dev *dev)
{ {
u16 linkcap, linkstat; u16 linkcap, linkstat;
struct altera_pcie *pcie = dev->bus->sysdata;
if (!altera_pcie_link_is_up(pcie))
return;
/* /*
* Set the retrain bit if the PCIe rootport support > 2.5GB/s, but * Set the retrain bit if the PCIe rootport support > 2.5GB/s, but
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment