ASoC: Use data based init for ak4671 DAPM
authorLu Guanqun <guanqun.lu@intel.com>
Wed, 30 Mar 2011 13:53:08 +0000 (21:53 +0800)
committerMark Brown <broonie@opensource.wolfsonmicro.com>
Wed, 30 Mar 2011 21:21:33 +0000 (06:21 +0900)
Signed-off-by: Lu Guanqun <guanqun.lu@intel.com>
Acked-by: Liam Girdwood <lrg@ti.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
sound/soc/codecs/ak4671.c

index 2ec75abfa3e9759036da009301d933a3c1ae7797..88b29f8c748bf09a1908ecad84b088a6dd6c270f 100644 (file)
@@ -352,7 +352,7 @@ static const struct snd_soc_dapm_widget ak4671_dapm_widgets[] = {
        SND_SOC_DAPM_SUPPLY("PMPLL", AK4671_PLL_MODE_SELECT1, 0, 0, NULL, 0),
 };
 
-static const struct snd_soc_dapm_route intercon[] = {
+static const struct snd_soc_dapm_route ak4671_intercon[] = {
        {"DAC Left", "NULL", "PMPLL"},
        {"DAC Right", "NULL", "PMPLL"},
        {"ADC Left", "NULL", "PMPLL"},
@@ -433,17 +433,6 @@ static const struct snd_soc_dapm_route intercon[] = {
        {"ROUT3 Mixer", "RINS4", "RIN4 Mixing Circuit"},
 };
 
-static int ak4671_add_widgets(struct snd_soc_codec *codec)
-{
-       struct snd_soc_dapm_context *dapm = &codec->dapm;
-
-       snd_soc_dapm_new_controls(dapm, ak4671_dapm_widgets,
-                                 ARRAY_SIZE(ak4671_dapm_widgets));
-       snd_soc_dapm_add_routes(dapm, intercon, ARRAY_SIZE(intercon));
-
-       return 0;
-}
-
 static int ak4671_hw_params(struct snd_pcm_substream *substream,
                struct snd_pcm_hw_params *params,
                struct snd_soc_dai *dai)
@@ -650,7 +639,6 @@ static int ak4671_probe(struct snd_soc_codec *codec)
 
        snd_soc_add_controls(codec, ak4671_snd_controls,
                             ARRAY_SIZE(ak4671_snd_controls));
-       ak4671_add_widgets(codec);
 
        ak4671_set_bias_level(codec, SND_SOC_BIAS_STANDBY);
 
@@ -670,6 +658,10 @@ static struct snd_soc_codec_driver soc_codec_dev_ak4671 = {
        .reg_cache_size = AK4671_CACHEREGNUM,
        .reg_word_size = sizeof(u8),
        .reg_cache_default = ak4671_reg,
+       .dapm_widgets = ak4671_dapm_widgets,
+       .num_dapm_widgets = ARRAY_SIZE(ak4671_dapm_widgets),
+       .dapm_routes = ak4671_intercon,
+       .num_dapm_routes = ARRAY_SIZE(ak4671_intercon),
 };
 
 static int __devinit ak4671_i2c_probe(struct i2c_client *client,