2009-07-23 02:10:34 +08:00
/*
2010-03-19 11:18:40 +08:00
* File : sound / soc / blackfin / bf5xx - ad193x . c
2009-07-23 02:10:34 +08:00
* Author : Barry Song < Barry . Song @ analog . com >
*
* Created : Thur June 4 2009
2010-03-19 11:18:40 +08:00
* Description : Board driver for ad193x sound chip
2009-07-23 02:10:34 +08:00
*
* Bugs : Enter bugs at http : //blackfin.uclinux.org/
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , see the file COPYING , or write
* to the Free Software Foundation , Inc . ,
* 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 USA
*/
# include <linux/module.h>
# include <linux/moduleparam.h>
# include <linux/device.h>
# include <sound/core.h>
# include <sound/pcm.h>
# include <sound/soc.h>
# include <sound/pcm_params.h>
# include <asm/blackfin.h>
# include <asm/cacheflush.h>
# include <asm/irq.h>
# include <asm/dma.h>
# include <asm/portmux.h>
2010-03-19 11:18:40 +08:00
# include "../codecs/ad193x.h"
2009-07-23 02:10:34 +08:00
# include "bf5xx-tdm-pcm.h"
# include "bf5xx-tdm.h"
2010-03-19 11:18:40 +08:00
static struct snd_soc_card bf5xx_ad193x ;
2009-07-23 02:10:34 +08:00
2010-03-19 11:18:40 +08:00
static int bf5xx_ad193x_hw_params ( struct snd_pcm_substream * substream ,
2009-07-23 02:10:34 +08:00
struct snd_pcm_hw_params * params )
{
struct snd_soc_pcm_runtime * rtd = substream - > private_data ;
2010-03-17 20:15:21 +00:00
struct snd_soc_dai * cpu_dai = rtd - > cpu_dai ;
struct snd_soc_dai * codec_dai = rtd - > codec_dai ;
2011-03-27 05:33:04 -04:00
unsigned int clk = 0 ;
2009-09-15 11:24:52 +08:00
unsigned int channel_map [ ] = { 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 } ;
2009-07-23 02:10:34 +08:00
int ret = 0 ;
2011-03-27 05:33:04 -04:00
switch ( params_rate ( params ) ) {
case 48000 :
2011-08-12 18:04:12 -04:00
clk = 24576000 ;
2011-03-27 05:33:04 -04:00
break ;
}
/* set the codec system clock for DAC and ADC */
ret = snd_soc_dai_set_sysclk ( codec_dai , 0 , clk ,
SND_SOC_CLOCK_IN ) ;
if ( ret < 0 )
return ret ;
2009-07-23 02:10:34 +08:00
/* set codec DAI slots, 8 channels, all channels are enabled */
2009-09-15 11:24:52 +08:00
ret = snd_soc_dai_set_tdm_slot ( codec_dai , 0xFF , 0xFF , 8 , 32 ) ;
if ( ret < 0 )
return ret ;
/* set cpu DAI channel mapping */
ret = snd_soc_dai_set_channel_map ( cpu_dai , ARRAY_SIZE ( channel_map ) ,
channel_map , ARRAY_SIZE ( channel_map ) , channel_map ) ;
2009-07-23 02:10:34 +08:00
if ( ret < 0 )
return ret ;
return 0 ;
}
2012-02-01 19:24:21 +01:00
# define BF5XX_AD193X_DAIFMT (SND_SOC_DAIFMT_DSP_A | SND_SOC_DAIFMT_IB_IF | \
SND_SOC_DAIFMT_CBM_CFM )
2010-03-19 11:18:40 +08:00
static struct snd_soc_ops bf5xx_ad193x_ops = {
. hw_params = bf5xx_ad193x_hw_params ,
2009-07-23 02:10:34 +08:00
} ;
2011-03-28 01:45:10 -04:00
static struct snd_soc_dai_link bf5xx_ad193x_dai [ ] = {
{
. name = " ad193x " ,
. stream_name = " AD193X " ,
. cpu_dai_name = " bfin-tdm.0 " ,
. codec_dai_name = " ad193x-hifi " ,
. platform_name = " bfin-tdm-pcm-audio " ,
2011-09-05 13:49:57 +02:00
. codec_name = " spi0.5 " ,
2011-03-28 01:45:10 -04:00
. ops = & bf5xx_ad193x_ops ,
2012-02-01 19:24:21 +01:00
. dai_fmt = BF5XX_AD193X_DAIFMT ,
2011-03-28 01:45:10 -04:00
} ,
{
. name = " ad193x " ,
. stream_name = " AD193X " ,
. cpu_dai_name = " bfin-tdm.1 " ,
. codec_dai_name = " ad193x-hifi " ,
. platform_name = " bfin-tdm-pcm-audio " ,
2011-09-05 13:49:57 +02:00
. codec_name = " spi0.5 " ,
2011-03-28 01:45:10 -04:00
. ops = & bf5xx_ad193x_ops ,
2012-02-01 19:24:21 +01:00
. dai_fmt = BF5XX_AD193X_DAIFMT ,
2011-03-28 01:45:10 -04:00
} ,
2009-07-23 02:10:34 +08:00
} ;
2010-03-19 11:18:40 +08:00
static struct snd_soc_card bf5xx_ad193x = {
2011-03-28 01:45:09 -04:00
. name = " bfin-ad193x " ,
2011-12-22 21:17:22 +08:00
. owner = THIS_MODULE ,
2011-03-28 01:45:10 -04:00
. dai_link = & bf5xx_ad193x_dai [ CONFIG_SND_BF5XX_SPORT_NUM ] ,
2009-07-23 02:10:34 +08:00
. num_links = 1 ,
} ;
2010-03-19 11:18:40 +08:00
static struct platform_device * bfxx_ad193x_snd_device ;
2009-07-23 02:10:34 +08:00
2010-03-19 11:18:40 +08:00
static int __init bf5xx_ad193x_init ( void )
2009-07-23 02:10:34 +08:00
{
int ret ;
2010-03-19 11:18:40 +08:00
bfxx_ad193x_snd_device = platform_device_alloc ( " soc-audio " , - 1 ) ;
if ( ! bfxx_ad193x_snd_device )
2009-07-23 02:10:34 +08:00
return - ENOMEM ;
2010-03-17 20:15:21 +00:00
platform_set_drvdata ( bfxx_ad193x_snd_device , & bf5xx_ad193x ) ;
2010-03-19 11:18:40 +08:00
ret = platform_device_add ( bfxx_ad193x_snd_device ) ;
2009-07-23 02:10:34 +08:00
if ( ret )
2010-03-19 11:18:40 +08:00
platform_device_put ( bfxx_ad193x_snd_device ) ;
2009-07-23 02:10:34 +08:00
return ret ;
}
2010-03-19 11:18:40 +08:00
static void __exit bf5xx_ad193x_exit ( void )
2009-07-23 02:10:34 +08:00
{
2010-03-19 11:18:40 +08:00
platform_device_unregister ( bfxx_ad193x_snd_device ) ;
2009-07-23 02:10:34 +08:00
}
2010-03-19 11:18:40 +08:00
module_init ( bf5xx_ad193x_init ) ;
module_exit ( bf5xx_ad193x_exit ) ;
2009-07-23 02:10:34 +08:00
/* Module information */
MODULE_AUTHOR ( " Barry Song " ) ;
2010-03-19 11:18:40 +08:00
MODULE_DESCRIPTION ( " ALSA SoC AD193X board driver " ) ;
2009-07-23 02:10:34 +08:00
MODULE_LICENSE ( " GPL " ) ;