ASoC: ak4642: Convert to table based control init
authorMark Brown <broonie@linaro.org>
Thu, 28 Nov 2013 17:27:02 +0000 (17:27 +0000)
committerMark Brown <broonie@linaro.org>
Mon, 2 Dec 2013 11:53:28 +0000 (11:53 +0000)
Improves error handling and saves code.

Signed-off-by: Mark Brown <broonie@linaro.org>
sound/soc/codecs/ak4642.c

index 2f861c9b1d69079ecf32740f89a939194bc80e43..7fe1e9030c4f44d92baa5f203dc0b914151bb68f 100644 (file)
@@ -469,9 +469,6 @@ static int ak4642_probe(struct snd_soc_codec *codec)
                return ret;
        }
 
-       snd_soc_add_codec_controls(codec, ak4642_snd_controls,
-                            ARRAY_SIZE(ak4642_snd_controls));
-
        ak4642_set_bias_level(codec, SND_SOC_BIAS_STANDBY);
 
        return 0;
@@ -491,6 +488,8 @@ static struct snd_soc_codec_driver soc_codec_dev_ak4642 = {
        .reg_cache_default      = ak4642_reg,                   /* ak4642 reg */
        .reg_cache_size         = ARRAY_SIZE(ak4642_reg),       /* ak4642 reg */
        .reg_word_size          = sizeof(u8),
+       .controls               = ak4642_snd_controls,
+       .num_controls           = ARRAY_SIZE(ak4642_snd_controls),
        .dapm_widgets           = ak4642_dapm_widgets,
        .num_dapm_widgets       = ARRAY_SIZE(ak4642_dapm_widgets),
        .dapm_routes            = ak4642_intercon,
@@ -505,6 +504,8 @@ static struct snd_soc_codec_driver soc_codec_dev_ak4648 = {
        .reg_cache_default      = ak4648_reg,                   /* ak4648 reg */
        .reg_cache_size         = ARRAY_SIZE(ak4648_reg),       /* ak4648 reg */
        .reg_word_size          = sizeof(u8),
+       .controls               = ak4642_snd_controls,
+       .num_controls           = ARRAY_SIZE(ak4642_snd_controls),
        .dapm_widgets           = ak4642_dapm_widgets,
        .num_dapm_widgets       = ARRAY_SIZE(ak4642_dapm_widgets),
        .dapm_routes            = ak4642_intercon,