diff options
author | Takashi Iwai <tiwai@suse.de> | 2022-03-22 18:07:19 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2022-03-22 20:56:42 +0100 |
commit | 3c3201f8c7bb77eb53b08a3ca8d9a4ddc500b4c0 (patch) | |
tree | cdc35dbfdb8c8f75bf2d2ba62912327d616f570d /lib/mpi/mpi-bit.c | |
parent | dca947d4d26dbf925a64a6cfb2ddbc035e831a3d (diff) |
ALSA: pcm: Fix races among concurrent prepare and hw_params/hw_free calls
Like the previous fixes to hw_params and hw_free ioctl races, we need
to paper over the concurrent prepare ioctl calls against hw_params and
hw_free, too.
This patch implements the locking with the existing
runtime->buffer_mutex for prepare ioctls. Unlike the previous case
for snd_pcm_hw_hw_params() and snd_pcm_hw_free(), snd_pcm_prepare() is
performed to the linked streams, hence the lock can't be applied
simply on the top. For tracking the lock in each linked substream, we
modify snd_pcm_action_group() slightly and apply the buffer_mutex for
the case stream_lock=false (formerly there was no lock applied)
there.
Cc: <stable@vger.kernel.org>
Reviewed-by: Jaroslav Kysela <perex@perex.cz>
Link: https://lore.kernel.org/r/20220322170720.3529-4-tiwai@suse.de
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'lib/mpi/mpi-bit.c')
0 files changed, 0 insertions, 0 deletions