2019-05-27 09:55:21 +03:00
// SPDX-License-Identifier: GPL-2.0-only
2014-03-14 18:42:45 +04:00
/*
* edma - pcm . c - eDMA PCM driver using dmaengine for AM3xxx , AM4xxx
*
* Copyright ( C ) 2014 Texas Instruments , Inc .
*
* Author : Peter Ujfalusi < peter . ujfalusi @ ti . com >
*
* Based on : sound / soc / tegra / tegra_pcm . c
*/
# include <linux/module.h>
# include <sound/core.h>
# include <sound/pcm.h>
# include <sound/pcm_params.h>
# include <sound/soc.h>
# include <sound/dmaengine_pcm.h>
2014-08-17 18:18:17 +04:00
# include "edma-pcm.h"
2014-03-14 18:42:45 +04:00
static const struct snd_pcm_hardware edma_pcm_hardware = {
. info = SNDRV_PCM_INFO_MMAP |
SNDRV_PCM_INFO_MMAP_VALID |
SNDRV_PCM_INFO_PAUSE | SNDRV_PCM_INFO_RESUME |
2014-07-16 16:12:02 +04:00
SNDRV_PCM_INFO_NO_PERIOD_WAKEUP |
2014-03-14 18:42:45 +04:00
SNDRV_PCM_INFO_INTERLEAVED ,
. buffer_bytes_max = 128 * 1024 ,
. period_bytes_min = 32 ,
. period_bytes_max = 64 * 1024 ,
. periods_min = 2 ,
. periods_max = 19 , /* Limit by edma dmaengine driver */
} ;
static const struct snd_dmaengine_pcm_config edma_dmaengine_pcm_config = {
. pcm_hardware = & edma_pcm_hardware ,
. prepare_slave_config = snd_dmaengine_pcm_prepare_slave_config ,
. prealloc_buffer_size = 128 * 1024 ,
} ;
int edma_pcm_platform_register ( struct device * dev )
{
2019-08-30 13:38:40 +03:00
struct snd_dmaengine_pcm_config * config ;
if ( dev - > of_node )
return devm_snd_dmaengine_pcm_register ( dev ,
& edma_dmaengine_pcm_config , 0 ) ;
config = devm_kzalloc ( dev , sizeof ( * config ) , GFP_KERNEL ) ;
if ( ! config )
return - ENOMEM ;
* config = edma_dmaengine_pcm_config ;
config - > chan_names [ 0 ] = " tx " ;
config - > chan_names [ 1 ] = " rx " ;
return devm_snd_dmaengine_pcm_register ( dev , config , 0 ) ;
2014-03-14 18:42:45 +04:00
}
EXPORT_SYMBOL_GPL ( edma_pcm_platform_register ) ;
MODULE_AUTHOR ( " Peter Ujfalusi <peter.ujfalusi@ti.com> " ) ;
MODULE_DESCRIPTION ( " eDMA PCM ASoC platform driver " ) ;
MODULE_LICENSE ( " GPL " ) ;