On Thu, Jan 15, 2015 at 02:07:11PM +0000, Nikesh Oswal wrote:
> dai-link params for codec-codec links were fixed. The fixed
> link between codec and another chip which may be another codec,
> baseband, bluetooth codec etc may require run time configuaration
> changes. This change provides an optional alsa control to select
> one of the params from a list of params.
> 
> Signed-off-by: Nikesh Oswal <nik...@opensource.wolfsonmicro.com>
> ---
>  include/sound/soc-dapm.h |    3 +
>  include/sound/soc.h      |    1 +
>  sound/soc/soc-core.c     |    6 +-
>  sound/soc/soc-dapm.c     |  155 
> ++++++++++++++++++++++++++++++++++++++++++++--
>  4 files changed, 157 insertions(+), 8 deletions(-)
> 
> diff --git a/include/sound/soc-dapm.h b/include/sound/soc-dapm.h
> index 5c0a798..a2098e4 100644
> @@ -3299,14 +3363,52 @@ int snd_soc_dapm_new_pcm(struct snd_soc_card *card,
>       struct snd_soc_dapm_widget *w;
>       size_t len;
>       char *link_name;
> -     int ret;
> +     int ret, count;
> +     unsigned long private_value;
> +     const char **w_param_text;
> +     struct soc_enum w_param_enum[] = {
> +             SOC_ENUM_SINGLE(0, 0, 0, NULL),
> +     };
> +     struct snd_kcontrol_new kcontrol_dai_link[] = {
> +             SOC_ENUM_EXT(NULL, w_param_enum[0],
> +                          snd_soc_dapm_dai_link_get,
> +                          snd_soc_dapm_dai_link_put),
> +     };
> +     const struct snd_soc_pcm_stream *config = params;
> +
> +     w_param_text = devm_kcalloc(card->dev, num_params,
> +                                     sizeof(char *), GFP_KERNEL);
> +     if (!w_param_text)
> +             return -ENOMEM;
>  
>       len = strlen(source->name) + strlen(sink->name) + 2;
>       link_name = devm_kzalloc(card->dev, len, GFP_KERNEL);
> -     if (!link_name)
> -             return -ENOMEM;
> +     if (!link_name) {
> +             ret = -ENOMEM;
> +             goto outfree_w_param;
> +     }
>       snprintf(link_name, len, "%s-%s", source->name, sink->name);
>  
> +     for (count = 0 ; count < num_params; count++) {
> +             if (!config->stream_name) {
> +                     dev_warn(card->dapm.dev,
> +                             "ASoC: anonymous config %d for dai link %s\n",
> +                             count, link_name);

The ALSA core doesn't like one of the string in the enum text
links being a NULL pointer so you will want to add some sort of
default text or something in this case.

> +             } else {
> +                     w_param_text[count] = devm_kmemdup(card->dev,
> +                                             config->stream_name,
> +                                             strlen(config->stream_name) + 1,
> +                                             GFP_KERNEL);
> +                     if (!w_param_text[count]) {
> +                             ret = -ENOMEM;
> +                             goto outfree_link_name;
> +                     }
> +             }
> +             config++;
> +     }
> +     w_param_enum[0].items = num_params;
> +     w_param_enum[0].texts = w_param_text;
> +
>       memset(&template, 0, sizeof(template));
>       template.reg = SND_SOC_NOPM;
>       template.id = snd_soc_dapm_dai_link;

Thanks,
Charles
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to