Commit 77fc9aa9 authored by Rob Herring's avatar Rob Herring Committed by Lorenzo Pieralisi

PCI: xilinx-nwl: Use pci_is_root_bus() to check if bus is root bus

Use pci_is_root_bus() rather than tracking the root bus number to
determine if the bus is the root bus or not. This removes storing
duplicated data as well as the need for the host bridge driver to have
to care about the bus numbers in most cases.

There was also a bug that the pci_host_bridge.busnr is set from
root_busno, but root_busno is never set which means the root bus number
is always 0 even if the DT said something else.

Link: https://lore.kernel.org/r/20200722022514.1283916-8-robh@kernel.orgSigned-off-by: default avatarRob Herring <robh@kernel.org>
Signed-off-by: default avatarLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: default avatarBjorn Helgaas <bhelgaas@google.com>
Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Michal Simek <michal.simek@xilinx.com>
parent 388637d9
...@@ -166,7 +166,6 @@ struct nwl_pcie { ...@@ -166,7 +166,6 @@ struct nwl_pcie {
int irq_misc; int irq_misc;
u32 ecam_value; u32 ecam_value;
u8 last_busno; u8 last_busno;
u8 root_busno;
struct nwl_msi msi; struct nwl_msi msi;
struct irq_domain *legacy_irq_domain; struct irq_domain *legacy_irq_domain;
raw_spinlock_t leg_mask_lock; raw_spinlock_t leg_mask_lock;
...@@ -217,13 +216,11 @@ static bool nwl_pcie_valid_device(struct pci_bus *bus, unsigned int devfn) ...@@ -217,13 +216,11 @@ static bool nwl_pcie_valid_device(struct pci_bus *bus, unsigned int devfn)
struct nwl_pcie *pcie = bus->sysdata; struct nwl_pcie *pcie = bus->sysdata;
/* Check link before accessing downstream ports */ /* Check link before accessing downstream ports */
if (bus->number != pcie->root_busno) { if (!pci_is_root_bus(bus)) {
if (!nwl_pcie_link_up(pcie)) if (!nwl_pcie_link_up(pcie))
return false; return false;
} } else if (devfn > 0)
/* Only one device down on each root port */ /* Only one device down on each root port */
if (bus->number == pcie->root_busno && devfn > 0)
return false; return false;
return true; return true;
...@@ -855,7 +852,6 @@ static int nwl_pcie_probe(struct platform_device *pdev) ...@@ -855,7 +852,6 @@ static int nwl_pcie_probe(struct platform_device *pdev)
} }
bridge->sysdata = pcie; bridge->sysdata = pcie;
bridge->busnr = pcie->root_busno;
bridge->ops = &nwl_pcie_ops; bridge->ops = &nwl_pcie_ops;
bridge->map_irq = of_irq_parse_and_map_pci; bridge->map_irq = of_irq_parse_and_map_pci;
bridge->swizzle_irq = pci_common_swizzle; bridge->swizzle_irq = pci_common_swizzle;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment