pci-dra7xx.c (23077B)
1// SPDX-License-Identifier: GPL-2.0 2/* 3 * pcie-dra7xx - PCIe controller driver for TI DRA7xx SoCs 4 * 5 * Copyright (C) 2013-2014 Texas Instruments Incorporated - https://www.ti.com 6 * 7 * Authors: Kishon Vijay Abraham I <kishon@ti.com> 8 */ 9 10#include <linux/clk.h> 11#include <linux/delay.h> 12#include <linux/device.h> 13#include <linux/err.h> 14#include <linux/interrupt.h> 15#include <linux/irq.h> 16#include <linux/irqdomain.h> 17#include <linux/kernel.h> 18#include <linux/module.h> 19#include <linux/of_device.h> 20#include <linux/of_gpio.h> 21#include <linux/of_pci.h> 22#include <linux/pci.h> 23#include <linux/phy/phy.h> 24#include <linux/platform_device.h> 25#include <linux/pm_runtime.h> 26#include <linux/resource.h> 27#include <linux/types.h> 28#include <linux/mfd/syscon.h> 29#include <linux/regmap.h> 30#include <linux/gpio/consumer.h> 31 32#include "../../pci.h" 33#include "pcie-designware.h" 34 35/* PCIe controller wrapper DRA7XX configuration registers */ 36 37#define PCIECTRL_DRA7XX_CONF_IRQSTATUS_MAIN 0x0024 38#define PCIECTRL_DRA7XX_CONF_IRQENABLE_SET_MAIN 0x0028 39#define ERR_SYS BIT(0) 40#define ERR_FATAL BIT(1) 41#define ERR_NONFATAL BIT(2) 42#define ERR_COR BIT(3) 43#define ERR_AXI BIT(4) 44#define ERR_ECRC BIT(5) 45#define PME_TURN_OFF BIT(8) 46#define PME_TO_ACK BIT(9) 47#define PM_PME BIT(10) 48#define LINK_REQ_RST BIT(11) 49#define LINK_UP_EVT BIT(12) 50#define CFG_BME_EVT BIT(13) 51#define CFG_MSE_EVT BIT(14) 52#define INTERRUPTS (ERR_SYS | ERR_FATAL | ERR_NONFATAL | ERR_COR | ERR_AXI | \ 53 ERR_ECRC | PME_TURN_OFF | PME_TO_ACK | PM_PME | \ 54 LINK_REQ_RST | LINK_UP_EVT | CFG_BME_EVT | CFG_MSE_EVT) 55 56#define PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI 0x0034 57#define PCIECTRL_DRA7XX_CONF_IRQENABLE_SET_MSI 0x0038 58#define INTA BIT(0) 59#define INTB BIT(1) 60#define INTC BIT(2) 61#define INTD BIT(3) 62#define MSI BIT(4) 63#define LEG_EP_INTERRUPTS (INTA | INTB | INTC | INTD) 64 65#define PCIECTRL_TI_CONF_DEVICE_TYPE 0x0100 66#define DEVICE_TYPE_EP 0x0 67#define DEVICE_TYPE_LEG_EP 0x1 68#define DEVICE_TYPE_RC 0x4 69 70#define PCIECTRL_DRA7XX_CONF_DEVICE_CMD 0x0104 71#define LTSSM_EN 0x1 72 73#define PCIECTRL_DRA7XX_CONF_PHY_CS 0x010C 74#define LINK_UP BIT(16) 75#define DRA7XX_CPU_TO_BUS_ADDR 0x0FFFFFFF 76 77#define PCIECTRL_TI_CONF_INTX_ASSERT 0x0124 78#define PCIECTRL_TI_CONF_INTX_DEASSERT 0x0128 79 80#define PCIECTRL_TI_CONF_MSI_XMT 0x012c 81#define MSI_REQ_GRANT BIT(0) 82#define MSI_VECTOR_SHIFT 7 83 84#define PCIE_1LANE_2LANE_SELECTION BIT(13) 85#define PCIE_B1C0_MODE_SEL BIT(2) 86#define PCIE_B0_B1_TSYNCEN BIT(0) 87 88struct dra7xx_pcie { 89 struct dw_pcie *pci; 90 void __iomem *base; /* DT ti_conf */ 91 int phy_count; /* DT phy-names count */ 92 struct phy **phy; 93 struct irq_domain *irq_domain; 94 struct clk *clk; 95 enum dw_pcie_device_mode mode; 96}; 97 98struct dra7xx_pcie_of_data { 99 enum dw_pcie_device_mode mode; 100 u32 b1co_mode_sel_mask; 101}; 102 103#define to_dra7xx_pcie(x) dev_get_drvdata((x)->dev) 104 105static inline u32 dra7xx_pcie_readl(struct dra7xx_pcie *pcie, u32 offset) 106{ 107 return readl(pcie->base + offset); 108} 109 110static inline void dra7xx_pcie_writel(struct dra7xx_pcie *pcie, u32 offset, 111 u32 value) 112{ 113 writel(value, pcie->base + offset); 114} 115 116static u64 dra7xx_pcie_cpu_addr_fixup(struct dw_pcie *pci, u64 pci_addr) 117{ 118 return pci_addr & DRA7XX_CPU_TO_BUS_ADDR; 119} 120 121static int dra7xx_pcie_link_up(struct dw_pcie *pci) 122{ 123 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 124 u32 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_PHY_CS); 125 126 return !!(reg & LINK_UP); 127} 128 129static void dra7xx_pcie_stop_link(struct dw_pcie *pci) 130{ 131 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 132 u32 reg; 133 134 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD); 135 reg &= ~LTSSM_EN; 136 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD, reg); 137} 138 139static int dra7xx_pcie_establish_link(struct dw_pcie *pci) 140{ 141 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 142 struct device *dev = pci->dev; 143 u32 reg; 144 145 if (dw_pcie_link_up(pci)) { 146 dev_err(dev, "link is already up\n"); 147 return 0; 148 } 149 150 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD); 151 reg |= LTSSM_EN; 152 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD, reg); 153 154 return 0; 155} 156 157static void dra7xx_pcie_enable_msi_interrupts(struct dra7xx_pcie *dra7xx) 158{ 159 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI, 160 LEG_EP_INTERRUPTS | MSI); 161 162 dra7xx_pcie_writel(dra7xx, 163 PCIECTRL_DRA7XX_CONF_IRQENABLE_SET_MSI, 164 MSI | LEG_EP_INTERRUPTS); 165} 166 167static void dra7xx_pcie_enable_wrapper_interrupts(struct dra7xx_pcie *dra7xx) 168{ 169 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MAIN, 170 INTERRUPTS); 171 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQENABLE_SET_MAIN, 172 INTERRUPTS); 173} 174 175static void dra7xx_pcie_enable_interrupts(struct dra7xx_pcie *dra7xx) 176{ 177 dra7xx_pcie_enable_wrapper_interrupts(dra7xx); 178 dra7xx_pcie_enable_msi_interrupts(dra7xx); 179} 180 181static int dra7xx_pcie_host_init(struct pcie_port *pp) 182{ 183 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); 184 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 185 186 dra7xx_pcie_enable_interrupts(dra7xx); 187 188 return 0; 189} 190 191static int dra7xx_pcie_intx_map(struct irq_domain *domain, unsigned int irq, 192 irq_hw_number_t hwirq) 193{ 194 irq_set_chip_and_handler(irq, &dummy_irq_chip, handle_simple_irq); 195 irq_set_chip_data(irq, domain->host_data); 196 197 return 0; 198} 199 200static const struct irq_domain_ops intx_domain_ops = { 201 .map = dra7xx_pcie_intx_map, 202 .xlate = pci_irqd_intx_xlate, 203}; 204 205static int dra7xx_pcie_handle_msi(struct pcie_port *pp, int index) 206{ 207 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); 208 unsigned long val; 209 int pos; 210 211 val = dw_pcie_readl_dbi(pci, PCIE_MSI_INTR0_STATUS + 212 (index * MSI_REG_CTRL_BLOCK_SIZE)); 213 if (!val) 214 return 0; 215 216 pos = find_first_bit(&val, MAX_MSI_IRQS_PER_CTRL); 217 while (pos != MAX_MSI_IRQS_PER_CTRL) { 218 generic_handle_domain_irq(pp->irq_domain, 219 (index * MAX_MSI_IRQS_PER_CTRL) + pos); 220 pos++; 221 pos = find_next_bit(&val, MAX_MSI_IRQS_PER_CTRL, pos); 222 } 223 224 return 1; 225} 226 227static void dra7xx_pcie_handle_msi_irq(struct pcie_port *pp) 228{ 229 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); 230 int ret, i, count, num_ctrls; 231 232 num_ctrls = pp->num_vectors / MAX_MSI_IRQS_PER_CTRL; 233 234 /** 235 * Need to make sure all MSI status bits read 0 before exiting. 236 * Else, new MSI IRQs are not registered by the wrapper. Have an 237 * upperbound for the loop and exit the IRQ in case of IRQ flood 238 * to avoid locking up system in interrupt context. 239 */ 240 count = 0; 241 do { 242 ret = 0; 243 244 for (i = 0; i < num_ctrls; i++) 245 ret |= dra7xx_pcie_handle_msi(pp, i); 246 count++; 247 } while (ret && count <= 1000); 248 249 if (count > 1000) 250 dev_warn_ratelimited(pci->dev, 251 "Too many MSI IRQs to handle\n"); 252} 253 254static void dra7xx_pcie_msi_irq_handler(struct irq_desc *desc) 255{ 256 struct irq_chip *chip = irq_desc_get_chip(desc); 257 struct dra7xx_pcie *dra7xx; 258 struct dw_pcie *pci; 259 struct pcie_port *pp; 260 unsigned long reg; 261 u32 bit; 262 263 chained_irq_enter(chip, desc); 264 265 pp = irq_desc_get_handler_data(desc); 266 pci = to_dw_pcie_from_pp(pp); 267 dra7xx = to_dra7xx_pcie(pci); 268 269 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI); 270 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MSI, reg); 271 272 switch (reg) { 273 case MSI: 274 dra7xx_pcie_handle_msi_irq(pp); 275 break; 276 case INTA: 277 case INTB: 278 case INTC: 279 case INTD: 280 for_each_set_bit(bit, ®, PCI_NUM_INTX) 281 generic_handle_domain_irq(dra7xx->irq_domain, bit); 282 break; 283 } 284 285 chained_irq_exit(chip, desc); 286} 287 288static irqreturn_t dra7xx_pcie_irq_handler(int irq, void *arg) 289{ 290 struct dra7xx_pcie *dra7xx = arg; 291 struct dw_pcie *pci = dra7xx->pci; 292 struct device *dev = pci->dev; 293 struct dw_pcie_ep *ep = &pci->ep; 294 u32 reg; 295 296 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MAIN); 297 298 if (reg & ERR_SYS) 299 dev_dbg(dev, "System Error\n"); 300 301 if (reg & ERR_FATAL) 302 dev_dbg(dev, "Fatal Error\n"); 303 304 if (reg & ERR_NONFATAL) 305 dev_dbg(dev, "Non Fatal Error\n"); 306 307 if (reg & ERR_COR) 308 dev_dbg(dev, "Correctable Error\n"); 309 310 if (reg & ERR_AXI) 311 dev_dbg(dev, "AXI tag lookup fatal Error\n"); 312 313 if (reg & ERR_ECRC) 314 dev_dbg(dev, "ECRC Error\n"); 315 316 if (reg & PME_TURN_OFF) 317 dev_dbg(dev, 318 "Power Management Event Turn-Off message received\n"); 319 320 if (reg & PME_TO_ACK) 321 dev_dbg(dev, 322 "Power Management Turn-Off Ack message received\n"); 323 324 if (reg & PM_PME) 325 dev_dbg(dev, "PM Power Management Event message received\n"); 326 327 if (reg & LINK_REQ_RST) 328 dev_dbg(dev, "Link Request Reset\n"); 329 330 if (reg & LINK_UP_EVT) { 331 if (dra7xx->mode == DW_PCIE_EP_TYPE) 332 dw_pcie_ep_linkup(ep); 333 dev_dbg(dev, "Link-up state change\n"); 334 } 335 336 if (reg & CFG_BME_EVT) 337 dev_dbg(dev, "CFG 'Bus Master Enable' change\n"); 338 339 if (reg & CFG_MSE_EVT) 340 dev_dbg(dev, "CFG 'Memory Space Enable' change\n"); 341 342 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_IRQSTATUS_MAIN, reg); 343 344 return IRQ_HANDLED; 345} 346 347static int dra7xx_pcie_init_irq_domain(struct pcie_port *pp) 348{ 349 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); 350 struct device *dev = pci->dev; 351 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 352 struct device_node *node = dev->of_node; 353 struct device_node *pcie_intc_node = of_get_next_child(node, NULL); 354 355 if (!pcie_intc_node) { 356 dev_err(dev, "No PCIe Intc node found\n"); 357 return -ENODEV; 358 } 359 360 irq_set_chained_handler_and_data(pp->irq, dra7xx_pcie_msi_irq_handler, 361 pp); 362 dra7xx->irq_domain = irq_domain_add_linear(pcie_intc_node, PCI_NUM_INTX, 363 &intx_domain_ops, pp); 364 of_node_put(pcie_intc_node); 365 if (!dra7xx->irq_domain) { 366 dev_err(dev, "Failed to get a INTx IRQ domain\n"); 367 return -ENODEV; 368 } 369 370 return 0; 371} 372 373static const struct dw_pcie_host_ops dra7xx_pcie_host_ops = { 374 .host_init = dra7xx_pcie_host_init, 375}; 376 377static void dra7xx_pcie_ep_init(struct dw_pcie_ep *ep) 378{ 379 struct dw_pcie *pci = to_dw_pcie_from_ep(ep); 380 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 381 enum pci_barno bar; 382 383 for (bar = 0; bar < PCI_STD_NUM_BARS; bar++) 384 dw_pcie_ep_reset_bar(pci, bar); 385 386 dra7xx_pcie_enable_wrapper_interrupts(dra7xx); 387} 388 389static void dra7xx_pcie_raise_legacy_irq(struct dra7xx_pcie *dra7xx) 390{ 391 dra7xx_pcie_writel(dra7xx, PCIECTRL_TI_CONF_INTX_ASSERT, 0x1); 392 mdelay(1); 393 dra7xx_pcie_writel(dra7xx, PCIECTRL_TI_CONF_INTX_DEASSERT, 0x1); 394} 395 396static void dra7xx_pcie_raise_msi_irq(struct dra7xx_pcie *dra7xx, 397 u8 interrupt_num) 398{ 399 u32 reg; 400 401 reg = (interrupt_num - 1) << MSI_VECTOR_SHIFT; 402 reg |= MSI_REQ_GRANT; 403 dra7xx_pcie_writel(dra7xx, PCIECTRL_TI_CONF_MSI_XMT, reg); 404} 405 406static int dra7xx_pcie_raise_irq(struct dw_pcie_ep *ep, u8 func_no, 407 enum pci_epc_irq_type type, u16 interrupt_num) 408{ 409 struct dw_pcie *pci = to_dw_pcie_from_ep(ep); 410 struct dra7xx_pcie *dra7xx = to_dra7xx_pcie(pci); 411 412 switch (type) { 413 case PCI_EPC_IRQ_LEGACY: 414 dra7xx_pcie_raise_legacy_irq(dra7xx); 415 break; 416 case PCI_EPC_IRQ_MSI: 417 dra7xx_pcie_raise_msi_irq(dra7xx, interrupt_num); 418 break; 419 default: 420 dev_err(pci->dev, "UNKNOWN IRQ type\n"); 421 } 422 423 return 0; 424} 425 426static const struct pci_epc_features dra7xx_pcie_epc_features = { 427 .linkup_notifier = true, 428 .msi_capable = true, 429 .msix_capable = false, 430}; 431 432static const struct pci_epc_features* 433dra7xx_pcie_get_features(struct dw_pcie_ep *ep) 434{ 435 return &dra7xx_pcie_epc_features; 436} 437 438static const struct dw_pcie_ep_ops pcie_ep_ops = { 439 .ep_init = dra7xx_pcie_ep_init, 440 .raise_irq = dra7xx_pcie_raise_irq, 441 .get_features = dra7xx_pcie_get_features, 442}; 443 444static int dra7xx_add_pcie_ep(struct dra7xx_pcie *dra7xx, 445 struct platform_device *pdev) 446{ 447 int ret; 448 struct dw_pcie_ep *ep; 449 struct device *dev = &pdev->dev; 450 struct dw_pcie *pci = dra7xx->pci; 451 452 ep = &pci->ep; 453 ep->ops = &pcie_ep_ops; 454 455 pci->dbi_base = devm_platform_ioremap_resource_byname(pdev, "ep_dbics"); 456 if (IS_ERR(pci->dbi_base)) 457 return PTR_ERR(pci->dbi_base); 458 459 pci->dbi_base2 = 460 devm_platform_ioremap_resource_byname(pdev, "ep_dbics2"); 461 if (IS_ERR(pci->dbi_base2)) 462 return PTR_ERR(pci->dbi_base2); 463 464 ret = dw_pcie_ep_init(ep); 465 if (ret) { 466 dev_err(dev, "failed to initialize endpoint\n"); 467 return ret; 468 } 469 470 return 0; 471} 472 473static int dra7xx_add_pcie_port(struct dra7xx_pcie *dra7xx, 474 struct platform_device *pdev) 475{ 476 int ret; 477 struct dw_pcie *pci = dra7xx->pci; 478 struct pcie_port *pp = &pci->pp; 479 struct device *dev = pci->dev; 480 481 pp->irq = platform_get_irq(pdev, 1); 482 if (pp->irq < 0) 483 return pp->irq; 484 485 /* MSI IRQ is muxed */ 486 pp->msi_irq = -ENODEV; 487 488 ret = dra7xx_pcie_init_irq_domain(pp); 489 if (ret < 0) 490 return ret; 491 492 pci->dbi_base = devm_platform_ioremap_resource_byname(pdev, "rc_dbics"); 493 if (IS_ERR(pci->dbi_base)) 494 return PTR_ERR(pci->dbi_base); 495 496 pp->ops = &dra7xx_pcie_host_ops; 497 498 ret = dw_pcie_host_init(pp); 499 if (ret) { 500 dev_err(dev, "failed to initialize host\n"); 501 return ret; 502 } 503 504 return 0; 505} 506 507static const struct dw_pcie_ops dw_pcie_ops = { 508 .cpu_addr_fixup = dra7xx_pcie_cpu_addr_fixup, 509 .start_link = dra7xx_pcie_establish_link, 510 .stop_link = dra7xx_pcie_stop_link, 511 .link_up = dra7xx_pcie_link_up, 512}; 513 514static void dra7xx_pcie_disable_phy(struct dra7xx_pcie *dra7xx) 515{ 516 int phy_count = dra7xx->phy_count; 517 518 while (phy_count--) { 519 phy_power_off(dra7xx->phy[phy_count]); 520 phy_exit(dra7xx->phy[phy_count]); 521 } 522} 523 524static int dra7xx_pcie_enable_phy(struct dra7xx_pcie *dra7xx) 525{ 526 int phy_count = dra7xx->phy_count; 527 int ret; 528 int i; 529 530 for (i = 0; i < phy_count; i++) { 531 ret = phy_set_mode(dra7xx->phy[i], PHY_MODE_PCIE); 532 if (ret < 0) 533 goto err_phy; 534 535 ret = phy_init(dra7xx->phy[i]); 536 if (ret < 0) 537 goto err_phy; 538 539 ret = phy_power_on(dra7xx->phy[i]); 540 if (ret < 0) { 541 phy_exit(dra7xx->phy[i]); 542 goto err_phy; 543 } 544 } 545 546 return 0; 547 548err_phy: 549 while (--i >= 0) { 550 phy_power_off(dra7xx->phy[i]); 551 phy_exit(dra7xx->phy[i]); 552 } 553 554 return ret; 555} 556 557static const struct dra7xx_pcie_of_data dra7xx_pcie_rc_of_data = { 558 .mode = DW_PCIE_RC_TYPE, 559}; 560 561static const struct dra7xx_pcie_of_data dra7xx_pcie_ep_of_data = { 562 .mode = DW_PCIE_EP_TYPE, 563}; 564 565static const struct dra7xx_pcie_of_data dra746_pcie_rc_of_data = { 566 .b1co_mode_sel_mask = BIT(2), 567 .mode = DW_PCIE_RC_TYPE, 568}; 569 570static const struct dra7xx_pcie_of_data dra726_pcie_rc_of_data = { 571 .b1co_mode_sel_mask = GENMASK(3, 2), 572 .mode = DW_PCIE_RC_TYPE, 573}; 574 575static const struct dra7xx_pcie_of_data dra746_pcie_ep_of_data = { 576 .b1co_mode_sel_mask = BIT(2), 577 .mode = DW_PCIE_EP_TYPE, 578}; 579 580static const struct dra7xx_pcie_of_data dra726_pcie_ep_of_data = { 581 .b1co_mode_sel_mask = GENMASK(3, 2), 582 .mode = DW_PCIE_EP_TYPE, 583}; 584 585static const struct of_device_id of_dra7xx_pcie_match[] = { 586 { 587 .compatible = "ti,dra7-pcie", 588 .data = &dra7xx_pcie_rc_of_data, 589 }, 590 { 591 .compatible = "ti,dra7-pcie-ep", 592 .data = &dra7xx_pcie_ep_of_data, 593 }, 594 { 595 .compatible = "ti,dra746-pcie-rc", 596 .data = &dra746_pcie_rc_of_data, 597 }, 598 { 599 .compatible = "ti,dra726-pcie-rc", 600 .data = &dra726_pcie_rc_of_data, 601 }, 602 { 603 .compatible = "ti,dra746-pcie-ep", 604 .data = &dra746_pcie_ep_of_data, 605 }, 606 { 607 .compatible = "ti,dra726-pcie-ep", 608 .data = &dra726_pcie_ep_of_data, 609 }, 610 {}, 611}; 612MODULE_DEVICE_TABLE(of, of_dra7xx_pcie_match); 613 614/* 615 * dra7xx_pcie_unaligned_memaccess: workaround for AM572x/AM571x Errata i870 616 * @dra7xx: the dra7xx device where the workaround should be applied 617 * 618 * Access to the PCIe slave port that are not 32-bit aligned will result 619 * in incorrect mapping to TLP Address and Byte enable fields. Therefore, 620 * byte and half-word accesses are not possible to byte offset 0x1, 0x2, or 621 * 0x3. 622 * 623 * To avoid this issue set PCIE_SS1_AXI2OCP_LEGACY_MODE_ENABLE to 1. 624 */ 625static int dra7xx_pcie_unaligned_memaccess(struct device *dev) 626{ 627 int ret; 628 struct device_node *np = dev->of_node; 629 struct of_phandle_args args; 630 struct regmap *regmap; 631 632 regmap = syscon_regmap_lookup_by_phandle(np, 633 "ti,syscon-unaligned-access"); 634 if (IS_ERR(regmap)) { 635 dev_dbg(dev, "can't get ti,syscon-unaligned-access\n"); 636 return -EINVAL; 637 } 638 639 ret = of_parse_phandle_with_fixed_args(np, "ti,syscon-unaligned-access", 640 2, 0, &args); 641 if (ret) { 642 dev_err(dev, "failed to parse ti,syscon-unaligned-access\n"); 643 return ret; 644 } 645 646 ret = regmap_update_bits(regmap, args.args[0], args.args[1], 647 args.args[1]); 648 if (ret) 649 dev_err(dev, "failed to enable unaligned access\n"); 650 651 of_node_put(args.np); 652 653 return ret; 654} 655 656static int dra7xx_pcie_configure_two_lane(struct device *dev, 657 u32 b1co_mode_sel_mask) 658{ 659 struct device_node *np = dev->of_node; 660 struct regmap *pcie_syscon; 661 unsigned int pcie_reg; 662 u32 mask; 663 u32 val; 664 665 pcie_syscon = syscon_regmap_lookup_by_phandle(np, "ti,syscon-lane-sel"); 666 if (IS_ERR(pcie_syscon)) { 667 dev_err(dev, "unable to get ti,syscon-lane-sel\n"); 668 return -EINVAL; 669 } 670 671 if (of_property_read_u32_index(np, "ti,syscon-lane-sel", 1, 672 &pcie_reg)) { 673 dev_err(dev, "couldn't get lane selection reg offset\n"); 674 return -EINVAL; 675 } 676 677 mask = b1co_mode_sel_mask | PCIE_B0_B1_TSYNCEN; 678 val = PCIE_B1C0_MODE_SEL | PCIE_B0_B1_TSYNCEN; 679 regmap_update_bits(pcie_syscon, pcie_reg, mask, val); 680 681 return 0; 682} 683 684static int dra7xx_pcie_probe(struct platform_device *pdev) 685{ 686 u32 reg; 687 int ret; 688 int irq; 689 int i; 690 int phy_count; 691 struct phy **phy; 692 struct device_link **link; 693 void __iomem *base; 694 struct dw_pcie *pci; 695 struct dra7xx_pcie *dra7xx; 696 struct device *dev = &pdev->dev; 697 struct device_node *np = dev->of_node; 698 char name[10]; 699 struct gpio_desc *reset; 700 const struct dra7xx_pcie_of_data *data; 701 enum dw_pcie_device_mode mode; 702 u32 b1co_mode_sel_mask; 703 704 data = of_device_get_match_data(dev); 705 if (!data) 706 return -EINVAL; 707 708 mode = (enum dw_pcie_device_mode)data->mode; 709 b1co_mode_sel_mask = data->b1co_mode_sel_mask; 710 711 dra7xx = devm_kzalloc(dev, sizeof(*dra7xx), GFP_KERNEL); 712 if (!dra7xx) 713 return -ENOMEM; 714 715 pci = devm_kzalloc(dev, sizeof(*pci), GFP_KERNEL); 716 if (!pci) 717 return -ENOMEM; 718 719 pci->dev = dev; 720 pci->ops = &dw_pcie_ops; 721 722 irq = platform_get_irq(pdev, 0); 723 if (irq < 0) 724 return irq; 725 726 base = devm_platform_ioremap_resource_byname(pdev, "ti_conf"); 727 if (IS_ERR(base)) 728 return PTR_ERR(base); 729 730 phy_count = of_property_count_strings(np, "phy-names"); 731 if (phy_count < 0) { 732 dev_err(dev, "unable to find the strings\n"); 733 return phy_count; 734 } 735 736 phy = devm_kcalloc(dev, phy_count, sizeof(*phy), GFP_KERNEL); 737 if (!phy) 738 return -ENOMEM; 739 740 link = devm_kcalloc(dev, phy_count, sizeof(*link), GFP_KERNEL); 741 if (!link) 742 return -ENOMEM; 743 744 dra7xx->clk = devm_clk_get_optional(dev, NULL); 745 if (IS_ERR(dra7xx->clk)) 746 return dev_err_probe(dev, PTR_ERR(dra7xx->clk), 747 "clock request failed"); 748 749 ret = clk_prepare_enable(dra7xx->clk); 750 if (ret) 751 return ret; 752 753 for (i = 0; i < phy_count; i++) { 754 snprintf(name, sizeof(name), "pcie-phy%d", i); 755 phy[i] = devm_phy_get(dev, name); 756 if (IS_ERR(phy[i])) 757 return PTR_ERR(phy[i]); 758 759 link[i] = device_link_add(dev, &phy[i]->dev, DL_FLAG_STATELESS); 760 if (!link[i]) { 761 ret = -EINVAL; 762 goto err_link; 763 } 764 } 765 766 dra7xx->base = base; 767 dra7xx->phy = phy; 768 dra7xx->pci = pci; 769 dra7xx->phy_count = phy_count; 770 771 if (phy_count == 2) { 772 ret = dra7xx_pcie_configure_two_lane(dev, b1co_mode_sel_mask); 773 if (ret < 0) 774 dra7xx->phy_count = 1; /* Fallback to x1 lane mode */ 775 } 776 777 ret = dra7xx_pcie_enable_phy(dra7xx); 778 if (ret) { 779 dev_err(dev, "failed to enable phy\n"); 780 return ret; 781 } 782 783 platform_set_drvdata(pdev, dra7xx); 784 785 pm_runtime_enable(dev); 786 ret = pm_runtime_get_sync(dev); 787 if (ret < 0) { 788 dev_err(dev, "pm_runtime_get_sync failed\n"); 789 goto err_get_sync; 790 } 791 792 reset = devm_gpiod_get_optional(dev, NULL, GPIOD_OUT_HIGH); 793 if (IS_ERR(reset)) { 794 ret = PTR_ERR(reset); 795 dev_err(&pdev->dev, "gpio request failed, ret %d\n", ret); 796 goto err_gpio; 797 } 798 799 reg = dra7xx_pcie_readl(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD); 800 reg &= ~LTSSM_EN; 801 dra7xx_pcie_writel(dra7xx, PCIECTRL_DRA7XX_CONF_DEVICE_CMD, reg); 802 803 switch (mode) { 804 case DW_PCIE_RC_TYPE: 805 if (!IS_ENABLED(CONFIG_PCI_DRA7XX_HOST)) { 806 ret = -ENODEV; 807 goto err_gpio; 808 } 809 810 dra7xx_pcie_writel(dra7xx, PCIECTRL_TI_CONF_DEVICE_TYPE, 811 DEVICE_TYPE_RC); 812 813 ret = dra7xx_pcie_unaligned_memaccess(dev); 814 if (ret) 815 dev_err(dev, "WA for Errata i870 not applied\n"); 816 817 ret = dra7xx_add_pcie_port(dra7xx, pdev); 818 if (ret < 0) 819 goto err_gpio; 820 break; 821 case DW_PCIE_EP_TYPE: 822 if (!IS_ENABLED(CONFIG_PCI_DRA7XX_EP)) { 823 ret = -ENODEV; 824 goto err_gpio; 825 } 826 827 dra7xx_pcie_writel(dra7xx, PCIECTRL_TI_CONF_DEVICE_TYPE, 828 DEVICE_TYPE_EP); 829 830 ret = dra7xx_pcie_unaligned_memaccess(dev); 831 if (ret) 832 goto err_gpio; 833 834 ret = dra7xx_add_pcie_ep(dra7xx, pdev); 835 if (ret < 0) 836 goto err_gpio; 837 break; 838 default: 839 dev_err(dev, "INVALID device type %d\n", mode); 840 } 841 dra7xx->mode = mode; 842 843 ret = devm_request_irq(dev, irq, dra7xx_pcie_irq_handler, 844 IRQF_SHARED, "dra7xx-pcie-main", dra7xx); 845 if (ret) { 846 dev_err(dev, "failed to request irq\n"); 847 goto err_gpio; 848 } 849 850 return 0; 851 852err_gpio: 853err_get_sync: 854 pm_runtime_put(dev); 855 pm_runtime_disable(dev); 856 dra7xx_pcie_disable_phy(dra7xx); 857 858err_link: 859 while (--i >= 0) 860 device_link_del(link[i]); 861 862 return ret; 863} 864 865#ifdef CONFIG_PM_SLEEP 866static int dra7xx_pcie_suspend(struct device *dev) 867{ 868 struct dra7xx_pcie *dra7xx = dev_get_drvdata(dev); 869 struct dw_pcie *pci = dra7xx->pci; 870 u32 val; 871 872 if (dra7xx->mode != DW_PCIE_RC_TYPE) 873 return 0; 874 875 /* clear MSE */ 876 val = dw_pcie_readl_dbi(pci, PCI_COMMAND); 877 val &= ~PCI_COMMAND_MEMORY; 878 dw_pcie_writel_dbi(pci, PCI_COMMAND, val); 879 880 return 0; 881} 882 883static int dra7xx_pcie_resume(struct device *dev) 884{ 885 struct dra7xx_pcie *dra7xx = dev_get_drvdata(dev); 886 struct dw_pcie *pci = dra7xx->pci; 887 u32 val; 888 889 if (dra7xx->mode != DW_PCIE_RC_TYPE) 890 return 0; 891 892 /* set MSE */ 893 val = dw_pcie_readl_dbi(pci, PCI_COMMAND); 894 val |= PCI_COMMAND_MEMORY; 895 dw_pcie_writel_dbi(pci, PCI_COMMAND, val); 896 897 return 0; 898} 899 900static int dra7xx_pcie_suspend_noirq(struct device *dev) 901{ 902 struct dra7xx_pcie *dra7xx = dev_get_drvdata(dev); 903 904 dra7xx_pcie_disable_phy(dra7xx); 905 906 return 0; 907} 908 909static int dra7xx_pcie_resume_noirq(struct device *dev) 910{ 911 struct dra7xx_pcie *dra7xx = dev_get_drvdata(dev); 912 int ret; 913 914 ret = dra7xx_pcie_enable_phy(dra7xx); 915 if (ret) { 916 dev_err(dev, "failed to enable phy\n"); 917 return ret; 918 } 919 920 return 0; 921} 922#endif 923 924static void dra7xx_pcie_shutdown(struct platform_device *pdev) 925{ 926 struct device *dev = &pdev->dev; 927 struct dra7xx_pcie *dra7xx = dev_get_drvdata(dev); 928 int ret; 929 930 dra7xx_pcie_stop_link(dra7xx->pci); 931 932 ret = pm_runtime_put_sync(dev); 933 if (ret < 0) 934 dev_dbg(dev, "pm_runtime_put_sync failed\n"); 935 936 pm_runtime_disable(dev); 937 dra7xx_pcie_disable_phy(dra7xx); 938 939 clk_disable_unprepare(dra7xx->clk); 940} 941 942static const struct dev_pm_ops dra7xx_pcie_pm_ops = { 943 SET_SYSTEM_SLEEP_PM_OPS(dra7xx_pcie_suspend, dra7xx_pcie_resume) 944 SET_NOIRQ_SYSTEM_SLEEP_PM_OPS(dra7xx_pcie_suspend_noirq, 945 dra7xx_pcie_resume_noirq) 946}; 947 948static struct platform_driver dra7xx_pcie_driver = { 949 .probe = dra7xx_pcie_probe, 950 .driver = { 951 .name = "dra7-pcie", 952 .of_match_table = of_dra7xx_pcie_match, 953 .suppress_bind_attrs = true, 954 .pm = &dra7xx_pcie_pm_ops, 955 }, 956 .shutdown = dra7xx_pcie_shutdown, 957}; 958module_platform_driver(dra7xx_pcie_driver); 959 960MODULE_AUTHOR("Kishon Vijay Abraham I <kishon@ti.com>"); 961MODULE_DESCRIPTION("PCIe controller driver for TI DRA7xx SoCs"); 962MODULE_LICENSE("GPL v2");