ASoC: soc-component: move snd_soc_component_initialize() to soc-component.c
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Thu, 4 Jun 2020 08:06:32 +0000 (17:06 +0900)
committerMark Brown <broonie@kernel.org>
Mon, 15 Jun 2020 17:21:20 +0000 (18:21 +0100)
snd_soc_component_xxx() should be implemented at soc-component.c

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

index 4811321..cb0d34f 100644 (file)
@@ -324,6 +324,10 @@ static inline int snd_soc_component_cache_sync(
        return regcache_sync(component->regmap);
 }
 
+int snd_soc_component_initialize(struct snd_soc_component *component,
+                                const struct snd_soc_component_driver *driver,
+                                struct device *dev, const char *name);
+
 /* component IO */
 int snd_soc_component_read(struct snd_soc_component *component,
                           unsigned int reg, unsigned int *val);
index 3c96a1a..5bf2e71 100644 (file)
@@ -8,6 +8,22 @@
 #include <linux/module.h>
 #include <sound/soc.h>
 
+int snd_soc_component_initialize(struct snd_soc_component *component,
+                                const struct snd_soc_component_driver *driver,
+                                struct device *dev, const char *name)
+{
+       INIT_LIST_HEAD(&component->dai_list);
+       INIT_LIST_HEAD(&component->dobj_list);
+       INIT_LIST_HEAD(&component->card_list);
+       mutex_init(&component->io_mutex);
+
+       component->name         = name;
+       component->dev          = dev;
+       component->driver       = driver;
+
+       return 0;
+}
+
 /**
  * snd_soc_component_set_sysclk - configure COMPONENT system or master clock.
  * @component: COMPONENT
index 13a5973..e596e5a 100644 (file)
@@ -2378,26 +2378,6 @@ err:
        return ret;
 }
 
-static int snd_soc_component_initialize(struct snd_soc_component *component,
-       const struct snd_soc_component_driver *driver, struct device *dev)
-{
-       INIT_LIST_HEAD(&component->dai_list);
-       INIT_LIST_HEAD(&component->dobj_list);
-       INIT_LIST_HEAD(&component->card_list);
-       mutex_init(&component->io_mutex);
-
-       component->name = fmt_single_name(dev, &component->id);
-       if (!component->name) {
-               dev_err(dev, "ASoC: Failed to allocate name\n");
-               return -ENOMEM;
-       }
-
-       component->dev = dev;
-       component->driver = driver;
-
-       return 0;
-}
-
 #define ENDIANNESS_MAP(name) \
        (SNDRV_PCM_FMTBIT_##name##LE | SNDRV_PCM_FMTBIT_##name##BE)
 static u64 endianness_format_map[] = {
@@ -2460,12 +2440,19 @@ int snd_soc_add_component(struct device *dev,
                        struct snd_soc_dai_driver *dai_drv,
                        int num_dai)
 {
+       const char *name = fmt_single_name(dev, &component->id);
        int ret;
        int i;
 
+       if (!name) {
+               dev_err(dev, "ASoC: Failed to allocate name\n");
+               return -ENOMEM;
+       }
+
        mutex_lock(&client_mutex);
 
-       ret = snd_soc_component_initialize(component, component_driver, dev);
+       ret = snd_soc_component_initialize(component, component_driver,
+                                          dev, name);
        if (ret)
                goto err_free;