On Mon, 2011-11-07 at 15:55 +1100, Benjamin Herrenschmidt wrote:
> When PCI_REASSIGN_ALL_RSRC is set, we used to clear all bus resources
> at the beginning of survey and re-allocate them later.
> 
> This changes it so instead, during early fixup, we mark all resources
> as IORESOURCE_UNSET and move them down to be 0-based.
> 
> Later, if bus resources are still unset at the beginning of the survey,
> then we clear them.
> 
> This shouldn't impact the re-assignment case on 4xx, but will enable
> us to have the platform do some custom resource assignment before the
> survey, by clearing individual resources IORESOURCE_UNSET bit.
> 
> Also limits the clutter in the kernel log from fixup when re-assigning
> since we don't care about the offset applied to the BAR values in this
> case.

Hi guys !

This one could be invasive to FSL and 4xx if you use
PCI_REASSIGN_ALL_RSRC. I very much want to merge it for 3.3, so any
chance you can give it a beating and see if everything is still
allright ?

Cheers,
Ben.

> Signed-off-by: Benjamin Herrenschmidt <b...@kernel.crashing.org>
> ---
>  arch/powerpc/kernel/pci-common.c |   66 ++++++++++++++++++++-----------------
>  1 files changed, 36 insertions(+), 30 deletions(-)
> 
> diff --git a/arch/powerpc/kernel/pci-common.c 
> b/arch/powerpc/kernel/pci-common.c
> index 855969f..d34ba7e 100644
> --- a/arch/powerpc/kernel/pci-common.c
> +++ b/arch/powerpc/kernel/pci-common.c
> @@ -920,18 +920,22 @@ static void __devinit pcibios_fixup_resources(struct 
> pci_dev *dev)
>               struct resource *res = dev->resource + i;
>               if (!res->flags)
>                       continue;
> -             /* On platforms that have PCI_PROBE_ONLY set, we don't
> -              * consider 0 as an unassigned BAR value. It's technically
> -              * a valid value, but linux doesn't like it... so when we can
> -              * re-assign things, we do so, but if we can't, we keep it
> -              * around and hope for the best...
> +
> +             /* If we're going to re-assign everything, we mark all resources
> +              * as unset (and 0-base them). In addition, we mark BARs 
> starting
> +              * at 0 as unset as well, except if PCI_PROBE_ONLY is also set
> +              * since in that case, we don't want to re-assign anything
>                */
> -             if (res->start == 0 && !pci_has_flag(PCI_PROBE_ONLY)) {
> -                     pr_debug("PCI:%s Resource %d %016llx-%016llx [%x] is 
> unassigned\n",
> -                              pci_name(dev), i,
> -                              (unsigned long long)res->start,
> -                              (unsigned long long)res->end,
> -                              (unsigned int)res->flags);
> +             if (pci_has_flag(PCI_REASSIGN_ALL_RSRC) ||
> +                 (res->start == 0 && !pci_has_flag(PCI_PROBE_ONLY))) {
> +                     /* Only print message if not re-assigning */
> +                     if (!pci_has_flag(PCI_REASSIGN_ALL_RSRC))
> +                             pr_debug("PCI:%s Resource %d %016llx-%016llx 
> [%x] "
> +                                      "is unassigned\n",
> +                                      pci_name(dev), i,
> +                                      (unsigned long long)res->start,
> +                                      (unsigned long long)res->end,
> +                                      (unsigned int)res->flags);
>                       res->end -= res->start;
>                       res->start = 0;
>                       res->flags |= IORESOURCE_UNSET;
> @@ -1041,6 +1045,16 @@ static void __devinit pcibios_fixup_bridge(struct 
> pci_bus *bus)
>               if (i >= 3 && bus->self->transparent)
>                       continue;
>  
> +             /* If we are going to re-assign everything, mark the resource
> +              * as unset and move it down to 0
> +              */
> +             if (pci_has_flag(PCI_REASSIGN_ALL_RSRC)) {
> +                     res->flags |= IORESOURCE_UNSET;
> +                     res->end -= res->start;
> +                     res->start = 0;
> +                     continue;
> +             }
> +
>               pr_debug("PCI:%s Bus rsrc %d %016llx-%016llx [%x] fixup...\n",
>                        pci_name(dev), i,
>                        (unsigned long long)res->start,\
> @@ -1261,18 +1275,15 @@ void pcibios_allocate_bus_resources(struct pci_bus 
> *bus)
>       pci_bus_for_each_resource(bus, res, i) {
>               if (!res || !res->flags || res->start > res->end || res->parent)
>                       continue;
> +
> +             /* If the resource was left unset at this point, we clear it */
> +             if (res->flags & IORESOURCE_UNSET)
> +                     goto clear_resource;
> +
>               if (bus->parent == NULL)
>                       pr = (res->flags & IORESOURCE_IO) ?
>                               &ioport_resource : &iomem_resource;
>               else {
> -                     /* Don't bother with non-root busses when
> -                      * re-assigning all resources. We clear the
> -                      * resource flags as if they were colliding
> -                      * and as such ensure proper re-allocation
> -                      * later.
> -                      */
> -                     if (pci_has_flag(PCI_REASSIGN_ALL_RSRC))
> -                             goto clear_resource;
>                       pr = pci_find_parent_resource(bus->self, res);
>                       if (pr == res) {
>                               /* this happens when the generic PCI
> @@ -1303,9 +1314,9 @@ void pcibios_allocate_bus_resources(struct pci_bus *bus)
>                       if (reparent_resources(pr, res) == 0)
>                               continue;
>               }
> -             printk(KERN_WARNING "PCI: Cannot allocate resource region "
> -                    "%d of PCI bridge %d, will remap\n", i, bus->number);
> -clear_resource:
> +             pr_warning("PCI: Cannot allocate resource region "
> +                        "%d of PCI bridge %d, will remap\n", i, bus->number);
> +     clear_resource:
>               res->start = res->end = 0;
>               res->flags = 0;
>       }
> @@ -1450,16 +1461,11 @@ void __init pcibios_resource_survey(void)
>  {
>       struct pci_bus *b;
>  
> -     /* Allocate and assign resources. If we re-assign everything, then
> -      * we skip the allocate phase
> -      */
> +     /* Allocate and assign resources */
>       list_for_each_entry(b, &pci_root_buses, node)
>               pcibios_allocate_bus_resources(b);
> -
> -     if (!pci_has_flag(PCI_REASSIGN_ALL_RSRC)) {
> -             pcibios_allocate_resources(0);
> -             pcibios_allocate_resources(1);
> -     }
> +     pcibios_allocate_resources(0);
> +     pcibios_allocate_resources(1);
>  
>       /* Before we start assigning unassigned resource, we try to reserve
>        * the low IO area and the VGA memory area if they intersect the


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to