[alsa-devel] 3.18.0-rc1 pulseaudio possible recursive locking

Arthur Marsh arthur.marsh at internode.on.net
Tue Oct 21 18:08:55 CEST 2014



Takashi Iwai wrote, on 22/10/14 00:08:
> At Tue, 21 Oct 2014 07:27:34 +0200,
> Takashi Iwai wrote:
>>
>> At Tue, 21 Oct 2014 00:30:59 +1030,
>> Arthur Marsh wrote:
>>>
>>> Hi, I have been seeing this a few times lately, and noticed that it was
>>> still present
>>>
>>> Is this the right place to report it or should I be reporting a bug
>>> against pulseaudio?
>>
>> This is likely a false-positive report, so ignore it unless you really
>> encounter the deadlock by this.
>
> Or try the patch below.  This seems hitting more often, so it's maybe
> worth to put into 3.18-rc2.  Let me know if this solves the problem.
>
>
> Takashi
>
> -- 8< --
> From: Takashi Iwai <tiwai at suse.de>
> Subject: [PATCH] ALSA: pcm: Fix false lockdep warnings
>
> As PCM core handles the multiple linked streams in parallel, lockdep
> gets confused (partly because of weak annotations) and spews the
> false-positive warnings.  This hasn't been a problem for long time but
> the latest PCM lock path update seems to have woken up a sleeping
> dog.
>
> Here is an attempt to paper over this issue: pass the lock subclass
> just calculated from the depth in snd_pcm_action_group().  Also, a
> (possibly) wrong lock subclass set in snd_pcm_action_lock_mutex() is
> dropped, too.
>
> Signed-off-by: Takashi Iwai <tiwai at suse.de>
> ---
>   sound/core/pcm_native.c | 12 +++++-------
>   1 file changed, 5 insertions(+), 7 deletions(-)
>
> diff --git a/sound/core/pcm_native.c b/sound/core/pcm_native.c
> index 815396d8427f..166d59cdc86b 100644
> --- a/sound/core/pcm_native.c
> +++ b/sound/core/pcm_native.c
> @@ -781,16 +781,15 @@ static int snd_pcm_action_group(struct action_ops *ops,
>   {
>   	struct snd_pcm_substream *s = NULL;
>   	struct snd_pcm_substream *s1;
> -	int res = 0;
> +	int res = 0, depth = 1;
>
>   	snd_pcm_group_for_each_entry(s, substream) {
>   		if (do_lock && s != substream) {
>   			if (s->pcm->nonatomic)
> -				mutex_lock_nested(&s->self_group.mutex,
> -						  SINGLE_DEPTH_NESTING);
> +				mutex_lock_nested(&s->self_group.mutex, depth);
>   			else
> -				spin_lock_nested(&s->self_group.lock,
> -						 SINGLE_DEPTH_NESTING);
> +				spin_lock_nested(&s->self_group.lock, depth);
> +			depth++;
>   		}
>   		res = ops->pre_action(s, state);
>   		if (res < 0)
> @@ -906,8 +905,7 @@ static int snd_pcm_action_lock_mutex(struct action_ops *ops,
>   	down_read(&snd_pcm_link_rwsem);
>   	if (snd_pcm_stream_linked(substream)) {
>   		mutex_lock(&substream->group->mutex);
> -		mutex_lock_nested(&substream->self_group.mutex,
> -				  SINGLE_DEPTH_NESTING);
> +		mutex_lock(&substream->self_group.mutex);
>   		res = snd_pcm_action_group(ops, substream, state, 1);
>   		mutex_unlock(&substream->self_group.mutex);
>   		mutex_unlock(&substream->group->mutex);
>

Hi, I applied this patch, rebuilt the kernel and am running it now and 
have not seen the "pulseaudio possible recursive locking" message yet.

For the previous 4 reboots with earlier kernels 3.17.0+ / 3.18.0-rc1 I 
saw the "pulseaudio possible recursive locking" message appear about 5 
minutes after boot-up.

Thanks for your help!

Arthur.


More information about the Alsa-devel mailing list