aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKuninori Morimoto <kuninori.morimoto.gx@renesas.com>2017-10-02 01:10:17 -0400
committerMark Brown <broonie@kernel.org>2017-10-10 05:18:58 -0400
commite0dac41b8c21d41534b04d520c1927c2b0ac9b5e (patch)
tree9fe2322e029a93eea4cc0f6d59ba2e3ea98676f0
parent840bc44849b9d7f8eaae34ac7b434e17c4cf7368 (diff)
ASoC: soc-core: add snd_soc_add_component()
ALSA SoC platform/codec will be replaced to component soon. But, some function exist in "platform" doesn't exist in "component". Current soc-core has snd_soc_register_component(), but doesn't have snd_soc_add_component() like snd_soc_add_platform(). This patch adds it. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--include/sound/soc.h5
-rw-r--r--sound/soc/soc-core.c34
2 files changed, 28 insertions, 11 deletions
diff --git a/include/sound/soc.h b/include/sound/soc.h
index 996bdbc125a5..580da1e4f141 100644
--- a/include/sound/soc.h
+++ b/include/sound/soc.h
@@ -468,6 +468,11 @@ int snd_soc_register_codec(struct device *dev,
468 const struct snd_soc_codec_driver *codec_drv, 468 const struct snd_soc_codec_driver *codec_drv,
469 struct snd_soc_dai_driver *dai_drv, int num_dai); 469 struct snd_soc_dai_driver *dai_drv, int num_dai);
470void snd_soc_unregister_codec(struct device *dev); 470void snd_soc_unregister_codec(struct device *dev);
471int snd_soc_add_component(struct device *dev,
472 struct snd_soc_component *component,
473 const struct snd_soc_component_driver *component_driver,
474 struct snd_soc_dai_driver *dai_drv,
475 int num_dai);
471int snd_soc_register_component(struct device *dev, 476int snd_soc_register_component(struct device *dev,
472 const struct snd_soc_component_driver *component_driver, 477 const struct snd_soc_component_driver *component_driver,
473 struct snd_soc_dai_driver *dai_drv, int num_dai); 478 struct snd_soc_dai_driver *dai_drv, int num_dai);
diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c
index fee4b0ef5566..3a1c3b44de5e 100644
--- a/sound/soc/soc-core.c
+++ b/sound/soc/soc-core.c
@@ -3371,20 +3371,14 @@ static void snd_soc_component_del_unlocked(struct snd_soc_component *component)
3371 list_del(&component->list); 3371 list_del(&component->list);
3372} 3372}
3373 3373
3374int snd_soc_register_component(struct device *dev, 3374int snd_soc_add_component(struct device *dev,
3375 const struct snd_soc_component_driver *component_driver, 3375 struct snd_soc_component *component,
3376 struct snd_soc_dai_driver *dai_drv, 3376 const struct snd_soc_component_driver *component_driver,
3377 int num_dai) 3377 struct snd_soc_dai_driver *dai_drv,
3378 int num_dai)
3378{ 3379{
3379 struct snd_soc_component *component;
3380 int ret; 3380 int ret;
3381 3381
3382 component = kzalloc(sizeof(*component), GFP_KERNEL);
3383 if (!component) {
3384 dev_err(dev, "ASoC: Failed to allocate memory\n");
3385 return -ENOMEM;
3386 }
3387
3388 ret = snd_soc_component_initialize(component, component_driver, dev); 3382 ret = snd_soc_component_initialize(component, component_driver, dev);
3389 if (ret) 3383 if (ret)
3390 goto err_free; 3384 goto err_free;
@@ -3408,6 +3402,24 @@ err_free:
3408 kfree(component); 3402 kfree(component);
3409 return ret; 3403 return ret;
3410} 3404}
3405EXPORT_SYMBOL_GPL(snd_soc_add_component);
3406
3407int snd_soc_register_component(struct device *dev,
3408 const struct snd_soc_component_driver *component_driver,
3409 struct snd_soc_dai_driver *dai_drv,
3410 int num_dai)
3411{
3412 struct snd_soc_component *component;
3413
3414 component = kzalloc(sizeof(*component), GFP_KERNEL);
3415 if (!component) {
3416 dev_err(dev, "ASoC: Failed to allocate memory\n");
3417 return -ENOMEM;
3418 }
3419
3420 return snd_soc_add_component(dev, component, component_driver,
3421 dai_drv, num_dai);
3422}
3411EXPORT_SYMBOL_GPL(snd_soc_register_component); 3423EXPORT_SYMBOL_GPL(snd_soc_register_component);
3412 3424
3413/** 3425/**