]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
usb: usbtmc: Flush anchored URBs in usbtmc_release
authorHeitor Alves de Siqueira <halves@igalia.com>
Thu, 12 Mar 2026 12:27:28 +0000 (09:27 -0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 18 Apr 2026 08:33:33 +0000 (10:33 +0200)
commit 8a768552f7a8276fb9e01d49773d2094ace7c8f1 upstream.

When calling usbtmc_release, pending anchored URBs must be flushed or
killed to prevent use-after-free errors (e.g. in the HCD giveback
path). Call usbtmc_draw_down() to allow anchored URBs to be completed.

Fixes: 4f3c8d6eddc2 ("usb: usbtmc: Support Read Status Byte with SRQ per file")
Reported-by: syzbot+9a3c54f52bd1edbd975f@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=9a3c54f52bd1edbd975f
Cc: stable <stable@kernel.org>
Signed-off-by: Heitor Alves de Siqueira <halves@igalia.com>
Link: https://patch.msgid.link/20260312-usbtmc-flush-release-v1-1-5755e9f4336f@igalia.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/class/usbtmc.c

index 8cf341a24834717408706b6cd86267a68a066802..bf8690bb654fb6bc21aca001c0cb933a205318ae 100644 (file)
@@ -254,6 +254,9 @@ static int usbtmc_release(struct inode *inode, struct file *file)
        list_del(&file_data->file_elem);
 
        spin_unlock_irq(&file_data->data->dev_lock);
+
+       /* flush anchored URBs */
+       usbtmc_draw_down(file_data);
        mutex_unlock(&file_data->data->io_mutex);
 
        kref_put(&file_data->data->kref, usbtmc_delete);