diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2010-11-24 18:05:17 -0500 |
---|---|---|
committer | Len Brown <len.brown@intel.com> | 2011-01-12 04:48:43 -0500 |
commit | 32a00d274e877eab3ea7ab196b75c9be5170d25e (patch) | |
tree | 0b7a515e8b2328e8cf8b22794cdf81ab19838b5d /drivers/acpi/power.c | |
parent | 3c0eee3fe6a3a1c745379547c7e7c904aa64f6d5 (diff) |
ACPI / PM: Prevent acpi_power_get_inferred_state() from making changes
acpi_power_get_inferred_state() should not update
device->power.state behind the back of its caller, so make it return
the state via a pointer instead.
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/acpi/power.c')
-rw-r--r-- | drivers/acpi/power.c | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/drivers/acpi/power.c b/drivers/acpi/power.c index 4c9c2fb5d98f..9bd1b6044b55 100644 --- a/drivers/acpi/power.c +++ b/drivers/acpi/power.c | |||
@@ -423,19 +423,16 @@ int acpi_disable_wakeup_device_power(struct acpi_device *dev) | |||
423 | Device Power Management | 423 | Device Power Management |
424 | -------------------------------------------------------------------------- */ | 424 | -------------------------------------------------------------------------- */ |
425 | 425 | ||
426 | int acpi_power_get_inferred_state(struct acpi_device *device) | 426 | int acpi_power_get_inferred_state(struct acpi_device *device, int *state) |
427 | { | 427 | { |
428 | int result = 0; | 428 | int result = 0; |
429 | struct acpi_handle_list *list = NULL; | 429 | struct acpi_handle_list *list = NULL; |
430 | int list_state = 0; | 430 | int list_state = 0; |
431 | int i = 0; | 431 | int i = 0; |
432 | 432 | ||
433 | 433 | if (!device || !state) | |
434 | if (!device) | ||
435 | return -EINVAL; | 434 | return -EINVAL; |
436 | 435 | ||
437 | device->power.state = ACPI_STATE_UNKNOWN; | ||
438 | |||
439 | /* | 436 | /* |
440 | * We know a device's inferred power state when all the resources | 437 | * We know a device's inferred power state when all the resources |
441 | * required for a given D-state are 'on'. | 438 | * required for a given D-state are 'on'. |
@@ -450,13 +447,12 @@ int acpi_power_get_inferred_state(struct acpi_device *device) | |||
450 | return result; | 447 | return result; |
451 | 448 | ||
452 | if (list_state == ACPI_POWER_RESOURCE_STATE_ON) { | 449 | if (list_state == ACPI_POWER_RESOURCE_STATE_ON) { |
453 | device->power.state = i; | 450 | *state = i; |
454 | return 0; | 451 | return 0; |
455 | } | 452 | } |
456 | } | 453 | } |
457 | 454 | ||
458 | device->power.state = ACPI_STATE_D3; | 455 | *state = ACPI_STATE_D3; |
459 | |||
460 | return 0; | 456 | return 0; |
461 | } | 457 | } |
462 | 458 | ||