diff options
-rw-r--r-- | include/sound/soc.h | 3 | ||||
-rw-r--r-- | sound/soc/Makefile | 2 | ||||
-rw-r--r-- | sound/soc/soc-devres.c | 52 |
3 files changed, 56 insertions, 1 deletions
diff --git a/include/sound/soc.h b/include/sound/soc.h index d22cb0a06feb..b970f019b452 100644 --- a/include/sound/soc.h +++ b/include/sound/soc.h | |||
@@ -386,6 +386,9 @@ void snd_soc_unregister_codec(struct device *dev); | |||
386 | int snd_soc_register_component(struct device *dev, | 386 | int snd_soc_register_component(struct device *dev, |
387 | const struct snd_soc_component_driver *cmpnt_drv, | 387 | const struct snd_soc_component_driver *cmpnt_drv, |
388 | struct snd_soc_dai_driver *dai_drv, int num_dai); | 388 | struct snd_soc_dai_driver *dai_drv, int num_dai); |
389 | int devm_snd_soc_register_component(struct device *dev, | ||
390 | const struct snd_soc_component_driver *cmpnt_drv, | ||
391 | struct snd_soc_dai_driver *dai_drv, int num_dai); | ||
389 | void snd_soc_unregister_component(struct device *dev); | 392 | void snd_soc_unregister_component(struct device *dev); |
390 | int snd_soc_codec_volatile_register(struct snd_soc_codec *codec, | 393 | int snd_soc_codec_volatile_register(struct snd_soc_codec *codec, |
391 | unsigned int reg); | 394 | unsigned int reg); |
diff --git a/sound/soc/Makefile b/sound/soc/Makefile index 61a64d281905..8b9e70105dd2 100644 --- a/sound/soc/Makefile +++ b/sound/soc/Makefile | |||
@@ -1,5 +1,5 @@ | |||
1 | snd-soc-core-objs := soc-core.o soc-dapm.o soc-jack.o soc-cache.o soc-utils.o | 1 | snd-soc-core-objs := soc-core.o soc-dapm.o soc-jack.o soc-cache.o soc-utils.o |
2 | snd-soc-core-objs += soc-pcm.o soc-compress.o soc-io.o | 2 | snd-soc-core-objs += soc-pcm.o soc-compress.o soc-io.o soc-devres.o |
3 | 3 | ||
4 | ifneq ($(CONFIG_SND_SOC_GENERIC_DMAENGINE_PCM),) | 4 | ifneq ($(CONFIG_SND_SOC_GENERIC_DMAENGINE_PCM),) |
5 | snd-soc-core-objs += soc-generic-dmaengine-pcm.o | 5 | snd-soc-core-objs += soc-generic-dmaengine-pcm.o |
diff --git a/sound/soc/soc-devres.c b/sound/soc/soc-devres.c new file mode 100644 index 000000000000..13fe86f7c9a8 --- /dev/null +++ b/sound/soc/soc-devres.c | |||
@@ -0,0 +1,52 @@ | |||
1 | /* | ||
2 | * soc-devres.c -- ALSA SoC Audio Layer devres functions | ||
3 | * | ||
4 | * Copyright (C) 2013 Linaro Ltd | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify it | ||
7 | * under the terms of the GNU General Public License as published by the | ||
8 | * Free Software Foundation; either version 2 of the License, or (at your | ||
9 | * option) any later version. | ||
10 | */ | ||
11 | |||
12 | #include <linux/module.h> | ||
13 | #include <linux/moduleparam.h> | ||
14 | #include <sound/soc.h> | ||
15 | |||
16 | static void devm_component_release(struct device *dev, void *res) | ||
17 | { | ||
18 | snd_soc_unregister_component(*(struct device **)res); | ||
19 | } | ||
20 | |||
21 | /** | ||
22 | * devm_snd_soc_register_component - resource managed component registration | ||
23 | * @dev: Device used to manage component | ||
24 | * @cmpnt_drv: Component driver | ||
25 | * @dai_drv: DAI driver | ||
26 | * @num_dai: Number of DAIs to register | ||
27 | * | ||
28 | * Register a component with automatic unregistration when the device is | ||
29 | * unregistered. | ||
30 | */ | ||
31 | int devm_snd_soc_register_component(struct device *dev, | ||
32 | const struct snd_soc_component_driver *cmpnt_drv, | ||
33 | struct snd_soc_dai_driver *dai_drv, int num_dai) | ||
34 | { | ||
35 | struct device **ptr; | ||
36 | int ret; | ||
37 | |||
38 | ptr = devres_alloc(devm_component_release, sizeof(*ptr), GFP_KERNEL); | ||
39 | if (!ptr) | ||
40 | return -ENOMEM; | ||
41 | |||
42 | ret = snd_soc_register_component(dev, cmpnt_drv, dai_drv, num_dai); | ||
43 | if (ret == 0) { | ||
44 | *ptr = dev; | ||
45 | devres_add(dev, ptr); | ||
46 | } else { | ||
47 | devres_free(ptr); | ||
48 | } | ||
49 | |||
50 | return ret; | ||
51 | } | ||
52 | EXPORT_SYMBOL_GPL(devm_snd_soc_register_component); | ||