mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-24 01:09:38 -05:00
ACPI / hotplug: Rework deferred execution of acpi_device_hotplug()
Since the only function executed by acpi_hotplug_execute() is acpi_device_hotplug() and it only is called by the ACPI core, simplify its definition so that it only takes two arguments, the ACPI device object pointer and event code, rename it to acpi_hotplug_schedule() and move its header from acpi_bus.h to the ACPI core's internal header file internal.h. Modify the definition of acpi_device_hotplug() so that its first argument is an ACPI device object pointer and modify the definition of struct acpi_hp_work accordingly. Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Acked-by: Toshi Kani <toshi.kani@hp.com>
This commit is contained in:
parent
8cc2568124
commit
1e3bcb596c
5 changed files with 11 additions and 18 deletions
|
@ -400,7 +400,7 @@ static void acpi_bus_notify(acpi_handle handle, u32 type, void *data)
|
||||||
case ACPI_NOTIFY_BUS_CHECK:
|
case ACPI_NOTIFY_BUS_CHECK:
|
||||||
case ACPI_NOTIFY_DEVICE_CHECK:
|
case ACPI_NOTIFY_DEVICE_CHECK:
|
||||||
case ACPI_NOTIFY_EJECT_REQUEST:
|
case ACPI_NOTIFY_EJECT_REQUEST:
|
||||||
status = acpi_hotplug_execute(acpi_device_hotplug, adev, type);
|
status = acpi_hotplug_schedule(adev, type);
|
||||||
if (ACPI_SUCCESS(status))
|
if (ACPI_SUCCESS(status))
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -78,8 +78,9 @@ void acpi_lpss_init(void);
|
||||||
static inline void acpi_lpss_init(void) {}
|
static inline void acpi_lpss_init(void) {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
acpi_status acpi_hotplug_schedule(struct acpi_device *adev, u32 src);
|
||||||
bool acpi_queue_hotplug_work(struct work_struct *work);
|
bool acpi_queue_hotplug_work(struct work_struct *work);
|
||||||
void acpi_device_hotplug(void *data, u32 src);
|
void acpi_device_hotplug(struct acpi_device *adev, u32 src);
|
||||||
bool acpi_scan_is_offline(struct acpi_device *adev, bool uevent);
|
bool acpi_scan_is_offline(struct acpi_device *adev, bool uevent);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------
|
||||||
|
|
|
@ -1168,8 +1168,7 @@ void acpi_os_wait_events_complete(void)
|
||||||
|
|
||||||
struct acpi_hp_work {
|
struct acpi_hp_work {
|
||||||
struct work_struct work;
|
struct work_struct work;
|
||||||
acpi_hp_callback func;
|
struct acpi_device *adev;
|
||||||
void *data;
|
|
||||||
u32 src;
|
u32 src;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1178,25 +1177,24 @@ static void acpi_hotplug_work_fn(struct work_struct *work)
|
||||||
struct acpi_hp_work *hpw = container_of(work, struct acpi_hp_work, work);
|
struct acpi_hp_work *hpw = container_of(work, struct acpi_hp_work, work);
|
||||||
|
|
||||||
acpi_os_wait_events_complete();
|
acpi_os_wait_events_complete();
|
||||||
hpw->func(hpw->data, hpw->src);
|
acpi_device_hotplug(hpw->adev, hpw->src);
|
||||||
kfree(hpw);
|
kfree(hpw);
|
||||||
}
|
}
|
||||||
|
|
||||||
acpi_status acpi_hotplug_execute(acpi_hp_callback func, void *data, u32 src)
|
acpi_status acpi_hotplug_schedule(struct acpi_device *adev, u32 src)
|
||||||
{
|
{
|
||||||
struct acpi_hp_work *hpw;
|
struct acpi_hp_work *hpw;
|
||||||
|
|
||||||
ACPI_DEBUG_PRINT((ACPI_DB_EXEC,
|
ACPI_DEBUG_PRINT((ACPI_DB_EXEC,
|
||||||
"Scheduling function [%p(%p, %u)] for deferred execution.\n",
|
"Scheduling hotplug event (%p, %u) for deferred execution.\n",
|
||||||
func, data, src));
|
adev, src));
|
||||||
|
|
||||||
hpw = kmalloc(sizeof(*hpw), GFP_KERNEL);
|
hpw = kmalloc(sizeof(*hpw), GFP_KERNEL);
|
||||||
if (!hpw)
|
if (!hpw)
|
||||||
return AE_NO_MEMORY;
|
return AE_NO_MEMORY;
|
||||||
|
|
||||||
INIT_WORK(&hpw->work, acpi_hotplug_work_fn);
|
INIT_WORK(&hpw->work, acpi_hotplug_work_fn);
|
||||||
hpw->func = func;
|
hpw->adev = adev;
|
||||||
hpw->data = data;
|
|
||||||
hpw->src = src;
|
hpw->src = src;
|
||||||
/*
|
/*
|
||||||
* We can't run hotplug code in kacpid_wq/kacpid_notify_wq etc., because
|
* We can't run hotplug code in kacpid_wq/kacpid_notify_wq etc., because
|
||||||
|
|
|
@ -481,10 +481,9 @@ static int acpi_generic_hotplug_event(struct acpi_device *adev, u32 type)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void acpi_device_hotplug(void *data, u32 src)
|
void acpi_device_hotplug(struct acpi_device *adev, u32 src)
|
||||||
{
|
{
|
||||||
u32 ost_code = ACPI_OST_SC_NON_SPECIFIC_FAILURE;
|
u32 ost_code = ACPI_OST_SC_NON_SPECIFIC_FAILURE;
|
||||||
struct acpi_device *adev = data;
|
|
||||||
int error = -ENODEV;
|
int error = -ENODEV;
|
||||||
|
|
||||||
lock_device_hotplug();
|
lock_device_hotplug();
|
||||||
|
@ -579,8 +578,7 @@ acpi_eject_store(struct device *d, struct device_attribute *attr,
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
|
||||||
get_device(&acpi_device->dev);
|
get_device(&acpi_device->dev);
|
||||||
status = acpi_hotplug_execute(acpi_device_hotplug, acpi_device,
|
status = acpi_hotplug_schedule(acpi_device, ACPI_OST_EC_OSPM_EJECT);
|
||||||
ACPI_OST_EC_OSPM_EJECT);
|
|
||||||
if (ACPI_SUCCESS(status))
|
if (ACPI_SUCCESS(status))
|
||||||
return count;
|
return count;
|
||||||
|
|
||||||
|
|
|
@ -455,10 +455,6 @@ static inline bool acpi_device_enumerated(struct acpi_device *adev)
|
||||||
return adev && adev->flags.initialized && adev->flags.visited;
|
return adev && adev->flags.initialized && adev->flags.visited;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef void (*acpi_hp_callback)(void *data, u32 src);
|
|
||||||
|
|
||||||
acpi_status acpi_hotplug_execute(acpi_hp_callback func, void *data, u32 src);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* module_acpi_driver(acpi_driver) - Helper macro for registering an ACPI driver
|
* module_acpi_driver(acpi_driver) - Helper macro for registering an ACPI driver
|
||||||
* @__acpi_driver: acpi_driver struct
|
* @__acpi_driver: acpi_driver struct
|
||||||
|
|
Loading…
Add table
Reference in a new issue