From: Johan Hovold <johan-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
To: Takashi Iwai <tiwai-l3A5Bk7waGM@public.gmane.org>
Cc: Johan Hovold <johan-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>,
alsa-devel-K7yf7f+aM1XWsZ/bQMPhNw@public.gmane.org,
linux-usb-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
Andrey Konovalov
<andreyknvl-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
Greg KH
<gregkh-hQyY1W1yCW8ekmWlsbkhG0B+6BGkLq7r@public.gmane.org>
Subject: Re: [PATCH v2 4/9] ALSA: line6: Add a sanity check for invalid EPs
Date: Wed, 11 Oct 2017 16:52:09 +0200 [thread overview]
Message-ID: <20171011145209.GE4269@localhost> (raw)
In-Reply-To: <s5h7ew1920z.wl-tiwai-l3A5Bk7waGM@public.gmane.org>
On Wed, Oct 11, 2017 at 04:45:16PM +0200, Takashi Iwai wrote:
> On Wed, 11 Oct 2017 16:28:37 +0200,
> Johan Hovold wrote:
> >
> > On Wed, Oct 11, 2017 at 12:36:41PM +0200, Takashi Iwai wrote:
> > > As syzkaller spotted, currently line6 drivers submit a URB with the
> > > fixed EP without checking whether it's actually available, which may
> > > result in a kernel warning like:
> > > usb 1-1: BOGUS urb xfer, pipe 3 != type 1
> > > ------------[ cut here ]------------
> > > WARNING: CPU: 0 PID: 24 at drivers/usb/core/urb.c:449
> > > usb_submit_urb+0xf8a/0x11d0
> > > Modules linked in:
> > > CPU: 0 PID: 24 Comm: kworker/0:1 Not tainted 4.14.0-rc2-42613-g1488251d1a98 #238
> > > Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS Bochs 01/01/2011
> > > Workqueue: usb_hub_wq hub_event
> > > Call Trace:
> > > line6_start_listen+0x55f/0x9e0 sound/usb/line6/driver.c:82
> > > line6_init_cap_control sound/usb/line6/driver.c:690
> > > line6_probe+0x7c9/0x1310 sound/usb/line6/driver.c:764
> > > podhd_probe+0x64/0x70 sound/usb/line6/podhd.c:474
> > > usb_probe_interface+0x35d/0x8e0 drivers/usb/core/driver.c:361
> > > ....
> > >
> > > This patch adds a sanity check of validity of EPs at the device
> > > initialization phase for avoiding the call with an invalid EP.
> > >
> > > Reported-by: Andrey Konovalov <andreyknvl-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
> > > Tested-by: Andrey Konovalov <andreyknvl-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
> > > Signed-off-by: Takashi Iwai <tiwai-l3A5Bk7waGM@public.gmane.org>
> > > ---
> > > sound/usb/line6/driver.c | 7 +++++++
> > > 1 file changed, 7 insertions(+)
> > >
> > > diff --git a/sound/usb/line6/driver.c b/sound/usb/line6/driver.c
> > > index 0ff5a7d2e19f..0da6f68761e3 100644
> > > --- a/sound/usb/line6/driver.c
> > > +++ b/sound/usb/line6/driver.c
> > > @@ -78,6 +78,13 @@ static int line6_start_listen(struct usb_line6 *line6)
> > > line6->buffer_listen, LINE6_BUFSIZE_LISTEN,
> > > line6_data_received, line6);
> > > }
> > > +
> > > + /* sanity checks of EP before actually submitting */
> > > + if (usb_urb_ep_type_check(line6->urb_listen)) {
> > > + dev_err(line6->ifcdev, "invalid control EP\n");
> > > + return -EINVAL;
> > > + }
> >
> > You're now doing this check twice (here and in usb_submit_urb) every
> > time this URB is submitted rather just checking it once in probe.
> >
> > Seems like a quick band-aid to me.
>
> Yes, it is :)
>
> We may split line6_start_listen() to two functions, one for
> initializing URBs and another for submission, but it'll be more codes
> and the check is fairly cheap. So again it's a question whether
> easier to read or to get minor optimization.
I'd say it's also a question about long-term maintainability. Those
quick band-aids tend to keep piling up over time.
Johan
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2017-10-11 14:52 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-11 10:36 [PATCH v2 0/9] sound: Add sanity checks for invalid EPs Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 6/9] ALSA: usx2y: " Takashi Iwai
[not found] ` <20171011103646.11879-7-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 14:33 ` Johan Hovold
2017-10-11 14:43 ` Takashi Iwai
[not found] ` <20171011103646.11879-1-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 10:36 ` [PATCH v2 1/9] usb: core: Add a helper function to check the validity of EP type in URB Takashi Iwai
2017-10-11 14:14 ` Johan Hovold
2017-10-11 14:31 ` Takashi Iwai
[not found] ` <s5hbmld92ok.wl-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 14:58 ` Johan Hovold
2017-10-11 10:36 ` [PATCH v2 2/9] ALSA: bcd2000: Add a sanity check for invalid EPs Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 3/9] ALSA: caiaq: " Takashi Iwai
2017-10-11 14:20 ` Johan Hovold
2017-10-11 14:40 ` Takashi Iwai
[not found] ` <s5ha80x928r.wl-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 14:49 ` Johan Hovold
2017-10-11 15:05 ` Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 4/9] ALSA: line6: " Takashi Iwai
2017-10-11 14:28 ` Johan Hovold
2017-10-11 14:45 ` Takashi Iwai
[not found] ` <s5h7ew1920z.wl-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 14:52 ` Johan Hovold [this message]
2017-10-11 14:58 ` Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 5/9] ALSA: usb-audio: Add sanity checks " Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 7/9] ALSA: hiface: " Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 8/9] ALSA: caiaq: Add yet more " Takashi Iwai
2017-10-11 10:36 ` [PATCH v2 9/9] ALSA: line6: " Takashi Iwai
[not found] ` <20171011103646.11879-10-tiwai-l3A5Bk7waGM@public.gmane.org>
2017-10-11 14:39 ` Johan Hovold
2017-10-11 14:48 ` Takashi Iwai
2017-10-11 13:03 ` [PATCH v2 0/9] sound: Add " Greg KH
[not found] ` <20171011130329.GI27734-U8xfFu+wG4EAvxtiuMwx3w@public.gmane.org>
2017-10-11 13:15 ` Takashi Iwai
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20171011145209.GE4269@localhost \
--to=johan-dgejt+ai2ygdnm+yrofe0a@public.gmane.org \
--cc=alsa-devel-K7yf7f+aM1XWsZ/bQMPhNw@public.gmane.org \
--cc=andreyknvl-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
--cc=gregkh-hQyY1W1yCW8ekmWlsbkhG0B+6BGkLq7r@public.gmane.org \
--cc=linux-usb-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=tiwai-l3A5Bk7waGM@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.