diff options
author | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2009-03-13 10:27:08 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2009-03-14 07:38:16 -0400 |
commit | 85fab7802a4bc00cc752f430e22a0d9fc41fe199 (patch) | |
tree | 60c583e62271c758eb34436f1b57e608d0479273 | |
parent | 0ce36c5f7f87632f26c8fbefe68b5116eda152d2 (diff) |
ASoC: Fix Zylonite for non-networked SSP mode
This also simplifies the code a bit.
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r-- | sound/soc/pxa/zylonite.c | 55 |
1 files changed, 25 insertions, 30 deletions
diff --git a/sound/soc/pxa/zylonite.c b/sound/soc/pxa/zylonite.c index 9f6116edbb84..9a386b4c4ed1 100644 --- a/sound/soc/pxa/zylonite.c +++ b/sound/soc/pxa/zylonite.c | |||
@@ -96,42 +96,35 @@ static int zylonite_voice_hw_params(struct snd_pcm_substream *substream, | |||
96 | struct snd_soc_dai *codec_dai = rtd->dai->codec_dai; | 96 | struct snd_soc_dai *codec_dai = rtd->dai->codec_dai; |
97 | struct snd_soc_dai *cpu_dai = rtd->dai->cpu_dai; | 97 | struct snd_soc_dai *cpu_dai = rtd->dai->cpu_dai; |
98 | unsigned int pll_out = 0; | 98 | unsigned int pll_out = 0; |
99 | unsigned int acds = 0; | ||
100 | unsigned int wm9713_div = 0; | 99 | unsigned int wm9713_div = 0; |
101 | int ret = 0; | 100 | int ret = 0; |
102 | 101 | int rate = params_rate(params); | |
103 | switch (params_rate(params)) { | 102 | int width = snd_pcm_format_physical_width(params_format(params)); |
103 | |||
104 | /* Only support ratios that we can generate neatly from the AC97 | ||
105 | * based master clock - in particular, this excludes 44.1kHz. | ||
106 | * In most applications the voice DAC will be used for telephony | ||
107 | * data so multiples of 8kHz will be the common case. | ||
108 | */ | ||
109 | switch (rate) { | ||
104 | case 8000: | 110 | case 8000: |
105 | wm9713_div = 12; | 111 | wm9713_div = 12; |
106 | pll_out = 2048000; | ||
107 | break; | 112 | break; |
108 | case 16000: | 113 | case 16000: |
109 | wm9713_div = 6; | 114 | wm9713_div = 6; |
110 | pll_out = 4096000; | ||
111 | break; | 115 | break; |
112 | case 48000: | 116 | case 48000: |
113 | default: | ||
114 | wm9713_div = 2; | 117 | wm9713_div = 2; |
115 | pll_out = 12288000; | ||
116 | acds = 1; | ||
117 | break; | 118 | break; |
119 | default: | ||
120 | /* Don't support OSS emulation */ | ||
121 | return -EINVAL; | ||
118 | } | 122 | } |
119 | 123 | ||
120 | ret = snd_soc_dai_set_fmt(codec_dai, SND_SOC_DAIFMT_I2S | | 124 | /* Add 1 to the width for the leading clock cycle */ |
121 | SND_SOC_DAIFMT_NB_NF | SND_SOC_DAIFMT_CBS_CFS); | 125 | pll_out = rate * (width + 1) * 8; |
122 | if (ret < 0) | ||
123 | return ret; | ||
124 | |||
125 | ret = snd_soc_dai_set_fmt(cpu_dai, SND_SOC_DAIFMT_I2S | | ||
126 | SND_SOC_DAIFMT_NB_NF | SND_SOC_DAIFMT_CBS_CFS); | ||
127 | if (ret < 0) | ||
128 | return ret; | ||
129 | 126 | ||
130 | /* Use network mode for stereo, one slot per channel. */ | 127 | ret = snd_soc_dai_set_sysclk(cpu_dai, PXA_SSP_CLK_AUDIO, 0, 1); |
131 | if (params_channels(params) > 1) | ||
132 | ret = snd_soc_dai_set_tdm_slot(cpu_dai, 0x3, 2); | ||
133 | else | ||
134 | ret = snd_soc_dai_set_tdm_slot(cpu_dai, 1, 1); | ||
135 | if (ret < 0) | 128 | if (ret < 0) |
136 | return ret; | 129 | return ret; |
137 | 130 | ||
@@ -139,14 +132,6 @@ static int zylonite_voice_hw_params(struct snd_pcm_substream *substream, | |||
139 | if (ret < 0) | 132 | if (ret < 0) |
140 | return ret; | 133 | return ret; |
141 | 134 | ||
142 | ret = snd_soc_dai_set_clkdiv(cpu_dai, PXA_SSP_AUDIO_DIV_ACDS, acds); | ||
143 | if (ret < 0) | ||
144 | return ret; | ||
145 | |||
146 | ret = snd_soc_dai_set_sysclk(cpu_dai, PXA_SSP_CLK_AUDIO, 0, 1); | ||
147 | if (ret < 0) | ||
148 | return ret; | ||
149 | |||
150 | if (clk_pout) | 135 | if (clk_pout) |
151 | ret = snd_soc_dai_set_clkdiv(codec_dai, WM9713_PCMCLK_PLL_DIV, | 136 | ret = snd_soc_dai_set_clkdiv(codec_dai, WM9713_PCMCLK_PLL_DIV, |
152 | WM9713_PCMDIV(wm9713_div)); | 137 | WM9713_PCMDIV(wm9713_div)); |
@@ -156,6 +141,16 @@ static int zylonite_voice_hw_params(struct snd_pcm_substream *substream, | |||
156 | if (ret < 0) | 141 | if (ret < 0) |
157 | return ret; | 142 | return ret; |
158 | 143 | ||
144 | ret = snd_soc_dai_set_fmt(codec_dai, SND_SOC_DAIFMT_I2S | | ||
145 | SND_SOC_DAIFMT_NB_NF | SND_SOC_DAIFMT_CBS_CFS); | ||
146 | if (ret < 0) | ||
147 | return ret; | ||
148 | |||
149 | ret = snd_soc_dai_set_fmt(cpu_dai, SND_SOC_DAIFMT_I2S | | ||
150 | SND_SOC_DAIFMT_NB_NF | SND_SOC_DAIFMT_CBS_CFS); | ||
151 | if (ret < 0) | ||
152 | return ret; | ||
153 | |||
159 | return 0; | 154 | return 0; |
160 | } | 155 | } |
161 | 156 | ||