Commit a5082947 authored by Dmitry Torokhov's avatar Dmitry Torokhov

Input: gtco - fix potential out-of-bound access

parse_hid_report_descriptor() has a while (i < length) loop, which
only guarantees that there's at least 1 byte in the buffer, but the
loop body can read multiple bytes which causes out-of-bounds access.
Reported-by: default avatarAndrey Konovalov <andreyknvl@google.com>
Reviewed-by: default avatarAndrey Konovalov <andreyknvl@google.com>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent 57a95b41
...@@ -230,13 +230,17 @@ static void parse_hid_report_descriptor(struct gtco *device, char * report, ...@@ -230,13 +230,17 @@ static void parse_hid_report_descriptor(struct gtco *device, char * report,
/* Walk this report and pull out the info we need */ /* Walk this report and pull out the info we need */
while (i < length) { while (i < length) {
prefix = report[i]; prefix = report[i++];
/* Skip over prefix */
i++;
/* Determine data size and save the data in the proper variable */ /* Determine data size and save the data in the proper variable */
size = PREF_SIZE(prefix); size = (1U << PREF_SIZE(prefix)) >> 1;
if (i + size > length) {
dev_err(ddev,
"Not enough data (need %d, have %d)\n",
i + size, length);
break;
}
switch (size) { switch (size) {
case 1: case 1:
data = report[i]; data = report[i];
...@@ -244,8 +248,7 @@ static void parse_hid_report_descriptor(struct gtco *device, char * report, ...@@ -244,8 +248,7 @@ static void parse_hid_report_descriptor(struct gtco *device, char * report,
case 2: case 2:
data16 = get_unaligned_le16(&report[i]); data16 = get_unaligned_le16(&report[i]);
break; break;
case 3: case 4:
size = 4;
data32 = get_unaligned_le32(&report[i]); data32 = get_unaligned_le32(&report[i]);
break; break;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment