HID: cp2112: fix to force single data-report reply
authorAntonio Borneo <borneo.antonio@gmail.com>
Sun, 21 Jun 2015 06:20:25 +0000 (14:20 +0800)
committerJiri Kosina <jkosina@suse.com>
Wed, 8 Jul 2015 10:40:23 +0000 (12:40 +0200)
commit6debce6f4e787a8eb4cec94e7afa85fb4f40db27
treeb590743fb1eb84392c6a434e4593ebd70f5d72ed
parent9633920e5ef65f81d30f2acd642d6d1c25cf7bc7
HID: cp2112: fix to force single data-report reply

Current implementation of cp2112_raw_event() only accepts one data report at a
time. If last received data report is not fully handled yet, a new incoming
data report will overwrite it. In such case we don't guaranteed to propagate
the correct incoming data.

The trivial fix implemented here forces a single report at a time by requesting
in cp2112_read() no more than 61 byte of data, which is the payload size of a
single data report.

Cc: stable@vger.kernel.org
Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com>
Tested-by: Ellen Wang <ellen@cumulusnetworks.com>
Signed-off-by: Jiri Kosina <jkosina@suse.com>
drivers/hid/hid-cp2112.c