Lines Matching refs:pcie

113 static inline u32 pcie_read(struct xilinx_pcie *pcie, u32 reg)
115 return readl(pcie->reg_base + reg);
118 static inline void pcie_write(struct xilinx_pcie *pcie, u32 val, u32 reg)
120 writel(val, pcie->reg_base + reg);
123 static inline bool xilinx_pcie_link_up(struct xilinx_pcie *pcie)
125 return (pcie_read(pcie, XILINX_PCIE_REG_PSCR) &
131 * @pcie: PCIe port information
133 static void xilinx_pcie_clear_err_interrupts(struct xilinx_pcie *pcie)
135 struct device *dev = pcie->dev;
136 unsigned long val = pcie_read(pcie, XILINX_PCIE_REG_RPEFR);
141 pcie_write(pcie, XILINX_PCIE_RPEFR_ALL_MASK,
155 struct xilinx_pcie *pcie = bus->sysdata;
157 /* Check if link is up when trying to access downstream pcie ports */
159 if (!xilinx_pcie_link_up(pcie))
180 struct xilinx_pcie *pcie = bus->sysdata;
185 return pcie->reg_base + PCIE_ECAM_OFFSET(bus->number, devfn, where);
218 struct xilinx_pcie *pcie = irq_data_get_irq_chip_data(data);
219 phys_addr_t pa = ALIGN_DOWN(virt_to_phys(pcie), SZ_4K);
235 struct xilinx_pcie *pcie = domain->host_data;
238 mutex_lock(&pcie->map_lock);
240 hwirq = bitmap_find_free_region(pcie->msi_map, XILINX_NUM_MSI_IRQS, order_base_2(nr_irqs));
242 mutex_unlock(&pcie->map_lock);
259 struct xilinx_pcie *pcie = domain->host_data;
261 mutex_lock(&pcie->map_lock);
263 bitmap_release_region(pcie->msi_map, d->hwirq, order_base_2(nr_irqs));
265 mutex_unlock(&pcie->map_lock);
278 static int xilinx_allocate_msi_domains(struct xilinx_pcie *pcie)
280 struct fwnode_handle *fwnode = dev_fwnode(pcie->dev);
284 &xilinx_msi_domain_ops, pcie);
286 dev_err(pcie->dev, "failed to create IRQ domain\n");
291 pcie->msi_domain = pci_msi_create_irq_domain(fwnode, &xilinx_msi_info, parent);
292 if (!pcie->msi_domain) {
293 dev_err(pcie->dev, "failed to create MSI domain\n");
301 static void xilinx_free_msi_domains(struct xilinx_pcie *pcie)
303 struct irq_domain *parent = pcie->msi_domain->parent;
305 irq_domain_remove(pcie->msi_domain);
345 struct xilinx_pcie *pcie = (struct xilinx_pcie *)data;
346 struct device *dev = pcie->dev;
350 val = pcie_read(pcie, XILINX_PCIE_REG_IDR);
351 mask = pcie_read(pcie, XILINX_PCIE_REG_IMR);
374 xilinx_pcie_clear_err_interrupts(pcie);
379 xilinx_pcie_clear_err_interrupts(pcie);
384 xilinx_pcie_clear_err_interrupts(pcie);
390 val = pcie_read(pcie, XILINX_PCIE_REG_RPIFR1);
400 val = pcie_read(pcie, XILINX_PCIE_REG_RPIFR2) &
402 domain = pcie->msi_domain->parent;
406 domain = pcie->leg_domain;
410 pcie_write(pcie, XILINX_PCIE_RPIFR1_ALL_MASK,
445 pcie_write(pcie, status, XILINX_PCIE_REG_IDR);
452 * @pcie: PCIe port information
456 static int xilinx_pcie_init_irq_domain(struct xilinx_pcie *pcie)
458 struct device *dev = pcie->dev;
469 pcie->leg_domain = irq_domain_add_linear(pcie_intc_node, PCI_NUM_INTX,
471 pcie);
473 if (!pcie->leg_domain) {
480 phys_addr_t pa = ALIGN_DOWN(virt_to_phys(pcie), SZ_4K);
482 ret = xilinx_allocate_msi_domains(pcie);
486 pcie_write(pcie, upper_32_bits(pa), XILINX_PCIE_REG_MSIBASE1);
487 pcie_write(pcie, lower_32_bits(pa), XILINX_PCIE_REG_MSIBASE2);
495 * @pcie: PCIe port information
497 static void xilinx_pcie_init_port(struct xilinx_pcie *pcie)
499 struct device *dev = pcie->dev;
501 if (xilinx_pcie_link_up(pcie))
507 pcie_write(pcie, ~XILINX_PCIE_IDR_ALL_MASK,
511 pcie_write(pcie, pcie_read(pcie, XILINX_PCIE_REG_IDR) &
516 pcie_write(pcie, XILINX_PCIE_IMR_ENABLE_MASK, XILINX_PCIE_REG_IMR);
519 pcie_write(pcie, pcie_read(pcie, XILINX_PCIE_REG_RPSC) |
526 * @pcie: PCIe port information
530 static int xilinx_pcie_parse_dt(struct xilinx_pcie *pcie)
532 struct device *dev = pcie->dev;
544 pcie->reg_base = devm_pci_remap_cfg_resource(dev, &regs);
545 if (IS_ERR(pcie->reg_base))
546 return PTR_ERR(pcie->reg_base);
551 "xilinx-pcie", pcie);
569 struct xilinx_pcie *pcie;
576 bridge = devm_pci_alloc_host_bridge(dev, sizeof(*pcie));
580 pcie = pci_host_bridge_priv(bridge);
581 mutex_init(&pcie->map_lock);
582 pcie->dev = dev;
584 err = xilinx_pcie_parse_dt(pcie);
590 xilinx_pcie_init_port(pcie);
592 err = xilinx_pcie_init_irq_domain(pcie);
598 bridge->sysdata = pcie;
603 xilinx_free_msi_domains(pcie);
609 { .compatible = "xlnx,axi-pcie-host-1.00.a", },
615 .name = "xilinx-pcie",