mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-25 21:59:32 +00:00
36a96a4493
In current state there's huge regression on ipq806x target that causes the device to transmit broken/malformed frames that are not corrected/detected by error control mechanisms and other less severe issues. https://bugs.lede-project.org/index.php?do=details&task_id=1197 This finally had been narrowed down to patch 0071-pcie-qcom-fixes.patch Meanwhile QSDK contains a handful of commits that add support for ipq806x to upstream qcom pcie driver https://source.codeaurora.org/quic/qsdk/oss/kernel/linux-msm/log/drivers/pci/host/pcie-qcom.c?h=eggplant Unfortunately qca developers do not bother to push it upstream. Using those commits instead of lede 0071 patch fixes mentioned issue and probably many others as it seems that corrupted data has been originating within pcie misconfiguration. Fixes: FS#1197 and probably others Signed-off-by: Pavel Kubelun <be.dissent@gmail.com>
70 lines
2.0 KiB
Diff
70 lines
2.0 KiB
Diff
From edff8f777c6321ca89bb950a382f409c4a126e28 Mon Sep 17 00:00:00 2001
|
|
From: Gokul Sriram Palanisamy <gpalan@codeaurora.org>
|
|
Date: Thu, 15 Dec 2016 17:38:18 +0530
|
|
Subject: pcie: Set PCIE MRRS and MPS to 256B
|
|
|
|
Set Max Read Request Size and Max Payload Size to 256 bytes,
|
|
per chip team recommendation.
|
|
|
|
Change-Id: I097004be2ced1b3096ffc10c318aae0b2bb155e8
|
|
Signed-off-by: Gokul Sriram Palanisamy <gpalan@codeaurora.org>
|
|
---
|
|
drivers/pci/host/pcie-qcom.c | 37 +++++++++++++++++++++++++++++++++++++
|
|
1 file changed, 37 insertions(+)
|
|
|
|
(limited to 'drivers/pci/host/pcie-qcom.c')
|
|
|
|
--- a/drivers/pci/host/pcie-qcom.c
|
|
+++ b/drivers/pci/host/pcie-qcom.c
|
|
@@ -92,6 +92,14 @@
|
|
|
|
#define PCIE20_LNK_CONTROL2_LINK_STATUS2 0xA0
|
|
|
|
+#define __set(v, a, b) (((v) << (b)) & GENMASK(a, b))
|
|
+#define __mask(a, b) (((1 << ((a) + 1)) - 1) & ~((1 << (b)) - 1))
|
|
+#define PCIE20_DEV_CAS 0x78
|
|
+#define PCIE20_MRRS_MASK __mask(14, 12)
|
|
+#define PCIE20_MRRS(x) __set(x, 14, 12)
|
|
+#define PCIE20_MPS_MASK __mask(7, 5)
|
|
+#define PCIE20_MPS(x) __set(x, 7, 5)
|
|
+
|
|
struct qcom_pcie_resources_v0 {
|
|
struct clk *iface_clk;
|
|
struct clk *core_clk;
|
|
@@ -745,6 +753,35 @@ static int qcom_pcie_probe(struct platfo
|
|
return 0;
|
|
}
|
|
|
|
+static void qcom_pcie_fixup_final(struct pci_dev *dev)
|
|
+{
|
|
+ int cap, err;
|
|
+ u16 ctl, reg_val;
|
|
+
|
|
+ cap = pci_pcie_cap(dev);
|
|
+ if (!cap)
|
|
+ return;
|
|
+
|
|
+ err = pci_read_config_word(dev, cap + PCI_EXP_DEVCTL, &ctl);
|
|
+
|
|
+ if (err)
|
|
+ return;
|
|
+
|
|
+ reg_val = ctl;
|
|
+
|
|
+ if (((reg_val & PCIE20_MRRS_MASK) >> 12) > 1)
|
|
+ reg_val = (reg_val & ~(PCIE20_MRRS_MASK)) | PCIE20_MRRS(0x1);
|
|
+
|
|
+ if (((ctl & PCIE20_MPS_MASK) >> 5) > 1)
|
|
+ reg_val = (reg_val & ~(PCIE20_MPS_MASK)) | PCIE20_MPS(0x1);
|
|
+
|
|
+ err = pci_write_config_word(dev, cap + PCI_EXP_DEVCTL, reg_val);
|
|
+
|
|
+ if (err)
|
|
+ pr_err("pcie config write failed %d\n", err);
|
|
+}
|
|
+DECLARE_PCI_FIXUP_FINAL(PCI_ANY_ID, PCI_ANY_ID, qcom_pcie_fixup_final);
|
|
+
|
|
static const struct of_device_id qcom_pcie_match[] = {
|
|
{ .compatible = "qcom,pcie-ipq8064", .data = &ops_v0 },
|
|
{ .compatible = "qcom,pcie-apq8064", .data = &ops_v0 },
|