ASoC: lm4857: Use table based setup for DAPM and controls
authorLars-Peter Clausen <lars@metafoo.de>
Sun, 28 Jul 2013 16:45:28 +0000 (18:45 +0200)
committerMark Brown <broonie@linaro.org>
Sun, 28 Jul 2013 18:09:16 +0000 (19:09 +0100)
Let the ASoC core take care of registering the DAPM widget and routes as well as
the controls. This makes the code a bit shorter.

Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Mark Brown <broonie@linaro.org>
sound/soc/codecs/lm4857.c

index 9f9f59573f721344995233da13ddf875f43436fc..5ea2ed053eb75f3753876b3fd32767f416a52bbc 100644 (file)
@@ -174,28 +174,9 @@ static const struct snd_soc_dapm_route lm4857_routes[] = {
 static int lm4857_probe(struct snd_soc_codec *codec)
 {
        struct lm4857 *lm4857 = snd_soc_codec_get_drvdata(codec);
-       struct snd_soc_dapm_context *dapm = &codec->dapm;
-       int ret;
 
        codec->control_data = lm4857->i2c;
 
-       ret = snd_soc_add_codec_controls(codec, lm4857_controls,
-                       ARRAY_SIZE(lm4857_controls));
-       if (ret)
-               return ret;
-
-       ret = snd_soc_dapm_new_controls(dapm, lm4857_dapm_widgets,
-                       ARRAY_SIZE(lm4857_dapm_widgets));
-       if (ret)
-               return ret;
-
-       ret = snd_soc_dapm_add_routes(dapm, lm4857_routes,
-                       ARRAY_SIZE(lm4857_routes));
-       if (ret)
-               return ret;
-
-       snd_soc_dapm_new_widgets(dapm);
-
        return 0;
 }
 
@@ -207,6 +188,13 @@ static struct snd_soc_codec_driver soc_codec_dev_lm4857 = {
        .reg_word_size = sizeof(uint8_t),
        .reg_cache_default = lm4857_default_regs,
        .set_bias_level = lm4857_set_bias_level,
+
+       .controls = lm4857_controls,
+       .num_controls = ARRAY_SIZE(lm4857_controls),
+       .dapm_widgets = lm4857_dapm_widgets,
+       .num_dapm_widgets = ARRAY_SIZE(lm4857_dapm_widgets),
+       .dapm_routes = lm4857_routes,
+       .num_dapm_routes = ARRAY_SIZE(lm4857_routes),
 };
 
 static int lm4857_i2c_probe(struct i2c_client *i2c,