|
@@ -20,61 +20,6 @@
|
|
|
#include <sound/pxa2xx-lib.h>
|
|
|
#include <sound/dmaengine_pcm.h>
|
|
|
|
|
|
-static int __pxa2xx_pcm_hw_params(struct snd_pcm_substream *substream,
|
|
|
- struct snd_pcm_hw_params *params)
|
|
|
-{
|
|
|
- struct snd_soc_pcm_runtime *rtd = substream->private_data;
|
|
|
- struct snd_dmaengine_dai_dma_data *dma;
|
|
|
-
|
|
|
- dma = snd_soc_dai_get_dma_data(rtd->cpu_dai, substream);
|
|
|
-
|
|
|
- /* return if this is a bufferless transfer e.g.
|
|
|
- * codec <--> BT codec or GSM modem -- lg FIXME */
|
|
|
- if (!dma)
|
|
|
- return 0;
|
|
|
-
|
|
|
- return pxa2xx_pcm_hw_params(substream, params);
|
|
|
-}
|
|
|
-
|
|
|
-static const struct snd_pcm_ops pxa2xx_pcm_ops = {
|
|
|
- .open = pxa2xx_pcm_open,
|
|
|
- .close = pxa2xx_pcm_close,
|
|
|
- .ioctl = snd_pcm_lib_ioctl,
|
|
|
- .hw_params = __pxa2xx_pcm_hw_params,
|
|
|
- .hw_free = pxa2xx_pcm_hw_free,
|
|
|
- .prepare = pxa2xx_pcm_prepare,
|
|
|
- .trigger = pxa2xx_pcm_trigger,
|
|
|
- .pointer = pxa2xx_pcm_pointer,
|
|
|
- .mmap = pxa2xx_pcm_mmap,
|
|
|
-};
|
|
|
-
|
|
|
-static int pxa2xx_soc_pcm_new(struct snd_soc_pcm_runtime *rtd)
|
|
|
-{
|
|
|
- struct snd_card *card = rtd->card->snd_card;
|
|
|
- struct snd_pcm *pcm = rtd->pcm;
|
|
|
- int ret;
|
|
|
-
|
|
|
- ret = dma_coerce_mask_and_coherent(card->dev, DMA_BIT_MASK(32));
|
|
|
- if (ret)
|
|
|
- return ret;
|
|
|
-
|
|
|
- if (pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream) {
|
|
|
- ret = pxa2xx_pcm_preallocate_dma_buffer(pcm,
|
|
|
- SNDRV_PCM_STREAM_PLAYBACK);
|
|
|
- if (ret)
|
|
|
- goto out;
|
|
|
- }
|
|
|
-
|
|
|
- if (pcm->streams[SNDRV_PCM_STREAM_CAPTURE].substream) {
|
|
|
- ret = pxa2xx_pcm_preallocate_dma_buffer(pcm,
|
|
|
- SNDRV_PCM_STREAM_CAPTURE);
|
|
|
- if (ret)
|
|
|
- goto out;
|
|
|
- }
|
|
|
- out:
|
|
|
- return ret;
|
|
|
-}
|
|
|
-
|
|
|
static const struct snd_soc_component_driver pxa2xx_soc_platform = {
|
|
|
.ops = &pxa2xx_pcm_ops,
|
|
|
.pcm_new = pxa2xx_soc_pcm_new,
|