提交 be1c9de9 编写于 作者: R Rafael J. Wysocki

ACPI / PCI: Make bus registration and unregistration symmetric

Since acpi_pci_slot_enumerate() and acpiphp_enumerate_slots() can get
the ACPI device handle they need from bus->bridge, it is not
necessary to pass that handle to them as an argument.

Drop the second argument of acpi_pci_slot_enumerate() and
acpiphp_enumerate_slots(), rework them to obtain the ACPI handle
from bus->bridge and make acpi_pci_add_bus() and
acpi_pci_remove_bus() entirely symmetrical.
Tested-by: NMika Westerberg <mika.westerberg@linux.intel.com>
Signed-off-by: NRafael J. Wysocki <rafael.j.wysocki@intel.com>
Acked-by: NYinghai Lu <yinghai@kernel.org>
上级 b9eb179f
...@@ -159,12 +159,16 @@ register_slot(acpi_handle handle, u32 lvl, void *context, void **rv) ...@@ -159,12 +159,16 @@ register_slot(acpi_handle handle, u32 lvl, void *context, void **rv)
return AE_OK; return AE_OK;
} }
void acpi_pci_slot_enumerate(struct pci_bus *bus, acpi_handle handle) void acpi_pci_slot_enumerate(struct pci_bus *bus)
{ {
mutex_lock(&slot_list_lock); acpi_handle handle = ACPI_HANDLE(bus->bridge);
acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, 1,
register_slot, NULL, bus, NULL); if (handle) {
mutex_unlock(&slot_list_lock); mutex_lock(&slot_list_lock);
acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, 1,
register_slot, NULL, bus, NULL);
mutex_unlock(&slot_list_lock);
}
} }
void acpi_pci_slot_remove(struct pci_bus *bus) void acpi_pci_slot_remove(struct pci_bus *bus)
......
...@@ -1147,14 +1147,16 @@ static void handle_hotplug_event_func(acpi_handle handle, u32 type, ...@@ -1147,14 +1147,16 @@ static void handle_hotplug_event_func(acpi_handle handle, u32 type,
* Create hotplug slots for the PCI bus. * Create hotplug slots for the PCI bus.
* It should always return 0 to avoid skipping following notifiers. * It should always return 0 to avoid skipping following notifiers.
*/ */
void acpiphp_enumerate_slots(struct pci_bus *bus, acpi_handle handle) void acpiphp_enumerate_slots(struct pci_bus *bus)
{ {
acpi_handle handle;
struct acpiphp_bridge *bridge; struct acpiphp_bridge *bridge;
if (acpiphp_disabled) if (acpiphp_disabled)
return; return;
if (detect_ejectable_slots(handle) <= 0) handle = ACPI_HANDLE(bus->bridge);
if (!handle || detect_ejectable_slots(handle) <= 0)
return; return;
bridge = kzalloc(sizeof(struct acpiphp_bridge), GFP_KERNEL); bridge = kzalloc(sizeof(struct acpiphp_bridge), GFP_KERNEL);
......
...@@ -290,24 +290,16 @@ static struct pci_platform_pm_ops acpi_pci_platform_pm = { ...@@ -290,24 +290,16 @@ static struct pci_platform_pm_ops acpi_pci_platform_pm = {
void acpi_pci_add_bus(struct pci_bus *bus) void acpi_pci_add_bus(struct pci_bus *bus)
{ {
acpi_handle handle = NULL; if (acpi_pci_disabled || !bus->bridge)
if (bus->bridge)
handle = ACPI_HANDLE(bus->bridge);
if (acpi_pci_disabled || handle == NULL)
return; return;
acpi_pci_slot_enumerate(bus, handle); acpi_pci_slot_enumerate(bus);
acpiphp_enumerate_slots(bus, handle); acpiphp_enumerate_slots(bus);
} }
void acpi_pci_remove_bus(struct pci_bus *bus) void acpi_pci_remove_bus(struct pci_bus *bus)
{ {
/* if (acpi_pci_disabled || !bus->bridge)
* bus->bridge->acpi_node.handle has already been reset to NULL
* when acpi_pci_remove_bus() is called, so don't check ACPI handle.
*/
if (acpi_pci_disabled)
return; return;
acpiphp_remove_slots(bus); acpiphp_remove_slots(bus);
......
...@@ -47,24 +47,22 @@ void acpi_pci_remove_bus(struct pci_bus *bus); ...@@ -47,24 +47,22 @@ void acpi_pci_remove_bus(struct pci_bus *bus);
#ifdef CONFIG_ACPI_PCI_SLOT #ifdef CONFIG_ACPI_PCI_SLOT
void acpi_pci_slot_init(void); void acpi_pci_slot_init(void);
void acpi_pci_slot_enumerate(struct pci_bus *bus, acpi_handle handle); void acpi_pci_slot_enumerate(struct pci_bus *bus);
void acpi_pci_slot_remove(struct pci_bus *bus); void acpi_pci_slot_remove(struct pci_bus *bus);
#else #else
static inline void acpi_pci_slot_init(void) { } static inline void acpi_pci_slot_init(void) { }
static inline void acpi_pci_slot_enumerate(struct pci_bus *bus, static inline void acpi_pci_slot_enumerate(struct pci_bus *bus) { }
acpi_handle handle) { }
static inline void acpi_pci_slot_remove(struct pci_bus *bus) { } static inline void acpi_pci_slot_remove(struct pci_bus *bus) { }
#endif #endif
#ifdef CONFIG_HOTPLUG_PCI_ACPI #ifdef CONFIG_HOTPLUG_PCI_ACPI
void acpiphp_init(void); void acpiphp_init(void);
void acpiphp_enumerate_slots(struct pci_bus *bus, acpi_handle handle); void acpiphp_enumerate_slots(struct pci_bus *bus);
void acpiphp_remove_slots(struct pci_bus *bus); void acpiphp_remove_slots(struct pci_bus *bus);
void acpiphp_check_host_bridge(acpi_handle handle); void acpiphp_check_host_bridge(acpi_handle handle);
#else #else
static inline void acpiphp_init(void) { } static inline void acpiphp_init(void) { }
static inline void acpiphp_enumerate_slots(struct pci_bus *bus, static inline void acpiphp_enumerate_slots(struct pci_bus *bus) { }
acpi_handle handle) { }
static inline void acpiphp_remove_slots(struct pci_bus *bus) { } static inline void acpiphp_remove_slots(struct pci_bus *bus) { }
static inline void acpiphp_check_host_bridge(acpi_handle handle) { } static inline void acpiphp_check_host_bridge(acpi_handle handle) { }
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册