]> www.infradead.org Git - users/willy/linux.git/commitdiff
ASoC: soc-core: Merge CPU/Codec DAIs
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Mon, 16 Mar 2020 06:36:58 +0000 (15:36 +0900)
committerMark Brown <broonie@kernel.org>
Fri, 20 Mar 2020 20:45:32 +0000 (20:45 +0000)
ALSA SoC is currently categorizing CPU/Codec DAIs,
and it works well.

But modern devices require more complex connections,
for example Codec to Codec, etc, and future devices will
enable to more complex connections.
Because of these background, CPU/Codec DAIs categorizing is
no longer good much to modern device.

Currently, rtd has both CPU/Codec DAIs pointer.

rtd->cpu_dais   = [][][][][][][][][]
rtd->codec_dais = [][][][][][][][][]

This patch merges these into DAIs pointer.

rtd->dais = [][][][][][][][][][][][][][][][][][]
            ^cpu_dais         ^codec_dais
            |--- num_cpus ---|--- num_codecs --|

Then, we can merge for_each_rtd_cpu/codec_dais() from this patch.

- for_each_rtd_cpu_dais() {
- ...
- }
- for_each_rtd_codec_dais() {
- ...
- }
+ for_each_rtd_dais() {
+ ...
+ }

Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/87wo7kolfa.wl-kuninori.morimoto.gx@renesas.com
Signed-off-by: Mark Brown <broonie@kernel.org>
include/sound/soc.h
sound/soc/soc-core.c

index d97c4aa779a269e78b37d9a615c76c5238a9e2b7..539211bd0f94937dc80dbe8a087cb9d3c7ac7879 100644 (file)
@@ -1145,6 +1145,7 @@ struct snd_soc_pcm_runtime {
        struct snd_compr *compr;
        struct snd_soc_dai *codec_dai;
        struct snd_soc_dai *cpu_dai;
+       struct snd_soc_dai **dais;
 
        struct snd_soc_dai **codec_dais;
        unsigned int num_codecs;
@@ -1184,7 +1185,11 @@ struct snd_soc_pcm_runtime {
             (i)++)
 #define for_each_rtd_codec_dais_rollback(rtd, i, dai)          \
        for (; (--(i) >= 0) && ((dai) = rtd->codec_dais[i]);)
-
+#define for_each_rtd_dais(rtd, i, dai)                                 \
+       for ((i) = 0;                                                   \
+            ((i) < (rtd)->num_cpus + (rtd)->num_codecs) &&             \
+                    ((dai) = (rtd)->dais[i]);                          \
+            (i)++)
 
 void snd_soc_close_delayed_work(struct snd_soc_pcm_runtime *rtd);
 
index e7e70b47590a5eb86e521b3dbcd29c06a556b38d..0fd582c19c038855c7bab264cbbd5c37f0c8e014 100644 (file)
@@ -475,22 +475,22 @@ static struct snd_soc_pcm_runtime *soc_new_pcm_runtime(
        INIT_DELAYED_WORK(&rtd->delayed_work, close_delayed_work);
 
        /*
-        * for rtd->codec_dais
+        * for rtd->dais
         */
-       rtd->codec_dais = devm_kcalloc(dev, dai_link->num_codecs,
+       rtd->dais = devm_kcalloc(dev, dai_link->num_cpus + dai_link->num_codecs,
                                        sizeof(struct snd_soc_dai *),
                                        GFP_KERNEL);
-       if (!rtd->codec_dais)
+       if (!rtd->dais)
                goto free_rtd;
 
        /*
-        * for rtd->cpu_dais
+        * dais = [][][][][][][][][][][][][][][][][][]
+        *        ^cpu_dais         ^codec_dais
+        *        |--- num_cpus ---|--- num_codecs --|
         */
-       rtd->cpu_dais = devm_kcalloc(dev, dai_link->num_cpus,
-                                    sizeof(struct snd_soc_dai *),
-                                    GFP_KERNEL);
-       if (!rtd->cpu_dais)
-               goto free_rtd;
+       rtd->cpu_dais   = &rtd->dais[0];
+       rtd->codec_dais = &rtd->dais[dai_link->num_cpus];
+
        /*
         * rtd remaining settings
         */