diff options
author | Jiri Kosina <jkosina@suse.cz> | 2010-08-13 14:19:45 +0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2010-08-13 14:19:45 +0400 |
commit | 9c9e54a8df0be48aa359744f412377cc55c3b7d2 (patch) | |
tree | 1df6c9dde015a961c2841437cb757e36119e7ea6 /drivers/hid/hid-core.c | |
parent | 7032269e87ade34cc12891675371fa2ac150a620 (diff) | |
download | linux-9c9e54a8df0be48aa359744f412377cc55c3b7d2.tar.xz |
HID: hiddev: fix memory corruption due to invalid intfdata
Commit bd25f4dd6972755579d0 ("HID: hiddev: use usb_find_interface,
get rid of BKL") introduced using of private intfdata in hiddev for
purpose of storing hiddev pointer.
This is a problem, because intf pointer is already being set to struct
hid_device pointer by HID core. This obviously lead to memory corruptions
at device disconnect time, such as
WARNING: at lib/kobject.c:595 kobject_put+0x37/0x4b()
kobject: '(null)' (ffff88011e9cd898): is not initialized, yet kobject_put() is being called.
Convert hiddev into accessing hiddev through struct hid_device which is
in intfdata already.
Reported-and-tested-by: Markus Trippelsdorf <markus@trippelsdorf.de>
Reported-and-tested-by: Heinz Diehl <htd@fritha.org>
Reported-and-tested-by: Alan Ott <alan@signal11.us>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid/hid-core.c')
0 files changed, 0 insertions, 0 deletions