PCI: Fix IOV resource sorting by alignment requirement
authorWei Yang <weiyang@linux.vnet.ibm.com>
Tue, 19 May 2015 06:24:17 +0000 (14:24 +0800)
committerBjorn Helgaas <bhelgaas@google.com>
Wed, 27 May 2015 16:47:17 +0000 (11:47 -0500)
In d74b9027a4da ("PCI: Consider additional PF's IOV BAR alignment in sizing
and assigning"), it stores additional alignment in realloc_head and takes
this into consideration for assignment.

After getting the additional alignment, it reorders the head list so
resources with bigger alignment are ahead of resources with smaller
alignment.  It does this by iterating over the head list and inserting
ahead of any resource with smaller alignment.  This should be done for the
first occurrence, but the code currently iterates over the whole list.

Fix this by terminating the loop when we find the first smaller resource in
the head list.

[bhelgaas: changelog]
Fixes: d74b9027a4da ("PCI: Consider additional PF's IOV BAR alignment in sizing and assigning")
Signed-off-by: Wei Yang <weiyang@linux.vnet.ibm.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
drivers/pci/setup-bus.c

index 4fd0cacf7ca0ae0dfaebf5c612f457cdf6fa43f9..aa281d909eb05038a592030d31a4945550d68646 100644 (file)
@@ -435,9 +435,11 @@ static void __assign_resources_sorted(struct list_head *head,
                        list_for_each_entry(dev_res2, head, list) {
                                align = pci_resource_alignment(dev_res2->dev,
                                                               dev_res2->res);
-                               if (add_align > align)
+                               if (add_align > align) {
                                        list_move_tail(&dev_res->list,
                                                       &dev_res2->list);
+                                       break;
+                               }
                        }
                }