summaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorLey Foon Tan <lftan@altera.com>2016-03-02 17:43:07 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-01-16 22:16:11 +0100
commitecd77ebfa6ddcf728c8eccb4cdfebc23ab7125b9 (patch)
treeb935f31a73f4e0aa42cb393ec75d232b28440781 /drivers
parent271137c0385839090dc195d5e3f41fd1d8999372 (diff)
downloadlinux-stable-ecd77ebfa6ddcf728c8eccb4cdfebc23ab7125b9.tar.gz
linux-stable-ecd77ebfa6ddcf728c8eccb4cdfebc23ab7125b9.tar.bz2
linux-stable-ecd77ebfa6ddcf728c8eccb4cdfebc23ab7125b9.zip
PCI: altera: Fix altera_pcie_link_is_up()
commit eff31f4002c4e25b9b8c39d0a3a551c6c64c77e8 upstream. Originally altera_pcie_link_is_up() decided the link was up if any of the low four bits of the LTSSM register were set. But the link is only up if the LTSSM state is L0, so check for that exact value. [bhelgaas: changelog] Signed-off-by: Ley Foon Tan <lftan@altera.com> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> Cc: Claudius Heine <claudius.heine.ext@siemens.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/pci/host/pcie-altera.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/pci/host/pcie-altera.c b/drivers/pci/host/pcie-altera.c
index 99da549d5d06..dbac6fb3f0bd 100644
--- a/drivers/pci/host/pcie-altera.c
+++ b/drivers/pci/host/pcie-altera.c
@@ -40,6 +40,7 @@
#define P2A_INT_ENABLE 0x3070
#define P2A_INT_ENA_ALL 0xf
#define RP_LTSSM 0x3c64
+#define RP_LTSSM_MASK 0x1f
#define LTSSM_L0 0xf
/* TLP configuration type 0 and 1 */
@@ -140,7 +141,7 @@ static void tlp_write_tx(struct altera_pcie *pcie,
static bool altera_pcie_link_is_up(struct altera_pcie *pcie)
{
- return !!(cra_readl(pcie, RP_LTSSM) & LTSSM_L0);
+ return !!((cra_readl(pcie, RP_LTSSM) & RP_LTSSM_MASK) == LTSSM_L0);
}
static bool altera_pcie_valid_config(struct altera_pcie *pcie,