aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorDmitry Torokhov <dtor@insightbb.com>2006-11-24 00:43:22 -0500
committerDmitry Torokhov <dtor@insightbb.com>2006-11-24 00:43:22 -0500
commit4bdbd2807deeccc0793d57fb5120d7a53f2c0b3c (patch)
treeaf7f75cdffeb2d25cc4c62574b7bb3194c1faf05 /drivers
parente4477d2d1bc3e6c76e83926f7fa8c8f94ba42615 (diff)
Input: handle errors from input_register_device in drivers/macintosh
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/macintosh/adbhid.c10
-rw-r--r--drivers/macintosh/mac_hid.c8
2 files changed, 13 insertions, 5 deletions
diff --git a/drivers/macintosh/adbhid.c b/drivers/macintosh/adbhid.c
index 5066e7a8ea9c..1c7d6f221b55 100644
--- a/drivers/macintosh/adbhid.c
+++ b/drivers/macintosh/adbhid.c
@@ -689,7 +689,6 @@ adbhid_input_register(int id, int default_id, int original_handler_id,
689 if (!hid || !input_dev) { 689 if (!hid || !input_dev) {
690 err = -ENOMEM; 690 err = -ENOMEM;
691 goto fail; 691 goto fail;
692
693 } 692 }
694 693
695 sprintf(hid->phys, "adb%d:%d.%02x/input", id, default_id, original_handler_id); 694 sprintf(hid->phys, "adb%d:%d.%02x/input", id, default_id, original_handler_id);
@@ -807,7 +806,9 @@ adbhid_input_register(int id, int default_id, int original_handler_id,
807 806
808 input_dev->keycode = hid->keycode; 807 input_dev->keycode = hid->keycode;
809 808
810 input_register_device(input_dev); 809 err = input_register_device(input_dev);
810 if (err)
811 goto fail;
811 812
812 if (default_id == ADB_KEYBOARD) { 813 if (default_id == ADB_KEYBOARD) {
813 /* HACK WARNING!! This should go away as soon there is an utility 814 /* HACK WARNING!! This should go away as soon there is an utility
@@ -820,7 +821,10 @@ adbhid_input_register(int id, int default_id, int original_handler_id,
820 return 0; 821 return 0;
821 822
822 fail: input_free_device(input_dev); 823 fail: input_free_device(input_dev);
823 kfree(hid); 824 if (hid) {
825 kfree(hid->keycode);
826 kfree(hid);
827 }
824 adbhid[id] = NULL; 828 adbhid[id] = NULL;
825 return err; 829 return err;
826} 830}
diff --git a/drivers/macintosh/mac_hid.c b/drivers/macintosh/mac_hid.c
index 6b129eef7987..ee6b4ca69130 100644
--- a/drivers/macintosh/mac_hid.c
+++ b/drivers/macintosh/mac_hid.c
@@ -106,6 +106,8 @@ EXPORT_SYMBOL(mac_hid_mouse_emulate_buttons);
106 106
107static int emumousebtn_input_register(void) 107static int emumousebtn_input_register(void)
108{ 108{
109 int ret;
110
109 emumousebtn = input_allocate_device(); 111 emumousebtn = input_allocate_device();
110 if (!emumousebtn) 112 if (!emumousebtn)
111 return -ENOMEM; 113 return -ENOMEM;
@@ -120,9 +122,11 @@ static int emumousebtn_input_register(void)
120 emumousebtn->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT); 122 emumousebtn->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_MIDDLE) | BIT(BTN_RIGHT);
121 emumousebtn->relbit[0] = BIT(REL_X) | BIT(REL_Y); 123 emumousebtn->relbit[0] = BIT(REL_X) | BIT(REL_Y);
122 124
123 input_register_device(emumousebtn); 125 ret = input_register_device(emumousebtn);
126 if (ret)
127 input_free_device(emumousebtn);
124 128
125 return 0; 129 return ret;
126} 130}
127 131
128int __init mac_hid_init(void) 132int __init mac_hid_init(void)