]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
ASoC: dmaengine: Make the pcm->name equal to pcm->id if the name is not set
authorPeter Ujfalusi <peter.ujfalusi@ti.com>
Fri, 6 Sep 2019 05:55:24 +0000 (08:55 +0300)
committerMark Brown <broonie@kernel.org>
Mon, 9 Sep 2019 09:47:10 +0000 (10:47 +0100)
Some tools use the snd_pcm_info_get_name() to try to identify PCMs or for
other purposes.

Currently it is left empty with the dmaengine-pcm, in this case copy the
pcm->id string as pcm->name.

For example IGT is using this to find the HDMI PCM for testing audio on it.

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Reported-by: Arthur She <arthur.she@linaro.org>
Link: https://lore.kernel.org/r/20190906055524.7393-1-peter.ujfalusi@ti.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/soc-generic-dmaengine-pcm.c

index 748f5f641002e91f0ab9e8246734b84a4af72083..d93db2c2b527029a37ae869abf6e222de2751eff 100644 (file)
@@ -306,6 +306,12 @@ static int dmaengine_pcm_new(struct snd_soc_pcm_runtime *rtd)
 
                if (!dmaengine_pcm_can_report_residue(dev, pcm->chan[i]))
                        pcm->flags |= SND_DMAENGINE_PCM_FLAG_NO_RESIDUE;
+
+               if (rtd->pcm->streams[i].pcm->name[0] == '\0') {
+                       strncpy(rtd->pcm->streams[i].pcm->name,
+                               rtd->pcm->streams[i].pcm->id,
+                               sizeof(rtd->pcm->streams[i].pcm->name));
+               }
        }
 
        return 0;