Merge remote-tracking branch 'sound-asoc/for-next'
[deliverable/linux.git] / sound / soc / samsung / dmaengine.c
index 063125937311e9600f063a3cc8ddac308e876c7f..9104c98deeb75ab8ac3113e5be85ff4958fa2bdf 100644 (file)
  */
 
 #include <linux/module.h>
-#include <linux/amba/pl08x.h>
-#include <linux/platform_data/dma-s3c24xx.h>
-
 #include <sound/core.h>
 #include <sound/pcm.h>
 #include <sound/pcm_params.h>
 #include <sound/dmaengine_pcm.h>
 #include <sound/soc.h>
-#include <sound/soc-dai.h>
 
 #include "dma.h"
 
-static struct snd_dmaengine_pcm_config samsung_dmaengine_pcm_config = {
-       .prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config,
-};
-
-void samsung_asoc_init_dma_data(struct snd_soc_dai *dai,
-                               struct s3c_dma_params *playback,
-                               struct s3c_dma_params *capture)
+int samsung_asoc_dma_platform_register(struct device *dev, dma_filter_fn filter,
+                                      const char *tx, const char *rx)
 {
-       struct snd_dmaengine_dai_dma_data *playback_data = NULL;
-       struct snd_dmaengine_dai_dma_data *capture_data = NULL;
+       unsigned int flags = SND_DMAENGINE_PCM_FLAG_COMPAT;
+       struct snd_dmaengine_pcm_config *pcm_conf;
 
-       if (playback) {
-               playback_data = &playback->dma_data;
-               playback_data->filter_data = playback->slave;
-               playback_data->chan_name = playback->ch_name;
-               playback_data->addr = playback->dma_addr;
-               playback_data->addr_width = playback->dma_size;
-       }
-       if (capture) {
-               capture_data = &capture->dma_data;
-               capture_data->filter_data = capture->slave;
-               capture_data->chan_name = capture->ch_name;
-               capture_data->addr = capture->dma_addr;
-               capture_data->addr_width = capture->dma_size;
-       }
+       pcm_conf = devm_kzalloc(dev, sizeof(*pcm_conf), GFP_KERNEL);
+       if (!pcm_conf)
+               return -ENOMEM;
 
-       snd_soc_dai_init_dma_data(dai, playback_data, capture_data);
-}
-EXPORT_SYMBOL_GPL(samsung_asoc_init_dma_data);
+       pcm_conf->prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config;
+       pcm_conf->compat_filter_fn = filter;
 
-int samsung_asoc_dma_platform_register(struct device *dev,
-                                      dma_filter_fn filter)
-{
-       samsung_dmaengine_pcm_config.compat_filter_fn = filter;
+       if (dev->of_node) {
+               pcm_conf->chan_names[SNDRV_PCM_STREAM_PLAYBACK] = tx;
+               pcm_conf->chan_names[SNDRV_PCM_STREAM_CAPTURE] = rx;
+       } else {
+               flags |= SND_DMAENGINE_PCM_FLAG_CUSTOM_CHANNEL_NAME;
+       }
 
-       return devm_snd_dmaengine_pcm_register(dev,
-                       &samsung_dmaengine_pcm_config,
-                       SND_DMAENGINE_PCM_FLAG_CUSTOM_CHANNEL_NAME |
-                       SND_DMAENGINE_PCM_FLAG_COMPAT);
+       return devm_snd_dmaengine_pcm_register(dev, pcm_conf, flags);
 }
 EXPORT_SYMBOL_GPL(samsung_asoc_dma_platform_register);
 
This page took 0.080056 seconds and 5 git commands to generate.