[PATCH 1/1] ASoC: soc-compress: lock pcm_mutex to resolve lockdep error
Vinod Koul
vkoul at kernel.org
Mon Mar 30 13:47:16 CEST 2020
Hello,
On 30-03-20, 20:01, �̰��� wrote:
> snd_soc_runtime_activate() and snd_soc_runtime_deactivate()
> require locked pcm_mutex.
>
> Signed-off-by: Gyeongtaek Lee <gt82.lee at samsung.com>
> ---
> sound/soc/soc-compress.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/sound/soc/soc-compress.c b/sound/soc/soc-compress.c
> index 392a1c5b15d3..42d416ac7e9b 100644
> --- a/sound/soc/soc-compress.c
> +++ b/sound/soc/soc-compress.c
> @@ -207,7 +207,9 @@ static int soc_compr_open_fe(struct snd_compr_stream
> *cstream)
> fe->dpcm[stream].state = SND_SOC_DPCM_STATE_OPEN;
> fe->dpcm[stream].runtime_update = SND_SOC_DPCM_UPDATE_NO;
>
> + mutex_lock_nested(&fe->pcm_mutex, fe->pcm_subclass);
> snd_soc_runtime_activate(fe, stream);
> + mutex_unlock(&fe->pcm_mutex);
Can you please explain why you need the lock here, as
>
> mutex_unlock(&fe->card->mutex);
we already have a lock here..
> @@ -285,7 +287,9 @@ static int soc_compr_free_fe(struct snd_compr_stream
> *cstream)
> else
> stream = SNDRV_PCM_STREAM_CAPTURE;
>
> + mutex_lock_nested(&fe->pcm_mutex, fe->pcm_subclass);
> snd_soc_runtime_deactivate(fe, stream);
> + mutex_unlock(&fe->pcm_mutex);
And this instance is also using fe->card->mutex.. so I think double lock
may not serve any purpose here..
Can you explain why we need the extra lock?
Thanks
--
~Vinod
More information about the Alsa-devel
mailing list