summary refs log tree commit diff
path: root/drivers/platform
diff options
context:
space:
mode:
authorAndy Whitcroft <apw@canonical.com>2009-04-04 09:33:34 +0100
committerLen Brown <len.brown@intel.com>2009-04-04 12:36:21 -0400
commit350e32907cf72ef82bbe7d72525fa2d9dcf64682 (patch)
tree160e78f3e687809cb2062ef1228cedccde0aef52 /drivers/platform
parenta74dd5fdabcd34c93e17e9c7024eeb503c92b048 (diff)
downloadlinux-350e32907cf72ef82bbe7d72525fa2d9dcf64682.tar.gz
acer-wmi: Cleanup the failure cleanup handling
Cleanup the failure cleanup handling for brightness and email led.

[cc: Split out from another patch]

Signed-off-by: Andy Whitcroft <apw@canonical.com>
Signed-off-by: Carlos Corbacho <carlos@strangeworlds.co.uk>
Signed-off-by: Len Brown <len.brown@intel.com>
Diffstat (limited to 'drivers/platform')
-rw-r--r--drivers/platform/x86/acer-wmi.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/platform/x86/acer-wmi.c b/drivers/platform/x86/acer-wmi.c
index 60fbef283e73..27837e8ae51d 100644
--- a/drivers/platform/x86/acer-wmi.c
+++ b/drivers/platform/x86/acer-wmi.c
@@ -1136,11 +1136,17 @@ static int __devinit acer_platform_probe(struct platform_device *device)
 	}
 
 	err = acer_rfkill_init(&device->dev);
+	if (err)
+		goto error_rfkill;
 
 	return err;
 
+error_rfkill:
+	if (has_cap(ACER_CAP_BRIGHTNESS))
+		acer_backlight_exit();
 error_brightness:
-	acer_led_exit();
+	if (has_cap(ACER_CAP_MAILLED))
+		acer_led_exit();
 error_mailled:
 	return err;
 }