ALSA: core: pcm: simplify locking for timers
Fix sparse warning: sound/core/pcm.c:999:9: warning: context imbalance in 'snd_pcm_detach_substream' - different lock contexts for basic block There's no real reason to test the same thing twice, and it's simpler have linear sequences. Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Link: https://lore.kernel.org/r/20200902212133.30964-2-pierre-louis.bossart@linux.intel.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
685a04a537
commit
931522b908
|
@ -991,11 +991,13 @@ void snd_pcm_detach_substream(struct snd_pcm_substream *substream)
|
||||||
PAGE_ALIGN(sizeof(struct snd_pcm_mmap_control)));
|
PAGE_ALIGN(sizeof(struct snd_pcm_mmap_control)));
|
||||||
kfree(runtime->hw_constraints.rules);
|
kfree(runtime->hw_constraints.rules);
|
||||||
/* Avoid concurrent access to runtime via PCM timer interface */
|
/* Avoid concurrent access to runtime via PCM timer interface */
|
||||||
if (substream->timer)
|
if (substream->timer) {
|
||||||
spin_lock_irq(&substream->timer->lock);
|
spin_lock_irq(&substream->timer->lock);
|
||||||
substream->runtime = NULL;
|
substream->runtime = NULL;
|
||||||
if (substream->timer)
|
|
||||||
spin_unlock_irq(&substream->timer->lock);
|
spin_unlock_irq(&substream->timer->lock);
|
||||||
|
} else {
|
||||||
|
substream->runtime = NULL;
|
||||||
|
}
|
||||||
kfree(runtime);
|
kfree(runtime);
|
||||||
put_pid(substream->pid);
|
put_pid(substream->pid);
|
||||||
substream->pid = NULL;
|
substream->pid = NULL;
|
||||||
|
|
Loading…
Reference in New Issue