aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLan Tianyu <tianyu.lan@intel.com>2012-07-20 01:29:16 -0400
committerLen Brown <len.brown@intel.com>2012-07-24 01:37:37 -0400
commitf197ac13f6eeb351b31250b9ab7d0da17434ea36 (patch)
treea8477613b7c7ed7529d9da65a62bef223a6a17b7
parent28a33cbc24e4256c143dce96c7d93bf423229f92 (diff)
ACPI/AC: prevent OOPS on some boxes due to missing check power_supply_register() return value check
In the ac.c, power_supply_register()'s return value is not checked. As a result, the driver's add() ops may return success even though the device failed to initialize. For example, some BIOS may describe two ACADs in the same DSDT. The second ACAD device will fail to register, but ACPI driver's add() ops returns sucessfully. The ACPI device will receive ACPI notification and cause OOPS. https://bugzilla.redhat.com/show_bug.cgi?id=772730 Signed-off-by: Lan Tianyu <tianyu.lan@intel.com> Cc: stable@vger.kernel.org Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r--drivers/acpi/ac.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/acpi/ac.c b/drivers/acpi/ac.c
index 6512b20aeccd..d1fcbc0f6cbc 100644
--- a/drivers/acpi/ac.c
+++ b/drivers/acpi/ac.c
@@ -292,7 +292,9 @@ static int acpi_ac_add(struct acpi_device *device)
292 ac->charger.properties = ac_props; 292 ac->charger.properties = ac_props;
293 ac->charger.num_properties = ARRAY_SIZE(ac_props); 293 ac->charger.num_properties = ARRAY_SIZE(ac_props);
294 ac->charger.get_property = get_ac_property; 294 ac->charger.get_property = get_ac_property;
295 power_supply_register(&ac->device->dev, &ac->charger); 295 result = power_supply_register(&ac->device->dev, &ac->charger);
296 if (result)
297 goto end;
296 298
297 printk(KERN_INFO PREFIX "%s [%s] (%s)\n", 299 printk(KERN_INFO PREFIX "%s [%s] (%s)\n",
298 acpi_device_name(device), acpi_device_bid(device), 300 acpi_device_name(device), acpi_device_bid(device),