diff options
author | Lars-Peter Clausen <lars@metafoo.de> | 2013-04-03 05:06:03 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2013-04-03 13:13:34 -0400 |
commit | 3489d5067a2cd8c51a2649b2f39bfb5b11852b8d (patch) | |
tree | f8dc9541af71beb7c9ed0f2eec97bc90152489f2 /sound/soc/tegra/tegra_pcm.c | |
parent | 09ae3aaf3cd28422d76b7b78d9491b17330b276a (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.c | 16 |
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) { |