{
    "version": 1,
    "title": "WARNING in usbtmc_ioctl/usb_submit_urb",
    "display-title": "WARNING in usbtmc_ioctl/usb_submit_urb",
    "id": "766aad2609c9a3742436a3e25518eba8f5c6ddc8",
    "status": "fixed",
    "fix-commits": [
        {
            "title": "usb: usbtmc: Fix bug in pipe direction for control transfers",
            "link": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=e9b667a82cdcfe21d590344447d65daed52b353b",
            "hash": "e9b667a82cdcfe21d590344447d65daed52b353b",
            "repo": "git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git",
            "branch": "master"
        }
    ],
    "discussions": [
        "https://lore.kernel.org/all/00000000000091f0b805d9556a82@google.com/T/",
        "https://lore.kernel.org/all/20220321133217.148831184@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20220321133219.643490199@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20220321133220.559554263@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/20220321133221.290173884@linuxfoundation.org/T/",
        "https://lore.kernel.org/all/YiEsYTPEE6lOCOA5@rowland.harvard.edu/T/"
    ],
    "crashes": [
        {
            "title": "WARNING in usbtmc_ioctl/usb_submit_urb",
            "syz-reproducer": "/text?tag=ReproSyz&x=172cdd12700000",
            "c-reproducer": "/text?tag=ReproC&x=170790e6700000",
            "kernel-config": "/text?tag=KernelConfig&x=4b9a7fa580ff2b33",
            "kernel-source-git": "https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/?id=2293be58d6a18cab800e25e42081bacb75c05752",
            "kernel-source-commit": "2293be58d6a18cab800e25e42081bacb75c05752",
            "syzkaller-git": "https://github.com/google/syzkaller/commits/45a13a7381e60020d94d037d88a75727984b7a9a",
            "syzkaller-commit": "45a13a7381e60020d94d037d88a75727984b7a9a",
            "compiler-description": "Debian clang version 11.0.1-2, GNU ld (GNU Binutils for Debian) 2.35.2",
            "architecture": "amd64",
            "crash-report-link": "/text?tag=CrashReport&x=12912a82700000"
        }
    ],
    "patch_modified_functions": [
        [
            "usbtmc_ioctl_request",
            "drivers/usb/class/usbtmc.c"
        ]
    ],
    "patch_commit_date": "2022-03-03T21:00:17+00:00",
    "cause_commit_date": null,
    "subsystems": [
        "usb"
    ],
    "parent_of_fix_commit": "239071064732bc4a30308cbba11014aa1aab550a",
    "patch": "diff --git a/drivers/usb/class/usbtmc.c b/drivers/usb/class/usbtmc.c\nindex 73f419adce61..4bb6d304eb4b 100644\n--- a/drivers/usb/class/usbtmc.c\n+++ b/drivers/usb/class/usbtmc.c\n@@ -1919,6 +1919,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \tstruct usbtmc_ctrlrequest request;\n \tu8 *buffer = NULL;\n \tint rv;\n+\tunsigned int is_in, pipe;\n \tunsigned long res;\n \n \tres = copy_from_user(&request, arg, sizeof(struct usbtmc_ctrlrequest));\n@@ -1928,12 +1929,14 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \tif (request.req.wLength > USBTMC_BUFSIZE)\n \t\treturn -EMSGSIZE;\n \n+\tis_in = request.req.bRequestType & USB_DIR_IN;\n+\n \tif (request.req.wLength) {\n \t\tbuffer = kmalloc(request.req.wLength, GFP_KERNEL);\n \t\tif (!buffer)\n \t\t\treturn -ENOMEM;\n \n-\t\tif ((request.req.bRequestType & USB_DIR_IN) == 0) {\n+\t\tif (!is_in) {\n \t\t\t/* Send control data to device */\n \t\t\tres = copy_from_user(buffer, request.data,\n \t\t\t\t\t     request.req.wLength);\n@@ -1944,8 +1947,12 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\t}\n \t}\n \n+\tif (is_in)\n+\t\tpipe = usb_rcvctrlpipe(data->usb_dev, 0);\n+\telse\n+\t\tpipe = usb_sndctrlpipe(data->usb_dev, 0);\n \trv = usb_control_msg(data->usb_dev,\n-\t\t\tusb_rcvctrlpipe(data->usb_dev, 0),\n+\t\t\tpipe,\n \t\t\trequest.req.bRequest,\n \t\t\trequest.req.bRequestType,\n \t\t\trequest.req.wValue,\n@@ -1957,7 +1964,7 @@ static int usbtmc_ioctl_request(struct usbtmc_device_data *data,\n \t\tgoto exit;\n \t}\n \n-\tif (rv && (request.req.bRequestType & USB_DIR_IN)) {\n+\tif (rv && is_in) {\n \t\t/* Read control data from device */\n \t\tres = copy_to_user(request.data, buffer, rv);\n \t\tif (res)\n",
    "patch_modified_files": [
        "drivers/usb/class/usbtmc.c"
    ]
}