2011-02-14 16:22:36 +09:00
/* linux/arch/arm/mach-exynos4/dev-audio.c
*
* Copyright ( c ) 2011 Samsung Electronics Co . , Ltd .
* http : //www.samsung.com
2010-11-19 08:49:44 +09:00
*
* Copyright ( c ) 2010 Samsung Electronics Co . Ltd
* Jaswinder Singh < jassi . brar @ samsung . com >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# include <linux/platform_device.h>
# include <linux/dma-mapping.h>
# include <linux/gpio.h>
2012-11-07 08:11:30 +09:00
# include <linux/platform_data/asoc-s3c.h>
2010-11-19 08:49:44 +09:00
# include <plat/gpio-cfg.h>
# include <mach/map.h>
# include <mach/dma.h>
# include <mach/irqs.h>
2011-07-21 14:12:19 +09:00
# include <mach/regs-audss.h>
2010-11-19 08:49:44 +09:00
2011-02-14 16:22:36 +09:00
static int exynos4_cfg_i2s ( struct platform_device * pdev )
2010-11-19 08:49:44 +09:00
{
/* configure GPIO for i2s port */
switch ( pdev - > id ) {
case 0 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPZ ( 0 ) , 7 , S3C_GPIO_SFN ( 2 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
case 1 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPC0 ( 0 ) , 5 , S3C_GPIO_SFN ( 2 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
case 2 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPC1 ( 0 ) , 5 , S3C_GPIO_SFN ( 4 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
default :
printk ( KERN_ERR " Invalid Device %d \n " , pdev - > id ) ;
return - EINVAL ;
}
return 0 ;
}
static struct s3c_audio_pdata i2sv5_pdata = {
2011-02-14 16:22:36 +09:00
. cfg_gpio = exynos4_cfg_i2s ,
2010-11-19 08:49:44 +09:00
. type = {
. i2s = {
. quirks = QUIRK_PRI_6CHAN | QUIRK_SEC_DAI
| QUIRK_NEED_RSTCLR ,
2011-07-21 14:12:19 +09:00
. idma_addr = EXYNOS4_AUDSS_INT_MEM ,
2010-11-19 08:49:44 +09:00
} ,
} ,
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_i2s0_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_I2S0 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_I2S0_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_I2S0_RX ) ,
[ 3 ] = DEFINE_RES_DMA ( DMACH_I2S0S_TX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_i2s0 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-i2s " ,
. id = 0 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_i2s0_resource ) ,
. resource = exynos4_i2s0_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & i2sv5_pdata ,
} ,
} ;
static struct s3c_audio_pdata i2sv3_pdata = {
2011-02-14 16:22:36 +09:00
. cfg_gpio = exynos4_cfg_i2s ,
2010-11-19 08:49:44 +09:00
. type = {
. i2s = {
. quirks = QUIRK_NO_MUXPSR ,
} ,
} ,
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_i2s1_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_I2S1 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_I2S1_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_I2S1_RX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_i2s1 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-i2s " ,
. id = 1 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_i2s1_resource ) ,
. resource = exynos4_i2s1_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & i2sv3_pdata ,
} ,
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_i2s2_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_I2S2 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_I2S2_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_I2S2_RX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_i2s2 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-i2s " ,
. id = 2 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_i2s2_resource ) ,
. resource = exynos4_i2s2_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & i2sv3_pdata ,
} ,
} ;
/* PCM Controller platform_devices */
2011-02-14 16:22:36 +09:00
static int exynos4_pcm_cfg_gpio ( struct platform_device * pdev )
2010-11-19 08:49:44 +09:00
{
switch ( pdev - > id ) {
case 0 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPZ ( 0 ) , 5 , S3C_GPIO_SFN ( 3 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
case 1 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPC0 ( 0 ) , 5 , S3C_GPIO_SFN ( 3 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
case 2 :
2011-02-14 16:22:36 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPC1 ( 0 ) , 5 , S3C_GPIO_SFN ( 3 ) ) ;
2010-11-19 08:49:44 +09:00
break ;
default :
printk ( KERN_DEBUG " Invalid PCM Controller number! " ) ;
return - EINVAL ;
}
return 0 ;
}
static struct s3c_audio_pdata s3c_pcm_pdata = {
2011-02-14 16:22:36 +09:00
. cfg_gpio = exynos4_pcm_cfg_gpio ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_pcm0_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_PCM0 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_PCM0_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_PCM0_RX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_pcm0 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-pcm " ,
. id = 0 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_pcm0_resource ) ,
. resource = exynos4_pcm0_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & s3c_pcm_pdata ,
} ,
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_pcm1_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_PCM1 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_PCM1_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_PCM1_RX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_pcm1 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-pcm " ,
. id = 1 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_pcm1_resource ) ,
. resource = exynos4_pcm1_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & s3c_pcm_pdata ,
} ,
} ;
2011-02-14 16:22:36 +09:00
static struct resource exynos4_pcm2_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_PCM2 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_PCM2_TX ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_PCM2_RX ) ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_pcm2 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-pcm " ,
. id = 2 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_pcm2_resource ) ,
. resource = exynos4_pcm2_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & s3c_pcm_pdata ,
} ,
} ;
/* AC97 Controller platform devices */
2011-02-14 16:22:36 +09:00
static int exynos4_ac97_cfg_gpio ( struct platform_device * pdev )
2010-11-19 08:49:44 +09:00
{
2011-02-14 16:22:36 +09:00
return s3c_gpio_cfgpin_range ( EXYNOS4_GPC0 ( 0 ) , 5 , S3C_GPIO_SFN ( 4 ) ) ;
2010-11-19 08:49:44 +09:00
}
2011-02-14 16:22:36 +09:00
static struct resource exynos4_ac97_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_AC97 , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_AC97_PCMOUT ) ,
[ 2 ] = DEFINE_RES_DMA ( DMACH_AC97_PCMIN ) ,
[ 3 ] = DEFINE_RES_DMA ( DMACH_AC97_MICIN ) ,
[ 4 ] = DEFINE_RES_IRQ ( EXYNOS4_IRQ_AC97 ) ,
2010-11-19 08:49:44 +09:00
} ;
static struct s3c_audio_pdata s3c_ac97_pdata = {
2011-02-14 16:22:36 +09:00
. cfg_gpio = exynos4_ac97_cfg_gpio ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
static u64 exynos4_ac97_dmamask = DMA_BIT_MASK ( 32 ) ;
2010-11-19 08:49:44 +09:00
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_ac97 = {
2010-11-19 08:49:44 +09:00
. name = " samsung-ac97 " ,
. id = - 1 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_ac97_resource ) ,
. resource = exynos4_ac97_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & s3c_ac97_pdata ,
2011-02-14 16:22:36 +09:00
. dma_mask = & exynos4_ac97_dmamask ,
2010-11-19 08:49:44 +09:00
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
} ;
/* S/PDIF Controller platform_device */
2011-02-14 16:22:36 +09:00
static int exynos4_spdif_cfg_gpio ( struct platform_device * pdev )
2010-11-19 08:49:44 +09:00
{
2011-06-16 19:33:29 +09:00
s3c_gpio_cfgpin_range ( EXYNOS4_GPC1 ( 0 ) , 2 , S3C_GPIO_SFN ( 4 ) ) ;
2010-11-19 08:49:44 +09:00
return 0 ;
}
2011-02-14 16:22:36 +09:00
static struct resource exynos4_spdif_resource [ ] = {
2012-05-12 16:12:20 +09:00
[ 0 ] = DEFINE_RES_MEM ( EXYNOS4_PA_SPDIF , SZ_256 ) ,
[ 1 ] = DEFINE_RES_DMA ( DMACH_SPDIF ) ,
2010-11-19 08:49:44 +09:00
} ;
static struct s3c_audio_pdata samsung_spdif_pdata = {
2011-02-14 16:22:36 +09:00
. cfg_gpio = exynos4_spdif_cfg_gpio ,
2010-11-19 08:49:44 +09:00
} ;
2011-02-14 16:22:36 +09:00
static u64 exynos4_spdif_dmamask = DMA_BIT_MASK ( 32 ) ;
2010-11-19 08:49:44 +09:00
2011-02-14 16:22:36 +09:00
struct platform_device exynos4_device_spdif = {
2010-11-19 08:49:44 +09:00
. name = " samsung-spdif " ,
. id = - 1 ,
2011-02-14 16:22:36 +09:00
. num_resources = ARRAY_SIZE ( exynos4_spdif_resource ) ,
. resource = exynos4_spdif_resource ,
2010-11-19 08:49:44 +09:00
. dev = {
. platform_data = & samsung_spdif_pdata ,
2011-02-14 16:22:36 +09:00
. dma_mask = & exynos4_spdif_dmamask ,
2010-11-19 08:49:44 +09:00
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
} ;