Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1879f9cb authored by Zachary Zhang's avatar Zachary Zhang Committed by Greg Kroah-Hartman
Browse files

PCI: aardvark: Size bridges before resources allocation



commit 91a2968e245d6ba616db37001fa1a043078b1a65 upstream.

The PCIE I/O and MEM resource allocation mechanism is that root bus
goes through the following steps:

1. Check PCI bridges' range and computes I/O and Mem base/limits.

2. Sort all subordinate devices I/O and MEM resource requirements and
   allocate the resources and writes/updates subordinate devices'
   requirements to PCI bridges I/O and Mem MEM/limits registers.

Currently, PCI Aardvark driver only handles the second step and lacks
the first step, so there is an I/O and MEM resource allocation failure
when using a PCI switch. This commit fixes that by sizing bridges
before doing the resource allocation.

Fixes: 8c39d710 ("PCI: aardvark: Add Aardvark PCI host controller
driver")
Signed-off-by: default avatarZachary Zhang <zhangzg@marvell.com>
[Thomas: edit commit log.]
Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@bootlin.com>
Signed-off-by: default avatarLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 72386b22
Loading
Loading
Loading
Loading
+1 −0
Original line number Diff line number Diff line
@@ -976,6 +976,7 @@ static int advk_pcie_probe(struct platform_device *pdev)
		return -ENOMEM;
	}

	pci_bus_size_bridges(bus);
	pci_bus_assign_resources(bus);

	list_for_each_entry(child, &bus->children, node)