diff options
Diffstat (limited to 'drivers/pci/bus.c')
| -rw-r--r-- | drivers/pci/bus.c | 56 |
1 files changed, 52 insertions, 4 deletions
diff --git a/drivers/pci/bus.c b/drivers/pci/bus.c index cef28a79103f..712250f5874a 100644 --- a/drivers/pci/bus.c +++ b/drivers/pci/bus.c | |||
| @@ -17,6 +17,52 @@ | |||
| 17 | 17 | ||
| 18 | #include "pci.h" | 18 | #include "pci.h" |
| 19 | 19 | ||
| 20 | void pci_bus_add_resource(struct pci_bus *bus, struct resource *res, | ||
| 21 | unsigned int flags) | ||
| 22 | { | ||
| 23 | struct pci_bus_resource *bus_res; | ||
| 24 | |||
| 25 | bus_res = kzalloc(sizeof(struct pci_bus_resource), GFP_KERNEL); | ||
| 26 | if (!bus_res) { | ||
| 27 | dev_err(&bus->dev, "can't add %pR resource\n", res); | ||
| 28 | return; | ||
| 29 | } | ||
| 30 | |||
| 31 | bus_res->res = res; | ||
| 32 | bus_res->flags = flags; | ||
| 33 | list_add_tail(&bus_res->list, &bus->resources); | ||
| 34 | } | ||
| 35 | |||
| 36 | struct resource *pci_bus_resource_n(const struct pci_bus *bus, int n) | ||
| 37 | { | ||
| 38 | struct pci_bus_resource *bus_res; | ||
| 39 | |||
| 40 | if (n < PCI_BRIDGE_RESOURCE_NUM) | ||
| 41 | return bus->resource[n]; | ||
| 42 | |||
| 43 | n -= PCI_BRIDGE_RESOURCE_NUM; | ||
| 44 | list_for_each_entry(bus_res, &bus->resources, list) { | ||
| 45 | if (n-- == 0) | ||
| 46 | return bus_res->res; | ||
| 47 | } | ||
| 48 | return NULL; | ||
| 49 | } | ||
| 50 | EXPORT_SYMBOL_GPL(pci_bus_resource_n); | ||
| 51 | |||
| 52 | void pci_bus_remove_resources(struct pci_bus *bus) | ||
| 53 | { | ||
| 54 | struct pci_bus_resource *bus_res, *tmp; | ||
| 55 | int i; | ||
| 56 | |||
| 57 | for (i = 0; i < PCI_BRIDGE_RESOURCE_NUM; i++) | ||
| 58 | bus->resource[i] = 0; | ||
| 59 | |||
| 60 | list_for_each_entry_safe(bus_res, tmp, &bus->resources, list) { | ||
| 61 | list_del(&bus_res->list); | ||
| 62 | kfree(bus_res); | ||
| 63 | } | ||
| 64 | } | ||
| 65 | |||
| 20 | /** | 66 | /** |
| 21 | * pci_bus_alloc_resource - allocate a resource from a parent bus | 67 | * pci_bus_alloc_resource - allocate a resource from a parent bus |
| 22 | * @bus: PCI bus | 68 | * @bus: PCI bus |
| @@ -36,11 +82,14 @@ int | |||
| 36 | pci_bus_alloc_resource(struct pci_bus *bus, struct resource *res, | 82 | pci_bus_alloc_resource(struct pci_bus *bus, struct resource *res, |
| 37 | resource_size_t size, resource_size_t align, | 83 | resource_size_t size, resource_size_t align, |
| 38 | resource_size_t min, unsigned int type_mask, | 84 | resource_size_t min, unsigned int type_mask, |
| 39 | void (*alignf)(void *, struct resource *, resource_size_t, | 85 | resource_size_t (*alignf)(void *, |
| 40 | resource_size_t), | 86 | const struct resource *, |
| 87 | resource_size_t, | ||
| 88 | resource_size_t), | ||
| 41 | void *alignf_data) | 89 | void *alignf_data) |
| 42 | { | 90 | { |
| 43 | int i, ret = -ENOMEM; | 91 | int i, ret = -ENOMEM; |
| 92 | struct resource *r; | ||
| 44 | resource_size_t max = -1; | 93 | resource_size_t max = -1; |
| 45 | 94 | ||
| 46 | type_mask |= IORESOURCE_IO | IORESOURCE_MEM; | 95 | type_mask |= IORESOURCE_IO | IORESOURCE_MEM; |
| @@ -49,8 +98,7 @@ pci_bus_alloc_resource(struct pci_bus *bus, struct resource *res, | |||
| 49 | if (!(res->flags & IORESOURCE_MEM_64)) | 98 | if (!(res->flags & IORESOURCE_MEM_64)) |
| 50 | max = PCIBIOS_MAX_MEM_32; | 99 | max = PCIBIOS_MAX_MEM_32; |
| 51 | 100 | ||
| 52 | for (i = 0; i < PCI_BUS_NUM_RESOURCES; i++) { | 101 | pci_bus_for_each_resource(bus, r, i) { |
| 53 | struct resource *r = bus->resource[i]; | ||
| 54 | if (!r) | 102 | if (!r) |
| 55 | continue; | 103 | continue; |
| 56 | 104 | ||
