PCI: cadence: Allow PTM Responder to be enabled
authorChristian Gmeiner <christian.gmeiner@gmail.com>
Thu, 12 May 2022 05:55:38 +0000 (07:55 +0200)
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Thu, 12 May 2022 21:03:05 +0000 (22:03 +0100)
This enables the Controller [RP] to automatically respond with
Response/ResponseD messages if CDNS_PCIE_LM_TPM_CTRL_PTMRSEN
and PCI_PTM_CTRL_ENABLE bits are both set.

Link: https://lore.kernel.org/r/20220512055539.1782437-1-christian.gmeiner@gmail.com
Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com>
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
drivers/pci/controller/cadence/pcie-cadence-host.c
drivers/pci/controller/cadence/pcie-cadence.h

index fb96d37..940c7dd 100644 (file)
@@ -123,6 +123,14 @@ static int cdns_pcie_retrain(struct cdns_pcie *pcie)
        return ret;
 }
 
+static void cdns_pcie_host_enable_ptm_response(struct cdns_pcie *pcie)
+{
+       u32 val;
+
+       val = cdns_pcie_readl(pcie, CDNS_PCIE_LM_PTM_CTRL);
+       cdns_pcie_writel(pcie, CDNS_PCIE_LM_PTM_CTRL, val | CDNS_PCIE_LM_TPM_CTRL_PTMRSEN);
+}
+
 static int cdns_pcie_host_start_link(struct cdns_pcie_rc *rc)
 {
        struct cdns_pcie *pcie = &rc->pcie;
@@ -501,6 +509,8 @@ int cdns_pcie_host_setup(struct cdns_pcie_rc *rc)
        if (rc->quirk_detect_quiet_flag)
                cdns_pcie_detect_quiet_min_delay_set(&rc->pcie);
 
+       cdns_pcie_host_enable_ptm_response(pcie);
+
        ret = cdns_pcie_start_link(pcie);
        if (ret) {
                dev_err(dev, "Failed to start link\n");
index c8a27b6..1ffa8fa 100644 (file)
 #define LM_RC_BAR_CFG_APERTURE(bar, aperture)          \
                                        (((aperture) - 2) << ((bar) * 8))
 
+/* PTM Control Register */
+#define CDNS_PCIE_LM_PTM_CTRL  (CDNS_PCIE_LM_BASE + 0x0da8)
+#define CDNS_PCIE_LM_TPM_CTRL_PTMRSEN  BIT(17)
+
 /*
  * Endpoint Function Registers (PCI configuration space for endpoint functions)
  */