aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc
diff options
context:
space:
mode:
authorMark Brown <broonie@linaro.org>2014-01-16 07:42:57 -0500
committerMark Brown <broonie@linaro.org>2014-01-16 07:42:57 -0500
commit2f43a23ab9ea1865a663e100b0af20198decb4f1 (patch)
tree7501fb678115cbbdb544c43dc7b59f95408f1f52 /sound/soc
parent7cfa7b547337faf5890c8c5f091e081fb79caf73 (diff)
parent55dcdb5051930dee75e9e2c0da90bc82ee3dcd77 (diff)
Merge remote-tracking branch 'asoc/topic/pcm' into for-tiwai
Diffstat (limited to 'sound/soc')
-rw-r--r--sound/soc/fsl/fsl_ssi.c3
-rw-r--r--sound/soc/fsl/mpc5200_psc_i2s.c3
-rw-r--r--sound/soc/s6000/s6000-i2s.c3
-rw-r--r--sound/soc/soc-pcm.c23
4 files changed, 14 insertions, 18 deletions
diff --git a/sound/soc/fsl/fsl_ssi.c b/sound/soc/fsl/fsl_ssi.c
index b2ebaf811599..76e56b39db01 100644
--- a/sound/soc/fsl/fsl_ssi.c
+++ b/sound/soc/fsl/fsl_ssi.c
@@ -80,8 +80,7 @@ static inline void write_ssi_mask(u32 __iomem *addr, u32 clear, u32 set)
80 * ALSA that we support all rates and let the codec driver decide what rates 80 * ALSA that we support all rates and let the codec driver decide what rates
81 * are really supported. 81 * are really supported.
82 */ 82 */
83#define FSLSSI_I2S_RATES (SNDRV_PCM_RATE_5512 | SNDRV_PCM_RATE_8000_192000 | \ 83#define FSLSSI_I2S_RATES SNDRV_PCM_RATE_CONTINUOUS
84 SNDRV_PCM_RATE_CONTINUOUS)
85 84
86/** 85/**
87 * FSLSSI_I2S_FORMATS: audio formats supported by the SSI 86 * FSLSSI_I2S_FORMATS: audio formats supported by the SSI
diff --git a/sound/soc/fsl/mpc5200_psc_i2s.c b/sound/soc/fsl/mpc5200_psc_i2s.c
index f4efaadb80a2..5d07e8a74a21 100644
--- a/sound/soc/fsl/mpc5200_psc_i2s.c
+++ b/sound/soc/fsl/mpc5200_psc_i2s.c
@@ -26,8 +26,7 @@
26 * ALSA that we support all rates and let the codec driver decide what rates 26 * ALSA that we support all rates and let the codec driver decide what rates
27 * are really supported. 27 * are really supported.
28 */ 28 */
29#define PSC_I2S_RATES (SNDRV_PCM_RATE_5512 | SNDRV_PCM_RATE_8000_192000 | \ 29#define PSC_I2S_RATES SNDRV_PCM_RATE_CONTINUOUS
30 SNDRV_PCM_RATE_CONTINUOUS)
31 30
32/** 31/**
33 * PSC_I2S_FORMATS: audio formats supported by the PSC I2S mode 32 * PSC_I2S_FORMATS: audio formats supported by the PSC I2S mode
diff --git a/sound/soc/s6000/s6000-i2s.c b/sound/soc/s6000/s6000-i2s.c
index 73bb99f0109a..7eba7979b9af 100644
--- a/sound/soc/s6000/s6000-i2s.c
+++ b/sound/soc/s6000/s6000-i2s.c
@@ -405,8 +405,7 @@ static int s6000_i2s_dai_probe(struct snd_soc_dai *dai)
405 return 0; 405 return 0;
406} 406}
407 407
408#define S6000_I2S_RATES (SNDRV_PCM_RATE_CONTINUOUS | SNDRV_PCM_RATE_5512 | \ 408#define S6000_I2S_RATES SNDRV_PCM_RATE_CONTINUOUS
409 SNDRV_PCM_RATE_8000_192000)
410#define S6000_I2S_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE) 409#define S6000_I2S_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE)
411 410
412static const struct snd_soc_dai_ops s6000_i2s_dai_ops = { 411static const struct snd_soc_dai_ops s6000_i2s_dai_ops = {
diff --git a/sound/soc/soc-pcm.c b/sound/soc/soc-pcm.c
index e95ef9586723..5932971cf54d 100644
--- a/sound/soc/soc-pcm.c
+++ b/sound/soc/soc-pcm.c
@@ -240,14 +240,15 @@ static void soc_pcm_init_runtime_hw(struct snd_pcm_runtime *runtime,
240 cpu_stream->channels_min); 240 cpu_stream->channels_min);
241 hw->channels_max = min(codec_stream->channels_max, 241 hw->channels_max = min(codec_stream->channels_max,
242 cpu_stream->channels_max); 242 cpu_stream->channels_max);
243 hw->formats = codec_stream->formats & cpu_stream->formats; 243 if (hw->formats)
244 hw->rates = codec_stream->rates & cpu_stream->rates; 244 hw->formats &= codec_stream->formats & cpu_stream->formats;
245 if (codec_stream->rates 245 else
246 & (SNDRV_PCM_RATE_KNOT | SNDRV_PCM_RATE_CONTINUOUS)) 246 hw->formats = codec_stream->formats & cpu_stream->formats;
247 hw->rates |= cpu_stream->rates; 247 hw->rates = snd_pcm_rate_mask_intersect(codec_stream->rates,
248 if (cpu_stream->rates 248 cpu_stream->rates);
249 & (SNDRV_PCM_RATE_KNOT | SNDRV_PCM_RATE_CONTINUOUS)) 249
250 hw->rates |= codec_stream->rates; 250 hw->rate_min = 0;
251 hw->rate_max = UINT_MAX;
251 252
252 snd_pcm_limit_hw_rates(runtime); 253 snd_pcm_limit_hw_rates(runtime);
253 254
@@ -2140,10 +2141,8 @@ int soc_new_pcm(struct snd_soc_pcm_runtime *rtd, int num)
2140 int ret = 0, playback = 0, capture = 0; 2141 int ret = 0, playback = 0, capture = 0;
2141 2142
2142 if (rtd->dai_link->dynamic || rtd->dai_link->no_pcm) { 2143 if (rtd->dai_link->dynamic || rtd->dai_link->no_pcm) {
2143 if (cpu_dai->driver->playback.channels_min) 2144 playback = rtd->dai_link->dpcm_playback;
2144 playback = 1; 2145 capture = rtd->dai_link->dpcm_capture;
2145 if (cpu_dai->driver->capture.channels_min)
2146 capture = 1;
2147 } else { 2146 } else {
2148 if (codec_dai->driver->playback.channels_min && 2147 if (codec_dai->driver->playback.channels_min &&
2149 cpu_dai->driver->playback.channels_min) 2148 cpu_dai->driver->playback.channels_min)