diff options
author | Axel Lin <axel.lin@gmail.com> | 2011-07-27 15:27:34 +0800 |
---|---|---|
committer | Matthew Garrett <mjg@redhat.com> | 2011-08-05 15:21:50 -0400 |
commit | 7451a55af08d40fd6b28802f4e26a13264114430 (patch) | |
tree | 651ab1840943cc5974e577806b3ddbe60f52470b | |
parent | 70fda70a724c737b0df4195763f9124d181fe64d (diff) | |
download | op-kernel-dev-7451a55af08d40fd6b28802f4e26a13264114430.zip op-kernel-dev-7451a55af08d40fd6b28802f4e26a13264114430.tar.gz |
platform-drivers-x86: ideapad-laptop: add missing ideapad_input_exit in ideapad_acpi_add error path
In the case of ideapad_backlight_init() failure,
we need to free the resources allocated by ideapad_input_init().
Aslo drop __devexit annotation for ideapad_input_exit() because
we also call it in ideapad_acpi_add() error path.
Signed-off-by: Axel Lin <axel.lin@gmail.com>
Signed-off-by: Matthew Garrett <mjg@redhat.com>
-rw-r--r-- | drivers/platform/x86/ideapad-laptop.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/platform/x86/ideapad-laptop.c b/drivers/platform/x86/ideapad-laptop.c index 8811c68..0c59541 100644 --- a/drivers/platform/x86/ideapad-laptop.c +++ b/drivers/platform/x86/ideapad-laptop.c @@ -406,7 +406,7 @@ err_free_dev: return error; } -static void __devexit ideapad_input_exit(struct ideapad_private *priv) +static void ideapad_input_exit(struct ideapad_private *priv) { sparse_keymap_free(priv->inputdev); input_unregister_device(priv->inputdev); @@ -563,6 +563,7 @@ static int __devinit ideapad_acpi_add(struct acpi_device *adevice) backlight_failed: for (i = 0; i < IDEAPAD_RFKILL_DEV_NUM; i++) ideapad_unregister_rfkill(adevice, i); + ideapad_input_exit(priv); input_failed: ideapad_platform_exit(priv); platform_failed: |