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)
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>

No differences found