arch/sh: pci: don't use disabled resources
authorThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Mon, 4 Dec 2017 15:09:02 +0000 (16:09 +0100)
committerRich Felker <dalias@libc.org>
Thu, 12 Apr 2018 23:47:54 +0000 (19:47 -0400)
In pcibios_scanbus(), we provide to the PCI core the usable MEM and IO
regions using pci_add_resource_offset(). We travel through all
resources available in the "struct pci_channel".

Also, in register_pci_controller(), we travel through all resources to
request them, making sure they don't conflict with already requested
resources.

However, some resources may be disabled, in which case they should not
be requested nor provided to the PCI core.

In the current situation, none of the resources are disabled. However,
follow-up patches in this series will make some resources disabled,
making this preliminary change necessary.

Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Signed-off-by: Rich Felker <dalias@libc.org>
arch/sh/drivers/pci/pci.c

index 5976a2c8a3e350db0e228b224593f17fb47dc602..e5b7437ab4afa3244dcf68f60240786a3474d2b3 100644 (file)
@@ -49,6 +49,8 @@ static void pcibios_scanbus(struct pci_channel *hose)
        for (i = 0; i < hose->nr_resources; i++) {
                res = hose->resources + i;
                offset = 0;
+               if (res->flags & IORESOURCE_DISABLED)
+                       continue;
                if (res->flags & IORESOURCE_IO)
                        offset = hose->io_offset;
                else if (res->flags & IORESOURCE_MEM)
@@ -102,6 +104,9 @@ int register_pci_controller(struct pci_channel *hose)
        for (i = 0; i < hose->nr_resources; i++) {
                struct resource *res = hose->resources + i;
 
+               if (res->flags & IORESOURCE_DISABLED)
+                       continue;
+
                if (res->flags & IORESOURCE_IO) {
                        if (request_resource(&ioport_resource, res) < 0)
                                goto out;