diff options
Diffstat (limited to 'sound/soc/codecs/wm8350.c')
-rw-r--r-- | sound/soc/codecs/wm8350.c | 42 |
1 files changed, 35 insertions, 7 deletions
diff --git a/sound/soc/codecs/wm8350.c b/sound/soc/codecs/wm8350.c index 0275321ff8ab..4ded0e3a35e0 100644 --- a/sound/soc/codecs/wm8350.c +++ b/sound/soc/codecs/wm8350.c | |||
@@ -406,7 +406,6 @@ static const char *wm8350_deemp[] = { "None", "32kHz", "44.1kHz", "48kHz" }; | |||
406 | static const char *wm8350_pol[] = { "Normal", "Inv R", "Inv L", "Inv L & R" }; | 406 | static const char *wm8350_pol[] = { "Normal", "Inv R", "Inv L", "Inv L & R" }; |
407 | static const char *wm8350_dacmutem[] = { "Normal", "Soft" }; | 407 | static const char *wm8350_dacmutem[] = { "Normal", "Soft" }; |
408 | static const char *wm8350_dacmutes[] = { "Fast", "Slow" }; | 408 | static const char *wm8350_dacmutes[] = { "Fast", "Slow" }; |
409 | static const char *wm8350_dacfilter[] = { "Normal", "Sloping" }; | ||
410 | static const char *wm8350_adcfilter[] = { "None", "High Pass" }; | 409 | static const char *wm8350_adcfilter[] = { "None", "High Pass" }; |
411 | static const char *wm8350_adchp[] = { "44.1kHz", "8kHz", "16kHz", "32kHz" }; | 410 | static const char *wm8350_adchp[] = { "44.1kHz", "8kHz", "16kHz", "32kHz" }; |
412 | static const char *wm8350_lr[] = { "Left", "Right" }; | 411 | static const char *wm8350_lr[] = { "Left", "Right" }; |
@@ -416,7 +415,6 @@ static const struct soc_enum wm8350_enum[] = { | |||
416 | SOC_ENUM_SINGLE(WM8350_DAC_CONTROL, 0, 4, wm8350_pol), | 415 | SOC_ENUM_SINGLE(WM8350_DAC_CONTROL, 0, 4, wm8350_pol), |
417 | SOC_ENUM_SINGLE(WM8350_DAC_MUTE_VOLUME, 14, 2, wm8350_dacmutem), | 416 | SOC_ENUM_SINGLE(WM8350_DAC_MUTE_VOLUME, 14, 2, wm8350_dacmutem), |
418 | SOC_ENUM_SINGLE(WM8350_DAC_MUTE_VOLUME, 13, 2, wm8350_dacmutes), | 417 | SOC_ENUM_SINGLE(WM8350_DAC_MUTE_VOLUME, 13, 2, wm8350_dacmutes), |
419 | SOC_ENUM_SINGLE(WM8350_DAC_MUTE_VOLUME, 12, 2, wm8350_dacfilter), | ||
420 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 15, 2, wm8350_adcfilter), | 418 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 15, 2, wm8350_adcfilter), |
421 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 8, 4, wm8350_adchp), | 419 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 8, 4, wm8350_adchp), |
422 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 0, 4, wm8350_pol), | 420 | SOC_ENUM_SINGLE(WM8350_ADC_CONTROL, 0, 4, wm8350_pol), |
@@ -444,10 +442,9 @@ static const struct snd_kcontrol_new wm8350_snd_controls[] = { | |||
444 | 0, 255, 0, dac_pcm_tlv), | 442 | 0, 255, 0, dac_pcm_tlv), |
445 | SOC_ENUM("Playback PCM Mute Function", wm8350_enum[2]), | 443 | SOC_ENUM("Playback PCM Mute Function", wm8350_enum[2]), |
446 | SOC_ENUM("Playback PCM Mute Speed", wm8350_enum[3]), | 444 | SOC_ENUM("Playback PCM Mute Speed", wm8350_enum[3]), |
447 | SOC_ENUM("Playback PCM Filter", wm8350_enum[4]), | 445 | SOC_ENUM("Capture PCM Filter", wm8350_enum[4]), |
448 | SOC_ENUM("Capture PCM Filter", wm8350_enum[5]), | 446 | SOC_ENUM("Capture PCM HP Filter", wm8350_enum[5]), |
449 | SOC_ENUM("Capture PCM HP Filter", wm8350_enum[6]), | 447 | SOC_ENUM("Capture ADC Inversion", wm8350_enum[6]), |
450 | SOC_ENUM("Capture ADC Inversion", wm8350_enum[7]), | ||
451 | SOC_WM8350_DOUBLE_R_TLV("Capture PCM Volume", | 448 | SOC_WM8350_DOUBLE_R_TLV("Capture PCM Volume", |
452 | WM8350_ADC_DIGITAL_VOLUME_L, | 449 | WM8350_ADC_DIGITAL_VOLUME_L, |
453 | WM8350_ADC_DIGITAL_VOLUME_R, | 450 | WM8350_ADC_DIGITAL_VOLUME_R, |
@@ -993,6 +990,7 @@ static int wm8350_pcm_hw_params(struct snd_pcm_substream *substream, | |||
993 | struct snd_soc_dai *codec_dai) | 990 | struct snd_soc_dai *codec_dai) |
994 | { | 991 | { |
995 | struct snd_soc_codec *codec = codec_dai->codec; | 992 | struct snd_soc_codec *codec = codec_dai->codec; |
993 | struct wm8350 *wm8350 = codec->control_data; | ||
996 | u16 iface = wm8350_codec_read(codec, WM8350_AI_FORMATING) & | 994 | u16 iface = wm8350_codec_read(codec, WM8350_AI_FORMATING) & |
997 | ~WM8350_AIF_WL_MASK; | 995 | ~WM8350_AIF_WL_MASK; |
998 | 996 | ||
@@ -1012,6 +1010,19 @@ static int wm8350_pcm_hw_params(struct snd_pcm_substream *substream, | |||
1012 | } | 1010 | } |
1013 | 1011 | ||
1014 | wm8350_codec_write(codec, WM8350_AI_FORMATING, iface); | 1012 | wm8350_codec_write(codec, WM8350_AI_FORMATING, iface); |
1013 | |||
1014 | /* The sloping stopband filter is recommended for use with | ||
1015 | * lower sample rates to improve performance. | ||
1016 | */ | ||
1017 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) { | ||
1018 | if (params_rate(params) < 24000) | ||
1019 | wm8350_set_bits(wm8350, WM8350_DAC_MUTE_VOLUME, | ||
1020 | WM8350_DAC_SB_FILT); | ||
1021 | else | ||
1022 | wm8350_clear_bits(wm8350, WM8350_DAC_MUTE_VOLUME, | ||
1023 | WM8350_DAC_SB_FILT); | ||
1024 | } | ||
1025 | |||
1015 | return 0; | 1026 | return 0; |
1016 | } | 1027 | } |
1017 | 1028 | ||
@@ -1108,7 +1119,7 @@ static int wm8350_set_fll(struct snd_soc_dai *codec_dai, | |||
1108 | if (ret < 0) | 1119 | if (ret < 0) |
1109 | return ret; | 1120 | return ret; |
1110 | dev_dbg(wm8350->dev, | 1121 | dev_dbg(wm8350->dev, |
1111 | "FLL in %d FLL out %d N 0x%x K 0x%x div %d ratio %d", | 1122 | "FLL in %u FLL out %u N 0x%x K 0x%x div %d ratio %d", |
1112 | freq_in, freq_out, fll_div.n, fll_div.k, fll_div.div, | 1123 | freq_in, freq_out, fll_div.n, fll_div.k, fll_div.div, |
1113 | fll_div.ratio); | 1124 | fll_div.ratio); |
1114 | 1125 | ||
@@ -1660,6 +1671,21 @@ static int __devexit wm8350_codec_remove(struct platform_device *pdev) | |||
1660 | return 0; | 1671 | return 0; |
1661 | } | 1672 | } |
1662 | 1673 | ||
1674 | #ifdef CONFIG_PM | ||
1675 | static int wm8350_codec_suspend(struct platform_device *pdev, pm_message_t m) | ||
1676 | { | ||
1677 | return snd_soc_suspend_device(&pdev->dev); | ||
1678 | } | ||
1679 | |||
1680 | static int wm8350_codec_resume(struct platform_device *pdev) | ||
1681 | { | ||
1682 | return snd_soc_resume_device(&pdev->dev); | ||
1683 | } | ||
1684 | #else | ||
1685 | #define wm8350_codec_suspend NULL | ||
1686 | #define wm8350_codec_resume NULL | ||
1687 | #endif | ||
1688 | |||
1663 | static struct platform_driver wm8350_codec_driver = { | 1689 | static struct platform_driver wm8350_codec_driver = { |
1664 | .driver = { | 1690 | .driver = { |
1665 | .name = "wm8350-codec", | 1691 | .name = "wm8350-codec", |
@@ -1667,6 +1693,8 @@ static struct platform_driver wm8350_codec_driver = { | |||
1667 | }, | 1693 | }, |
1668 | .probe = wm8350_codec_probe, | 1694 | .probe = wm8350_codec_probe, |
1669 | .remove = __devexit_p(wm8350_codec_remove), | 1695 | .remove = __devexit_p(wm8350_codec_remove), |
1696 | .suspend = wm8350_codec_suspend, | ||
1697 | .resume = wm8350_codec_resume, | ||
1670 | }; | 1698 | }; |
1671 | 1699 | ||
1672 | static __init int wm8350_init(void) | 1700 | static __init int wm8350_init(void) |