2009-09-01 08:45:14 +04:00
/*
* File : sound / soc / blackfin / bf5xx - ad1836 . c
* Author : Barry Song < Barry . Song @ analog . com >
*
* Created : Aug 4 2009
* Description : Board driver for ad1836 sound chip
*
* 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 .
*
*/
# 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>
# include "../codecs/ad1836.h"
# include "bf5xx-tdm-pcm.h"
# include "bf5xx-tdm.h"
static struct snd_soc_card bf5xx_ad1836 ;
static int bf5xx_ad1836_hw_params ( struct snd_pcm_substream * substream ,
struct snd_pcm_hw_params * params )
{
struct snd_soc_pcm_runtime * rtd = substream - > private_data ;
2010-03-17 23:15:21 +03:00
struct snd_soc_dai * cpu_dai = rtd - > cpu_dai ;
struct snd_soc_dai * codec_dai = rtd - > codec_dai ;
2009-09-15 07:24:52 +04:00
unsigned int channel_map [ ] = { 0 , 4 , 1 , 5 , 2 , 6 , 3 , 7 } ;
2009-09-01 08:45:14 +04:00
int ret = 0 ;
/* set cpu DAI configuration */
ret = snd_soc_dai_set_fmt ( cpu_dai , SND_SOC_DAIFMT_DSP_A |
SND_SOC_DAIFMT_IB_IF | SND_SOC_DAIFMT_CBM_CFM ) ;
if ( ret < 0 )
return ret ;
/* set codec DAI configuration */
ret = snd_soc_dai_set_fmt ( codec_dai , SND_SOC_DAIFMT_DSP_A |
SND_SOC_DAIFMT_IB_IF | SND_SOC_DAIFMT_CBM_CFM ) ;
if ( ret < 0 )
return ret ;
2009-09-15 07:24:52 +04:00
/* 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 ) ;
if ( ret < 0 )
return ret ;
2009-09-01 08:45:14 +04:00
return 0 ;
}
static struct snd_soc_ops bf5xx_ad1836_ops = {
. hw_params = bf5xx_ad1836_hw_params ,
} ;
2011-03-28 09:45:10 +04:00
static struct snd_soc_dai_link bf5xx_ad1836_dai [ ] = {
{
. name = " ad1836 " ,
. stream_name = " AD1836 " ,
. cpu_dai_name = " bfin-tdm.0 " ,
. codec_dai_name = " ad1836-hifi " ,
. platform_name = " bfin-tdm-pcm-audio " ,
2011-06-07 12:24:46 +04:00
. codec_name = " spi0.4 " ,
2011-03-28 09:45:10 +04:00
. ops = & bf5xx_ad1836_ops ,
} ,
{
. name = " ad1836 " ,
. stream_name = " AD1836 " ,
. cpu_dai_name = " bfin-tdm.1 " ,
. codec_dai_name = " ad1836-hifi " ,
. platform_name = " bfin-tdm-pcm-audio " ,
2011-06-07 12:24:46 +04:00
. codec_name = " spi0.4 " ,
2011-03-28 09:45:10 +04:00
. ops = & bf5xx_ad1836_ops ,
} ,
2009-09-01 08:45:14 +04:00
} ;
static struct snd_soc_card bf5xx_ad1836 = {
2011-03-28 09:45:09 +04:00
. name = " bfin-ad1836 " ,
2011-03-28 09:45:10 +04:00
. dai_link = & bf5xx_ad1836_dai [ CONFIG_SND_BF5XX_SPORT_NUM ] ,
2009-09-01 08:45:14 +04:00
. num_links = 1 ,
} ;
static struct platform_device * bfxx_ad1836_snd_device ;
static int __init bf5xx_ad1836_init ( void )
{
int ret ;
bfxx_ad1836_snd_device = platform_device_alloc ( " soc-audio " , - 1 ) ;
if ( ! bfxx_ad1836_snd_device )
return - ENOMEM ;
2010-03-17 23:15:21 +03:00
platform_set_drvdata ( bfxx_ad1836_snd_device , & bf5xx_ad1836 ) ;
2009-09-01 08:45:14 +04:00
ret = platform_device_add ( bfxx_ad1836_snd_device ) ;
if ( ret )
platform_device_put ( bfxx_ad1836_snd_device ) ;
return ret ;
}
static void __exit bf5xx_ad1836_exit ( void )
{
platform_device_unregister ( bfxx_ad1836_snd_device ) ;
}
module_init ( bf5xx_ad1836_init ) ;
module_exit ( bf5xx_ad1836_exit ) ;
/* Module information */
MODULE_AUTHOR ( " Barry Song " ) ;
MODULE_DESCRIPTION ( " ALSA SoC AD1836 board driver " ) ;
MODULE_LICENSE ( " GPL " ) ;