]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
media: pvrusb2: fix URB leak in pvr2_send_request_ex
authorSzymon Wilczek <szymonwilczek@gmx.com>
Sat, 20 Dec 2025 18:24:19 +0000 (19:24 +0100)
committerHans Verkuil <hverkuil+cisco@kernel.org>
Tue, 13 Jan 2026 12:21:03 +0000 (13:21 +0100)
When pvr2_send_request_ex() submits a write URB successfully but fails to
submit the read URB (e.g. returns -ENOMEM), it returns immediately without
waiting for the write URB to complete. Since the driver reuses the same
URB structure, a subsequent call to pvr2_send_request_ex() attempts to
submit the still-active write URB, triggering a 'URB submitted while
active' warning in usb_submit_urb().

Fix this by ensuring the write URB is unlinked and waited upon if the read
URB submission fails.

Reported-by: syzbot+405dcd13121ff75a9e16@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=405dcd13121ff75a9e16
Signed-off-by: Szymon Wilczek <szymonwilczek@gmx.com>
Acked-by: Mike Isely <isely@pobox.com>
Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
drivers/media/usb/pvrusb2/pvrusb2-hdw.c

index b32bb906a9de29eee3fcba990fa78614c44ca111..5807734ae26c656988dee028142d5c3422fee3de 100644 (file)
@@ -3709,6 +3709,11 @@ status);
                                   "Failed to submit read-control URB status=%d",
 status);
                        hdw->ctl_read_pend_flag = 0;
+                       if (hdw->ctl_write_pend_flag) {
+                               usb_unlink_urb(hdw->ctl_write_urb);
+                               while (hdw->ctl_write_pend_flag)
+                                       wait_for_completion(&hdw->ctl_done);
+                       }
                        goto done;
                }
        }