ALSA: core: pcm: simplify locking for timers
authorPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Wed, 2 Sep 2020 21:21:16 +0000 (16:21 -0500)
committerTakashi Iwai <tiwai@suse.de>
Thu, 3 Sep 2020 07:24:33 +0000 (09:24 +0200)
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>
sound/core/pcm.c

index b6d2331a82f70ac8a54b5f61790e456731473bd2..be5714f1bb58c6e71af6a818eef9d48819d9f9d9 100644 (file)
@@ -991,11 +991,13 @@ void snd_pcm_detach_substream(struct snd_pcm_substream *substream)
                       PAGE_ALIGN(sizeof(struct snd_pcm_mmap_control)));
        kfree(runtime->hw_constraints.rules);
        /* Avoid concurrent access to runtime via PCM timer interface */
-       if (substream->timer)
+       if (substream->timer) {
                spin_lock_irq(&substream->timer->lock);
-       substream->runtime = NULL;
-       if (substream->timer)
+               substream->runtime = NULL;
                spin_unlock_irq(&substream->timer->lock);
+       } else {
+               substream->runtime = NULL;
+       }
        kfree(runtime);
        put_pid(substream->pid);
        substream->pid = NULL;