From mboxrd@z Thu Jan 1 00:00:00 1970 From: Yasuaki Ishimatsu Subject: Re: [PATCH] ACPI / PM: Fix error code path for power resources initialization Date: Wed, 19 Jun 2013 13:45:28 +0900 Message-ID: <51C13768.30000@jp.fujitsu.com> References: <8547354.D2OPcUytEB@vostro.rjw.lan> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from fgwmail6.fujitsu.co.jp ([192.51.44.36]:46162 "EHLO fgwmail6.fujitsu.co.jp" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750884Ab3FSEpv (ORCPT ); Wed, 19 Jun 2013 00:45:51 -0400 In-Reply-To: <8547354.D2OPcUytEB@vostro.rjw.lan> Sender: linux-acpi-owner@vger.kernel.org List-Id: linux-acpi@vger.kernel.org To: "Rafael J. Wysocki" Cc: ACPI Devel Maling List , LKML , Linux PM list , Mika Westerberg 2013/06/18 7:37, Rafael J. Wysocki wrote: > From: Rafael J. Wysocki > > Commit 781d737 (ACPI: Drop power resources driver) introduced a > bug in the power resources initialization error code path causing > a NULL pointer to be referenced in acpi_release_power_resource() > if there's an error triggering a jump to the 'err' label in > acpi_add_power_resource(). This happens because the list_node > field of struct acpi_power_resource has not been initialized yet > at this point and doing a list_del() on it is a bad idea. > > To prevent this problem from occuring, initialize the list_node > field of struct acpi_power_resource upfront. > > Reported-by: Mika Westerberg > Signed-off-by: Rafael J. Wysocki > Cc: 3.9+ Acked-by: Yasuaki Ishimatsu Thanks, Yasuaki Ishimatsu > --- > drivers/acpi/power.c | 1 + > 1 file changed, 1 insertion(+) > > Index: linux-pm/drivers/acpi/power.c > =================================================================== > --- linux-pm.orig/drivers/acpi/power.c > +++ linux-pm/drivers/acpi/power.c > @@ -882,6 +882,7 @@ int acpi_add_power_resource(acpi_handle > ACPI_STA_DEFAULT); > mutex_init(&resource->resource_lock); > INIT_LIST_HEAD(&resource->dependent); > + INIT_LIST_HEAD(&resource->list_node); > resource->name = device->pnp.bus_id; > strcpy(acpi_device_name(device), ACPI_POWER_DEVICE_NAME); > strcpy(acpi_device_class(device), ACPI_POWER_CLASS); > > -- > To unsubscribe from this list: send the line "unsubscribe linux-acpi" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html >