pcie-qcom-ep.c 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Qualcomm PCIe Endpoint controller driver
  4. *
  5. * Copyright (c) 2020, The Linux Foundation. All rights reserved.
  6. * Author: Siddartha Mohanadoss <smohanad@codeaurora.org
  7. *
  8. * Copyright (c) 2021, Linaro Ltd.
  9. * Author: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org
  10. */
  11. #include <linux/clk.h>
  12. #include <linux/debugfs.h>
  13. #include <linux/delay.h>
  14. #include <linux/gpio/consumer.h>
  15. #include <linux/interconnect.h>
  16. #include <linux/mfd/syscon.h>
  17. #include <linux/phy/pcie.h>
  18. #include <linux/phy/phy.h>
  19. #include <linux/platform_device.h>
  20. #include <linux/pm_domain.h>
  21. #include <linux/regmap.h>
  22. #include <linux/reset.h>
  23. #include <linux/module.h>
  24. #include "../../pci.h"
  25. #include "pcie-designware.h"
  26. #include "pcie-qcom-common.h"
  27. /* PARF registers */
  28. #define PARF_SYS_CTRL 0x00
  29. #define PARF_DB_CTRL 0x10
  30. #define PARF_PM_CTRL 0x20
  31. #define PARF_MHI_CLOCK_RESET_CTRL 0x174
  32. #define PARF_MHI_BASE_ADDR_LOWER 0x178
  33. #define PARF_MHI_BASE_ADDR_UPPER 0x17c
  34. #define PARF_DEBUG_INT_EN 0x190
  35. #define PARF_AXI_MSTR_RD_HALT_NO_WRITES 0x1a4
  36. #define PARF_AXI_MSTR_WR_ADDR_HALT 0x1a8
  37. #define PARF_Q2A_FLUSH 0x1ac
  38. #define PARF_LTSSM 0x1b0
  39. #define PARF_CFG_BITS 0x210
  40. #define PARF_INT_ALL_STATUS 0x224
  41. #define PARF_INT_ALL_CLEAR 0x228
  42. #define PARF_INT_ALL_MASK 0x22c
  43. #define PARF_SLV_ADDR_MSB_CTRL 0x2c0
  44. #define PARF_DBI_BASE_ADDR 0x350
  45. #define PARF_DBI_BASE_ADDR_HI 0x354
  46. #define PARF_SLV_ADDR_SPACE_SIZE 0x358
  47. #define PARF_SLV_ADDR_SPACE_SIZE_HI 0x35c
  48. #define PARF_NO_SNOOP_OVERRIDE 0x3d4
  49. #define PARF_ATU_BASE_ADDR 0x634
  50. #define PARF_ATU_BASE_ADDR_HI 0x638
  51. #define PARF_SRIS_MODE 0x644
  52. #define PARF_DEBUG_CNT_PM_LINKST_IN_L2 0xc04
  53. #define PARF_DEBUG_CNT_PM_LINKST_IN_L1 0xc0c
  54. #define PARF_DEBUG_CNT_PM_LINKST_IN_L0S 0xc10
  55. #define PARF_DEBUG_CNT_AUX_CLK_IN_L1SUB_L1 0xc84
  56. #define PARF_DEBUG_CNT_AUX_CLK_IN_L1SUB_L2 0xc88
  57. #define PARF_DEVICE_TYPE 0x1000
  58. #define PARF_BDF_TO_SID_CFG 0x2c00
  59. #define PARF_INT_ALL_5_MASK 0x2dcc
  60. #define PARF_INT_ALL_3_MASK 0x2e18
  61. /* PARF_INT_ALL_{STATUS/CLEAR/MASK} register fields */
  62. #define PARF_INT_ALL_LINK_DOWN BIT(1)
  63. #define PARF_INT_ALL_BME BIT(2)
  64. #define PARF_INT_ALL_PM_TURNOFF BIT(3)
  65. #define PARF_INT_ALL_DEBUG BIT(4)
  66. #define PARF_INT_ALL_LTR BIT(5)
  67. #define PARF_INT_ALL_MHI_Q6 BIT(6)
  68. #define PARF_INT_ALL_MHI_A7 BIT(7)
  69. #define PARF_INT_ALL_DSTATE_CHANGE BIT(8)
  70. #define PARF_INT_ALL_L1SUB_TIMEOUT BIT(9)
  71. #define PARF_INT_ALL_MMIO_WRITE BIT(10)
  72. #define PARF_INT_ALL_CFG_WRITE BIT(11)
  73. #define PARF_INT_ALL_BRIDGE_FLUSH_N BIT(12)
  74. #define PARF_INT_ALL_LINK_UP BIT(13)
  75. #define PARF_INT_ALL_AER_LEGACY BIT(14)
  76. #define PARF_INT_ALL_PLS_ERR BIT(15)
  77. #define PARF_INT_ALL_PME_LEGACY BIT(16)
  78. #define PARF_INT_ALL_PLS_PME BIT(17)
  79. #define PARF_INT_ALL_EDMA BIT(22)
  80. /* PARF_BDF_TO_SID_CFG register fields */
  81. #define PARF_BDF_TO_SID_BYPASS BIT(0)
  82. /* PARF_DEBUG_INT_EN register fields */
  83. #define PARF_DEBUG_INT_PM_DSTATE_CHANGE BIT(1)
  84. #define PARF_DEBUG_INT_CFG_BUS_MASTER_EN BIT(2)
  85. #define PARF_DEBUG_INT_RADM_PM_TURNOFF BIT(3)
  86. /* PARF_NO_SNOOP_OVERRIDE register fields */
  87. #define WR_NO_SNOOP_OVERRIDE_EN BIT(1)
  88. #define RD_NO_SNOOP_OVERRIDE_EN BIT(3)
  89. /* PARF_DEVICE_TYPE register fields */
  90. #define PARF_DEVICE_TYPE_EP 0x0
  91. /* PARF_PM_CTRL register fields */
  92. #define PARF_PM_CTRL_REQ_EXIT_L1 BIT(1)
  93. #define PARF_PM_CTRL_READY_ENTR_L23 BIT(2)
  94. #define PARF_PM_CTRL_REQ_NOT_ENTR_L1 BIT(5)
  95. /* PARF_MHI_CLOCK_RESET_CTRL fields */
  96. #define PARF_MSTR_AXI_CLK_EN BIT(1)
  97. /* PARF_AXI_MSTR_RD_HALT_NO_WRITES register fields */
  98. #define PARF_AXI_MSTR_RD_HALT_NO_WRITE_EN BIT(0)
  99. /* PARF_AXI_MSTR_WR_ADDR_HALT register fields */
  100. #define PARF_AXI_MSTR_WR_ADDR_HALT_EN BIT(31)
  101. /* PARF_Q2A_FLUSH register fields */
  102. #define PARF_Q2A_FLUSH_EN BIT(16)
  103. /* PARF_SYS_CTRL register fields */
  104. #define PARF_SYS_CTRL_AUX_PWR_DET BIT(4)
  105. #define PARF_SYS_CTRL_CORE_CLK_CGC_DIS BIT(6)
  106. #define PARF_SYS_CTRL_MSTR_ACLK_CGC_DIS BIT(10)
  107. #define PARF_SYS_CTRL_SLV_DBI_WAKE_DISABLE BIT(11)
  108. /* PARF_DB_CTRL register fields */
  109. #define PARF_DB_CTRL_INSR_DBNCR_BLOCK BIT(0)
  110. #define PARF_DB_CTRL_RMVL_DBNCR_BLOCK BIT(1)
  111. #define PARF_DB_CTRL_DBI_WKP_BLOCK BIT(4)
  112. #define PARF_DB_CTRL_SLV_WKP_BLOCK BIT(5)
  113. #define PARF_DB_CTRL_MST_WKP_BLOCK BIT(6)
  114. /* PARF_CFG_BITS register fields */
  115. #define PARF_CFG_BITS_REQ_EXIT_L1SS_MSI_LTR_EN BIT(1)
  116. /* PARF_INT_ALL_5_MASK fields */
  117. #define PARF_INT_ALL_5_MHI_RAM_DATA_PARITY_ERR BIT(0)
  118. /* PARF_INT_ALL_3_MASK fields */
  119. #define PARF_INT_ALL_3_PTM_UPDATING BIT(4)
  120. /* ELBI registers */
  121. #define ELBI_SYS_STTS 0x08
  122. #define ELBI_CS2_ENABLE 0xa4
  123. /* DBI registers */
  124. #define DBI_CON_STATUS 0x44
  125. /* DBI register fields */
  126. #define DBI_CON_STATUS_POWER_STATE_MASK GENMASK(1, 0)
  127. #define XMLH_LINK_UP 0x400
  128. #define CORE_RESET_TIME_US_MIN 1000
  129. #define CORE_RESET_TIME_US_MAX 1005
  130. #define WAKE_DELAY_US 2000 /* 2 ms */
  131. #define QCOM_PCIE_LINK_SPEED_TO_BW(speed) \
  132. Mbps_to_icc(PCIE_SPEED2MBS_ENC(pcie_link_speed[speed]))
  133. #define to_pcie_ep(x) dev_get_drvdata((x)->dev)
  134. enum qcom_pcie_ep_link_status {
  135. QCOM_PCIE_EP_LINK_DISABLED,
  136. QCOM_PCIE_EP_LINK_ENABLED,
  137. QCOM_PCIE_EP_LINK_UP,
  138. QCOM_PCIE_EP_LINK_DOWN,
  139. };
  140. /**
  141. * struct qcom_pcie_ep_cfg - Per SoC config struct
  142. * @hdma_support: HDMA support on this SoC
  143. * @override_no_snoop: Override NO_SNOOP attribute in TLP to enable cache snooping
  144. * @disable_mhi_ram_parity_check: Disable MHI RAM data parity error check
  145. * @firmware_managed: Set if the controller is firmware managed
  146. */
  147. struct qcom_pcie_ep_cfg {
  148. bool hdma_support;
  149. bool override_no_snoop;
  150. bool disable_mhi_ram_parity_check;
  151. bool firmware_managed;
  152. };
  153. /**
  154. * struct qcom_pcie_ep - Qualcomm PCIe Endpoint Controller
  155. * @pci: Designware PCIe controller struct
  156. * @parf: Qualcomm PCIe specific PARF register base
  157. * @mmio: MMIO register base
  158. * @perst_map: PERST regmap
  159. * @mmio_res: MMIO region resource
  160. * @core_reset: PCIe Endpoint core reset
  161. * @reset: PERST# GPIO
  162. * @wake: WAKE# GPIO
  163. * @phy: PHY controller block
  164. * @debugfs: PCIe Endpoint Debugfs directory
  165. * @icc_mem: Handle to an interconnect path between PCIe and MEM
  166. * @clks: PCIe clocks
  167. * @num_clks: PCIe clocks count
  168. * @perst_en: Flag for PERST enable
  169. * @perst_sep_en: Flag for PERST separation enable
  170. * @cfg: PCIe EP config struct
  171. * @link_status: PCIe Link status
  172. * @global_irq: Qualcomm PCIe specific Global IRQ
  173. * @perst_irq: PERST# IRQ
  174. */
  175. struct qcom_pcie_ep {
  176. struct dw_pcie pci;
  177. void __iomem *parf;
  178. void __iomem *mmio;
  179. struct regmap *perst_map;
  180. struct resource *mmio_res;
  181. struct reset_control *core_reset;
  182. struct gpio_desc *reset;
  183. struct gpio_desc *wake;
  184. struct phy *phy;
  185. struct dentry *debugfs;
  186. struct icc_path *icc_mem;
  187. struct clk_bulk_data *clks;
  188. int num_clks;
  189. u32 perst_en;
  190. u32 perst_sep_en;
  191. const struct qcom_pcie_ep_cfg *cfg;
  192. enum qcom_pcie_ep_link_status link_status;
  193. int global_irq;
  194. int perst_irq;
  195. };
  196. static int qcom_pcie_ep_core_reset(struct qcom_pcie_ep *pcie_ep)
  197. {
  198. struct dw_pcie *pci = &pcie_ep->pci;
  199. struct device *dev = pci->dev;
  200. int ret;
  201. ret = reset_control_assert(pcie_ep->core_reset);
  202. if (ret) {
  203. dev_err(dev, "Cannot assert core reset\n");
  204. return ret;
  205. }
  206. usleep_range(CORE_RESET_TIME_US_MIN, CORE_RESET_TIME_US_MAX);
  207. ret = reset_control_deassert(pcie_ep->core_reset);
  208. if (ret) {
  209. dev_err(dev, "Cannot de-assert core reset\n");
  210. return ret;
  211. }
  212. usleep_range(CORE_RESET_TIME_US_MIN, CORE_RESET_TIME_US_MAX);
  213. return 0;
  214. }
  215. /*
  216. * Delatch PERST_EN and PERST_SEPARATION_ENABLE with TCSR to avoid
  217. * device reset during host reboot and hibernation. The driver is
  218. * expected to handle this situation.
  219. */
  220. static void qcom_pcie_ep_configure_tcsr(struct qcom_pcie_ep *pcie_ep)
  221. {
  222. if (pcie_ep->perst_map) {
  223. regmap_write(pcie_ep->perst_map, pcie_ep->perst_en, 0);
  224. regmap_write(pcie_ep->perst_map, pcie_ep->perst_sep_en, 0);
  225. }
  226. }
  227. static bool qcom_pcie_dw_link_up(struct dw_pcie *pci)
  228. {
  229. u32 reg;
  230. reg = readl_relaxed(pci->elbi_base + ELBI_SYS_STTS);
  231. return reg & XMLH_LINK_UP;
  232. }
  233. static int qcom_pcie_dw_start_link(struct dw_pcie *pci)
  234. {
  235. struct qcom_pcie_ep *pcie_ep = to_pcie_ep(pci);
  236. enable_irq(pcie_ep->perst_irq);
  237. return 0;
  238. }
  239. static void qcom_pcie_dw_stop_link(struct dw_pcie *pci)
  240. {
  241. struct qcom_pcie_ep *pcie_ep = to_pcie_ep(pci);
  242. disable_irq(pcie_ep->perst_irq);
  243. }
  244. static void qcom_pcie_dw_write_dbi2(struct dw_pcie *pci, void __iomem *base,
  245. u32 reg, size_t size, u32 val)
  246. {
  247. int ret;
  248. writel(1, pci->elbi_base + ELBI_CS2_ENABLE);
  249. ret = dw_pcie_write(pci->dbi_base2 + reg, size, val);
  250. if (ret)
  251. dev_err(pci->dev, "Failed to write DBI2 register (0x%x): %d\n", reg, ret);
  252. writel(0, pci->elbi_base + ELBI_CS2_ENABLE);
  253. }
  254. static void qcom_pcie_ep_icc_update(struct qcom_pcie_ep *pcie_ep)
  255. {
  256. struct dw_pcie *pci = &pcie_ep->pci;
  257. u32 offset, status;
  258. int speed, width;
  259. int ret;
  260. if (!pcie_ep->icc_mem)
  261. return;
  262. offset = dw_pcie_find_capability(pci, PCI_CAP_ID_EXP);
  263. status = readw(pci->dbi_base + offset + PCI_EXP_LNKSTA);
  264. speed = FIELD_GET(PCI_EXP_LNKSTA_CLS, status);
  265. width = FIELD_GET(PCI_EXP_LNKSTA_NLW, status);
  266. ret = icc_set_bw(pcie_ep->icc_mem, 0, width * QCOM_PCIE_LINK_SPEED_TO_BW(speed));
  267. if (ret)
  268. dev_err(pci->dev, "failed to set interconnect bandwidth: %d\n",
  269. ret);
  270. }
  271. static int qcom_pcie_enable_resources(struct qcom_pcie_ep *pcie_ep)
  272. {
  273. struct dw_pcie *pci = &pcie_ep->pci;
  274. int ret;
  275. ret = clk_bulk_prepare_enable(pcie_ep->num_clks, pcie_ep->clks);
  276. if (ret)
  277. return ret;
  278. ret = qcom_pcie_ep_core_reset(pcie_ep);
  279. if (ret)
  280. goto err_disable_clk;
  281. ret = phy_init(pcie_ep->phy);
  282. if (ret)
  283. goto err_disable_clk;
  284. ret = phy_set_mode_ext(pcie_ep->phy, PHY_MODE_PCIE, PHY_MODE_PCIE_EP);
  285. if (ret)
  286. goto err_phy_exit;
  287. ret = phy_power_on(pcie_ep->phy);
  288. if (ret)
  289. goto err_phy_exit;
  290. /*
  291. * Some Qualcomm platforms require interconnect bandwidth constraints
  292. * to be set before enabling interconnect clocks.
  293. *
  294. * Set an initial peak bandwidth corresponding to single-lane Gen 1
  295. * for the pcie-mem path.
  296. */
  297. ret = icc_set_bw(pcie_ep->icc_mem, 0, QCOM_PCIE_LINK_SPEED_TO_BW(1));
  298. if (ret) {
  299. dev_err(pci->dev, "failed to set interconnect bandwidth: %d\n",
  300. ret);
  301. goto err_phy_off;
  302. }
  303. return 0;
  304. err_phy_off:
  305. phy_power_off(pcie_ep->phy);
  306. err_phy_exit:
  307. phy_exit(pcie_ep->phy);
  308. err_disable_clk:
  309. clk_bulk_disable_unprepare(pcie_ep->num_clks, pcie_ep->clks);
  310. return ret;
  311. }
  312. static void qcom_pcie_disable_resources(struct qcom_pcie_ep *pcie_ep)
  313. {
  314. struct device *dev = pcie_ep->pci.dev;
  315. pm_runtime_put(dev);
  316. /* Skip resource disablement if controller is firmware-managed */
  317. if (pcie_ep->cfg && pcie_ep->cfg->firmware_managed)
  318. return;
  319. icc_set_bw(pcie_ep->icc_mem, 0, 0);
  320. phy_power_off(pcie_ep->phy);
  321. phy_exit(pcie_ep->phy);
  322. clk_bulk_disable_unprepare(pcie_ep->num_clks, pcie_ep->clks);
  323. }
  324. static int qcom_pcie_perst_deassert(struct dw_pcie *pci)
  325. {
  326. struct qcom_pcie_ep *pcie_ep = to_pcie_ep(pci);
  327. struct device *dev = pci->dev;
  328. u32 val, offset;
  329. int ret;
  330. ret = pm_runtime_resume_and_get(dev);
  331. if (ret < 0) {
  332. dev_err(dev, "Failed to enable device: %d\n", ret);
  333. return ret;
  334. }
  335. /* Skip resource enablement if controller is firmware-managed */
  336. if (pcie_ep->cfg && pcie_ep->cfg->firmware_managed)
  337. goto skip_resources_enable;
  338. ret = qcom_pcie_enable_resources(pcie_ep);
  339. if (ret) {
  340. dev_err(dev, "Failed to enable resources: %d\n", ret);
  341. pm_runtime_put(dev);
  342. return ret;
  343. }
  344. skip_resources_enable:
  345. /* Perform cleanup that requires refclk */
  346. pci_epc_deinit_notify(pci->ep.epc);
  347. dw_pcie_ep_cleanup(&pci->ep);
  348. /* Assert WAKE# to RC to indicate device is ready */
  349. gpiod_set_value_cansleep(pcie_ep->wake, 1);
  350. usleep_range(WAKE_DELAY_US, WAKE_DELAY_US + 500);
  351. gpiod_set_value_cansleep(pcie_ep->wake, 0);
  352. qcom_pcie_ep_configure_tcsr(pcie_ep);
  353. /* Disable BDF to SID mapping */
  354. val = readl_relaxed(pcie_ep->parf + PARF_BDF_TO_SID_CFG);
  355. val |= PARF_BDF_TO_SID_BYPASS;
  356. writel_relaxed(val, pcie_ep->parf + PARF_BDF_TO_SID_CFG);
  357. /* Enable debug IRQ */
  358. val = readl_relaxed(pcie_ep->parf + PARF_DEBUG_INT_EN);
  359. val |= PARF_DEBUG_INT_RADM_PM_TURNOFF |
  360. PARF_DEBUG_INT_CFG_BUS_MASTER_EN |
  361. PARF_DEBUG_INT_PM_DSTATE_CHANGE;
  362. writel_relaxed(val, pcie_ep->parf + PARF_DEBUG_INT_EN);
  363. /* Configure PCIe to endpoint mode */
  364. writel_relaxed(PARF_DEVICE_TYPE_EP, pcie_ep->parf + PARF_DEVICE_TYPE);
  365. /* Allow entering L1 state */
  366. val = readl_relaxed(pcie_ep->parf + PARF_PM_CTRL);
  367. val &= ~PARF_PM_CTRL_REQ_NOT_ENTR_L1;
  368. writel_relaxed(val, pcie_ep->parf + PARF_PM_CTRL);
  369. /* Read halts write */
  370. val = readl_relaxed(pcie_ep->parf + PARF_AXI_MSTR_RD_HALT_NO_WRITES);
  371. val &= ~PARF_AXI_MSTR_RD_HALT_NO_WRITE_EN;
  372. writel_relaxed(val, pcie_ep->parf + PARF_AXI_MSTR_RD_HALT_NO_WRITES);
  373. /* Write after write halt */
  374. val = readl_relaxed(pcie_ep->parf + PARF_AXI_MSTR_WR_ADDR_HALT);
  375. val |= PARF_AXI_MSTR_WR_ADDR_HALT_EN;
  376. writel_relaxed(val, pcie_ep->parf + PARF_AXI_MSTR_WR_ADDR_HALT);
  377. /* Q2A flush disable */
  378. val = readl_relaxed(pcie_ep->parf + PARF_Q2A_FLUSH);
  379. val &= ~PARF_Q2A_FLUSH_EN;
  380. writel_relaxed(val, pcie_ep->parf + PARF_Q2A_FLUSH);
  381. /*
  382. * Disable Master AXI clock during idle. Do not allow DBI access
  383. * to take the core out of L1. Disable core clock gating that
  384. * gates PIPE clock from propagating to core clock. Report to the
  385. * host that Vaux is present.
  386. */
  387. val = readl_relaxed(pcie_ep->parf + PARF_SYS_CTRL);
  388. val &= ~PARF_SYS_CTRL_MSTR_ACLK_CGC_DIS;
  389. val |= PARF_SYS_CTRL_SLV_DBI_WAKE_DISABLE |
  390. PARF_SYS_CTRL_CORE_CLK_CGC_DIS |
  391. PARF_SYS_CTRL_AUX_PWR_DET;
  392. writel_relaxed(val, pcie_ep->parf + PARF_SYS_CTRL);
  393. /* Disable the debouncers */
  394. val = readl_relaxed(pcie_ep->parf + PARF_DB_CTRL);
  395. val |= PARF_DB_CTRL_INSR_DBNCR_BLOCK | PARF_DB_CTRL_RMVL_DBNCR_BLOCK |
  396. PARF_DB_CTRL_DBI_WKP_BLOCK | PARF_DB_CTRL_SLV_WKP_BLOCK |
  397. PARF_DB_CTRL_MST_WKP_BLOCK;
  398. writel_relaxed(val, pcie_ep->parf + PARF_DB_CTRL);
  399. /* Request to exit from L1SS for MSI and LTR MSG */
  400. val = readl_relaxed(pcie_ep->parf + PARF_CFG_BITS);
  401. val |= PARF_CFG_BITS_REQ_EXIT_L1SS_MSI_LTR_EN;
  402. writel_relaxed(val, pcie_ep->parf + PARF_CFG_BITS);
  403. dw_pcie_dbi_ro_wr_en(pci);
  404. /* Set the L0s Exit Latency to 2us-4us = 0x6 */
  405. offset = dw_pcie_find_capability(pci, PCI_CAP_ID_EXP);
  406. val = dw_pcie_readl_dbi(pci, offset + PCI_EXP_LNKCAP);
  407. val &= ~PCI_EXP_LNKCAP_L0SEL;
  408. val |= FIELD_PREP(PCI_EXP_LNKCAP_L0SEL, 0x6);
  409. dw_pcie_writel_dbi(pci, offset + PCI_EXP_LNKCAP, val);
  410. /* Set the L1 Exit Latency to be 32us-64 us = 0x6 */
  411. offset = dw_pcie_find_capability(pci, PCI_CAP_ID_EXP);
  412. val = dw_pcie_readl_dbi(pci, offset + PCI_EXP_LNKCAP);
  413. val &= ~PCI_EXP_LNKCAP_L1EL;
  414. val |= FIELD_PREP(PCI_EXP_LNKCAP_L1EL, 0x6);
  415. dw_pcie_writel_dbi(pci, offset + PCI_EXP_LNKCAP, val);
  416. dw_pcie_dbi_ro_wr_dis(pci);
  417. writel_relaxed(0, pcie_ep->parf + PARF_INT_ALL_MASK);
  418. val = PARF_INT_ALL_LINK_DOWN | PARF_INT_ALL_BME |
  419. PARF_INT_ALL_PM_TURNOFF | PARF_INT_ALL_DSTATE_CHANGE |
  420. PARF_INT_ALL_LINK_UP | PARF_INT_ALL_EDMA;
  421. writel_relaxed(val, pcie_ep->parf + PARF_INT_ALL_MASK);
  422. if (pcie_ep->cfg && pcie_ep->cfg->disable_mhi_ram_parity_check) {
  423. val = readl_relaxed(pcie_ep->parf + PARF_INT_ALL_5_MASK);
  424. val &= ~PARF_INT_ALL_5_MHI_RAM_DATA_PARITY_ERR;
  425. writel_relaxed(val, pcie_ep->parf + PARF_INT_ALL_5_MASK);
  426. }
  427. val = readl_relaxed(pcie_ep->parf + PARF_INT_ALL_3_MASK);
  428. val &= ~PARF_INT_ALL_3_PTM_UPDATING;
  429. writel_relaxed(val, pcie_ep->parf + PARF_INT_ALL_3_MASK);
  430. ret = dw_pcie_ep_init_registers(&pcie_ep->pci.ep);
  431. if (ret) {
  432. dev_err(dev, "Failed to complete initialization: %d\n", ret);
  433. goto err_disable_resources;
  434. }
  435. qcom_pcie_common_set_equalization(pci);
  436. if (pcie_link_speed[pci->max_link_speed] == PCIE_SPEED_16_0GT)
  437. qcom_pcie_common_set_16gt_lane_margining(pci);
  438. /*
  439. * The physical address of the MMIO region which is exposed as the BAR
  440. * should be written to MHI BASE registers.
  441. */
  442. writel_relaxed(pcie_ep->mmio_res->start,
  443. pcie_ep->parf + PARF_MHI_BASE_ADDR_LOWER);
  444. writel_relaxed(0, pcie_ep->parf + PARF_MHI_BASE_ADDR_UPPER);
  445. /* Gate Master AXI clock to MHI bus during L1SS */
  446. val = readl_relaxed(pcie_ep->parf + PARF_MHI_CLOCK_RESET_CTRL);
  447. val &= ~PARF_MSTR_AXI_CLK_EN;
  448. writel_relaxed(val, pcie_ep->parf + PARF_MHI_CLOCK_RESET_CTRL);
  449. pci_epc_init_notify(pcie_ep->pci.ep.epc);
  450. /* Enable LTSSM */
  451. val = readl_relaxed(pcie_ep->parf + PARF_LTSSM);
  452. val |= BIT(8);
  453. writel_relaxed(val, pcie_ep->parf + PARF_LTSSM);
  454. if (pcie_ep->cfg && pcie_ep->cfg->override_no_snoop)
  455. writel_relaxed(WR_NO_SNOOP_OVERRIDE_EN | RD_NO_SNOOP_OVERRIDE_EN,
  456. pcie_ep->parf + PARF_NO_SNOOP_OVERRIDE);
  457. return 0;
  458. err_disable_resources:
  459. qcom_pcie_disable_resources(pcie_ep);
  460. return ret;
  461. }
  462. static void qcom_pcie_perst_assert(struct dw_pcie *pci)
  463. {
  464. struct qcom_pcie_ep *pcie_ep = to_pcie_ep(pci);
  465. qcom_pcie_disable_resources(pcie_ep);
  466. pcie_ep->link_status = QCOM_PCIE_EP_LINK_DISABLED;
  467. }
  468. /* Common DWC controller ops */
  469. static const struct dw_pcie_ops pci_ops = {
  470. .link_up = qcom_pcie_dw_link_up,
  471. .start_link = qcom_pcie_dw_start_link,
  472. .stop_link = qcom_pcie_dw_stop_link,
  473. .write_dbi2 = qcom_pcie_dw_write_dbi2,
  474. };
  475. static int qcom_pcie_ep_get_io_resources(struct platform_device *pdev,
  476. struct qcom_pcie_ep *pcie_ep)
  477. {
  478. struct device *dev = &pdev->dev;
  479. struct dw_pcie *pci = &pcie_ep->pci;
  480. struct device_node *syscon;
  481. struct resource *res;
  482. int ret;
  483. pcie_ep->parf = devm_platform_ioremap_resource_byname(pdev, "parf");
  484. if (IS_ERR(pcie_ep->parf))
  485. return PTR_ERR(pcie_ep->parf);
  486. res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "dbi");
  487. pci->dbi_base = devm_pci_remap_cfg_resource(dev, res);
  488. if (IS_ERR(pci->dbi_base))
  489. return PTR_ERR(pci->dbi_base);
  490. pci->dbi_base2 = pci->dbi_base;
  491. pcie_ep->mmio_res = platform_get_resource_byname(pdev, IORESOURCE_MEM,
  492. "mmio");
  493. if (!pcie_ep->mmio_res) {
  494. dev_err(dev, "Failed to get mmio resource\n");
  495. return -EINVAL;
  496. }
  497. pcie_ep->mmio = devm_pci_remap_cfg_resource(dev, pcie_ep->mmio_res);
  498. if (IS_ERR(pcie_ep->mmio))
  499. return PTR_ERR(pcie_ep->mmio);
  500. syscon = of_parse_phandle(dev->of_node, "qcom,perst-regs", 0);
  501. if (!syscon) {
  502. dev_dbg(dev, "PERST separation not available\n");
  503. return 0;
  504. }
  505. pcie_ep->perst_map = syscon_node_to_regmap(syscon);
  506. of_node_put(syscon);
  507. if (IS_ERR(pcie_ep->perst_map))
  508. return PTR_ERR(pcie_ep->perst_map);
  509. ret = of_property_read_u32_index(dev->of_node, "qcom,perst-regs",
  510. 1, &pcie_ep->perst_en);
  511. if (ret < 0) {
  512. dev_err(dev, "No Perst Enable offset in syscon\n");
  513. return ret;
  514. }
  515. ret = of_property_read_u32_index(dev->of_node, "qcom,perst-regs",
  516. 2, &pcie_ep->perst_sep_en);
  517. if (ret < 0) {
  518. dev_err(dev, "No Perst Separation Enable offset in syscon\n");
  519. return ret;
  520. }
  521. return 0;
  522. }
  523. static int qcom_pcie_ep_get_resources(struct platform_device *pdev,
  524. struct qcom_pcie_ep *pcie_ep)
  525. {
  526. struct device *dev = &pdev->dev;
  527. int ret;
  528. ret = qcom_pcie_ep_get_io_resources(pdev, pcie_ep);
  529. if (ret) {
  530. dev_err(dev, "Failed to get io resources %d\n", ret);
  531. return ret;
  532. }
  533. pcie_ep->reset = devm_gpiod_get(dev, "reset", GPIOD_IN);
  534. if (IS_ERR(pcie_ep->reset))
  535. return PTR_ERR(pcie_ep->reset);
  536. pcie_ep->wake = devm_gpiod_get_optional(dev, "wake", GPIOD_OUT_LOW);
  537. if (IS_ERR(pcie_ep->wake))
  538. return PTR_ERR(pcie_ep->wake);
  539. if (pcie_ep->cfg && pcie_ep->cfg->firmware_managed)
  540. return 0;
  541. pcie_ep->num_clks = devm_clk_bulk_get_all(dev, &pcie_ep->clks);
  542. if (pcie_ep->num_clks < 0) {
  543. dev_err(dev, "Failed to get clocks\n");
  544. return pcie_ep->num_clks;
  545. }
  546. pcie_ep->core_reset = devm_reset_control_get_exclusive(dev, "core");
  547. if (IS_ERR(pcie_ep->core_reset))
  548. return PTR_ERR(pcie_ep->core_reset);
  549. pcie_ep->phy = devm_phy_optional_get(dev, "pciephy");
  550. if (IS_ERR(pcie_ep->phy))
  551. ret = PTR_ERR(pcie_ep->phy);
  552. pcie_ep->icc_mem = devm_of_icc_get(dev, "pcie-mem");
  553. if (IS_ERR(pcie_ep->icc_mem))
  554. ret = PTR_ERR(pcie_ep->icc_mem);
  555. return ret;
  556. }
  557. /* TODO: Notify clients about PCIe state change */
  558. static irqreturn_t qcom_pcie_ep_global_irq_thread(int irq, void *data)
  559. {
  560. struct qcom_pcie_ep *pcie_ep = data;
  561. struct dw_pcie *pci = &pcie_ep->pci;
  562. struct device *dev = pci->dev;
  563. u32 status = readl_relaxed(pcie_ep->parf + PARF_INT_ALL_STATUS);
  564. u32 dstate, val;
  565. writel_relaxed(status, pcie_ep->parf + PARF_INT_ALL_CLEAR);
  566. if (FIELD_GET(PARF_INT_ALL_LINK_DOWN, status)) {
  567. dev_dbg(dev, "Received Linkdown event\n");
  568. pcie_ep->link_status = QCOM_PCIE_EP_LINK_DOWN;
  569. dw_pcie_ep_linkdown(&pci->ep);
  570. } else if (FIELD_GET(PARF_INT_ALL_BME, status)) {
  571. dev_dbg(dev, "Received Bus Master Enable event\n");
  572. pcie_ep->link_status = QCOM_PCIE_EP_LINK_ENABLED;
  573. qcom_pcie_ep_icc_update(pcie_ep);
  574. pci_epc_bus_master_enable_notify(pci->ep.epc);
  575. } else if (FIELD_GET(PARF_INT_ALL_PM_TURNOFF, status)) {
  576. dev_dbg(dev, "Received PM Turn-off event! Entering L23\n");
  577. val = readl_relaxed(pcie_ep->parf + PARF_PM_CTRL);
  578. val |= PARF_PM_CTRL_READY_ENTR_L23;
  579. writel_relaxed(val, pcie_ep->parf + PARF_PM_CTRL);
  580. } else if (FIELD_GET(PARF_INT_ALL_DSTATE_CHANGE, status)) {
  581. dstate = dw_pcie_readl_dbi(pci, DBI_CON_STATUS) &
  582. DBI_CON_STATUS_POWER_STATE_MASK;
  583. dev_dbg(dev, "Received D%d state event\n", dstate);
  584. if (dstate == 3) {
  585. val = readl_relaxed(pcie_ep->parf + PARF_PM_CTRL);
  586. val |= PARF_PM_CTRL_REQ_EXIT_L1;
  587. writel_relaxed(val, pcie_ep->parf + PARF_PM_CTRL);
  588. }
  589. } else if (FIELD_GET(PARF_INT_ALL_LINK_UP, status)) {
  590. dev_dbg(dev, "Received Linkup event. Enumeration complete!\n");
  591. dw_pcie_ep_linkup(&pci->ep);
  592. pcie_ep->link_status = QCOM_PCIE_EP_LINK_UP;
  593. } else {
  594. dev_WARN_ONCE(dev, 1, "Received unknown event. INT_STATUS: 0x%08x\n",
  595. status);
  596. }
  597. return IRQ_HANDLED;
  598. }
  599. static irqreturn_t qcom_pcie_ep_perst_irq_thread(int irq, void *data)
  600. {
  601. struct qcom_pcie_ep *pcie_ep = data;
  602. struct dw_pcie *pci = &pcie_ep->pci;
  603. struct device *dev = pci->dev;
  604. u32 perst;
  605. perst = gpiod_get_value(pcie_ep->reset);
  606. if (perst) {
  607. dev_dbg(dev, "PERST asserted by host. Shutting down the PCIe link!\n");
  608. qcom_pcie_perst_assert(pci);
  609. } else {
  610. dev_dbg(dev, "PERST de-asserted by host. Starting link training!\n");
  611. qcom_pcie_perst_deassert(pci);
  612. }
  613. irq_set_irq_type(gpiod_to_irq(pcie_ep->reset),
  614. (perst ? IRQF_TRIGGER_HIGH : IRQF_TRIGGER_LOW));
  615. return IRQ_HANDLED;
  616. }
  617. static int qcom_pcie_ep_enable_irq_resources(struct platform_device *pdev,
  618. struct qcom_pcie_ep *pcie_ep)
  619. {
  620. struct device *dev = pcie_ep->pci.dev;
  621. char *name;
  622. int ret;
  623. name = devm_kasprintf(dev, GFP_KERNEL, "qcom_pcie_ep_global_irq%d",
  624. pcie_ep->pci.ep.epc->domain_nr);
  625. if (!name)
  626. return -ENOMEM;
  627. pcie_ep->global_irq = platform_get_irq_byname(pdev, "global");
  628. if (pcie_ep->global_irq < 0)
  629. return pcie_ep->global_irq;
  630. ret = devm_request_threaded_irq(&pdev->dev, pcie_ep->global_irq, NULL,
  631. qcom_pcie_ep_global_irq_thread,
  632. IRQF_ONESHOT,
  633. name, pcie_ep);
  634. if (ret) {
  635. dev_err(&pdev->dev, "Failed to request Global IRQ\n");
  636. return ret;
  637. }
  638. name = devm_kasprintf(dev, GFP_KERNEL, "qcom_pcie_ep_perst_irq%d",
  639. pcie_ep->pci.ep.epc->domain_nr);
  640. if (!name)
  641. return -ENOMEM;
  642. pcie_ep->perst_irq = gpiod_to_irq(pcie_ep->reset);
  643. irq_set_status_flags(pcie_ep->perst_irq, IRQ_NOAUTOEN);
  644. ret = devm_request_threaded_irq(&pdev->dev, pcie_ep->perst_irq, NULL,
  645. qcom_pcie_ep_perst_irq_thread,
  646. IRQF_TRIGGER_HIGH | IRQF_ONESHOT,
  647. name, pcie_ep);
  648. if (ret) {
  649. dev_err(&pdev->dev, "Failed to request PERST IRQ\n");
  650. disable_irq(pcie_ep->global_irq);
  651. return ret;
  652. }
  653. return 0;
  654. }
  655. static int qcom_pcie_ep_raise_irq(struct dw_pcie_ep *ep, u8 func_no,
  656. unsigned int type, u16 interrupt_num)
  657. {
  658. struct dw_pcie *pci = to_dw_pcie_from_ep(ep);
  659. switch (type) {
  660. case PCI_IRQ_INTX:
  661. return dw_pcie_ep_raise_intx_irq(ep, func_no);
  662. case PCI_IRQ_MSI:
  663. return dw_pcie_ep_raise_msi_irq(ep, func_no, interrupt_num);
  664. default:
  665. dev_err(pci->dev, "Unknown IRQ type\n");
  666. return -EINVAL;
  667. }
  668. }
  669. static int qcom_pcie_ep_link_transition_count(struct seq_file *s, void *data)
  670. {
  671. struct qcom_pcie_ep *pcie_ep = (struct qcom_pcie_ep *)
  672. dev_get_drvdata(s->private);
  673. seq_printf(s, "L0s transition count: %u\n",
  674. readl_relaxed(pcie_ep->mmio + PARF_DEBUG_CNT_PM_LINKST_IN_L0S));
  675. seq_printf(s, "L1 transition count: %u\n",
  676. readl_relaxed(pcie_ep->mmio + PARF_DEBUG_CNT_PM_LINKST_IN_L1));
  677. seq_printf(s, "L1.1 transition count: %u\n",
  678. readl_relaxed(pcie_ep->mmio + PARF_DEBUG_CNT_AUX_CLK_IN_L1SUB_L1));
  679. seq_printf(s, "L1.2 transition count: %u\n",
  680. readl_relaxed(pcie_ep->mmio + PARF_DEBUG_CNT_AUX_CLK_IN_L1SUB_L2));
  681. seq_printf(s, "L2 transition count: %u\n",
  682. readl_relaxed(pcie_ep->mmio + PARF_DEBUG_CNT_PM_LINKST_IN_L2));
  683. return 0;
  684. }
  685. static void qcom_pcie_ep_init_debugfs(struct qcom_pcie_ep *pcie_ep)
  686. {
  687. struct dw_pcie *pci = &pcie_ep->pci;
  688. debugfs_create_devm_seqfile(pci->dev, "link_transition_count", pcie_ep->debugfs,
  689. qcom_pcie_ep_link_transition_count);
  690. }
  691. static const struct pci_epc_features qcom_pcie_epc_features = {
  692. DWC_EPC_COMMON_FEATURES,
  693. .linkup_notifier = true,
  694. .msi_capable = true,
  695. .align = SZ_4K,
  696. .bar[BAR_0] = { .only_64bit = true, },
  697. .bar[BAR_1] = { .type = BAR_RESERVED, },
  698. .bar[BAR_2] = { .only_64bit = true, },
  699. .bar[BAR_3] = { .type = BAR_RESERVED, },
  700. };
  701. static const struct pci_epc_features *
  702. qcom_pcie_epc_get_features(struct dw_pcie_ep *pci_ep)
  703. {
  704. return &qcom_pcie_epc_features;
  705. }
  706. static void qcom_pcie_ep_init(struct dw_pcie_ep *ep)
  707. {
  708. struct dw_pcie *pci = to_dw_pcie_from_ep(ep);
  709. enum pci_barno bar;
  710. for (bar = BAR_0; bar <= BAR_5; bar++)
  711. dw_pcie_ep_reset_bar(pci, bar);
  712. }
  713. static const struct dw_pcie_ep_ops pci_ep_ops = {
  714. .init = qcom_pcie_ep_init,
  715. .raise_irq = qcom_pcie_ep_raise_irq,
  716. .get_features = qcom_pcie_epc_get_features,
  717. };
  718. static int qcom_pcie_ep_probe(struct platform_device *pdev)
  719. {
  720. struct device *dev = &pdev->dev;
  721. struct qcom_pcie_ep *pcie_ep;
  722. char *name;
  723. int ret;
  724. pcie_ep = devm_kzalloc(dev, sizeof(*pcie_ep), GFP_KERNEL);
  725. if (!pcie_ep)
  726. return -ENOMEM;
  727. pcie_ep->pci.dev = dev;
  728. pcie_ep->pci.ops = &pci_ops;
  729. pcie_ep->pci.ep.ops = &pci_ep_ops;
  730. pcie_ep->cfg = of_device_get_match_data(dev);
  731. if (pcie_ep->cfg && pcie_ep->cfg->hdma_support) {
  732. pcie_ep->pci.edma.ll_wr_cnt = 8;
  733. pcie_ep->pci.edma.ll_rd_cnt = 8;
  734. pcie_ep->pci.edma.mf = EDMA_MF_HDMA_NATIVE;
  735. }
  736. platform_set_drvdata(pdev, pcie_ep);
  737. pm_runtime_get_noresume(dev);
  738. pm_runtime_set_active(dev);
  739. ret = devm_pm_runtime_enable(dev);
  740. if (ret)
  741. return ret;
  742. ret = qcom_pcie_ep_get_resources(pdev, pcie_ep);
  743. if (ret)
  744. return ret;
  745. ret = dw_pcie_ep_init(&pcie_ep->pci.ep);
  746. if (ret) {
  747. dev_err(dev, "Failed to initialize endpoint: %d\n", ret);
  748. return ret;
  749. }
  750. ret = qcom_pcie_ep_enable_irq_resources(pdev, pcie_ep);
  751. if (ret)
  752. goto err_ep_deinit;
  753. name = devm_kasprintf(dev, GFP_KERNEL, "%pOFP", dev->of_node);
  754. if (!name) {
  755. ret = -ENOMEM;
  756. goto err_disable_irqs;
  757. }
  758. ret = pm_runtime_put_sync(dev);
  759. if (ret < 0) {
  760. dev_err(dev, "Failed to suspend device: %d\n", ret);
  761. goto err_disable_irqs;
  762. }
  763. pcie_ep->debugfs = debugfs_create_dir(name, NULL);
  764. qcom_pcie_ep_init_debugfs(pcie_ep);
  765. return 0;
  766. err_disable_irqs:
  767. disable_irq(pcie_ep->global_irq);
  768. disable_irq(pcie_ep->perst_irq);
  769. err_ep_deinit:
  770. dw_pcie_ep_deinit(&pcie_ep->pci.ep);
  771. return ret;
  772. }
  773. static void qcom_pcie_ep_remove(struct platform_device *pdev)
  774. {
  775. struct qcom_pcie_ep *pcie_ep = platform_get_drvdata(pdev);
  776. disable_irq(pcie_ep->global_irq);
  777. disable_irq(pcie_ep->perst_irq);
  778. debugfs_remove_recursive(pcie_ep->debugfs);
  779. if (pcie_ep->link_status == QCOM_PCIE_EP_LINK_DISABLED)
  780. return;
  781. qcom_pcie_disable_resources(pcie_ep);
  782. }
  783. static const struct qcom_pcie_ep_cfg cfg_1_34_0 = {
  784. .hdma_support = true,
  785. .override_no_snoop = true,
  786. .disable_mhi_ram_parity_check = true,
  787. };
  788. static const struct qcom_pcie_ep_cfg cfg_1_34_0_fw_managed = {
  789. .hdma_support = true,
  790. .override_no_snoop = true,
  791. .disable_mhi_ram_parity_check = true,
  792. .firmware_managed = true,
  793. };
  794. static const struct of_device_id qcom_pcie_ep_match[] = {
  795. { .compatible = "qcom,sa8255p-pcie-ep", .data = &cfg_1_34_0_fw_managed},
  796. { .compatible = "qcom,sa8775p-pcie-ep", .data = &cfg_1_34_0},
  797. { .compatible = "qcom,sdx55-pcie-ep", },
  798. { .compatible = "qcom,sm8450-pcie-ep", },
  799. { .compatible = "qcom,sar2130p-pcie-ep", },
  800. { }
  801. };
  802. MODULE_DEVICE_TABLE(of, qcom_pcie_ep_match);
  803. static struct platform_driver qcom_pcie_ep_driver = {
  804. .probe = qcom_pcie_ep_probe,
  805. .remove = qcom_pcie_ep_remove,
  806. .driver = {
  807. .name = "qcom-pcie-ep",
  808. .of_match_table = qcom_pcie_ep_match,
  809. },
  810. };
  811. builtin_platform_driver(qcom_pcie_ep_driver);
  812. MODULE_AUTHOR("Siddartha Mohanadoss <smohanad@codeaurora.org>");
  813. MODULE_AUTHOR("Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>");
  814. MODULE_DESCRIPTION("Qualcomm PCIe Endpoint controller driver");
  815. MODULE_LICENSE("GPL v2");