diff options
author | Yinghai Lu <yinghai@kernel.org> | 2012-04-02 21:31:53 -0400 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2012-04-30 15:53:42 -0400 |
commit | 7b54366358008241f88228f02cc80ab352265eac (patch) | |
tree | 4de6ae8ce83afabf1b4405cba6895b09d1bc790d /drivers/pci/host-bridge.c | |
parent | 459f58ce51e2e11235b7bb4b1732ebf3c17d86f7 (diff) |
PCI: add generic device into pci_host_bridge struct
Use that device for pci_root_bus bridge pointer.
Use pci_release_bus_bridge_dev() to release allocated pci_host_bridge in
remove path.
Use root bus bridge pointer to get host bridge pointer instead of searching
host bridge list. That leaves the host bridge list unused, so remove it.
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Diffstat (limited to 'drivers/pci/host-bridge.c')
-rw-r--r-- | drivers/pci/host-bridge.c | 15 |
1 files changed, 1 insertions, 14 deletions
diff --git a/drivers/pci/host-bridge.c b/drivers/pci/host-bridge.c index c49a1c482cfb..122df80592c3 100644 --- a/drivers/pci/host-bridge.c +++ b/drivers/pci/host-bridge.c | |||
@@ -9,13 +9,6 @@ | |||
9 | 9 | ||
10 | #include "pci.h" | 10 | #include "pci.h" |
11 | 11 | ||
12 | static LIST_HEAD(pci_host_bridges); | ||
13 | |||
14 | void add_to_pci_host_bridges(struct pci_host_bridge *bridge) | ||
15 | { | ||
16 | list_add_tail(&bridge->list, &pci_host_bridges); | ||
17 | } | ||
18 | |||
19 | static struct pci_bus *find_pci_root_bus(struct pci_dev *dev) | 12 | static struct pci_bus *find_pci_root_bus(struct pci_dev *dev) |
20 | { | 13 | { |
21 | struct pci_bus *bus; | 14 | struct pci_bus *bus; |
@@ -30,14 +23,8 @@ static struct pci_bus *find_pci_root_bus(struct pci_dev *dev) | |||
30 | static struct pci_host_bridge *find_pci_host_bridge(struct pci_dev *dev) | 23 | static struct pci_host_bridge *find_pci_host_bridge(struct pci_dev *dev) |
31 | { | 24 | { |
32 | struct pci_bus *bus = find_pci_root_bus(dev); | 25 | struct pci_bus *bus = find_pci_root_bus(dev); |
33 | struct pci_host_bridge *bridge; | ||
34 | |||
35 | list_for_each_entry(bridge, &pci_host_bridges, list) { | ||
36 | if (bridge->bus == bus) | ||
37 | return bridge; | ||
38 | } | ||
39 | 26 | ||
40 | return NULL; | 27 | return to_pci_host_bridge(bus->bridge); |
41 | } | 28 | } |
42 | 29 | ||
43 | static bool resource_contains(struct resource *res1, struct resource *res2) | 30 | static bool resource_contains(struct resource *res1, struct resource *res2) |