[RAMEN9610-21029]ALSA: core: Fix card races between register and disconnect
authorTakashi Iwai <tiwai@suse.de>
Tue, 16 Apr 2019 15:06:33 +0000 (17:06 +0200)
committerlingsen1 <lingsen1@lenovo.com>
Thu, 19 Dec 2019 03:01:49 +0000 (11:01 +0800)
commit077a5c3c70b9cefbd427e48804657747bbc76c13
tree6dcf3ee289e1812de044f17c87f8fafe0cc08ebe
parentd533c4e7fc39792f0a90690ee629d07bfdf71f03
[RAMEN9610-21029]ALSA: core: Fix card races between register and disconnect

commit 2a3f7221acddfe1caa9ff09b3a8158c39b2fdeac upstream.

There is a small race window in the card disconnection code that
allows the registration of another card with the very same card id.
This leads to a warning in procfs creation as caught by syzkaller.

The problem is that we delete snd_cards and snd_cards_lock entries at
the very beGinning of the disconnection procedure.  This makes the
slot available to be assigned for another card object while the
disconnection procedure is being processed.  Then it becomes possible
to issue a procfs registration with the existing file name although we
check the conflict beforehand.

The fix is simply to move the snd_cards and snd_cards_lock clearances
at the end of the disconnection procedure.  The references to these
entries are merely either from the global proc files like
/proc/asound/cards or from the card registration / disconnection, so
it should be fine to shift at the very end.

Change-Id: I41623db42717d2d4bacab913b966faad7407d5c7
Reported-by: syzbot+48df349490c36f9f54ab@syzkaller.appspotmail.com
Cc: <stable@vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
sound/core/init.c