diff options
author | Lu Guanqun <guanqun.lu@intel.com> | 2011-03-30 09:53:08 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2011-03-30 17:21:33 -0400 |
commit | fc3b9230cc2cdbcbef37953fe8cf5af0977e7a95 (patch) | |
tree | b00daf9d62ce69b24a39e44ee13142f91f620d85 /sound/soc/codecs/ak4671.c | |
parent | f20eda5d8fafe35ca3c63ec8149a700a7db228a5 (diff) |
ASoC: Use data based init for ak4671 DAPM
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>
Diffstat (limited to 'sound/soc/codecs/ak4671.c')
-rw-r--r-- | sound/soc/codecs/ak4671.c | 18 |
1 files changed, 5 insertions, 13 deletions
diff --git a/sound/soc/codecs/ak4671.c b/sound/soc/codecs/ak4671.c index 2ec75abfa3e..88b29f8c748 100644 --- a/sound/soc/codecs/ak4671.c +++ b/sound/soc/codecs/ak4671.c | |||
@@ -352,7 +352,7 @@ static const struct snd_soc_dapm_widget ak4671_dapm_widgets[] = { | |||
352 | SND_SOC_DAPM_SUPPLY("PMPLL", AK4671_PLL_MODE_SELECT1, 0, 0, NULL, 0), | 352 | SND_SOC_DAPM_SUPPLY("PMPLL", AK4671_PLL_MODE_SELECT1, 0, 0, NULL, 0), |
353 | }; | 353 | }; |
354 | 354 | ||
355 | static const struct snd_soc_dapm_route intercon[] = { | 355 | static const struct snd_soc_dapm_route ak4671_intercon[] = { |
356 | {"DAC Left", "NULL", "PMPLL"}, | 356 | {"DAC Left", "NULL", "PMPLL"}, |
357 | {"DAC Right", "NULL", "PMPLL"}, | 357 | {"DAC Right", "NULL", "PMPLL"}, |
358 | {"ADC Left", "NULL", "PMPLL"}, | 358 | {"ADC Left", "NULL", "PMPLL"}, |
@@ -433,17 +433,6 @@ static const struct snd_soc_dapm_route intercon[] = { | |||
433 | {"ROUT3 Mixer", "RINS4", "RIN4 Mixing Circuit"}, | 433 | {"ROUT3 Mixer", "RINS4", "RIN4 Mixing Circuit"}, |
434 | }; | 434 | }; |
435 | 435 | ||
436 | static int ak4671_add_widgets(struct snd_soc_codec *codec) | ||
437 | { | ||
438 | struct snd_soc_dapm_context *dapm = &codec->dapm; | ||
439 | |||
440 | snd_soc_dapm_new_controls(dapm, ak4671_dapm_widgets, | ||
441 | ARRAY_SIZE(ak4671_dapm_widgets)); | ||
442 | snd_soc_dapm_add_routes(dapm, intercon, ARRAY_SIZE(intercon)); | ||
443 | |||
444 | return 0; | ||
445 | } | ||
446 | |||
447 | static int ak4671_hw_params(struct snd_pcm_substream *substream, | 436 | static int ak4671_hw_params(struct snd_pcm_substream *substream, |
448 | struct snd_pcm_hw_params *params, | 437 | struct snd_pcm_hw_params *params, |
449 | struct snd_soc_dai *dai) | 438 | struct snd_soc_dai *dai) |
@@ -650,7 +639,6 @@ static int ak4671_probe(struct snd_soc_codec *codec) | |||
650 | 639 | ||
651 | snd_soc_add_controls(codec, ak4671_snd_controls, | 640 | snd_soc_add_controls(codec, ak4671_snd_controls, |
652 | ARRAY_SIZE(ak4671_snd_controls)); | 641 | ARRAY_SIZE(ak4671_snd_controls)); |
653 | ak4671_add_widgets(codec); | ||
654 | 642 | ||
655 | ak4671_set_bias_level(codec, SND_SOC_BIAS_STANDBY); | 643 | ak4671_set_bias_level(codec, SND_SOC_BIAS_STANDBY); |
656 | 644 | ||
@@ -670,6 +658,10 @@ static struct snd_soc_codec_driver soc_codec_dev_ak4671 = { | |||
670 | .reg_cache_size = AK4671_CACHEREGNUM, | 658 | .reg_cache_size = AK4671_CACHEREGNUM, |
671 | .reg_word_size = sizeof(u8), | 659 | .reg_word_size = sizeof(u8), |
672 | .reg_cache_default = ak4671_reg, | 660 | .reg_cache_default = ak4671_reg, |
661 | .dapm_widgets = ak4671_dapm_widgets, | ||
662 | .num_dapm_widgets = ARRAY_SIZE(ak4671_dapm_widgets), | ||
663 | .dapm_routes = ak4671_intercon, | ||
664 | .num_dapm_routes = ARRAY_SIZE(ak4671_intercon), | ||
673 | }; | 665 | }; |
674 | 666 | ||
675 | static int __devinit ak4671_i2c_probe(struct i2c_client *client, | 667 | static int __devinit ak4671_i2c_probe(struct i2c_client *client, |