On Wed, Nov 1, 2017 at 8:49 PM, Takashi Iwai <tiwai@xxxxxxx> wrote: > On Wed, 01 Nov 2017 19:39:46 +0100, > Dmitry Vyukov wrote: >> >> On Wed, Nov 1, 2017 at 9:38 PM, syzbot >> <bot+31681772ec7a18dde8d3f8caf475f361a89b9514@xxxxxxxxxxxxxxxxxxxxxxxxx> >> wrote: >> > Hello, >> > >> > syzkaller hit the following crash on >> > fc2e8b1a47c14b22c33eb087fca0db58e1f4ed0e >> > git://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/master >> > compiler: gcc (GCC) 7.1.1 20170620 >> > .config is attached >> > Raw console output is attached. >> > C reproducer is attached >> > syzkaller reproducer is attached. See https://goo.gl/kgGztJ >> > for information about syzkaller reproducers >> >> This also happened on more recent commits, including upstream >> 9c323bff13f92832e03657cabdd70d731408d621 (Oct 20): > > Could you try the patch below with CONFIG_SND_DEBUG=y and see whether > it catches any bad calls? It's already in for-next branch for 4.15. Hi Takashi, Unfortunately it's not possible to test custom patches in syzbot infrastructure. We've experimented with applying a bunch of custom patches in the past and it lead to unrecoverable mess. We were not able to communicate precise state of code with reports, we were not able to provide meaningful report with line numbers that matter (not possible to understand what exactly line caused a bug), developers could (rightfully) suspect that some bugs might be caused the unknown set of private patches, random subset of patches won't apply and that set changes over time and depends on order in which we apply patches, etc. It's also not possible to dedicate a syzkaller instance with a bunch of attached machines for this. First, it will require lots of resources (your request is not unique). Then, whenever we test kernel we get dozens of bugs. What should we do with these bugs? We don't know which are related to your patch and which are not. We can't report them upstream (see above). Basically you would need to go through these dozens of bugs after testing and do something with each of them, but I don't think you want to. But we are happy to test whatever is in upstream tree (this patch already is). Re CONFIG_SND_DEBUG=y, should we enable it permanently in syzbot configs? >From our point of view, the more debug configs are enabled, the more bugs we find, the better. There just must be somebody who will then fix problems uncovered by the config (either bugs of config false positives). If you will take a look on the config attached to the first mail, do you see anything else to fix there re sound? Maybe turn off some deprecated configs that nobody uses for a long time? Or enable some new configs? Thanks > -- 8< -- > From: Takashi Iwai <tiwai@xxxxxxx> > Subject: [PATCH] ALSA: seq: Add sanity check for user-space pointer delivery > > The sequencer event may contain a user-space pointer with its > SNDRV_SEQ_EXT_USRPTR bit, and we assure that its delivery is limited > with non-atomic mode. Otherwise the copy_from_user() may hit the > fault and cause a problem. Although the core code doesn't set such a > flag (only set at snd_seq_write()), any wild driver may set it > mistakenly and lead to an unexpected crash. > > This patch adds a sanity check of such events at the delivery core > code to filter out the invalid invocation in the atomic mode. > > Signed-off-by: Takashi Iwai <tiwai@xxxxxxx> > --- > sound/core/seq/seq_clientmgr.c | 4 ++++ > 1 file changed, 4 insertions(+) > > diff --git a/sound/core/seq/seq_clientmgr.c b/sound/core/seq/seq_clientmgr.c > index ea2d0ae85bd3..f2343f63ba26 100644 > --- a/sound/core/seq/seq_clientmgr.c > +++ b/sound/core/seq/seq_clientmgr.c > @@ -802,6 +802,10 @@ static int snd_seq_deliver_event(struct snd_seq_client *client, struct snd_seq_e > return -EMLINK; > } > > + if (snd_seq_ev_is_variable(event) && > + snd_BUG_ON(atomic && (event->data.ext.len & SNDRV_SEQ_EXT_USRPTR))) > + return -EINVAL; > + > if (event->queue == SNDRV_SEQ_ADDRESS_SUBSCRIBERS || > event->dest.client == SNDRV_SEQ_ADDRESS_SUBSCRIBERS) > result = deliver_to_subscribers(client, event, atomic, hop); > -- > 2.14.2 > > -- > You received this message because you are subscribed to the Google Groups "syzkaller-bugs" group. > To unsubscribe from this group and stop receiving emails from it, send an email to syzkaller-bugs+unsubscribe@xxxxxxxxxxxxxxxx. > To view this discussion on the web visit https://groups.google.com/d/msgid/syzkaller-bugs/s5h4lqddbk9.wl-tiwai%40suse.de. > For more options, visit https://groups.google.com/d/optout. _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx http://mailman.alsa-project.org/mailman/listinfo/alsa-devel