HID: steelseries: validate output report details
authorKees Cook <keescook@chromium.org>
Wed, 11 Sep 2013 19:56:53 +0000 (21:56 +0200)
committerJohn Stultz <john.stultz@linaro.org>
Tue, 16 Feb 2016 21:50:59 +0000 (13:50 -0800)
A HID device could send a malicious output report that would cause the
steelseries HID driver to write beyond the output report allocation
during initialization, causing a heap overflow:

[  167.981534] usb 1-1: New USB device found, idVendor=1038, idProduct=1410
...
[  182.050547] BUG kmalloc-256 (Tainted: G        W   ): Redzone overwritten

CVE-2013-2891

Signed-off-by: Kees Cook <keescook@chromium.org>
Cc: stable@vger.kernel.org
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
drivers/hid/hid-steelseries.c

index 3edd4ac364942b1f181a5577a2d8db757efea540..93ddc1c65b4ccee72c51a054928020420414c06d 100644 (file)
@@ -253,6 +253,11 @@ static int steelseries_srws1_probe(struct hid_device *hdev,
                goto err_free;
        }
 
+       if (!hid_validate_values(hdev, HID_OUTPUT_REPORT, 0, 0, 16)) {
+               ret = -ENODEV;
+               goto err_free;
+       }
+
        ret = hid_hw_start(hdev, HID_CONNECT_DEFAULT);
        if (ret) {
                hid_err(hdev, "hw start failed\n");