From f5e2372cb7082d91cf3e0a4188c70cbc623d88eb Mon Sep 17 00:00:00 2001 From: Bjorn Helgaas Date: Fri, 28 Oct 2011 16:25:35 -0600 Subject: [PATCH] --- yaml --- r: 283355 b: refs/heads/master c: 45ca9e9730c5acdb482dd95799fd8ac834481897 h: refs/heads/master i: 283353: a1e86f9b57aa5b770af903df448cd652be9742e8 283351: f87b696565c06ad9fa91f802738a27d3fd70eb14 v: v3 --- [refs] | 2 +- trunk/drivers/pci/bus.c | 32 +++++++++++++++++++++++++++----- trunk/include/linux/pci.h | 2 ++ 3 files changed, 30 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index a49e3695341f..5d4000930467 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: afd24ece5c76af87f6fc477f2747b83a764f161c +refs/heads/master: 45ca9e9730c5acdb482dd95799fd8ac834481897 diff --git a/trunk/drivers/pci/bus.c b/trunk/drivers/pci/bus.c index 1e2ad92a4752..398f5d859791 100644 --- a/trunk/drivers/pci/bus.c +++ b/trunk/drivers/pci/bus.c @@ -18,6 +18,32 @@ #include "pci.h" +void pci_add_resource(struct list_head *resources, struct resource *res) +{ + struct pci_bus_resource *bus_res; + + bus_res = kzalloc(sizeof(struct pci_bus_resource), GFP_KERNEL); + if (!bus_res) { + printk(KERN_ERR "PCI: can't add bus resource %pR\n", res); + return; + } + + bus_res->res = res; + list_add_tail(&bus_res->list, resources); +} +EXPORT_SYMBOL(pci_add_resource); + +void pci_free_resource_list(struct list_head *resources) +{ + struct pci_bus_resource *bus_res, *tmp; + + list_for_each_entry_safe(bus_res, tmp, resources, list) { + list_del(&bus_res->list); + kfree(bus_res); + } +} +EXPORT_SYMBOL(pci_free_resource_list); + void pci_bus_add_resource(struct pci_bus *bus, struct resource *res, unsigned int flags) { @@ -52,16 +78,12 @@ EXPORT_SYMBOL_GPL(pci_bus_resource_n); void pci_bus_remove_resources(struct pci_bus *bus) { - struct pci_bus_resource *bus_res, *tmp; int i; for (i = 0; i < PCI_BRIDGE_RESOURCE_NUM; i++) bus->resource[i] = NULL; - list_for_each_entry_safe(bus_res, tmp, &bus->resources, list) { - list_del(&bus_res->list); - kfree(bus_res); - } + pci_free_resource_list(&bus->resources); } /** diff --git a/trunk/include/linux/pci.h b/trunk/include/linux/pci.h index 4c16a5788998..9daa79901122 100644 --- a/trunk/include/linux/pci.h +++ b/trunk/include/linux/pci.h @@ -917,6 +917,8 @@ int pci_request_selected_regions_exclusive(struct pci_dev *, int, const char *); void pci_release_selected_regions(struct pci_dev *, int); /* drivers/pci/bus.c */ +void pci_add_resource(struct list_head *resources, struct resource *res); +void pci_free_resource_list(struct list_head *resources); void pci_bus_add_resource(struct pci_bus *bus, struct resource *res, unsigned int flags); struct resource *pci_bus_resource_n(const struct pci_bus *bus, int n); void pci_bus_remove_resources(struct pci_bus *bus);