aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorHenrique de Moraes Holschuh <hmh@hmh.eng.br>2010-02-25 19:28:58 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2010-03-15 12:06:44 -0400
commit17cab421d82a9be3afcd59d1385eb74bbd58b432 (patch)
treedfddc832e4446f922fee441104369b922a8874c7 /drivers
parent3362453cc98979c3552a1570574505fdb06e99e3 (diff)
thinkpad-acpi: fix poll thread auto-start
commit b589ea4c44170d3f7a845684e2d1b3b9571663af upstream. The driver was not starting the NVRAM polling thread if the input device was bound immediately after registration. This fixes: http://bugzilla.kernel.org/show_bug.cgi?id=15118 Reported-by: Florian Zumbiehl <florz@florz.de> Signed-off-by: Henrique de Moraes Holschuh <hmh@hmh.eng.br> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/platform/x86/thinkpad_acpi.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/drivers/platform/x86/thinkpad_acpi.c b/drivers/platform/x86/thinkpad_acpi.c
index 159a1f877d91..e63a4f2b1ff7 100644
--- a/drivers/platform/x86/thinkpad_acpi.c
+++ b/drivers/platform/x86/thinkpad_acpi.c
@@ -2607,16 +2607,11 @@ static int hotkey_inputdev_open(struct input_dev *dev)
2607{ 2607{
2608 switch (tpacpi_lifecycle) { 2608 switch (tpacpi_lifecycle) {
2609 case TPACPI_LIFE_INIT: 2609 case TPACPI_LIFE_INIT:
2610 /*
2611 * hotkey_init will call hotkey_poll_setup_safe
2612 * at the appropriate moment
2613 */
2614 return 0;
2615 case TPACPI_LIFE_EXITING:
2616 return -EBUSY;
2617 case TPACPI_LIFE_RUNNING: 2610 case TPACPI_LIFE_RUNNING:
2618 hotkey_poll_setup_safe(false); 2611 hotkey_poll_setup_safe(false);
2619 return 0; 2612 return 0;
2613 case TPACPI_LIFE_EXITING:
2614 return -EBUSY;
2620 } 2615 }
2621 2616
2622 /* Should only happen if tpacpi_lifecycle is corrupt */ 2617 /* Should only happen if tpacpi_lifecycle is corrupt */
@@ -2627,7 +2622,7 @@ static int hotkey_inputdev_open(struct input_dev *dev)
2627static void hotkey_inputdev_close(struct input_dev *dev) 2622static void hotkey_inputdev_close(struct input_dev *dev)
2628{ 2623{
2629 /* disable hotkey polling when possible */ 2624 /* disable hotkey polling when possible */
2630 if (tpacpi_lifecycle == TPACPI_LIFE_RUNNING && 2625 if (tpacpi_lifecycle != TPACPI_LIFE_EXITING &&
2631 !(hotkey_source_mask & hotkey_driver_mask)) 2626 !(hotkey_source_mask & hotkey_driver_mask))
2632 hotkey_poll_setup_safe(false); 2627 hotkey_poll_setup_safe(false);
2633} 2628}
@@ -9051,6 +9046,9 @@ static int __init thinkpad_acpi_module_init(void)
9051 return ret; 9046 return ret;
9052 } 9047 }
9053 } 9048 }
9049
9050 tpacpi_lifecycle = TPACPI_LIFE_RUNNING;
9051
9054 ret = input_register_device(tpacpi_inputdev); 9052 ret = input_register_device(tpacpi_inputdev);
9055 if (ret < 0) { 9053 if (ret < 0) {
9056 printk(TPACPI_ERR "unable to register input device\n"); 9054 printk(TPACPI_ERR "unable to register input device\n");
@@ -9060,7 +9058,6 @@ static int __init thinkpad_acpi_module_init(void)
9060 tp_features.input_device_registered = 1; 9058 tp_features.input_device_registered = 1;
9061 } 9059 }
9062 9060
9063 tpacpi_lifecycle = TPACPI_LIFE_RUNNING;
9064 return 0; 9061 return 0;
9065} 9062}
9066 9063