PCI Hotplug: convert acpi_pci_detect_ejectable() to take an acpi_handle
authorAlex Chiang <achiang@hp.com>
Thu, 10 Sep 2009 18:34:09 +0000 (12:34 -0600)
committerJesse Barnes <jbarnes@virtuousgeek.org>
Mon, 14 Sep 2009 15:46:58 +0000 (08:46 -0700)
acpi_pci_detect_ejectable() goes through effort to convert its
struct pci_bus arg to an acpi_handle, but every time we use this
interface, we already have the handle available.

So let's just use the handle instead of converting back and forth.

Reviewed-by: Kenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>
Tested-by: Kenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>
Signed-off-by: Alex Chiang <achiang@hp.com>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
drivers/pci/hotplug/acpi_pcihp.c
drivers/pci/hotplug/acpiphp_glue.c
drivers/pci/hotplug/pciehp_acpi.c
include/linux/pci_hotplug.h

index eb159587d0bfa5701c2d9476c8b606625d761af9..ec3c039b7ebd43c882cf729d60d5c0dccfcababb 100644 (file)
@@ -500,18 +500,18 @@ check_hotplug(acpi_handle handle, u32 lvl, void *context, void **rv)
 
 /**
  * acpi_pci_detect_ejectable - check if the PCI bus has ejectable slots
- * @pbus - PCI bus to scan
+ * @handle - handle of the PCI bus to scan
  *
  * Returns 1 if the PCI bus has ACPI based ejectable slots, 0 otherwise.
  */
-int acpi_pci_detect_ejectable(struct pci_bus *pbus)
+int acpi_pci_detect_ejectable(acpi_handle handle)
 {
-       acpi_handle handle;
        int found = 0;
 
-       if (!(handle = acpi_pci_get_bridge_handle(pbus)))
-               return 0;
-       acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, (u32)1,
+       if (!handle)
+               return found;
+
+       acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, 1,
                            check_hotplug, (void *)&found, NULL);
        return found;
 }
index e72e0adc0681ba07cc936a8b3f608b57b2935053..680c33635b6f3a21e3824f81fc2b7e7be678aab3 100644 (file)
@@ -62,22 +62,6 @@ static void acpiphp_sanitize_bus(struct pci_bus *bus);
 static void acpiphp_set_hpp_values(acpi_handle handle, struct pci_bus *bus);
 static void handle_hotplug_event_func(acpi_handle handle, u32 type, void *context);
 
-static struct pci_bus *pci_bus_from_handle(acpi_handle handle)
-{
-       struct pci_bus *pbus;
-       struct acpi_pci_root *root;
-
-       root = acpi_pci_find_root(handle);
-       if (root)
-               pbus = root->bus;
-       else {
-               struct pci_dev *pdev = acpi_get_pci_dev(handle);
-               pbus = pdev->subordinate;
-               pci_dev_put(pdev);
-       }
-       return pbus;
-}
-
 /* callback routine to check for the existence of a pci dock device */
 static acpi_status
 is_pci_dock_device(acpi_handle handle, u32 lvl, void *context, void **rv)
@@ -279,11 +263,7 @@ register_slot(acpi_handle handle, u32 lvl, void *context, void **rv)
 /* see if it's worth looking at this bridge */
 static int detect_ejectable_slots(acpi_handle handle)
 {
-       int found;
-       struct pci_bus *pbus;
-
-       pbus = pci_bus_from_handle(handle);
-       found = acpi_pci_detect_ejectable(pbus);
+       int found = acpi_pci_detect_ejectable(handle);
        if (!found) {
                acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, (u32)1,
                                    is_pci_dock_device, (void *)&found, NULL);
@@ -1364,7 +1344,16 @@ static void acpiphp_sanitize_bus(struct pci_bus *bus)
 /* Program resources in newly inserted bridge */
 static int acpiphp_configure_bridge (acpi_handle handle)
 {
-       struct pci_bus *bus = pci_bus_from_handle(handle);
+       struct pci_bus *bus;
+
+       if (acpi_is_root_bridge(handle)) {
+               struct acpi_pci_root *root = acpi_pci_find_root(handle);
+               bus = root->bus;
+       } else {
+               struct pci_dev *pdev = acpi_get_pci_dev(handle);
+               bus = pdev->subordinate;
+               pci_dev_put(pdev);
+       }
 
        pci_bus_size_bridges(bus);
        pci_bus_assign_resources(bus);
index 96048010e7d9064f2f6b0a2d007ab056bfb8e94a..7163e6a6cfaedaa199cd5813fcf73365c5ce6a00 100644 (file)
@@ -47,7 +47,7 @@ int pciehp_acpi_slot_detection_check(struct pci_dev *dev)
 {
        if (slot_detection_mode != PCIEHP_DETECT_ACPI)
                return 0;
-       if (acpi_pci_detect_ejectable(dev->subordinate))
+       if (acpi_pci_detect_ejectable(DEVICE_ACPI_HANDLE(&dev->dev)))
                return 0;
        return -ENODEV;
 }
@@ -76,9 +76,9 @@ static int __init dummy_probe(struct pcie_device *dev)
 {
        int pos;
        u32 slot_cap;
+       acpi_handle handle;
        struct slot *slot, *tmp;
        struct pci_dev *pdev = dev->port;
-       struct pci_bus *pbus = pdev->subordinate;
        /* Note: pciehp_detect_mode != PCIEHP_DETECT_ACPI here */
        if (pciehp_get_hp_hw_control_from_firmware(pdev))
                return -ENODEV;
@@ -94,7 +94,8 @@ static int __init dummy_probe(struct pcie_device *dev)
                        dup_slot_id++;
        }
        list_add_tail(&slot->slot_list, &dummy_slots);
-       if (!acpi_slot_detected && acpi_pci_detect_ejectable(pbus))
+       handle = DEVICE_ACPI_HANDLE(&pdev->dev);
+       if (!acpi_slot_detected && acpi_pci_detect_ejectable(handle))
                acpi_slot_detected = 1;
        return -ENODEV;         /* dummy driver always returns error */
 }
index 1b00cc3177fcc1e528382729ee49b35816834bd9..f0c31ae3f842967a6e3da660367282855efe2a68 100644 (file)
@@ -231,7 +231,7 @@ extern acpi_status acpi_get_hp_params_from_firmware(struct pci_bus *bus,
                                struct hotplug_params *hpp);
 int acpi_get_hp_hw_control_from_firmware(struct pci_dev *dev, u32 flags);
 int acpi_pci_check_ejectable(struct pci_bus *pbus, acpi_handle handle);
-int acpi_pci_detect_ejectable(struct pci_bus *pbus);
+int acpi_pci_detect_ejectable(acpi_handle handle);
 #endif
 #endif