diff options
author | Lars-Peter Clausen <lars@metafoo.de> | 2013-04-15 13:19:58 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2013-04-17 09:26:27 -0400 |
commit | fc8ba7f94d84e1ccd351e41c778e36710834334e (patch) | |
tree | 5e7a69fddf6c2bc009f506c82c72e1eb80322767 /sound/soc | |
parent | 610f780050090db1af024bd060f819478a656cd0 (diff) |
ASoC: imx: Setup dma data in DAI probe
This allows us to access the DAI DMA data when we create the PCM. We'll use
this when converting imx to generic DMA engine PCM driver.
Signed-off-by: Lars-Peter Clausen <lars@metafoo.de>
Tested-by: Shawn Guo <shawn.guo@linaro.org>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc')
-rw-r--r-- | sound/soc/fsl/fsl_ssi.c | 19 | ||||
-rw-r--r-- | sound/soc/fsl/imx-ssi.c | 22 |
2 files changed, 17 insertions, 24 deletions
diff --git a/sound/soc/fsl/fsl_ssi.c b/sound/soc/fsl/fsl_ssi.c index 8a7eac4bf651..ab27ffab83f3 100644 --- a/sound/soc/fsl/fsl_ssi.c +++ b/sound/soc/fsl/fsl_ssi.c | |||
@@ -425,12 +425,6 @@ static int fsl_ssi_startup(struct snd_pcm_substream *substream, | |||
425 | ssi_private->second_stream = substream; | 425 | ssi_private->second_stream = substream; |
426 | } | 426 | } |
427 | 427 | ||
428 | if (ssi_private->ssi_on_imx) | ||
429 | snd_soc_dai_set_dma_data(dai, substream, | ||
430 | (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) ? | ||
431 | &ssi_private->dma_params_tx : | ||
432 | &ssi_private->dma_params_rx); | ||
433 | |||
434 | return 0; | 428 | return 0; |
435 | } | 429 | } |
436 | 430 | ||
@@ -552,6 +546,18 @@ static void fsl_ssi_shutdown(struct snd_pcm_substream *substream, | |||
552 | } | 546 | } |
553 | } | 547 | } |
554 | 548 | ||
549 | static int fsl_ssi_dai_probe(struct snd_soc_dai *dai) | ||
550 | { | ||
551 | struct fsl_ssi_private *ssi_private = snd_soc_dai_get_drvdata(dai); | ||
552 | |||
553 | if (ssi_private->ssi_on_imx) { | ||
554 | dai->playback_dma_data = &ssi_private->dma_params_tx; | ||
555 | dai->capture_dma_data = &ssi_private->dma_params_rx; | ||
556 | } | ||
557 | |||
558 | return 0; | ||
559 | } | ||
560 | |||
555 | static const struct snd_soc_dai_ops fsl_ssi_dai_ops = { | 561 | static const struct snd_soc_dai_ops fsl_ssi_dai_ops = { |
556 | .startup = fsl_ssi_startup, | 562 | .startup = fsl_ssi_startup, |
557 | .hw_params = fsl_ssi_hw_params, | 563 | .hw_params = fsl_ssi_hw_params, |
@@ -561,6 +567,7 @@ static const struct snd_soc_dai_ops fsl_ssi_dai_ops = { | |||
561 | 567 | ||
562 | /* Template for the CPU dai driver structure */ | 568 | /* Template for the CPU dai driver structure */ |
563 | static struct snd_soc_dai_driver fsl_ssi_dai_template = { | 569 | static struct snd_soc_dai_driver fsl_ssi_dai_template = { |
570 | .probe = fsl_ssi_dai_probe, | ||
564 | .playback = { | 571 | .playback = { |
565 | /* The SSI does not support monaural audio. */ | 572 | /* The SSI does not support monaural audio. */ |
566 | .channels_min = 2, | 573 | .channels_min = 2, |
diff --git a/sound/soc/fsl/imx-ssi.c b/sound/soc/fsl/imx-ssi.c index 7c84eb123d76..9128b7b26ecf 100644 --- a/sound/soc/fsl/imx-ssi.c +++ b/sound/soc/fsl/imx-ssi.c | |||
@@ -232,23 +232,6 @@ static int imx_ssi_set_dai_clkdiv(struct snd_soc_dai *cpu_dai, | |||
232 | return 0; | 232 | return 0; |
233 | } | 233 | } |
234 | 234 | ||
235 | static int imx_ssi_startup(struct snd_pcm_substream *substream, | ||
236 | struct snd_soc_dai *cpu_dai) | ||
237 | { | ||
238 | struct imx_ssi *ssi = snd_soc_dai_get_drvdata(cpu_dai); | ||
239 | struct snd_dmaengine_dai_dma_data *dma_data; | ||
240 | |||
241 | /* Tx/Rx config */ | ||
242 | if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) | ||
243 | dma_data = &ssi->dma_params_tx; | ||
244 | else | ||
245 | dma_data = &ssi->dma_params_rx; | ||
246 | |||
247 | snd_soc_dai_set_dma_data(cpu_dai, substream, dma_data); | ||
248 | |||
249 | return 0; | ||
250 | } | ||
251 | |||
252 | /* | 235 | /* |
253 | * Should only be called when port is inactive (i.e. SSIEN = 0), | 236 | * Should only be called when port is inactive (i.e. SSIEN = 0), |
254 | * although can be called multiple times by upper layers. | 237 | * although can be called multiple times by upper layers. |
@@ -353,7 +336,6 @@ static int imx_ssi_trigger(struct snd_pcm_substream *substream, int cmd, | |||
353 | } | 336 | } |
354 | 337 | ||
355 | static const struct snd_soc_dai_ops imx_ssi_pcm_dai_ops = { | 338 | static const struct snd_soc_dai_ops imx_ssi_pcm_dai_ops = { |
356 | .startup = imx_ssi_startup, | ||
357 | .hw_params = imx_ssi_hw_params, | 339 | .hw_params = imx_ssi_hw_params, |
358 | .set_fmt = imx_ssi_set_dai_fmt, | 340 | .set_fmt = imx_ssi_set_dai_fmt, |
359 | .set_clkdiv = imx_ssi_set_dai_clkdiv, | 341 | .set_clkdiv = imx_ssi_set_dai_clkdiv, |
@@ -373,6 +355,10 @@ static int imx_ssi_dai_probe(struct snd_soc_dai *dai) | |||
373 | SSI_SFCSR_RFWM0(ssi->dma_params_rx.maxburst); | 355 | SSI_SFCSR_RFWM0(ssi->dma_params_rx.maxburst); |
374 | writel(val, ssi->base + SSI_SFCSR); | 356 | writel(val, ssi->base + SSI_SFCSR); |
375 | 357 | ||
358 | /* Tx/Rx config */ | ||
359 | dai->playback_dma_data = &ssi->dma_params_tx; | ||
360 | dai->capture_dma_data = &ssi->dma_params_rx; | ||
361 | |||
376 | return 0; | 362 | return 0; |
377 | } | 363 | } |
378 | 364 | ||