Commit 91a2968e authored by Zachary Zhang's avatar Zachary Zhang Committed by Lorenzo Pieralisi
Browse files

PCI: aardvark: Size bridges before resources allocation

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
Signed-off-by: default avatarZachary Zhang <>
[Thomas: edit commit log.]
Signed-off-by: default avatarThomas Petazzoni <>
Signed-off-by: default avatarLorenzo Pieralisi <>
Cc: <>
parent 6df6ba97
......@@ -906,6 +906,7 @@ static int advk_pcie_probe(struct platform_device *pdev)
bus = bridge->bus;
list_for_each_entry(child, &bus->children, node)
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