[alsa-devel] [PATCH] ASoC: Ensure we generate a driver name

Scott Jiang scott.jiang.linux at gmail.com
Wed Sep 21 07:09:30 CEST 2011


2011/9/20 Mark Brown <broonie at opensource.wolfsonmicro.com>:
> Commit 873bd4c (ASoC: Don't set invalid name string to snd_card->driver
> field) broke generation of a driver name for all ASoC cards relying on the
> automatic generation of one. Fix this by using the old default with spaces
> replaced by underscores.
>
> Signed-off-by: Mark Brown <broonie at opensource.wolfsonmicro.com>
> ---
>  sound/soc/soc-core.c |   18 +++++++++++++++---
>  1 files changed, 15 insertions(+), 3 deletions(-)
>
> diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c
> index 10e5cde..bd20154 100644
> --- a/sound/soc/soc-core.c
> +++ b/sound/soc/soc-core.c
> @@ -30,6 +30,7 @@
>  #include <linux/bitops.h>
>  #include <linux/debugfs.h>
>  #include <linux/platform_device.h>
> +#include <linux/ctype.h>
>  #include <linux/slab.h>
>  #include <sound/ac97_codec.h>
>  #include <sound/core.h>
> @@ -1432,9 +1433,20 @@ static void snd_soc_instantiate_card(struct snd_soc_card *card)
>                 "%s", card->name);
>        snprintf(card->snd_card->longname, sizeof(card->snd_card->longname),
>                 "%s", card->long_name ? card->long_name : card->name);
> -       if (card->driver_name)
> -               strlcpy(card->snd_card->driver, card->driver_name,
> -                       sizeof(card->snd_card->driver));
> +       snprintf(card->snd_card->driver, sizeof(card->snd_card->driver),
> +                "%s", card->driver_name ? card->driver_name : card->name);
> +       for (i = 0; i < ARRAY_SIZE(card->snd_card->driver); i++) {
> +               switch (card->snd_card->driver[i]) {
> +               case '_':
> +               case '-':
> +               case '\0':
> +                       break;
> +               default:
> +                       if (!isalnum(card->snd_card->driver[i]))
> +                               card->snd_card->driver[i] = '_';
> +                       break;
> +               }
> +       }
>
>        if (card->late_probe) {
>                ret = card->late_probe(card);
> --
If '\0', we should break out of loop?


More information about the Alsa-devel mailing list