Commit 5bfeca31 authored by Alexey Starikovskiy's avatar Alexey Starikovskiy Committed by Linus Torvalds

ACPI: AC: Update AC state on resume

Check if AC state has changed across resume and notify userspace if so.

Fixes "[2.6.24-rc1 regression] AC adapter state does not change after resume"
Signed-off-by: default avatarAlexey Starikovskiy <astarikovskiy@suse.de>
Tested-by: default avatarAndrey Borzenkov <arvidjaar@mail.ru>
Cc: Len Brown <lenb@kernel.org>
Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 8a246ee4
...@@ -59,6 +59,7 @@ static int acpi_ac_open_fs(struct inode *inode, struct file *file); ...@@ -59,6 +59,7 @@ static int acpi_ac_open_fs(struct inode *inode, struct file *file);
static int acpi_ac_add(struct acpi_device *device); static int acpi_ac_add(struct acpi_device *device);
static int acpi_ac_remove(struct acpi_device *device, int type); static int acpi_ac_remove(struct acpi_device *device, int type);
static int acpi_ac_resume(struct acpi_device *device);
const static struct acpi_device_id ac_device_ids[] = { const static struct acpi_device_id ac_device_ids[] = {
{"ACPI0003", 0}, {"ACPI0003", 0},
...@@ -73,6 +74,7 @@ static struct acpi_driver acpi_ac_driver = { ...@@ -73,6 +74,7 @@ static struct acpi_driver acpi_ac_driver = {
.ops = { .ops = {
.add = acpi_ac_add, .add = acpi_ac_add,
.remove = acpi_ac_remove, .remove = acpi_ac_remove,
.resume = acpi_ac_resume,
}, },
}; };
...@@ -307,6 +309,21 @@ static int acpi_ac_add(struct acpi_device *device) ...@@ -307,6 +309,21 @@ static int acpi_ac_add(struct acpi_device *device)
return result; return result;
} }
static int acpi_ac_resume(struct acpi_device *device)
{
struct acpi_ac *ac;
unsigned old_state;
if (!device || !acpi_driver_data(device))
return -EINVAL;
ac = acpi_driver_data(device);
old_state = ac->state;
if (acpi_ac_get_state(ac))
return 0;
if (old_state != ac->state)
kobject_uevent(&ac->charger.dev->kobj, KOBJ_CHANGE);
return 0;
}
static int acpi_ac_remove(struct acpi_device *device, int type) static int acpi_ac_remove(struct acpi_device *device, int type)
{ {
acpi_status status = AE_OK; acpi_status status = AE_OK;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment