]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
4.4-stable patches
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 14 Jan 2019 17:39:40 +0000 (18:39 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 14 Jan 2019 17:39:40 +0000 (18:39 +0100)
added patches:
pci-altera-check-link-status-before-retrain-link.patch
pci-altera-fix-altera_pcie_link_is_up.patch
pci-altera-move-retrain-from-fixup-to-altera_pcie_host_init.patch
pci-altera-poll-for-link-training-status-after-retraining-the-link.patch
pci-altera-poll-for-link-up-status-after-retraining-the-link.patch
pci-altera-reorder-read-write-functions.patch
pci-altera-rework-config-accessors-for-use-without-a-struct-pci_bus.patch

queue-4.4/pci-altera-check-link-status-before-retrain-link.patch [new file with mode: 0644]
queue-4.4/pci-altera-fix-altera_pcie_link_is_up.patch [new file with mode: 0644]
queue-4.4/pci-altera-move-retrain-from-fixup-to-altera_pcie_host_init.patch [new file with mode: 0644]
queue-4.4/pci-altera-poll-for-link-training-status-after-retraining-the-link.patch [new file with mode: 0644]
queue-4.4/pci-altera-poll-for-link-up-status-after-retraining-the-link.patch [new file with mode: 0644]
queue-4.4/pci-altera-reorder-read-write-functions.patch [new file with mode: 0644]
queue-4.4/pci-altera-rework-config-accessors-for-use-without-a-struct-pci_bus.patch [new file with mode: 0644]
queue-4.4/series

diff --git a/queue-4.4/pci-altera-check-link-status-before-retrain-link.patch b/queue-4.4/pci-altera-check-link-status-before-retrain-link.patch
new file mode 100644 (file)
index 0000000..4899b14
--- /dev/null
@@ -0,0 +1,35 @@
+From c622032ebc538cb3869c312ae3ad235a99da84b6 Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Tue, 21 Jun 2016 16:53:12 +0800
+Subject: PCI: altera: Check link status before retrain link
+
+From: Ley Foon Tan <lftan@altera.com>
+
+commit c622032ebc538cb3869c312ae3ad235a99da84b6 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: 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>
+
+---
+ drivers/pci/host/pcie-altera.c |    4 ++++
+ 1 file changed, 4 insertions(+)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -100,6 +100,10 @@ static bool altera_pcie_link_is_up(struc
+ static void altera_pcie_retrain(struct pci_dev *dev)
+ {
+       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
diff --git a/queue-4.4/pci-altera-fix-altera_pcie_link_is_up.patch b/queue-4.4/pci-altera-fix-altera_pcie_link_is_up.patch
new file mode 100644 (file)
index 0000000..f64b698
--- /dev/null
@@ -0,0 +1,42 @@
+From eff31f4002c4e25b9b8c39d0a3a551c6c64c77e8 Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Wed, 2 Mar 2016 17:43:07 +0800
+Subject: PCI: altera: Fix altera_pcie_link_is_up()
+
+From: Ley Foon Tan <lftan@altera.com>
+
+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>
+
+---
+ drivers/pci/host/pcie-altera.c |    3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+--- 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_p
+ 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,
diff --git a/queue-4.4/pci-altera-move-retrain-from-fixup-to-altera_pcie_host_init.patch b/queue-4.4/pci-altera-move-retrain-from-fixup-to-altera_pcie_host_init.patch
new file mode 100644 (file)
index 0000000..4a69f6c
--- /dev/null
@@ -0,0 +1,216 @@
+From ce4f1c7ad490aa7129bde5632d6e53943f8a866c Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Fri, 26 Aug 2016 09:47:25 +0800
+Subject: PCI: altera: Move retrain from fixup to altera_pcie_host_init()
+
+From: Ley Foon Tan <lftan@altera.com>
+
+commit ce4f1c7ad490aa7129bde5632d6e53943f8a866c upstream.
+
+Previously we used a PCI early fixup to initiate a link retrain on Altera
+devices.  But Altera PCIe IP can be configured as either a Root Port or an
+Endpoint, and they might have same vendor ID, so the fixup would be run for
+both.
+
+We only want to initiate a link retrain for Altera Root Port devices, not
+for Endpoints, so move the link retrain functionality from the fixup to
+altera_pcie_host_init().
+
+[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>
+
+---
+ drivers/pci/host/pcie-altera.c |  151 ++++++++++++++++++++++++-----------------
+ 1 file changed, 91 insertions(+), 60 deletions(-)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -43,6 +43,7 @@
+ #define RP_LTSSM_MASK                 0x1f
+ #define LTSSM_L0                      0xf
++#define PCIE_CAP_OFFSET                       0x80
+ /* TLP configuration type 0 and 1 */
+ #define TLP_FMTTYPE_CFGRD0            0x04    /* Configuration Read Type 0 */
+ #define TLP_FMTTYPE_CFGWR0            0x44    /* Configuration Write Type 0 */
+@@ -100,66 +101,6 @@ static bool altera_pcie_link_is_up(struc
+       return !!((cra_readl(pcie, RP_LTSSM) & RP_LTSSM_MASK) == LTSSM_L0);
+ }
+-static void altera_wait_link_retrain(struct pci_dev *dev)
+-{
+-      u16 reg16;
+-      unsigned long start_jiffies;
+-      struct altera_pcie *pcie = dev->bus->sysdata;
+-
+-      /* Wait for link training end. */
+-      start_jiffies = jiffies;
+-      for (;;) {
+-              pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &reg16);
+-              if (!(reg16 & PCI_EXP_LNKSTA_LT))
+-                      break;
+-
+-              if (time_after(jiffies, start_jiffies + LINK_RETRAIN_TIMEOUT)) {
+-                      dev_err(&pcie->pdev->dev, "link retrain timeout\n");
+-                      break;
+-              }
+-              udelay(100);
+-      }
+-
+-      /* Wait for link is up */
+-      start_jiffies = jiffies;
+-      for (;;) {
+-              if (altera_pcie_link_is_up(pcie))
+-                      break;
+-
+-              if (time_after(jiffies, start_jiffies + LINK_UP_TIMEOUT)) {
+-                      dev_err(&pcie->pdev->dev, "link up timeout\n");
+-                      break;
+-              }
+-              udelay(100);
+-      }
+-}
+-
+-static void altera_pcie_retrain(struct pci_dev *dev)
+-{
+-      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
+-       * current speed is 2.5 GB/s.
+-       */
+-      pcie_capability_read_word(dev, PCI_EXP_LNKCAP, &linkcap);
+-
+-      if ((linkcap & PCI_EXP_LNKCAP_SLS) <= PCI_EXP_LNKCAP_SLS_2_5GB)
+-              return;
+-
+-      pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &linkstat);
+-      if ((linkstat & PCI_EXP_LNKSTA_CLS) == PCI_EXP_LNKSTA_CLS_2_5GB) {
+-              pcie_capability_set_word(dev, PCI_EXP_LNKCTL,
+-                                       PCI_EXP_LNKCTL_RL);
+-              altera_wait_link_retrain(dev);
+-      }
+-}
+-DECLARE_PCI_FIXUP_EARLY(0x1172, PCI_ANY_ID, altera_pcie_retrain);
+-
+ /*
+  * Altera PCIe port uses BAR0 of RC's configuration space as the translation
+  * from PCI bus to native BUS.  Entire DDR region is mapped into PCIe space
+@@ -434,6 +375,90 @@ static struct pci_ops altera_pcie_ops =
+       .write = altera_pcie_cfg_write,
+ };
++static int altera_read_cap_word(struct altera_pcie *pcie, u8 busno,
++                              unsigned int devfn, int offset, u16 *value)
++{
++      u32 data;
++      int ret;
++
++      ret = _altera_pcie_cfg_read(pcie, busno, devfn,
++                                  PCIE_CAP_OFFSET + offset, sizeof(*value),
++                                  &data);
++      *value = data;
++      return ret;
++}
++
++static int altera_write_cap_word(struct altera_pcie *pcie, u8 busno,
++                               unsigned int devfn, int offset, u16 value)
++{
++      return _altera_pcie_cfg_write(pcie, busno, devfn,
++                                    PCIE_CAP_OFFSET + offset, sizeof(value),
++                                    value);
++}
++
++static void altera_wait_link_retrain(struct altera_pcie *pcie)
++{
++      u16 reg16;
++      unsigned long start_jiffies;
++
++      /* Wait for link training end. */
++      start_jiffies = jiffies;
++      for (;;) {
++              altera_read_cap_word(pcie, pcie->root_bus_nr, RP_DEVFN,
++                                   PCI_EXP_LNKSTA, &reg16);
++              if (!(reg16 & PCI_EXP_LNKSTA_LT))
++                      break;
++
++              if (time_after(jiffies, start_jiffies + LINK_RETRAIN_TIMEOUT)) {
++                      dev_err(&pcie->pdev->dev, "link retrain timeout\n");
++                      break;
++              }
++              udelay(100);
++      }
++
++      /* Wait for link is up */
++      start_jiffies = jiffies;
++      for (;;) {
++              if (altera_pcie_link_is_up(pcie))
++                      break;
++
++              if (time_after(jiffies, start_jiffies + LINK_UP_TIMEOUT)) {
++                      dev_err(&pcie->pdev->dev, "link up timeout\n");
++                      break;
++              }
++              udelay(100);
++      }
++}
++
++static void altera_pcie_retrain(struct altera_pcie *pcie)
++{
++      u16 linkcap, linkstat, linkctl;
++
++      if (!altera_pcie_link_is_up(pcie))
++              return;
++
++      /*
++       * Set the retrain bit if the PCIe rootport support > 2.5GB/s, but
++       * current speed is 2.5 GB/s.
++       */
++      altera_read_cap_word(pcie, pcie->root_bus_nr, RP_DEVFN, PCI_EXP_LNKCAP,
++                           &linkcap);
++      if ((linkcap & PCI_EXP_LNKCAP_SLS) <= PCI_EXP_LNKCAP_SLS_2_5GB)
++              return;
++
++      altera_read_cap_word(pcie, pcie->root_bus_nr, RP_DEVFN, PCI_EXP_LNKSTA,
++                           &linkstat);
++      if ((linkstat & PCI_EXP_LNKSTA_CLS) == PCI_EXP_LNKSTA_CLS_2_5GB) {
++              altera_read_cap_word(pcie, pcie->root_bus_nr, RP_DEVFN,
++                                   PCI_EXP_LNKCTL, &linkctl);
++              linkctl |= PCI_EXP_LNKCTL_RL;
++              altera_write_cap_word(pcie, pcie->root_bus_nr, RP_DEVFN,
++                                    PCI_EXP_LNKCTL, linkctl);
++
++              altera_wait_link_retrain(pcie);
++      }
++}
++
+ static int altera_pcie_intx_map(struct irq_domain *domain, unsigned int irq,
+                               irq_hw_number_t hwirq)
+ {
+@@ -568,6 +593,11 @@ static int altera_pcie_parse_dt(struct a
+       return 0;
+ }
++static void altera_pcie_host_init(struct altera_pcie *pcie)
++{
++      altera_pcie_retrain(pcie);
++}
++
+ static int altera_pcie_probe(struct platform_device *pdev)
+ {
+       struct altera_pcie *pcie;
+@@ -605,6 +635,7 @@ static int altera_pcie_probe(struct plat
+       cra_writel(pcie, P2A_INT_STS_ALL, P2A_INT_STATUS);
+       /* enable all interrupts */
+       cra_writel(pcie, P2A_INT_ENA_ALL, P2A_INT_ENABLE);
++      altera_pcie_host_init(pcie);
+       bus = pci_scan_root_bus(&pdev->dev, pcie->root_bus_nr, &altera_pcie_ops,
+                               pcie, &pcie->resources);
diff --git a/queue-4.4/pci-altera-poll-for-link-training-status-after-retraining-the-link.patch b/queue-4.4/pci-altera-poll-for-link-training-status-after-retraining-the-link.patch
new file mode 100644 (file)
index 0000000..3946c71
--- /dev/null
@@ -0,0 +1,94 @@
+From 411dc32d8810e0a204c799ce5c97cb56990de1cb Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Mon, 15 Aug 2016 14:06:02 +0800
+Subject: PCI: altera: Poll for link training status after retraining the link
+
+From: Ley Foon Tan <lftan@altera.com>
+
+commit 411dc32d8810e0a204c799ce5c97cb56990de1cb upstream.
+
+Poll for link training status is cleared before poll for link up status.
+This can help to get the reliable link up status, especially when PCIe is
+in Gen 3 speed.
+
+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>
+
+---
+ drivers/pci/host/pcie-altera.c |   45 +++++++++++++++++++++++++++++++++--------
+ 1 file changed, 37 insertions(+), 8 deletions(-)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -61,7 +61,8 @@
+ #define TLP_LOOP                      500
+ #define RP_DEVFN                      0
+-#define LINK_UP_TIMEOUT                       5000
++#define LINK_UP_TIMEOUT                       HZ
++#define LINK_RETRAIN_TIMEOUT          HZ
+ #define INTX_NUM                      4
+@@ -99,11 +100,44 @@ static bool altera_pcie_link_is_up(struc
+       return !!((cra_readl(pcie, RP_LTSSM) & RP_LTSSM_MASK) == LTSSM_L0);
+ }
++static void altera_wait_link_retrain(struct pci_dev *dev)
++{
++      u16 reg16;
++      unsigned long start_jiffies;
++      struct altera_pcie *pcie = dev->bus->sysdata;
++
++      /* Wait for link training end. */
++      start_jiffies = jiffies;
++      for (;;) {
++              pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &reg16);
++              if (!(reg16 & PCI_EXP_LNKSTA_LT))
++                      break;
++
++              if (time_after(jiffies, start_jiffies + LINK_RETRAIN_TIMEOUT)) {
++                      dev_err(&pcie->pdev->dev, "link retrain timeout\n");
++                      break;
++              }
++              udelay(100);
++      }
++
++      /* Wait for link is up */
++      start_jiffies = jiffies;
++      for (;;) {
++              if (altera_pcie_link_is_up(pcie))
++                      break;
++
++              if (time_after(jiffies, start_jiffies + LINK_UP_TIMEOUT)) {
++                      dev_err(&pcie->pdev->dev, "link up timeout\n");
++                      break;
++              }
++              udelay(100);
++      }
++}
++
+ static void altera_pcie_retrain(struct pci_dev *dev)
+ {
+       u16 linkcap, linkstat;
+       struct altera_pcie *pcie = dev->bus->sysdata;
+-      int timeout =  0;
+       if (!altera_pcie_link_is_up(pcie))
+               return;
+@@ -121,12 +155,7 @@ static void altera_pcie_retrain(struct p
+       if ((linkstat & PCI_EXP_LNKSTA_CLS) == PCI_EXP_LNKSTA_CLS_2_5GB) {
+               pcie_capability_set_word(dev, PCI_EXP_LNKCTL,
+                                        PCI_EXP_LNKCTL_RL);
+-              while (!altera_pcie_link_is_up(pcie)) {
+-                      timeout++;
+-                      if (timeout > LINK_UP_TIMEOUT)
+-                              break;
+-                      udelay(5);
+-              }
++              altera_wait_link_retrain(dev);
+       }
+ }
+ DECLARE_PCI_FIXUP_EARLY(0x1172, PCI_ANY_ID, altera_pcie_retrain);
diff --git a/queue-4.4/pci-altera-poll-for-link-up-status-after-retraining-the-link.patch b/queue-4.4/pci-altera-poll-for-link-up-status-after-retraining-the-link.patch
new file mode 100644 (file)
index 0000000..d28598e
--- /dev/null
@@ -0,0 +1,60 @@
+From 3a928e98a833e1a470a60d2fedf3c55502185fb7 Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Tue, 21 Jun 2016 16:53:13 +0800
+Subject: PCI: altera: Poll for link up status after retraining the link
+
+From: Ley Foon Tan <lftan@altera.com>
+
+commit 3a928e98a833e1a470a60d2fedf3c55502185fb7 upstream.
+
+Some PCIe devices take a long time to reach link up state after retrain.
+Poll for link up status after retraining the link.  This is to make sure
+the link is up before we access configuration space.
+
+[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>
+
+---
+ drivers/pci/host/pcie-altera.c |   12 +++++++++++-
+ 1 file changed, 11 insertions(+), 1 deletion(-)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -61,6 +61,8 @@
+ #define TLP_LOOP                      500
+ #define RP_DEVFN                      0
++#define LINK_UP_TIMEOUT                       5000
++
+ #define INTX_NUM                      4
+ #define DWORD_MASK                    3
+@@ -101,6 +103,7 @@ static void altera_pcie_retrain(struct p
+ {
+       u16 linkcap, linkstat;
+       struct altera_pcie *pcie = dev->bus->sysdata;
++      int timeout =  0;
+       if (!altera_pcie_link_is_up(pcie))
+               return;
+@@ -115,9 +118,16 @@ static void altera_pcie_retrain(struct p
+               return;
+       pcie_capability_read_word(dev, PCI_EXP_LNKSTA, &linkstat);
+-      if ((linkstat & PCI_EXP_LNKSTA_CLS) == PCI_EXP_LNKSTA_CLS_2_5GB)
++      if ((linkstat & PCI_EXP_LNKSTA_CLS) == PCI_EXP_LNKSTA_CLS_2_5GB) {
+               pcie_capability_set_word(dev, PCI_EXP_LNKCTL,
+                                        PCI_EXP_LNKCTL_RL);
++              while (!altera_pcie_link_is_up(pcie)) {
++                      timeout++;
++                      if (timeout > LINK_UP_TIMEOUT)
++                              break;
++                      udelay(5);
++              }
++      }
+ }
+ DECLARE_PCI_FIXUP_EARLY(0x1172, PCI_ANY_ID, altera_pcie_retrain);
diff --git a/queue-4.4/pci-altera-reorder-read-write-functions.patch b/queue-4.4/pci-altera-reorder-read-write-functions.patch
new file mode 100644 (file)
index 0000000..a566119
--- /dev/null
@@ -0,0 +1,76 @@
+From f8be11ae3d2c9a1338da37ff91ff4c65922d21be Mon Sep 17 00:00:00 2001
+From: Bjorn Helgaas <bhelgaas@google.com>
+Date: Fri, 22 Jul 2016 15:54:41 -0500
+Subject: PCI: altera: Reorder read/write functions
+
+From: Bjorn Helgaas <bhelgaas@google.com>
+
+commit f8be11ae3d2c9a1338da37ff91ff4c65922d21be upstream.
+
+Move cra_writel(), cra_readl(), and altera_pcie_link_is_up() so a future
+patch can use them in altera_pcie_retrain().  No functional change
+intended.
+
+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>
+
+---
+ drivers/pci/host/pcie-altera.c |   32 ++++++++++++++++----------------
+ 1 file changed, 16 insertions(+), 16 deletions(-)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -81,6 +81,22 @@ struct tlp_rp_regpair_t {
+       u32 reg1;
+ };
++static inline void cra_writel(struct altera_pcie *pcie, const u32 value,
++                            const u32 reg)
++{
++      writel_relaxed(value, pcie->cra_base + reg);
++}
++
++static inline u32 cra_readl(struct altera_pcie *pcie, const u32 reg)
++{
++      return readl_relaxed(pcie->cra_base + reg);
++}
++
++static bool altera_pcie_link_is_up(struct altera_pcie *pcie)
++{
++      return !!((cra_readl(pcie, RP_LTSSM) & RP_LTSSM_MASK) == LTSSM_L0);
++}
++
+ static void altera_pcie_retrain(struct pci_dev *dev)
+ {
+       u16 linkcap, linkstat;
+@@ -120,17 +136,6 @@ static bool altera_pcie_hide_rc_bar(stru
+       return false;
+ }
+-static inline void cra_writel(struct altera_pcie *pcie, const u32 value,
+-                            const u32 reg)
+-{
+-      writel_relaxed(value, pcie->cra_base + reg);
+-}
+-
+-static inline u32 cra_readl(struct altera_pcie *pcie, const u32 reg)
+-{
+-      return readl_relaxed(pcie->cra_base + reg);
+-}
+-
+ static void tlp_write_tx(struct altera_pcie *pcie,
+                        struct tlp_rp_regpair_t *tlp_rp_regdata)
+ {
+@@ -139,11 +144,6 @@ static void tlp_write_tx(struct altera_p
+       cra_writel(pcie, tlp_rp_regdata->ctrl, RP_TX_CNTRL);
+ }
+-static bool altera_pcie_link_is_up(struct altera_pcie *pcie)
+-{
+-      return !!((cra_readl(pcie, RP_LTSSM) & RP_LTSSM_MASK) == LTSSM_L0);
+-}
+-
+ static bool altera_pcie_valid_config(struct altera_pcie *pcie,
+                                    struct pci_bus *bus, int dev)
+ {
diff --git a/queue-4.4/pci-altera-rework-config-accessors-for-use-without-a-struct-pci_bus.patch b/queue-4.4/pci-altera-rework-config-accessors-for-use-without-a-struct-pci_bus.patch
new file mode 100644 (file)
index 0000000..9c6844c
--- /dev/null
@@ -0,0 +1,125 @@
+From 31fc0ad47e2e0b8417616aa0f1ddcc67edf1e109 Mon Sep 17 00:00:00 2001
+From: Ley Foon Tan <lftan@altera.com>
+Date: Fri, 26 Aug 2016 09:47:24 +0800
+Subject: PCI: altera: Rework config accessors for use without a struct pci_bus
+
+From: Ley Foon Tan <lftan@altera.com>
+
+commit 31fc0ad47e2e0b8417616aa0f1ddcc67edf1e109 upstream.
+
+Rework configs accessors so a future patch can use them in _probe() with
+struct altera_pcie instead of struct pci_bus.
+
+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>
+
+---
+ drivers/pci/host/pcie-altera.c |   64 ++++++++++++++++++++++++++---------------
+ 1 file changed, 41 insertions(+), 23 deletions(-)
+
+--- a/drivers/pci/host/pcie-altera.c
++++ b/drivers/pci/host/pcie-altera.c
+@@ -330,22 +330,14 @@ static int tlp_cfg_dword_write(struct al
+       return PCIBIOS_SUCCESSFUL;
+ }
+-static int altera_pcie_cfg_read(struct pci_bus *bus, unsigned int devfn,
+-                              int where, int size, u32 *value)
++static int _altera_pcie_cfg_read(struct altera_pcie *pcie, u8 busno,
++                               unsigned int devfn, int where, int size,
++                               u32 *value)
+ {
+-      struct altera_pcie *pcie = bus->sysdata;
+       int ret;
+       u32 data;
+       u8 byte_en;
+-      if (altera_pcie_hide_rc_bar(bus, devfn, where))
+-              return PCIBIOS_BAD_REGISTER_NUMBER;
+-
+-      if (!altera_pcie_valid_config(pcie, bus, PCI_SLOT(devfn))) {
+-              *value = 0xffffffff;
+-              return PCIBIOS_DEVICE_NOT_FOUND;
+-      }
+-
+       switch (size) {
+       case 1:
+               byte_en = 1 << (where & 3);
+@@ -358,7 +350,7 @@ static int altera_pcie_cfg_read(struct p
+               break;
+       }
+-      ret = tlp_cfg_dword_read(pcie, bus->number, devfn,
++      ret = tlp_cfg_dword_read(pcie, busno, devfn,
+                                (where & ~DWORD_MASK), byte_en, &data);
+       if (ret != PCIBIOS_SUCCESSFUL)
+               return ret;
+@@ -378,20 +370,14 @@ static int altera_pcie_cfg_read(struct p
+       return PCIBIOS_SUCCESSFUL;
+ }
+-static int altera_pcie_cfg_write(struct pci_bus *bus, unsigned int devfn,
+-                               int where, int size, u32 value)
++static int _altera_pcie_cfg_write(struct altera_pcie *pcie, u8 busno,
++                                unsigned int devfn, int where, int size,
++                                u32 value)
+ {
+-      struct altera_pcie *pcie = bus->sysdata;
+       u32 data32;
+       u32 shift = 8 * (where & 3);
+       u8 byte_en;
+-      if (altera_pcie_hide_rc_bar(bus, devfn, where))
+-              return PCIBIOS_BAD_REGISTER_NUMBER;
+-
+-      if (!altera_pcie_valid_config(pcie, bus, PCI_SLOT(devfn)))
+-              return PCIBIOS_DEVICE_NOT_FOUND;
+-
+       switch (size) {
+       case 1:
+               data32 = (value & 0xff) << shift;
+@@ -407,8 +393,40 @@ static int altera_pcie_cfg_write(struct
+               break;
+       }
+-      return tlp_cfg_dword_write(pcie, bus->number, devfn,
+-              (where & ~DWORD_MASK), byte_en, data32);
++      return tlp_cfg_dword_write(pcie, busno, devfn, (where & ~DWORD_MASK),
++                                 byte_en, data32);
++}
++
++static int altera_pcie_cfg_read(struct pci_bus *bus, unsigned int devfn,
++                              int where, int size, u32 *value)
++{
++      struct altera_pcie *pcie = bus->sysdata;
++
++      if (altera_pcie_hide_rc_bar(bus, devfn, where))
++              return PCIBIOS_BAD_REGISTER_NUMBER;
++
++      if (!altera_pcie_valid_config(pcie, bus, PCI_SLOT(devfn))) {
++              *value = 0xffffffff;
++              return PCIBIOS_DEVICE_NOT_FOUND;
++      }
++
++      return _altera_pcie_cfg_read(pcie, bus->number, devfn, where, size,
++                                   value);
++}
++
++static int altera_pcie_cfg_write(struct pci_bus *bus, unsigned int devfn,
++                               int where, int size, u32 value)
++{
++      struct altera_pcie *pcie = bus->sysdata;
++
++      if (altera_pcie_hide_rc_bar(bus, devfn, where))
++              return PCIBIOS_BAD_REGISTER_NUMBER;
++
++      if (!altera_pcie_valid_config(pcie, bus, PCI_SLOT(devfn)))
++              return PCIBIOS_DEVICE_NOT_FOUND;
++
++      return _altera_pcie_cfg_write(pcie, bus->number, devfn, where, size,
++                                   value);
+ }
+ static struct pci_ops altera_pcie_ops = {
index f11d38a131a47aee849ae17d2919f12ec99d97d2..01e45f423230b1ddbdaaa37d836b073d8918944d 100644 (file)
@@ -37,3 +37,10 @@ usb-storage-don-t-insert-sane-sense-for-spc3-when-bad-sense-specified.patch
 usb-storage-add-quirk-for-smi-sm3350.patch
 usb-add-usb_quirk_delay_ctrl_msg-quirk-for-corsair-k70-rgb.patch
 slab-alien-caches-must-not-be-initialized-if-the-allocation-of-the-alien-cache-failed.patch
+pci-altera-fix-altera_pcie_link_is_up.patch
+pci-altera-reorder-read-write-functions.patch
+pci-altera-check-link-status-before-retrain-link.patch
+pci-altera-poll-for-link-up-status-after-retraining-the-link.patch
+pci-altera-poll-for-link-training-status-after-retraining-the-link.patch
+pci-altera-rework-config-accessors-for-use-without-a-struct-pci_bus.patch
+pci-altera-move-retrain-from-fixup-to-altera_pcie_host_init.patch