aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/tegra/tegra_pcm.c
diff options
context:
space:
mode:
authorLars-Peter Clausen <lars@metafoo.de>2013-04-03 05:06:03 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2013-04-03 13:13:34 -0400
commit3489d5067a2cd8c51a2649b2f39bfb5b11852b8d (patch)
treef8dc9541af71beb7c9ed0f2eec97bc90152489f2 /sound/soc/tegra/tegra_pcm.c
parent09ae3aaf3cd28422d76b7b78d9491b17330b276a (diff)
ASoC: tegra: Use common DAI DMA data struct
Use the common DAI DMA data struct for tegra, this allows us to use the common helper function to configure the DMA slave config based on the DAI DMA data. Signed-off-by: Lars-Peter Clausen <lars@metafoo.de> Reviewed-by: Stephen Warren <swarren@nvidia.com> Tested-by: Stephen Warren <swarren@nvidia.com> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/tegra/tegra_pcm.c')
-rw-r--r--sound/soc/tegra/tegra_pcm.c16
1 files changed, 3 insertions, 13 deletions
diff --git a/sound/soc/tegra/tegra_pcm.c b/sound/soc/tegra/tegra_pcm.c
index e67af0b5d35d..f91d08bc1753 100644
--- a/sound/soc/tegra/tegra_pcm.c
+++ b/sound/soc/tegra/tegra_pcm.c
@@ -81,12 +81,9 @@ static int tegra_pcm_hw_params(struct snd_pcm_substream *substream,
81 struct snd_soc_pcm_runtime *rtd = substream->private_data; 81 struct snd_soc_pcm_runtime *rtd = substream->private_data;
82 struct device *dev = rtd->platform->dev; 82 struct device *dev = rtd->platform->dev;
83 struct dma_chan *chan = snd_dmaengine_pcm_get_chan(substream); 83 struct dma_chan *chan = snd_dmaengine_pcm_get_chan(substream);
84 struct tegra_pcm_dma_params *dmap;
85 struct dma_slave_config slave_config; 84 struct dma_slave_config slave_config;
86 int ret; 85 int ret;
87 86
88 dmap = snd_soc_dai_get_dma_data(rtd->cpu_dai, substream);
89
90 ret = snd_hwparams_to_dma_slave_config(substream, params, 87 ret = snd_hwparams_to_dma_slave_config(substream, params,
91 &slave_config); 88 &slave_config);
92 if (ret) { 89 if (ret) {
@@ -94,16 +91,9 @@ static int tegra_pcm_hw_params(struct snd_pcm_substream *substream,
94 return ret; 91 return ret;
95 } 92 }
96 93
97 if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) { 94 snd_dmaengine_pcm_set_config_from_dai_data(substream,
98 slave_config.dst_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; 95 snd_soc_dai_get_dma_data(rtd->cpu_dai, substream),
99 slave_config.dst_addr = dmap->addr; 96 &slave_config);
100 slave_config.dst_maxburst = 4;
101 } else {
102 slave_config.src_addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES;
103 slave_config.src_addr = dmap->addr;
104 slave_config.src_maxburst = 4;
105 }
106 slave_config.slave_id = dmap->req_sel;
107 97
108 ret = dmaengine_slave_config(chan, &slave_config); 98 ret = dmaengine_slave_config(chan, &slave_config);
109 if (ret < 0) { 99 if (ret < 0) {