aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc
diff options
context:
space:
mode:
authorGabriel M. Beddingfield <gabrbedd@ti.com>2011-10-27 16:02:48 -0500
committerZiyann <jaraidaniel@gmail.com>2014-10-01 12:56:13 +0200
commit483505b696227d507f593289464ec913f11c9654 (patch)
treeb1dcf1013e4c0debc2b87c2b5b4f4842ec04d580 /sound/soc
parent62f928ef00b95d4540f0f91259b6869f225c97ea (diff)
downloadkernel_samsung_tuna-483505b696227d507f593289464ec913f11c9654.zip
kernel_samsung_tuna-483505b696227d507f593289464ec913f11c9654.tar.gz
kernel_samsung_tuna-483505b696227d507f593289464ec913f11c9654.tar.bz2
ASoC: OMAP ABE: Restore defaults for DMA params
The static struct omap_abe_dai_dma_params is used to both set defaults and serve as the omap_pcm_dma_data instance for the driver. In some cases, the values in this struct are overridden to suit the end-use. When these overrides happen, there was nothing to set them back to the original default. This fixes an issue where single-channel headset (AMic) recording causes subsequent DMic recordings to be rendered at double-speed. This happened because the the dma data_type was being set to OMAP_DMA_DATA_TYPE_S16 in the static struct omap_abe_dai_dma_params. After being set, the value was never restored to OMAP_DMA_DATA_TYPE_S32 (needed by DMic recording). Change-Id: Iea2b19d451edc10ab864ca6c1a2b6b3449b05bea Signed-off-by: Gabriel M. Beddingfield <gabrbedd@ti.com>
Diffstat (limited to 'sound/soc')
-rw-r--r--sound/soc/omap/omap-abe.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/sound/soc/omap/omap-abe.c b/sound/soc/omap/omap-abe.c
index b05dfe8..943f9d6 100644
--- a/sound/soc/omap/omap-abe.c
+++ b/sound/soc/omap/omap-abe.c
@@ -1019,6 +1019,12 @@ static int omap_abe_dai_hw_params(struct snd_pcm_substream *substream,
dma_data = &omap_abe_dai_dma_params[dai->id][substream->stream];
+ /* Reset DMA info that may have been overridden */
+ dma_data->port_addr = 0L;
+ dma_data->set_threshold = NULL;
+ dma_data->data_type = OMAP_DMA_DATA_TYPE_S32;
+ dma_data->packet_size = 0;
+
switch (params_channels(params)) {
case 1:
if (params_format(params) == SNDRV_PCM_FORMAT_S16_LE) {