pcie_rockchip.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Rockchip AXI PCIe host controller driver
  4. *
  5. * Copyright (c) 2016 Rockchip, Inc.
  6. * Copyright (c) 2020 Amarula Solutions(India)
  7. * Copyright (c) 2020 Jagan Teki <jagan@amarulasolutions.com>
  8. * Copyright (c) 2019 Patrick Wildt <patrick@blueri.se>
  9. * Copyright (c) 2018 Mark Kettenis <kettenis@openbsd.org>
  10. *
  11. * Bits taken from Linux Rockchip PCIe host controller.
  12. */
  13. #include <common.h>
  14. #include <dm.h>
  15. #include <dm/device_compat.h>
  16. #include <generic-phy.h>
  17. #include <pci.h>
  18. #include <power/regulator.h>
  19. #include <reset.h>
  20. #include <asm-generic/gpio.h>
  21. #include <linux/iopoll.h>
  22. #define HIWORD_UPDATE(mask, val) (((mask) << 16) | (val))
  23. #define HIWORD_UPDATE_BIT(val) HIWORD_UPDATE(val, val)
  24. #define ENCODE_LANES(x) ((((x) >> 1) & 3) << 4)
  25. #define PCIE_CLIENT_BASE 0x0
  26. #define PCIE_CLIENT_CONFIG (PCIE_CLIENT_BASE + 0x00)
  27. #define PCIE_CLIENT_CONF_ENABLE HIWORD_UPDATE_BIT(0x0001)
  28. #define PCIE_CLIENT_LINK_TRAIN_ENABLE HIWORD_UPDATE_BIT(0x0002)
  29. #define PCIE_CLIENT_MODE_RC HIWORD_UPDATE_BIT(0x0040)
  30. #define PCIE_CLIENT_GEN_SEL_1 HIWORD_UPDATE(0x0080, 0)
  31. #define PCIE_CLIENT_BASIC_STATUS1 0x0048
  32. #define PCIE_CLIENT_LINK_STATUS_UP GENMASK(21, 20)
  33. #define PCIE_CLIENT_LINK_STATUS_MASK GENMASK(21, 20)
  34. #define PCIE_LINK_UP(x) \
  35. (((x) & PCIE_CLIENT_LINK_STATUS_MASK) == PCIE_CLIENT_LINK_STATUS_UP)
  36. #define PCIE_RC_NORMAL_BASE 0x800000
  37. #define PCIE_LM_BASE 0x900000
  38. #define PCIE_LM_VENDOR_ID (PCIE_LM_BASE + 0x44)
  39. #define PCIE_LM_VENDOR_ROCKCHIP 0x1d87
  40. #define PCIE_LM_RCBAR (PCIE_LM_BASE + 0x300)
  41. #define PCIE_LM_RCBARPIE BIT(19)
  42. #define PCIE_LM_RCBARPIS BIT(20)
  43. #define PCIE_RC_BASE 0xa00000
  44. #define PCIE_RC_CONFIG_DCR (PCIE_RC_BASE + 0x0c4)
  45. #define PCIE_RC_CONFIG_DCR_CSPL_SHIFT 18
  46. #define PCIE_RC_CONFIG_DCR_CPLS_SHIFT 26
  47. #define PCIE_RC_PCIE_LCAP (PCIE_RC_BASE + 0x0cc)
  48. #define PCIE_RC_PCIE_LCAP_APMS_L0S BIT(10)
  49. #define PCIE_ATR_BASE 0xc00000
  50. #define PCIE_ATR_OB_ADDR0(i) (PCIE_ATR_BASE + 0x000 + (i) * 0x20)
  51. #define PCIE_ATR_OB_ADDR1(i) (PCIE_ATR_BASE + 0x004 + (i) * 0x20)
  52. #define PCIE_ATR_OB_DESC0(i) (PCIE_ATR_BASE + 0x008 + (i) * 0x20)
  53. #define PCIE_ATR_OB_DESC1(i) (PCIE_ATR_BASE + 0x00c + (i) * 0x20)
  54. #define PCIE_ATR_IB_ADDR0(i) (PCIE_ATR_BASE + 0x800 + (i) * 0x8)
  55. #define PCIE_ATR_IB_ADDR1(i) (PCIE_ATR_BASE + 0x804 + (i) * 0x8)
  56. #define PCIE_ATR_HDR_MEM 0x2
  57. #define PCIE_ATR_HDR_IO 0x6
  58. #define PCIE_ATR_HDR_CFG_TYPE0 0xa
  59. #define PCIE_ATR_HDR_CFG_TYPE1 0xb
  60. #define PCIE_ATR_HDR_RID BIT(23)
  61. #define PCIE_ATR_OB_REGION0_SIZE (32 * 1024 * 1024)
  62. #define PCIE_ATR_OB_REGION_SIZE (1 * 1024 * 1024)
  63. struct rockchip_pcie {
  64. fdt_addr_t axi_base;
  65. fdt_addr_t apb_base;
  66. int first_busno;
  67. struct udevice *dev;
  68. /* resets */
  69. struct reset_ctl core_rst;
  70. struct reset_ctl mgmt_rst;
  71. struct reset_ctl mgmt_sticky_rst;
  72. struct reset_ctl pipe_rst;
  73. struct reset_ctl pm_rst;
  74. struct reset_ctl pclk_rst;
  75. struct reset_ctl aclk_rst;
  76. /* gpio */
  77. struct gpio_desc ep_gpio;
  78. /* vpcie regulators */
  79. struct udevice *vpcie12v;
  80. struct udevice *vpcie3v3;
  81. struct udevice *vpcie1v8;
  82. struct udevice *vpcie0v9;
  83. /* phy */
  84. struct phy pcie_phy;
  85. };
  86. static int rockchip_pcie_rd_conf(const struct udevice *udev, pci_dev_t bdf,
  87. uint offset, ulong *valuep,
  88. enum pci_size_t size)
  89. {
  90. struct rockchip_pcie *priv = dev_get_priv(udev);
  91. unsigned int bus = PCI_BUS(bdf);
  92. unsigned int dev = PCI_DEV(bdf);
  93. int where = PCIE_ECAM_OFFSET(PCI_BUS(bdf), PCI_DEV(bdf), PCI_FUNC(bdf), offset & ~0x3);
  94. ulong value;
  95. if (bus == priv->first_busno && dev == 0) {
  96. value = readl(priv->apb_base + PCIE_RC_NORMAL_BASE + where);
  97. *valuep = pci_conv_32_to_size(value, offset, size);
  98. return 0;
  99. }
  100. if ((bus == priv->first_busno + 1) && dev == 0) {
  101. value = readl(priv->axi_base + where);
  102. *valuep = pci_conv_32_to_size(value, offset, size);
  103. return 0;
  104. }
  105. *valuep = pci_get_ff(size);
  106. return 0;
  107. }
  108. static int rockchip_pcie_wr_conf(struct udevice *udev, pci_dev_t bdf,
  109. uint offset, ulong value,
  110. enum pci_size_t size)
  111. {
  112. struct rockchip_pcie *priv = dev_get_priv(udev);
  113. unsigned int bus = PCI_BUS(bdf);
  114. unsigned int dev = PCI_DEV(bdf);
  115. int where = PCIE_ECAM_OFFSET(PCI_BUS(bdf), PCI_DEV(bdf), PCI_FUNC(bdf), offset & ~0x3);
  116. ulong old;
  117. if (bus == priv->first_busno && dev == 0) {
  118. old = readl(priv->apb_base + PCIE_RC_NORMAL_BASE + where);
  119. value = pci_conv_size_to_32(old, value, offset, size);
  120. writel(value, priv->apb_base + PCIE_RC_NORMAL_BASE + where);
  121. return 0;
  122. }
  123. if ((bus == priv->first_busno + 1) && dev == 0) {
  124. old = readl(priv->axi_base + where);
  125. value = pci_conv_size_to_32(old, value, offset, size);
  126. writel(value, priv->axi_base + where);
  127. return 0;
  128. }
  129. return 0;
  130. }
  131. static int rockchip_pcie_atr_init(struct rockchip_pcie *priv)
  132. {
  133. struct udevice *ctlr = pci_get_controller(priv->dev);
  134. struct pci_controller *hose = dev_get_uclass_priv(ctlr);
  135. u64 addr, size, offset;
  136. u32 type;
  137. int i, region;
  138. /* Use region 0 to map PCI configuration space. */
  139. writel(25 - 1, priv->apb_base + PCIE_ATR_OB_ADDR0(0));
  140. writel(0, priv->apb_base + PCIE_ATR_OB_ADDR1(0));
  141. writel(PCIE_ATR_HDR_CFG_TYPE0 | PCIE_ATR_HDR_RID,
  142. priv->apb_base + PCIE_ATR_OB_DESC0(0));
  143. writel(0, priv->apb_base + PCIE_ATR_OB_DESC1(0));
  144. for (i = 0; i < hose->region_count; i++) {
  145. if (hose->regions[i].flags == PCI_REGION_SYS_MEMORY)
  146. continue;
  147. if (hose->regions[i].flags == PCI_REGION_IO)
  148. type = PCIE_ATR_HDR_IO;
  149. else
  150. type = PCIE_ATR_HDR_MEM;
  151. /* Only support identity mappings. */
  152. if (hose->regions[i].bus_start !=
  153. hose->regions[i].phys_start)
  154. return -EINVAL;
  155. /* Only support mappings aligned on a region boundary. */
  156. addr = hose->regions[i].bus_start;
  157. if (addr & (PCIE_ATR_OB_REGION_SIZE - 1))
  158. return -EINVAL;
  159. /* Mappings should lie between AXI and APB regions. */
  160. size = hose->regions[i].size;
  161. if (addr < (u64)priv->axi_base + PCIE_ATR_OB_REGION0_SIZE)
  162. return -EINVAL;
  163. if (addr + size > (u64)priv->apb_base)
  164. return -EINVAL;
  165. offset = addr - (u64)priv->axi_base - PCIE_ATR_OB_REGION0_SIZE;
  166. region = 1 + (offset / PCIE_ATR_OB_REGION_SIZE);
  167. while (size > 0) {
  168. writel(32 - 1,
  169. priv->apb_base + PCIE_ATR_OB_ADDR0(region));
  170. writel(0, priv->apb_base + PCIE_ATR_OB_ADDR1(region));
  171. writel(type | PCIE_ATR_HDR_RID,
  172. priv->apb_base + PCIE_ATR_OB_DESC0(region));
  173. writel(0, priv->apb_base + PCIE_ATR_OB_DESC1(region));
  174. addr += PCIE_ATR_OB_REGION_SIZE;
  175. size -= PCIE_ATR_OB_REGION_SIZE;
  176. region++;
  177. }
  178. }
  179. /* Passthrough inbound translations unmodified. */
  180. writel(32 - 1, priv->apb_base + PCIE_ATR_IB_ADDR0(2));
  181. writel(0, priv->apb_base + PCIE_ATR_IB_ADDR1(2));
  182. return 0;
  183. }
  184. static int rockchip_pcie_init_port(struct udevice *dev)
  185. {
  186. struct rockchip_pcie *priv = dev_get_priv(dev);
  187. u32 cr, val, status;
  188. int ret;
  189. if (dm_gpio_is_valid(&priv->ep_gpio))
  190. dm_gpio_set_value(&priv->ep_gpio, 0);
  191. ret = reset_assert(&priv->aclk_rst);
  192. if (ret) {
  193. dev_err(dev, "failed to assert aclk reset (ret=%d)\n", ret);
  194. return ret;
  195. }
  196. ret = reset_assert(&priv->pclk_rst);
  197. if (ret) {
  198. dev_err(dev, "failed to assert pclk reset (ret=%d)\n", ret);
  199. return ret;
  200. }
  201. ret = reset_assert(&priv->pm_rst);
  202. if (ret) {
  203. dev_err(dev, "failed to assert pm reset (ret=%d)\n", ret);
  204. return ret;
  205. }
  206. ret = generic_phy_init(&priv->pcie_phy);
  207. if (ret) {
  208. dev_err(dev, "failed to init phy (ret=%d)\n", ret);
  209. goto err_exit_phy;
  210. }
  211. ret = reset_assert(&priv->core_rst);
  212. if (ret) {
  213. dev_err(dev, "failed to assert core reset (ret=%d)\n", ret);
  214. goto err_exit_phy;
  215. }
  216. ret = reset_assert(&priv->mgmt_rst);
  217. if (ret) {
  218. dev_err(dev, "failed to assert mgmt reset (ret=%d)\n", ret);
  219. goto err_exit_phy;
  220. }
  221. ret = reset_assert(&priv->mgmt_sticky_rst);
  222. if (ret) {
  223. dev_err(dev, "failed to assert mgmt-sticky reset (ret=%d)\n",
  224. ret);
  225. goto err_exit_phy;
  226. }
  227. ret = reset_assert(&priv->pipe_rst);
  228. if (ret) {
  229. dev_err(dev, "failed to assert pipe reset (ret=%d)\n", ret);
  230. goto err_exit_phy;
  231. }
  232. udelay(10);
  233. ret = reset_deassert(&priv->pm_rst);
  234. if (ret) {
  235. dev_err(dev, "failed to deassert pm reset (ret=%d)\n", ret);
  236. goto err_exit_phy;
  237. }
  238. ret = reset_deassert(&priv->aclk_rst);
  239. if (ret) {
  240. dev_err(dev, "failed to deassert aclk reset (ret=%d)\n", ret);
  241. goto err_exit_phy;
  242. }
  243. ret = reset_deassert(&priv->pclk_rst);
  244. if (ret) {
  245. dev_err(dev, "failed to deassert pclk reset (ret=%d)\n", ret);
  246. goto err_exit_phy;
  247. }
  248. /* Select GEN1 for now */
  249. cr = PCIE_CLIENT_GEN_SEL_1;
  250. /* Set Root complex mode */
  251. cr |= PCIE_CLIENT_CONF_ENABLE | PCIE_CLIENT_MODE_RC;
  252. writel(cr, priv->apb_base + PCIE_CLIENT_CONFIG);
  253. ret = generic_phy_power_on(&priv->pcie_phy);
  254. if (ret) {
  255. dev_err(dev, "failed to power on phy (ret=%d)\n", ret);
  256. goto err_power_off_phy;
  257. }
  258. ret = reset_deassert(&priv->mgmt_sticky_rst);
  259. if (ret) {
  260. dev_err(dev, "failed to deassert mgmt-sticky reset (ret=%d)\n",
  261. ret);
  262. goto err_power_off_phy;
  263. }
  264. ret = reset_deassert(&priv->core_rst);
  265. if (ret) {
  266. dev_err(dev, "failed to deassert core reset (ret=%d)\n", ret);
  267. goto err_power_off_phy;
  268. }
  269. ret = reset_deassert(&priv->mgmt_rst);
  270. if (ret) {
  271. dev_err(dev, "failed to deassert mgmt reset (ret=%d)\n", ret);
  272. goto err_power_off_phy;
  273. }
  274. ret = reset_deassert(&priv->pipe_rst);
  275. if (ret) {
  276. dev_err(dev, "failed to deassert pipe reset (ret=%d)\n", ret);
  277. goto err_power_off_phy;
  278. }
  279. /* Enable Gen1 training */
  280. writel(PCIE_CLIENT_LINK_TRAIN_ENABLE,
  281. priv->apb_base + PCIE_CLIENT_CONFIG);
  282. if (dm_gpio_is_valid(&priv->ep_gpio))
  283. dm_gpio_set_value(&priv->ep_gpio, 1);
  284. ret = readl_poll_sleep_timeout
  285. (priv->apb_base + PCIE_CLIENT_BASIC_STATUS1,
  286. status, PCIE_LINK_UP(status), 20, 500 * 1000);
  287. if (ret) {
  288. dev_err(dev, "PCIe link training gen1 timeout!\n");
  289. goto err_power_off_phy;
  290. }
  291. /* Initialize Root Complex registers. */
  292. writel(PCIE_LM_VENDOR_ROCKCHIP, priv->apb_base + PCIE_LM_VENDOR_ID);
  293. writel(PCI_CLASS_BRIDGE_PCI_NORMAL << 8,
  294. priv->apb_base + PCIE_RC_BASE + PCI_CLASS_REVISION);
  295. writel(PCIE_LM_RCBARPIE | PCIE_LM_RCBARPIS,
  296. priv->apb_base + PCIE_LM_RCBAR);
  297. if (dev_read_bool(dev, "aspm-no-l0s")) {
  298. val = readl(priv->apb_base + PCIE_RC_PCIE_LCAP);
  299. val &= ~PCIE_RC_PCIE_LCAP_APMS_L0S;
  300. writel(val, priv->apb_base + PCIE_RC_PCIE_LCAP);
  301. }
  302. /* Configure Address Translation. */
  303. ret = rockchip_pcie_atr_init(priv);
  304. if (ret) {
  305. dev_err(dev, "PCIE-%d: ATR init failed\n", dev_seq(dev));
  306. goto err_power_off_phy;
  307. }
  308. return 0;
  309. err_power_off_phy:
  310. generic_phy_power_off(&priv->pcie_phy);
  311. err_exit_phy:
  312. generic_phy_exit(&priv->pcie_phy);
  313. return ret;
  314. }
  315. static int rockchip_pcie_set_vpcie(struct udevice *dev)
  316. {
  317. struct rockchip_pcie *priv = dev_get_priv(dev);
  318. int ret;
  319. ret = regulator_set_enable_if_allowed(priv->vpcie12v, true);
  320. if (ret && ret != -ENOSYS) {
  321. dev_err(dev, "failed to enable vpcie12v (ret=%d)\n", ret);
  322. return ret;
  323. }
  324. ret = regulator_set_enable_if_allowed(priv->vpcie3v3, true);
  325. if (ret && ret != -ENOSYS) {
  326. dev_err(dev, "failed to enable vpcie3v3 (ret=%d)\n", ret);
  327. goto err_disable_12v;
  328. }
  329. ret = regulator_set_enable_if_allowed(priv->vpcie1v8, true);
  330. if (ret && ret != -ENOSYS) {
  331. dev_err(dev, "failed to enable vpcie1v8 (ret=%d)\n", ret);
  332. goto err_disable_3v3;
  333. }
  334. ret = regulator_set_enable_if_allowed(priv->vpcie0v9, true);
  335. if (ret && ret != -ENOSYS) {
  336. dev_err(dev, "failed to enable vpcie0v9 (ret=%d)\n", ret);
  337. goto err_disable_1v8;
  338. }
  339. return 0;
  340. err_disable_1v8:
  341. regulator_set_enable_if_allowed(priv->vpcie1v8, false);
  342. err_disable_3v3:
  343. regulator_set_enable_if_allowed(priv->vpcie3v3, false);
  344. err_disable_12v:
  345. regulator_set_enable_if_allowed(priv->vpcie12v, false);
  346. return ret;
  347. }
  348. static int rockchip_pcie_parse_dt(struct udevice *dev)
  349. {
  350. struct rockchip_pcie *priv = dev_get_priv(dev);
  351. int ret;
  352. priv->axi_base = dev_read_addr_name(dev, "axi-base");
  353. if (priv->axi_base == FDT_ADDR_T_NONE)
  354. return -EINVAL;
  355. priv->apb_base = dev_read_addr_name(dev, "apb-base");
  356. if (priv->apb_base == FDT_ADDR_T_NONE)
  357. return -EINVAL;
  358. ret = reset_get_by_name(dev, "core", &priv->core_rst);
  359. if (ret) {
  360. dev_err(dev, "failed to get core reset (ret=%d)\n", ret);
  361. return ret;
  362. }
  363. ret = reset_get_by_name(dev, "mgmt", &priv->mgmt_rst);
  364. if (ret) {
  365. dev_err(dev, "failed to get mgmt reset (ret=%d)\n", ret);
  366. return ret;
  367. }
  368. ret = reset_get_by_name(dev, "mgmt-sticky", &priv->mgmt_sticky_rst);
  369. if (ret) {
  370. dev_err(dev, "failed to get mgmt-sticky reset (ret=%d)\n", ret);
  371. return ret;
  372. }
  373. ret = reset_get_by_name(dev, "pipe", &priv->pipe_rst);
  374. if (ret) {
  375. dev_err(dev, "failed to get pipe reset (ret=%d)\n", ret);
  376. return ret;
  377. }
  378. ret = reset_get_by_name(dev, "pm", &priv->pm_rst);
  379. if (ret) {
  380. dev_err(dev, "failed to get pm reset (ret=%d)\n", ret);
  381. return ret;
  382. }
  383. ret = reset_get_by_name(dev, "pclk", &priv->pclk_rst);
  384. if (ret) {
  385. dev_err(dev, "failed to get pclk reset (ret=%d)\n", ret);
  386. return ret;
  387. }
  388. ret = reset_get_by_name(dev, "aclk", &priv->aclk_rst);
  389. if (ret) {
  390. dev_err(dev, "failed to get aclk reset (ret=%d)\n", ret);
  391. return ret;
  392. }
  393. ret = device_get_supply_regulator(dev, "vpcie12v-supply",
  394. &priv->vpcie12v);
  395. if (ret && ret != -ENOENT) {
  396. dev_err(dev, "failed to get vpcie12v supply (ret=%d)\n", ret);
  397. return ret;
  398. }
  399. ret = device_get_supply_regulator(dev, "vpcie3v3-supply",
  400. &priv->vpcie3v3);
  401. if (ret && ret != -ENOENT) {
  402. dev_err(dev, "failed to get vpcie3v3 supply (ret=%d)\n", ret);
  403. return ret;
  404. }
  405. ret = device_get_supply_regulator(dev, "vpcie1v8-supply",
  406. &priv->vpcie1v8);
  407. if (ret && ret != -ENOENT) {
  408. dev_err(dev, "failed to get vpcie1v8 supply (ret=%d)\n", ret);
  409. return ret;
  410. }
  411. ret = device_get_supply_regulator(dev, "vpcie0v9-supply",
  412. &priv->vpcie0v9);
  413. if (ret && ret != -ENOENT) {
  414. dev_err(dev, "failed to get vpcie0v9 supply (ret=%d)\n", ret);
  415. return ret;
  416. }
  417. ret = generic_phy_get_by_index(dev, 0, &priv->pcie_phy);
  418. if (ret) {
  419. dev_err(dev, "failed to get pcie-phy (ret=%d)\n", ret);
  420. return ret;
  421. }
  422. ret = gpio_request_by_name(dev, "ep-gpios", 0,
  423. &priv->ep_gpio, GPIOD_IS_OUT);
  424. if (ret) {
  425. dev_err(dev, "failed to find ep-gpios property\n");
  426. return ret;
  427. }
  428. return 0;
  429. }
  430. static int rockchip_pcie_probe(struct udevice *dev)
  431. {
  432. struct rockchip_pcie *priv = dev_get_priv(dev);
  433. struct udevice *ctlr = pci_get_controller(dev);
  434. struct pci_controller *hose = dev_get_uclass_priv(ctlr);
  435. int ret;
  436. priv->first_busno = dev_seq(dev);
  437. priv->dev = dev;
  438. ret = rockchip_pcie_parse_dt(dev);
  439. if (ret)
  440. return ret;
  441. ret = rockchip_pcie_set_vpcie(dev);
  442. if (ret)
  443. goto err_gpio_free;
  444. ret = rockchip_pcie_init_port(dev);
  445. if (ret)
  446. goto err_disable_vpcie;
  447. dev_info(dev, "PCIE-%d: Link up (Bus%d)\n",
  448. dev_seq(dev), hose->first_busno);
  449. return 0;
  450. err_disable_vpcie:
  451. regulator_set_enable_if_allowed(priv->vpcie0v9, false);
  452. regulator_set_enable_if_allowed(priv->vpcie1v8, false);
  453. regulator_set_enable_if_allowed(priv->vpcie3v3, false);
  454. regulator_set_enable_if_allowed(priv->vpcie12v, false);
  455. err_gpio_free:
  456. if (dm_gpio_is_valid(&priv->ep_gpio))
  457. dm_gpio_free(dev, &priv->ep_gpio);
  458. return ret;
  459. }
  460. static const struct dm_pci_ops rockchip_pcie_ops = {
  461. .read_config = rockchip_pcie_rd_conf,
  462. .write_config = rockchip_pcie_wr_conf,
  463. };
  464. static const struct udevice_id rockchip_pcie_ids[] = {
  465. { .compatible = "rockchip,rk3399-pcie" },
  466. { }
  467. };
  468. U_BOOT_DRIVER(rockchip_pcie) = {
  469. .name = "rockchip_pcie",
  470. .id = UCLASS_PCI,
  471. .of_match = rockchip_pcie_ids,
  472. .ops = &rockchip_pcie_ops,
  473. .probe = rockchip_pcie_probe,
  474. .priv_auto = sizeof(struct rockchip_pcie),
  475. };