First part is for_each_pci_resource support: Now pci device resource iteration is done via "for (i=0...)" open code. That make code hard to read esp when only bridge or sriov resources are involved. We want to replace those open code with for_each_pci_resource() to make the code more readable. Also will add addon_resource handling, and need to make addon resource to be treated as normal PCI resources during iteration, add for_each_pci_resource will make that support transition more simple. To make for_each_pci_resource more efficient. We will use preset bitmap of different type for searching next idx. Second part is addon_res support: Now there is some non normal pci resources other than standard,rom, sriov, bridges. Some could be same as standard reg, but using different position. Some could have own way to read/write to them. Kernel are using different way to hack those resources like abusing pci bridge resource spot on non bridge pci device. Add addon_resources list in pci_dev for those non-standard resources. With this patch, will treat addon-resource like standard resources with special ops. At last replace some quirk_io with addon_res. could get from git://git.kernel.org/pub/scm/linux/kernel/git/yinghai/linux-yinghai.git for-pci-for-each-res-addon -v4: split one patch out, and remove PCI_NO_.... Notes: We still need to keep _idx as we use it all the time, and drivers still use them to get resource. Thanks Yinghai Lu Ram Pai (1): PCI: pci resource iterator Yinghai Lu (28): PCI: Clean up quirk_io_region PCI: Add pci_dev_resource_n() PCI: Update pci_resource_start etc to use pci_dev_resource_n() PCI: Add pci_dev_resource_idx() helper PCI: Add is_pci_*_resource_idx() helpers PCI, x86: Use for_each_pci_resource() with pci_allocate_bridge_resources PCI, x86: Use for_each_pci_resource() with pci_allocate_dev_resources PCI: Use for_each_pci_resource() with IOV releated functions PCI, acpiphp: Use for_each_pci_resource() helper PCI, pciehp: Use for_each_pci_resource() helper PCI: Use for_each_pci_resource() in pci_enable_dev PCI: Use for_each_pci_resource() in pci_reassigndev PCI: Use for_each_pci_resource() with pci bar reassign funcs PCI: Use for_each_pci_resource() in pci_assign_resource PCI, x86: Use for_each_pci_resource() with noassign_bars PCI: Use for_each_pci_resource() in pci_dev_driver() PCI: Use for_each_pci_resource() in pci resource release PCI: Use for_each_pci_resource() in pci bases reading PCI, x86: Use for_each_pci_resource() with mrst PCI, xen: Use for_each_pci_resource() with xen pci PCI: Add addon_resource support for pci devices PCI: Treat addon res as std resources PCI: Add helpers to add addon_resource PCI: Update pci_resource_bar() to support addon_resource PCI: Assign/update resource to addon_res PCI: Make piix4 quirk to use addon_res PCI: Make quirk_io_region to use addon_res PCI: Use addon_fixed_resource with ati fixed resource arch/x86/pci/common.c | 3 +- arch/x86/pci/i386.c | 58 +++------ arch/x86/pci/mrst.c | 7 +- drivers/pci/hotplug/acpiphp_glue.c | 4 +- drivers/pci/hotplug/pciehp_hpc.c | 5 +- drivers/pci/iov.c | 31 +++-- drivers/pci/pci-driver.c | 7 +- drivers/pci/pci.c | 27 ++-- drivers/pci/probe.c | 176 ++++++++++++++++++++++++- drivers/pci/quirks.c | 258 ++++++++++++++++++++++--------------- drivers/pci/remove.c | 5 +- drivers/pci/setup-bus.c | 28 ++-- drivers/pci/setup-res.c | 38 ++++-- drivers/pci/xen-pcifront.c | 4 +- include/linux/pci.h | 116 +++++++++++++++-- 15 files changed, 541 insertions(+), 226 deletions(-) -- 1.8.1.4 -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html