ALSA: seq: Fix lockdep warnings due to double mutex locks
authorTakashi Iwai <tiwai@suse.de>
Wed, 3 Feb 2016 07:32:44 +0000 (08:32 +0100)
committerTakashi Iwai <tiwai@suse.de>
Wed, 3 Feb 2016 13:51:51 +0000 (14:51 +0100)
commit7f0973e973cd74aa40747c9d38844560cd184ee8
tree995f82e9dfe6c69c8c6136f61be99577de81a85b
parent81f577542af15640cbcb6ef68baa4caa610cbbfc
ALSA: seq: Fix lockdep warnings due to double mutex locks

The port subscription code uses double mutex locks for source and
destination ports, and this may become racy once when wrongly set up.
It leads to lockdep warning splat, typically triggered by fuzzer like
syzkaller, although the actual deadlock hasn't been seen, so far.

This patch simplifies the handling by reducing to two single locks, so
that no lockdep warning will be trigger any longer.

By splitting to two actions, a still-in-progress element shall be
added in one list while handling another.  For ignoring this element,
a new check is added in deliver_to_subscribers().

Along with it, the code to add/remove the subscribers list element was
cleaned up and refactored.

BugLink: http://lkml.kernel.org/r/CACT4Y+aKQXV7xkBW9hpQbzaDO7LrUvohxWh-UwMxXjDy-yBD=A@mail.gmail.com
Reported-by: Dmitry Vyukov <dvyukov@google.com>
Tested-by: Dmitry Vyukov <dvyukov@google.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/core/seq/seq_clientmgr.c
sound/core/seq/seq_ports.c