ALSA: hda: Error out if invalid stream is being setup
authorCezary Rojewski <cezary.rojewski@intel.com>
Thu, 8 Dec 2022 14:26:35 +0000 (15:26 +0100)
committerTakashi Iwai <tiwai@suse.de>
Fri, 9 Dec 2022 08:54:53 +0000 (09:54 +0100)
Scenario when snd_hdac_stream_setup_periods() receives an instance of
struct hdac_stream with neither ->substream nor ->cstream initialized is
invalid.

Simultaneously addresses "uninitialized symbol 'dmab'" error reported by
Smatch.

Fixes: 3e9582267e3a ("ALSA: hda: Interrupt servicing and BDL setup for compress streams")
Signed-off-by: Cezary Rojewski <cezary.rojewski@intel.com>
Link: https://lore.kernel.org/r/20221208142635.1514944-1-cezary.rojewski@intel.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/hda/hdac_stream.c

index 8f625402505f8709b7af4bc92806926de3dcad75..547adbc22590e85dbc839b0df0c1c6d18b11b4b5 100644 (file)
@@ -500,6 +500,9 @@ int snd_hdac_stream_setup_periods(struct hdac_stream *azx_dev)
                dmab = snd_pcm_get_dma_buf(substream);
        } else if (cstream) {
                dmab = snd_pcm_get_dma_buf(cstream);
+       } else {
+               WARN(1, "No substream or cstream assigned\n");
+               return -EINVAL;
        }
 
        /* reset BDL address */