HID: keep dev_rdesc unmodified and use it for comparisons
authorKevin Daughtridge <kevin@kdau.com>
Thu, 20 Sep 2012 19:00:32 +0000 (12:00 -0700)
committerJiri Kosina <jkosina@suse.cz>
Mon, 1 Oct 2012 08:09:26 +0000 (10:09 +0200)
commit86e6b77eb7cf9ca2e9c7092b4dfd588f0a3307b6
treed00ef9d1f11bae93c5e809246f8eae156d74b1ed
parent4cc9834518efed3b69d3a8ff3bd162e089f68d34
HID: keep dev_rdesc unmodified and use it for comparisons

The dev_rdesc member of the hid_device structure is meant to store the original
report descriptor received from the device, but it is currently passed to any
report_fixup method before it is copied to the rdesc member. This patch uses a
temporary buffer to shield dev_rdesc from the side effects of many HID drivers'
report_fixup implementations.

usbhid's hid_post_reset checks the report descriptor currently returned by the
device against a descriptor that may have been modified by a driver's
report_fixup method. That leaves some devices nonfunctional after a resume, with
a "reset_resume error 1" reported. This patch checks the new descriptor against
the unmodified dev_rdesc instead and uses the original, instead of modified,
report size.

BugLink: http://bugs.launchpad.net/bugs/1049623
Signed-off-by: Kevin Daughtridge <kevin@kdau.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
drivers/hid/hid-core.c
drivers/hid/usbhid/hid-core.c