resource_lock should be released when acpi_power_get_state() fails and before
passing to next power resource on the acpi power resource list.
Signed-off-by: Lan Tianyu <[email protected]>
---
drivers/acpi/power.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/drivers/acpi/power.c b/drivers/acpi/power.c
index 0dbe5cd..0c1c3ec 100644
--- a/drivers/acpi/power.c
+++ b/drivers/acpi/power.c
@@ -936,8 +936,10 @@ void acpi_resume_power_resources(void)
mutex_lock(&resource->resource_lock);
result = acpi_power_get_state(resource->device.handle, &state);
- if (result)
+ if (result) {
+ mutex_unlock(&resource->resource_lock);
continue;
+ }
if (state == ACPI_POWER_RESOURCE_STATE_OFF
&& resource->ref_count) {
--
1.8.2.1
On Tuesday, October 15, 2013 07:48:11 PM Lan Tianyu wrote:
> resource_lock should be released when acpi_power_get_state() fails and before
> passing to next power resource on the acpi power resource list.
>
> Signed-off-by: Lan Tianyu <[email protected]>
Yup, good catch!
I'll queue this up as a fix for 3.12.
Thanks!
> ---
> drivers/acpi/power.c | 4 +++-
> 1 file changed, 3 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/acpi/power.c b/drivers/acpi/power.c
> index 0dbe5cd..0c1c3ec 100644
> --- a/drivers/acpi/power.c
> +++ b/drivers/acpi/power.c
> @@ -936,8 +936,10 @@ void acpi_resume_power_resources(void)
> mutex_lock(&resource->resource_lock);
>
> result = acpi_power_get_state(resource->device.handle, &state);
> - if (result)
> + if (result) {
> + mutex_unlock(&resource->resource_lock);
> continue;
> + }
>
> if (state == ACPI_POWER_RESOURCE_STATE_OFF
> && resource->ref_count) {
>
--
I speak only for myself.
Rafael J. Wysocki, Intel Open Source Technology Center.