Skip to content

Commit 541b745

Browse files
Marc Zyngiergregkh
authored andcommitted
PCI: xgene: Revert "PCI: xgene: Use inbound resources for setup"
commit 1874b6d upstream. Commit 6dce5aa ("PCI: xgene: Use inbound resources for setup") killed PCIe on my XGene-1 box (a Mustang board). The machine itself is still alive, but half of its storage (over NVMe) is gone, and the NVMe driver just times out. Note that this machine boots with a device tree provided by the UEFI firmware (2016 vintage), which could well be non conformant with the spec, hence the breakage. With the patch reverted, the box boots 5.17-rc8 with flying colors. Link: https://lore.kernel.org/all/Yf2wTLjmcRj+AbDv@xps13.dannf Link: https://lore.kernel.org/r/20220321104843.949645-2-maz@kernel.org Fixes: 6dce5aa ("PCI: xgene: Use inbound resources for setup") Signed-off-by: Marc Zyngier <maz@kernel.org> Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Cc: stable@vger.kernel.org Cc: Rob Herring <robh@kernel.org> Cc: Toan Le <toan@os.amperecomputing.com> Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> Cc: Krzysztof Wilczyński <kw@linux.com> Cc: Bjorn Helgaas <bhelgaas@google.com> Cc: Stéphane Graber <stgraber@ubuntu.com> Cc: dann frazier <dann.frazier@canonical.com> [dannf: minor context adjustment] Signed-off-by: dann frazier <dann.frazier@canonical.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 39fd0cc commit 541b745

File tree

1 file changed

+22
-11
lines changed

1 file changed

+22
-11
lines changed

drivers/pci/controller/pci-xgene.c

Lines changed: 22 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -480,28 +480,27 @@ static int xgene_pcie_select_ib_reg(u8 *ib_reg_mask, u64 size)
480480
}
481481

482482
static void xgene_pcie_setup_ib_reg(struct xgene_pcie_port *port,
483-
struct resource_entry *entry,
484-
u8 *ib_reg_mask)
483+
struct of_pci_range *range, u8 *ib_reg_mask)
485484
{
486485
void __iomem *cfg_base = port->cfg_base;
487486
struct device *dev = port->dev;
488487
void __iomem *bar_addr;
489488
u32 pim_reg;
490-
u64 cpu_addr = entry->res->start;
491-
u64 pci_addr = cpu_addr - entry->offset;
492-
u64 size = resource_size(entry->res);
489+
u64 cpu_addr = range->cpu_addr;
490+
u64 pci_addr = range->pci_addr;
491+
u64 size = range->size;
493492
u64 mask = ~(size - 1) | EN_REG;
494493
u32 flags = PCI_BASE_ADDRESS_MEM_TYPE_64;
495494
u32 bar_low;
496495
int region;
497496

498-
region = xgene_pcie_select_ib_reg(ib_reg_mask, size);
497+
region = xgene_pcie_select_ib_reg(ib_reg_mask, range->size);
499498
if (region < 0) {
500499
dev_warn(dev, "invalid pcie dma-range config\n");
501500
return;
502501
}
503502

504-
if (entry->res->flags & IORESOURCE_PREFETCH)
503+
if (range->flags & IORESOURCE_PREFETCH)
505504
flags |= PCI_BASE_ADDRESS_MEM_PREFETCH;
506505

507506
bar_low = pcie_bar_low_val((u32)cpu_addr, flags);
@@ -532,13 +531,25 @@ static void xgene_pcie_setup_ib_reg(struct xgene_pcie_port *port,
532531

533532
static int xgene_pcie_parse_map_dma_ranges(struct xgene_pcie_port *port)
534533
{
535-
struct pci_host_bridge *bridge = pci_host_bridge_from_priv(port);
536-
struct resource_entry *entry;
534+
struct device_node *np = port->node;
535+
struct of_pci_range range;
536+
struct of_pci_range_parser parser;
537+
struct device *dev = port->dev;
537538
u8 ib_reg_mask = 0;
538539

539-
resource_list_for_each_entry(entry, &bridge->dma_ranges)
540-
xgene_pcie_setup_ib_reg(port, entry, &ib_reg_mask);
540+
if (of_pci_dma_range_parser_init(&parser, np)) {
541+
dev_err(dev, "missing dma-ranges property\n");
542+
return -EINVAL;
543+
}
544+
545+
/* Get the dma-ranges from DT */
546+
for_each_of_pci_range(&parser, &range) {
547+
u64 end = range.cpu_addr + range.size - 1;
541548

549+
dev_dbg(dev, "0x%08x 0x%016llx..0x%016llx -> 0x%016llx\n",
550+
range.flags, range.cpu_addr, end, range.pci_addr);
551+
xgene_pcie_setup_ib_reg(port, &range, &ib_reg_mask);
552+
}
542553
return 0;
543554
}
544555

0 commit comments

Comments
 (0)