diff options
author | Dmitry Torokhov <dtor_core@ameritech.net> | 2006-03-14 00:09:05 -0500 |
---|---|---|
committer | Dmitry Torokhov <dtor_core@ameritech.net> | 2006-03-14 00:09:05 -0500 |
commit | 493a7e0d5614c30e1f3e56d59ab774300a2609f2 (patch) | |
tree | b0da1f3a92d03ca821060e4f48bf440cc12c4969 | |
parent | 58a343f22e8ef987b90e34bbef7f1455e3bb5a15 (diff) |
Input: fix input_free_device() implementation
input_free_device can't just call kfree because if input_register_device
fails after successfully registering corresponding class device there
is a chance that someone could get a reference to it. We need to use
input_put_device() to make sure that we don't delete input device until
last reference to it was dropped.
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
-rw-r--r-- | include/linux/input.h | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/include/linux/input.h b/include/linux/input.h index 6dca6baf06ff..cf30f3cb191a 100644 --- a/include/linux/input.h +++ b/include/linux/input.h | |||
@@ -421,7 +421,7 @@ struct input_absinfo { | |||
421 | #define BTN_GEAR_UP 0x151 | 421 | #define BTN_GEAR_UP 0x151 |
422 | 422 | ||
423 | #define KEY_OK 0x160 | 423 | #define KEY_OK 0x160 |
424 | #define KEY_SELECT 0x161 | 424 | #define KEY_SELECT 0x161 |
425 | #define KEY_GOTO 0x162 | 425 | #define KEY_GOTO 0x162 |
426 | #define KEY_CLEAR 0x163 | 426 | #define KEY_CLEAR 0x163 |
427 | #define KEY_POWER2 0x164 | 427 | #define KEY_POWER2 0x164 |
@@ -995,11 +995,6 @@ static inline void init_input_dev(struct input_dev *dev) | |||
995 | 995 | ||
996 | struct input_dev *input_allocate_device(void); | 996 | struct input_dev *input_allocate_device(void); |
997 | 997 | ||
998 | static inline void input_free_device(struct input_dev *dev) | ||
999 | { | ||
1000 | kfree(dev); | ||
1001 | } | ||
1002 | |||
1003 | static inline struct input_dev *input_get_device(struct input_dev *dev) | 998 | static inline struct input_dev *input_get_device(struct input_dev *dev) |
1004 | { | 999 | { |
1005 | return to_input_dev(class_device_get(&dev->cdev)); | 1000 | return to_input_dev(class_device_get(&dev->cdev)); |
@@ -1010,6 +1005,11 @@ static inline void input_put_device(struct input_dev *dev) | |||
1010 | class_device_put(&dev->cdev); | 1005 | class_device_put(&dev->cdev); |
1011 | } | 1006 | } |
1012 | 1007 | ||
1008 | static inline void input_free_device(struct input_dev *dev) | ||
1009 | { | ||
1010 | input_put_device(dev); | ||
1011 | } | ||
1012 | |||
1013 | int input_register_device(struct input_dev *); | 1013 | int input_register_device(struct input_dev *); |
1014 | void input_unregister_device(struct input_dev *); | 1014 | void input_unregister_device(struct input_dev *); |
1015 | 1015 | ||