[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <0000000000007b7990058ed028d0@google.com>
Date: Mon, 29 Jul 2019 04:26:07 -0700
From: syzbot <syzbot+01a77b82edaa374068e1@...kaller.appspotmail.com>
To: Oliver Neukum <oneukum@...e.com>
Cc: andreyknvl@...gle.com, gregkh@...uxfoundation.org,
gustavo@...eddedor.com, linux-kernel@...r.kernel.org,
linux-usb@...r.kernel.org, oneukum@...e.com,
syzkaller-bugs@...glegroups.com
Subject: Re: Re: WARNING in iguanair_probe/usb_submit_urb
> Am Freitag, den 26.07.2019, 05:28 -0700 schrieb syzbot:
>> Hello,
>> syzbot found the following crash on:
>> HEAD commit: 6a3599ce usb-fuzzer: main usb gadget fuzzer driver
>> git tree: https://github.com/google/kasan.git usb-fuzzer
>> console output: https://syzkaller.appspot.com/x/log.txt?x=164ab1f0600000
>> kernel config:
>> https://syzkaller.appspot.com/x/.config?x=700ca426ab83faae
>> dashboard link:
>> https://syzkaller.appspot.com/bug?extid=01a77b82edaa374068e1
>> compiler: gcc (GCC) 9.0.0 20181231 (experimental)
>> syz repro:
>> https://syzkaller.appspot.com/x/repro.syz?x=143d7978600000
>> C reproducer: https://syzkaller.appspot.com/x/repro.c?x=134623f4600000
>> IMPORTANT: if you fix the bug, please add the following tag to the
>> commit:
>> Reported-by: syzbot+01a77b82edaa374068e1@...kaller.appspotmail.com
> #syz test: https://github.com/google/kasan.git
> usb-fuzzer-usb-testing-2019.07.11]
"usb-fuzzer-usb-testing-2019.07.11]" does not look like a valid git branch
or commit.
> From 0b0a7f7e980973e0c0d17f1dfe2bd7742492bfcc Mon Sep 17 00:00:00 2001
> From: Oliver Neukum <oneukum@...e.com>
> Date: Mon, 29 Jul 2019 11:49:00 +0200
> Subject: [PATCH] iguanair: add sanity checks
> The driver needs to check the endpoint types, too, as opposed
> to the number of endpoints. This also requires moving the check earlier.
> Reported-by: syzbot+01a77b82edaa374068e1@...kaller.appspotmail.com
> Signed-off-by: Oliver Neukum <oneukum@...e.com>
> ---
> drivers/media/rc/iguanair.c | 15 +++++++--------
> 1 file changed, 7 insertions(+), 8 deletions(-)
> diff --git a/drivers/media/rc/iguanair.c b/drivers/media/rc/iguanair.c
> index ea05e125016a..663083a6b399 100644
> --- a/drivers/media/rc/iguanair.c
> +++ b/drivers/media/rc/iguanair.c
> @@ -413,6 +413,10 @@ static int iguanair_probe(struct usb_interface *intf,
> int ret, pipein, pipeout;
> struct usb_host_interface *idesc;
> + idesc = intf->altsetting;
> + if (idesc->desc.bNumEndpoints < 2)
> + return -ENODEV;
> +
> ir = kzalloc(sizeof(*ir), GFP_KERNEL);
> rc = rc_allocate_device(RC_DRIVER_IR_RAW);
> if (!ir || !rc) {
> @@ -427,18 +431,13 @@ static int iguanair_probe(struct usb_interface
> *intf,
> ir->urb_in = usb_alloc_urb(0, GFP_KERNEL);
> ir->urb_out = usb_alloc_urb(0, GFP_KERNEL);
> - if (!ir->buf_in || !ir->packet || !ir->urb_in || !ir->urb_out) {
> + if (!ir->buf_in || !ir->packet || !ir->urb_in || !ir->urb_out ||
> + !usb_endpoint_is_int_in(&idesc->endpoint[0].desc) ||
> + !usb_endpoint_is_int_out(&idesc->endpoint[1].desc)) {
> ret = -ENOMEM;
> goto out;
> }
> - idesc = intf->altsetting;
> -
> - if (idesc->desc.bNumEndpoints < 2) {
> - ret = -ENODEV;
> - goto out;
> - }
> -
> ir->rc = rc;
> ir->dev = &intf->dev;
> ir->udev = udev;
> --
> 2.16.4
Powered by blists - more mailing lists