]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
Input: pegasus-notetaker - fix potential out-of-bounds access
authorSeungjin Bae <eeodqql09@gmail.com>
Fri, 17 Oct 2025 22:36:31 +0000 (15:36 -0700)
committerDmitry Torokhov <dmitry.torokhov@gmail.com>
Sat, 18 Oct 2025 01:04:15 +0000 (18:04 -0700)
In the pegasus_notetaker driver, the pegasus_probe() function allocates
the URB transfer buffer using the wMaxPacketSize value from
the endpoint descriptor. An attacker can use a malicious USB descriptor
to force the allocation of a very small buffer.

Subsequently, if the device sends an interrupt packet with a specific
pattern (e.g., where the first byte is 0x80 or 0x42),
the pegasus_parse_packet() function parses the packet without checking
the allocated buffer size. This leads to an out-of-bounds memory access.

Fixes: 1afca2b66aac ("Input: add Pegasus Notetaker tablet driver")
Signed-off-by: Seungjin Bae <eeodqql09@gmail.com>
Link: https://lore.kernel.org/r/20251007214131.3737115-2-eeodqql09@gmail.com
Cc: stable@vger.kernel.org
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
drivers/input/tablet/pegasus_notetaker.c

index 8d6b71d59793168ead381dcbcedf2062e3833741..eabb4a0b8a0d2b811732c4400029b4ab2e297117 100644 (file)
@@ -63,6 +63,9 @@
 #define BUTTON_PRESSED                 0xb5
 #define COMMAND_VERSION                        0xa9
 
+/* 1 Status + 1 Color + 2 X + 2 Y = 6 bytes */
+#define NOTETAKER_PACKET_SIZE          6
+
 /* in xy data packet */
 #define BATTERY_NO_REPORT              0x40
 #define BATTERY_LOW                    0x41
@@ -311,6 +314,12 @@ static int pegasus_probe(struct usb_interface *intf,
        }
 
        pegasus->data_len = usb_maxpacket(dev, pipe);
+       if (pegasus->data_len < NOTETAKER_PACKET_SIZE) {
+               dev_err(&intf->dev, "packet size is too small (%d)\n",
+                       pegasus->data_len);
+               error = -EINVAL;
+               goto err_free_mem;
+       }
 
        pegasus->data = usb_alloc_coherent(dev, pegasus->data_len, GFP_KERNEL,
                                           &pegasus->data_dma);