diff options
author | Vinicius Costa Gomes <vinicius.gomes@openbossa.org> | 2012-07-14 17:59:25 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2012-07-20 03:53:45 -0400 |
commit | adefb69b1b94df29ea2df05cd838c0e032b2c473 (patch) | |
tree | fee338077704e19810075750bb1b2c5577c358c9 /drivers/hid | |
parent | 1a8b294ce6b0cdab438175eed45ebb088bdd659a (diff) |
HID: uhid: Fix sending events with invalid data
This was detected because events with invalid types were arriving
to userspace.
The code before this patch would only work for the first event in the
queue (when uhid->tail is 0).
Signed-off-by: Vinicius Costa Gomes <vinicius.gomes@openbossa.org>
Reviewed-by: David Herrmann <dh.herrmann@googlemail.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Diffstat (limited to 'drivers/hid')
-rw-r--r-- | drivers/hid/uhid.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c index 119b7e6405be..714cd8cc9579 100644 --- a/drivers/hid/uhid.c +++ b/drivers/hid/uhid.c | |||
@@ -465,7 +465,7 @@ try_again: | |||
465 | goto try_again; | 465 | goto try_again; |
466 | } else { | 466 | } else { |
467 | len = min(count, sizeof(**uhid->outq)); | 467 | len = min(count, sizeof(**uhid->outq)); |
468 | if (copy_to_user(buffer, &uhid->outq[uhid->tail], len)) { | 468 | if (copy_to_user(buffer, uhid->outq[uhid->tail], len)) { |
469 | ret = -EFAULT; | 469 | ret = -EFAULT; |
470 | } else { | 470 | } else { |
471 | kfree(uhid->outq[uhid->tail]); | 471 | kfree(uhid->outq[uhid->tail]); |