ipq806x: rework L2 cache patch
[openwrt/openwrt.git] / target / linux / ipq806x / patches-5.4 / 0071-3-PCI-qcom-Fixed-IPQ806x-PCIE-init-changes.patch
1 From eddd13215d0f2b549ebc5f0e8796d5b1231f90a0 Mon Sep 17 00:00:00 2001
2 From: Sham Muthayyan <smuthayy@codeaurora.org>
3 Date: Tue, 19 Jul 2016 19:58:22 +0530
4 Subject: PCI: qcom: Fixed IPQ806x PCIE init changes
5
6 Change-Id: Ic319b1aec27a47809284759f8fcb6a8815b7cf7e
7 Signed-off-by: Sham Muthayyan <smuthayy@codeaurora.org>
8 ---
9
10 --- a/drivers/pci/controller/dwc/pcie-qcom.c
11 +++ b/drivers/pci/controller/dwc/pcie-qcom.c
12 @@ -45,7 +45,13 @@
13 #define PCIE_CAP_CPL_TIMEOUT_DISABLE 0x10
14
15 #define PCIE20_PARF_PHY_CTRL 0x40
16 +#define PHY_CTRL_PHY_TX0_TERM_OFFSET_MASK (0x1f << 16)
17 +#define PHY_CTRL_PHY_TX0_TERM_OFFSET(x) (x << 16)
18 +
19 #define PCIE20_PARF_PHY_REFCLK 0x4C
20 +#define REF_SSP_EN BIT(16)
21 +#define REF_USE_PAD BIT(12)
22 +
23 #define PCIE20_PARF_DBI_BASE_ADDR 0x168
24 #define PCIE20_PARF_SLV_ADDR_SPACE_SIZE 0x16C
25 #define PCIE20_PARF_MHI_CLOCK_RESET_CTRL 0x174
26 @@ -76,6 +82,18 @@
27 #define DBI_RO_WR_EN 1
28
29 #define PERST_DELAY_US 1000
30 +/* PARF registers */
31 +#define PCIE20_PARF_PCS_DEEMPH 0x34
32 +#define PCS_DEEMPH_TX_DEEMPH_GEN1(x) (x << 16)
33 +#define PCS_DEEMPH_TX_DEEMPH_GEN2_3_5DB(x) (x << 8)
34 +#define PCS_DEEMPH_TX_DEEMPH_GEN2_6DB(x) (x << 0)
35 +
36 +#define PCIE20_PARF_PCS_SWING 0x38
37 +#define PCS_SWING_TX_SWING_FULL(x) (x << 8)
38 +#define PCS_SWING_TX_SWING_LOW(x) (x << 0)
39 +
40 +#define PCIE20_PARF_CONFIG_BITS 0x50
41 +#define PHY_RX0_EQ(x) (x << 24)
42
43 #define PCIE20_v3_PARF_SLV_ADDR_SPACE_SIZE 0x358
44 #define SLV_ADDR_SPACE_SZ 0x10000000
45 @@ -94,6 +112,7 @@ struct qcom_pcie_resources_2_1_0 {
46 struct reset_control *phy_reset;
47 struct reset_control *ext_reset;
48 struct regulator_bulk_data supplies[QCOM_PCIE_2_1_0_MAX_SUPPLY];
49 + uint8_t phy_tx0_term_offset;
50 };
51
52 struct qcom_pcie_resources_1_0_0 {
53 @@ -173,6 +192,16 @@ struct qcom_pcie {
54
55 #define to_qcom_pcie(x) dev_get_drvdata((x)->dev)
56
57 +static inline void
58 +writel_masked(void __iomem *addr, u32 clear_mask, u32 set_mask)
59 +{
60 + u32 val = readl(addr);
61 +
62 + val &= ~clear_mask;
63 + val |= set_mask;
64 + writel(val, addr);
65 +}
66 +
67 static void qcom_ep_reset_assert(struct qcom_pcie *pcie)
68 {
69 gpiod_set_value_cansleep(pcie->reset, 1);
70 @@ -266,6 +295,10 @@ static int qcom_pcie_get_resources_2_1_0
71 if (IS_ERR(res->ext_reset))
72 return PTR_ERR(res->ext_reset);
73
74 + if (of_property_read_u8(dev->of_node, "phy-tx0-term-offset",
75 + &res->phy_tx0_term_offset))
76 + res->phy_tx0_term_offset = 0;
77 +
78 res->phy_reset = devm_reset_control_get_exclusive(dev, "phy");
79 return PTR_ERR_OR_ZERO(res->phy_reset);
80 }
81 @@ -293,7 +326,6 @@ static int qcom_pcie_init_2_1_0(struct q
82 struct qcom_pcie_resources_2_1_0 *res = &pcie->res.v2_1_0;
83 struct dw_pcie *pci = pcie->pci;
84 struct device *dev = pci->dev;
85 - u32 val;
86 int ret;
87
88 ret = reset_control_assert(res->ahb_reset);
89 @@ -350,15 +382,26 @@ static int qcom_pcie_init_2_1_0(struct q
90 goto err_deassert_ahb;
91 }
92
93 - /* enable PCIe clocks and resets */
94 - val = readl(pcie->parf + PCIE20_PARF_PHY_CTRL);
95 - val &= ~BIT(0);
96 - writel(val, pcie->parf + PCIE20_PARF_PHY_CTRL);
97 -
98 - /* enable external reference clock */
99 - val = readl(pcie->parf + PCIE20_PARF_PHY_REFCLK);
100 - val |= BIT(16);
101 - writel(val, pcie->parf + PCIE20_PARF_PHY_REFCLK);
102 + writel_masked(pcie->parf + PCIE20_PARF_PHY_CTRL, BIT(0), 0);
103 +
104 + /* Set Tx termination offset */
105 + writel_masked(pcie->parf + PCIE20_PARF_PHY_CTRL,
106 + PHY_CTRL_PHY_TX0_TERM_OFFSET_MASK,
107 + PHY_CTRL_PHY_TX0_TERM_OFFSET(res->phy_tx0_term_offset));
108 +
109 + /* PARF programming */
110 + writel(PCS_DEEMPH_TX_DEEMPH_GEN1(0x18) |
111 + PCS_DEEMPH_TX_DEEMPH_GEN2_3_5DB(0x18) |
112 + PCS_DEEMPH_TX_DEEMPH_GEN2_6DB(0x22),
113 + pcie->parf + PCIE20_PARF_PCS_DEEMPH);
114 + writel(PCS_SWING_TX_SWING_FULL(0x78) |
115 + PCS_SWING_TX_SWING_LOW(0x78),
116 + pcie->parf + PCIE20_PARF_PCS_SWING);
117 + writel(PHY_RX0_EQ(0x4), pcie->parf + PCIE20_PARF_CONFIG_BITS);
118 +
119 + /* Enable reference clock */
120 + writel_masked(pcie->parf + PCIE20_PARF_PHY_REFCLK,
121 + REF_USE_PAD, REF_SSP_EN);
122
123 ret = reset_control_deassert(res->phy_reset);
124 if (ret) {