pci-imx6.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. /*
  2. * PCIe host controller driver for Freescale i.MX6 SoCs
  3. *
  4. * Copyright (C) 2013 Kosagi
  5. * http://www.kosagi.com
  6. *
  7. * Author: Sean Cross <xobs@kosagi.com>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License version 2 as
  11. * published by the Free Software Foundation.
  12. */
  13. #include <linux/clk.h>
  14. #include <linux/delay.h>
  15. #include <linux/gpio.h>
  16. #include <linux/kernel.h>
  17. #include <linux/mfd/syscon.h>
  18. #include <linux/mfd/syscon/imx6q-iomuxc-gpr.h>
  19. #include <linux/module.h>
  20. #include <linux/of_gpio.h>
  21. #include <linux/pci.h>
  22. #include <linux/platform_device.h>
  23. #include <linux/regmap.h>
  24. #include <linux/resource.h>
  25. #include <linux/signal.h>
  26. #include <linux/types.h>
  27. #include "pcie-designware.h"
  28. #define to_imx6_pcie(x) container_of(x, struct imx6_pcie, pp)
  29. struct imx6_pcie {
  30. int reset_gpio;
  31. int power_on_gpio;
  32. int wake_up_gpio;
  33. int disable_gpio;
  34. struct clk *lvds_gate;
  35. struct clk *sata_ref_100m;
  36. struct clk *pcie_ref_125m;
  37. struct clk *pcie_axi;
  38. struct pcie_port pp;
  39. struct regmap *iomuxc_gpr;
  40. void __iomem *mem_base;
  41. };
  42. /* PCIe Port Logic registers (memory-mapped) */
  43. #define PL_OFFSET 0x700
  44. #define PCIE_PHY_DEBUG_R0 (PL_OFFSET + 0x28)
  45. #define PCIE_PHY_DEBUG_R1 (PL_OFFSET + 0x2c)
  46. #define PCIE_PHY_CTRL (PL_OFFSET + 0x114)
  47. #define PCIE_PHY_CTRL_DATA_LOC 0
  48. #define PCIE_PHY_CTRL_CAP_ADR_LOC 16
  49. #define PCIE_PHY_CTRL_CAP_DAT_LOC 17
  50. #define PCIE_PHY_CTRL_WR_LOC 18
  51. #define PCIE_PHY_CTRL_RD_LOC 19
  52. #define PCIE_PHY_STAT (PL_OFFSET + 0x110)
  53. #define PCIE_PHY_STAT_ACK_LOC 16
  54. /* PHY registers (not memory-mapped) */
  55. #define PCIE_PHY_RX_ASIC_OUT 0x100D
  56. #define PHY_RX_OVRD_IN_LO 0x1005
  57. #define PHY_RX_OVRD_IN_LO_RX_DATA_EN (1 << 5)
  58. #define PHY_RX_OVRD_IN_LO_RX_PLL_EN (1 << 3)
  59. static int pcie_phy_poll_ack(void __iomem *dbi_base, int exp_val)
  60. {
  61. u32 val;
  62. u32 max_iterations = 10;
  63. u32 wait_counter = 0;
  64. do {
  65. val = readl(dbi_base + PCIE_PHY_STAT);
  66. val = (val >> PCIE_PHY_STAT_ACK_LOC) & 0x1;
  67. wait_counter++;
  68. if (val == exp_val)
  69. return 0;
  70. udelay(1);
  71. } while (wait_counter < max_iterations);
  72. return -ETIMEDOUT;
  73. }
  74. static int pcie_phy_wait_ack(void __iomem *dbi_base, int addr)
  75. {
  76. u32 val;
  77. int ret;
  78. val = addr << PCIE_PHY_CTRL_DATA_LOC;
  79. writel(val, dbi_base + PCIE_PHY_CTRL);
  80. val |= (0x1 << PCIE_PHY_CTRL_CAP_ADR_LOC);
  81. writel(val, dbi_base + PCIE_PHY_CTRL);
  82. ret = pcie_phy_poll_ack(dbi_base, 1);
  83. if (ret)
  84. return ret;
  85. val = addr << PCIE_PHY_CTRL_DATA_LOC;
  86. writel(val, dbi_base + PCIE_PHY_CTRL);
  87. ret = pcie_phy_poll_ack(dbi_base, 0);
  88. if (ret)
  89. return ret;
  90. return 0;
  91. }
  92. /* Read from the 16-bit PCIe PHY control registers (not memory-mapped) */
  93. static int pcie_phy_read(void __iomem *dbi_base, int addr , int *data)
  94. {
  95. u32 val, phy_ctl;
  96. int ret;
  97. ret = pcie_phy_wait_ack(dbi_base, addr);
  98. if (ret)
  99. return ret;
  100. /* assert Read signal */
  101. phy_ctl = 0x1 << PCIE_PHY_CTRL_RD_LOC;
  102. writel(phy_ctl, dbi_base + PCIE_PHY_CTRL);
  103. ret = pcie_phy_poll_ack(dbi_base, 1);
  104. if (ret)
  105. return ret;
  106. val = readl(dbi_base + PCIE_PHY_STAT);
  107. *data = val & 0xffff;
  108. /* deassert Read signal */
  109. writel(0x00, dbi_base + PCIE_PHY_CTRL);
  110. ret = pcie_phy_poll_ack(dbi_base, 0);
  111. if (ret)
  112. return ret;
  113. return 0;
  114. }
  115. static int pcie_phy_write(void __iomem *dbi_base, int addr, int data)
  116. {
  117. u32 var;
  118. int ret;
  119. /* write addr */
  120. /* cap addr */
  121. ret = pcie_phy_wait_ack(dbi_base, addr);
  122. if (ret)
  123. return ret;
  124. var = data << PCIE_PHY_CTRL_DATA_LOC;
  125. writel(var, dbi_base + PCIE_PHY_CTRL);
  126. /* capture data */
  127. var |= (0x1 << PCIE_PHY_CTRL_CAP_DAT_LOC);
  128. writel(var, dbi_base + PCIE_PHY_CTRL);
  129. ret = pcie_phy_poll_ack(dbi_base, 1);
  130. if (ret)
  131. return ret;
  132. /* deassert cap data */
  133. var = data << PCIE_PHY_CTRL_DATA_LOC;
  134. writel(var, dbi_base + PCIE_PHY_CTRL);
  135. /* wait for ack de-assertion */
  136. ret = pcie_phy_poll_ack(dbi_base, 0);
  137. if (ret)
  138. return ret;
  139. /* assert wr signal */
  140. var = 0x1 << PCIE_PHY_CTRL_WR_LOC;
  141. writel(var, dbi_base + PCIE_PHY_CTRL);
  142. /* wait for ack */
  143. ret = pcie_phy_poll_ack(dbi_base, 1);
  144. if (ret)
  145. return ret;
  146. /* deassert wr signal */
  147. var = data << PCIE_PHY_CTRL_DATA_LOC;
  148. writel(var, dbi_base + PCIE_PHY_CTRL);
  149. /* wait for ack de-assertion */
  150. ret = pcie_phy_poll_ack(dbi_base, 0);
  151. if (ret)
  152. return ret;
  153. writel(0x0, dbi_base + PCIE_PHY_CTRL);
  154. return 0;
  155. }
  156. /* Added for PCI abort handling */
  157. static int imx6q_pcie_abort_handler(unsigned long addr,
  158. unsigned int fsr, struct pt_regs *regs)
  159. {
  160. /*
  161. * If it was an imprecise abort, then we need to correct the
  162. * return address to be _after_ the instruction.
  163. */
  164. if (fsr & (1 << 10))
  165. regs->ARM_pc += 4;
  166. return 0;
  167. }
  168. static int imx6_pcie_assert_core_reset(struct pcie_port *pp)
  169. {
  170. struct imx6_pcie *imx6_pcie = to_imx6_pcie(pp);
  171. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1,
  172. IMX6Q_GPR1_PCIE_TEST_PD, 1 << 18);
  173. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12,
  174. IMX6Q_GPR12_PCIE_CTL_2, 1 << 10);
  175. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1,
  176. IMX6Q_GPR1_PCIE_REF_CLK_EN, 0 << 16);
  177. gpio_set_value(imx6_pcie->reset_gpio, 0);
  178. msleep(100);
  179. gpio_set_value(imx6_pcie->reset_gpio, 1);
  180. return 0;
  181. }
  182. static int imx6_pcie_deassert_core_reset(struct pcie_port *pp)
  183. {
  184. struct imx6_pcie *imx6_pcie = to_imx6_pcie(pp);
  185. int ret;
  186. if (gpio_is_valid(imx6_pcie->power_on_gpio))
  187. gpio_set_value(imx6_pcie->power_on_gpio, 1);
  188. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1,
  189. IMX6Q_GPR1_PCIE_TEST_PD, 0 << 18);
  190. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR1,
  191. IMX6Q_GPR1_PCIE_REF_CLK_EN, 1 << 16);
  192. ret = clk_prepare_enable(imx6_pcie->sata_ref_100m);
  193. if (ret) {
  194. dev_err(pp->dev, "unable to enable sata_ref_100m\n");
  195. goto err_sata_ref;
  196. }
  197. ret = clk_prepare_enable(imx6_pcie->pcie_ref_125m);
  198. if (ret) {
  199. dev_err(pp->dev, "unable to enable pcie_ref_125m\n");
  200. goto err_pcie_ref;
  201. }
  202. ret = clk_prepare_enable(imx6_pcie->lvds_gate);
  203. if (ret) {
  204. dev_err(pp->dev, "unable to enable lvds_gate\n");
  205. goto err_lvds_gate;
  206. }
  207. ret = clk_prepare_enable(imx6_pcie->pcie_axi);
  208. if (ret) {
  209. dev_err(pp->dev, "unable to enable pcie_axi\n");
  210. goto err_pcie_axi;
  211. }
  212. /* allow the clocks to stabilize */
  213. usleep_range(200, 500);
  214. return 0;
  215. err_pcie_axi:
  216. clk_disable_unprepare(imx6_pcie->lvds_gate);
  217. err_lvds_gate:
  218. clk_disable_unprepare(imx6_pcie->pcie_ref_125m);
  219. err_pcie_ref:
  220. clk_disable_unprepare(imx6_pcie->sata_ref_100m);
  221. err_sata_ref:
  222. return ret;
  223. }
  224. static void imx6_pcie_init_phy(struct pcie_port *pp)
  225. {
  226. struct imx6_pcie *imx6_pcie = to_imx6_pcie(pp);
  227. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12,
  228. IMX6Q_GPR12_PCIE_CTL_2, 0 << 10);
  229. /* configure constant input signal to the pcie ctrl and phy */
  230. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12,
  231. IMX6Q_GPR12_DEVICE_TYPE, PCI_EXP_TYPE_ROOT_PORT << 12);
  232. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12,
  233. IMX6Q_GPR12_LOS_LEVEL, 9 << 4);
  234. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8,
  235. IMX6Q_GPR8_TX_DEEMPH_GEN1, 0 << 0);
  236. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8,
  237. IMX6Q_GPR8_TX_DEEMPH_GEN2_3P5DB, 0 << 6);
  238. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8,
  239. IMX6Q_GPR8_TX_DEEMPH_GEN2_6DB, 20 << 12);
  240. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8,
  241. IMX6Q_GPR8_TX_SWING_FULL, 127 << 18);
  242. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR8,
  243. IMX6Q_GPR8_TX_SWING_LOW, 127 << 25);
  244. }
  245. static void imx6_pcie_host_init(struct pcie_port *pp)
  246. {
  247. int count = 0;
  248. struct imx6_pcie *imx6_pcie = to_imx6_pcie(pp);
  249. imx6_pcie_assert_core_reset(pp);
  250. imx6_pcie_init_phy(pp);
  251. imx6_pcie_deassert_core_reset(pp);
  252. dw_pcie_setup_rc(pp);
  253. regmap_update_bits(imx6_pcie->iomuxc_gpr, IOMUXC_GPR12,
  254. IMX6Q_GPR12_PCIE_CTL_2, 1 << 10);
  255. while (!dw_pcie_link_up(pp)) {
  256. usleep_range(100, 1000);
  257. count++;
  258. if (count >= 10) {
  259. dev_err(pp->dev, "phy link never came up\n");
  260. dev_dbg(pp->dev,
  261. "DEBUG_R0: 0x%08x, DEBUG_R1: 0x%08x\n",
  262. readl(pp->dbi_base + PCIE_PHY_DEBUG_R0),
  263. readl(pp->dbi_base + PCIE_PHY_DEBUG_R1));
  264. break;
  265. }
  266. }
  267. return;
  268. }
  269. static int imx6_pcie_link_up(struct pcie_port *pp)
  270. {
  271. u32 rc, ltssm, rx_valid, temp;
  272. /* link is debug bit 36, debug register 1 starts at bit 32 */
  273. rc = readl(pp->dbi_base + PCIE_PHY_DEBUG_R1) & (0x1 << (36 - 32));
  274. if (rc)
  275. return -EAGAIN;
  276. /*
  277. * From L0, initiate MAC entry to gen2 if EP/RC supports gen2.
  278. * Wait 2ms (LTSSM timeout is 24ms, PHY lock is ~5us in gen2).
  279. * If (MAC/LTSSM.state == Recovery.RcvrLock)
  280. * && (PHY/rx_valid==0) then pulse PHY/rx_reset. Transition
  281. * to gen2 is stuck
  282. */
  283. pcie_phy_read(pp->dbi_base, PCIE_PHY_RX_ASIC_OUT, &rx_valid);
  284. ltssm = readl(pp->dbi_base + PCIE_PHY_DEBUG_R0) & 0x3F;
  285. if (rx_valid & 0x01)
  286. return 0;
  287. if (ltssm != 0x0d)
  288. return 0;
  289. dev_err(pp->dev, "transition to gen2 is stuck, reset PHY!\n");
  290. pcie_phy_read(pp->dbi_base,
  291. PHY_RX_OVRD_IN_LO, &temp);
  292. temp |= (PHY_RX_OVRD_IN_LO_RX_DATA_EN
  293. | PHY_RX_OVRD_IN_LO_RX_PLL_EN);
  294. pcie_phy_write(pp->dbi_base,
  295. PHY_RX_OVRD_IN_LO, temp);
  296. usleep_range(2000, 3000);
  297. pcie_phy_read(pp->dbi_base,
  298. PHY_RX_OVRD_IN_LO, &temp);
  299. temp &= ~(PHY_RX_OVRD_IN_LO_RX_DATA_EN
  300. | PHY_RX_OVRD_IN_LO_RX_PLL_EN);
  301. pcie_phy_write(pp->dbi_base,
  302. PHY_RX_OVRD_IN_LO, temp);
  303. return 0;
  304. }
  305. static struct pcie_host_ops imx6_pcie_host_ops = {
  306. .link_up = imx6_pcie_link_up,
  307. .host_init = imx6_pcie_host_init,
  308. };
  309. static int imx6_add_pcie_port(struct pcie_port *pp,
  310. struct platform_device *pdev)
  311. {
  312. int ret;
  313. pp->irq = platform_get_irq(pdev, 0);
  314. if (!pp->irq) {
  315. dev_err(&pdev->dev, "failed to get irq\n");
  316. return -ENODEV;
  317. }
  318. pp->root_bus_nr = -1;
  319. pp->ops = &imx6_pcie_host_ops;
  320. spin_lock_init(&pp->conf_lock);
  321. ret = dw_pcie_host_init(pp);
  322. if (ret) {
  323. dev_err(&pdev->dev, "failed to initialize host\n");
  324. return ret;
  325. }
  326. return 0;
  327. }
  328. static int __init imx6_pcie_probe(struct platform_device *pdev)
  329. {
  330. struct imx6_pcie *imx6_pcie;
  331. struct pcie_port *pp;
  332. struct device_node *np = pdev->dev.of_node;
  333. struct resource *dbi_base;
  334. int ret;
  335. imx6_pcie = devm_kzalloc(&pdev->dev, sizeof(*imx6_pcie), GFP_KERNEL);
  336. if (!imx6_pcie)
  337. return -ENOMEM;
  338. pp = &imx6_pcie->pp;
  339. pp->dev = &pdev->dev;
  340. /* Added for PCI abort handling */
  341. hook_fault_code(16 + 6, imx6q_pcie_abort_handler, SIGBUS, 0,
  342. "imprecise external abort");
  343. dbi_base = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  344. if (!dbi_base) {
  345. dev_err(&pdev->dev, "dbi_base memory resource not found\n");
  346. return -ENODEV;
  347. }
  348. pp->dbi_base = devm_ioremap_resource(&pdev->dev, dbi_base);
  349. if (IS_ERR(pp->dbi_base)) {
  350. ret = PTR_ERR(pp->dbi_base);
  351. goto err;
  352. }
  353. /* Fetch GPIOs */
  354. imx6_pcie->reset_gpio = of_get_named_gpio(np, "reset-gpio", 0);
  355. if (!gpio_is_valid(imx6_pcie->reset_gpio)) {
  356. dev_err(&pdev->dev, "no reset-gpio defined\n");
  357. ret = -ENODEV;
  358. }
  359. ret = devm_gpio_request_one(&pdev->dev,
  360. imx6_pcie->reset_gpio,
  361. GPIOF_OUT_INIT_LOW,
  362. "PCIe reset");
  363. if (ret) {
  364. dev_err(&pdev->dev, "unable to get reset gpio\n");
  365. goto err;
  366. }
  367. imx6_pcie->power_on_gpio = of_get_named_gpio(np, "power-on-gpio", 0);
  368. if (gpio_is_valid(imx6_pcie->power_on_gpio)) {
  369. ret = devm_gpio_request_one(&pdev->dev,
  370. imx6_pcie->power_on_gpio,
  371. GPIOF_OUT_INIT_LOW,
  372. "PCIe power enable");
  373. if (ret) {
  374. dev_err(&pdev->dev, "unable to get power-on gpio\n");
  375. goto err;
  376. }
  377. }
  378. imx6_pcie->wake_up_gpio = of_get_named_gpio(np, "wake-up-gpio", 0);
  379. if (gpio_is_valid(imx6_pcie->wake_up_gpio)) {
  380. ret = devm_gpio_request_one(&pdev->dev,
  381. imx6_pcie->wake_up_gpio,
  382. GPIOF_IN,
  383. "PCIe wake up");
  384. if (ret) {
  385. dev_err(&pdev->dev, "unable to get wake-up gpio\n");
  386. goto err;
  387. }
  388. }
  389. imx6_pcie->disable_gpio = of_get_named_gpio(np, "disable-gpio", 0);
  390. if (gpio_is_valid(imx6_pcie->disable_gpio)) {
  391. ret = devm_gpio_request_one(&pdev->dev,
  392. imx6_pcie->disable_gpio,
  393. GPIOF_OUT_INIT_HIGH,
  394. "PCIe disable endpoint");
  395. if (ret) {
  396. dev_err(&pdev->dev, "unable to get disable-ep gpio\n");
  397. goto err;
  398. }
  399. }
  400. /* Fetch clocks */
  401. imx6_pcie->lvds_gate = devm_clk_get(&pdev->dev, "lvds_gate");
  402. if (IS_ERR(imx6_pcie->lvds_gate)) {
  403. dev_err(&pdev->dev,
  404. "lvds_gate clock select missing or invalid\n");
  405. ret = PTR_ERR(imx6_pcie->lvds_gate);
  406. goto err;
  407. }
  408. imx6_pcie->sata_ref_100m = devm_clk_get(&pdev->dev, "sata_ref_100m");
  409. if (IS_ERR(imx6_pcie->sata_ref_100m)) {
  410. dev_err(&pdev->dev,
  411. "sata_ref_100m clock source missing or invalid\n");
  412. ret = PTR_ERR(imx6_pcie->sata_ref_100m);
  413. goto err;
  414. }
  415. imx6_pcie->pcie_ref_125m = devm_clk_get(&pdev->dev, "pcie_ref_125m");
  416. if (IS_ERR(imx6_pcie->pcie_ref_125m)) {
  417. dev_err(&pdev->dev,
  418. "pcie_ref_125m clock source missing or invalid\n");
  419. ret = PTR_ERR(imx6_pcie->pcie_ref_125m);
  420. goto err;
  421. }
  422. imx6_pcie->pcie_axi = devm_clk_get(&pdev->dev, "pcie_axi");
  423. if (IS_ERR(imx6_pcie->pcie_axi)) {
  424. dev_err(&pdev->dev,
  425. "pcie_axi clock source missing or invalid\n");
  426. ret = PTR_ERR(imx6_pcie->pcie_axi);
  427. goto err;
  428. }
  429. /* Grab GPR config register range */
  430. imx6_pcie->iomuxc_gpr =
  431. syscon_regmap_lookup_by_compatible("fsl,imx6q-iomuxc-gpr");
  432. if (IS_ERR(imx6_pcie->iomuxc_gpr)) {
  433. dev_err(&pdev->dev, "unable to find iomuxc registers\n");
  434. ret = PTR_ERR(imx6_pcie->iomuxc_gpr);
  435. goto err;
  436. }
  437. ret = imx6_add_pcie_port(pp, pdev);
  438. if (ret < 0)
  439. goto err;
  440. platform_set_drvdata(pdev, imx6_pcie);
  441. return 0;
  442. err:
  443. return ret;
  444. }
  445. static const struct of_device_id imx6_pcie_of_match[] = {
  446. { .compatible = "fsl,imx6q-pcie", },
  447. {},
  448. };
  449. MODULE_DEVICE_TABLE(of, imx6_pcie_of_match);
  450. static struct platform_driver imx6_pcie_driver = {
  451. .driver = {
  452. .name = "imx6q-pcie",
  453. .owner = THIS_MODULE,
  454. .of_match_table = of_match_ptr(imx6_pcie_of_match),
  455. },
  456. };
  457. /* Freescale PCIe driver does not allow module unload */
  458. static int __init imx6_pcie_init(void)
  459. {
  460. return platform_driver_probe(&imx6_pcie_driver, imx6_pcie_probe);
  461. }
  462. module_init(imx6_pcie_init);
  463. MODULE_AUTHOR("Sean Cross <xobs@kosagi.com>");
  464. MODULE_DESCRIPTION("Freescale i.MX6 PCIe host controller driver");
  465. MODULE_LICENSE("GPL v2");