2007-12-19 17:14:02 +08:00
# include <linux/module.h>
# include <linux/kernel.h>
# include <linux/init.h>
# include <linux/platform_device.h>
# include <linux/dma-mapping.h>
2010-11-22 17:12:15 -08:00
# include <linux/spi/pxa2xx_spi.h>
2011-02-23 12:38:16 +01:00
# include <linux/i2c/pxa-i2c.h>
2007-12-19 17:14:02 +08:00
2015-01-30 10:45:33 +01:00
# include "udc.h"
2012-08-24 15:16:48 +02:00
# include <linux/platform_data/usb-pxa3xx-ulpi.h>
# include <linux/platform_data/video-pxafb.h>
# include <linux/platform_data/mmc-pxamci.h>
# include <linux/platform_data/irda-pxaficp.h>
2012-01-03 16:53:48 -06:00
# include <mach/irqs.h>
2012-08-24 15:16:48 +02:00
# include <linux/platform_data/usb-ohci-pxa27x.h>
# include <linux/platform_data/keypad-pxa27x.h>
2015-11-17 07:11:13 -02:00
# include <linux/platform_data/media/camera-pxa.h>
2008-08-05 16:14:15 +01:00
# include <mach/audio.h>
2009-12-16 21:35:52 +08:00
# include <mach/hardware.h>
2015-02-14 23:38:39 +01:00
# include <linux/platform_data/mmp_dma.h>
2012-08-24 15:16:48 +02:00
# include <linux/platform_data/mtd-nand-pxa3xx.h>
2007-12-19 17:14:02 +08:00
# include "devices.h"
2008-06-02 18:49:27 +01:00
# include "generic.h"
2007-12-19 17:14:02 +08:00
void __init pxa_register_device ( struct platform_device * dev , void * data )
{
int ret ;
dev - > dev . platform_data = data ;
ret = platform_device_register ( dev ) ;
if ( ret )
dev_err ( & dev - > dev , " unable to register device: %d \n " , ret ) ;
}
2010-06-14 00:43:00 +08:00
static struct resource pxa_resource_pmu = {
. start = IRQ_PMU ,
. end = IRQ_PMU ,
. flags = IORESOURCE_IRQ ,
} ;
struct platform_device pxa_device_pmu = {
2014-05-23 12:27:37 +01:00
. name = " xscale-pmu " ,
2012-07-19 09:50:21 +01:00
. id = - 1 ,
2010-06-14 00:43:00 +08:00
. resource = & pxa_resource_pmu ,
. num_resources = 1 ,
} ;
2007-12-19 17:14:02 +08:00
static struct resource pxamci_resources [ ] = {
[ 0 ] = {
. start = 0x41100000 ,
. end = 0x41100fff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_MMC ,
. end = IRQ_MMC ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
. start = 21 ,
. end = 21 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
. start = 22 ,
. end = 22 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
static u64 pxamci_dmamask = 0xffffffffUL ;
struct platform_device pxa_device_mci = {
. name = " pxa2xx-mci " ,
2007-12-21 19:00:13 +08:00
. id = 0 ,
2007-12-19 17:14:02 +08:00
. dev = {
. dma_mask = & pxamci_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxamci_resources ) ,
. resource = pxamci_resources ,
} ;
void __init pxa_set_mci_info ( struct pxamci_platform_data * info )
{
pxa_register_device ( & pxa_device_mci , info ) ;
}
2009-05-26 22:03:32 +02:00
static struct pxa2xx_udc_mach_info pxa_udc_info = {
. gpio_pullup = - 1 ,
} ;
2007-12-19 17:14:02 +08:00
void __init pxa_set_udc_info ( struct pxa2xx_udc_mach_info * info )
{
memcpy ( & pxa_udc_info , info , sizeof * info ) ;
}
static struct resource pxa2xx_udc_resources [ ] = {
[ 0 ] = {
. start = 0x40600000 ,
. end = 0x4060ffff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_USB ,
. end = IRQ_USB ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static u64 udc_dma_mask = ~ ( u32 ) 0 ;
2008-06-22 23:36:39 +01:00
struct platform_device pxa25x_device_udc = {
. name = " pxa25x-udc " ,
. id = - 1 ,
. resource = pxa2xx_udc_resources ,
. num_resources = ARRAY_SIZE ( pxa2xx_udc_resources ) ,
. dev = {
. platform_data = & pxa_udc_info ,
. dma_mask = & udc_dma_mask ,
}
} ;
struct platform_device pxa27x_device_udc = {
. name = " pxa27x-udc " ,
2007-12-19 17:14:02 +08:00
. id = - 1 ,
. resource = pxa2xx_udc_resources ,
. num_resources = ARRAY_SIZE ( pxa2xx_udc_resources ) ,
. dev = {
. platform_data = & pxa_udc_info ,
. dma_mask = & udc_dma_mask ,
}
} ;
2010-07-27 15:06:58 +03:00
# ifdef CONFIG_PXA3xx
static struct resource pxa3xx_u2d_resources [ ] = {
[ 0 ] = {
. start = 0x54100000 ,
. end = 0x54100fff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_USB2 ,
. end = IRQ_USB2 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa3xx_device_u2d = {
. name = " pxa3xx-u2d " ,
. id = - 1 ,
. resource = pxa3xx_u2d_resources ,
. num_resources = ARRAY_SIZE ( pxa3xx_u2d_resources ) ,
} ;
void __init pxa3xx_set_u2d_info ( struct pxa3xx_u2d_platform_data * info )
{
pxa_register_device ( & pxa3xx_device_u2d , info ) ;
}
# endif /* CONFIG_PXA3xx */
2007-12-19 17:14:02 +08:00
static struct resource pxafb_resources [ ] = {
[ 0 ] = {
. start = 0x44000000 ,
. end = 0x4400ffff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_LCD ,
. end = IRQ_LCD ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static u64 fb_dma_mask = ~ ( u64 ) 0 ;
struct platform_device pxa_device_fb = {
. name = " pxa2xx-fb " ,
. id = - 1 ,
. dev = {
. dma_mask = & fb_dma_mask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxafb_resources ) ,
. resource = pxafb_resources ,
} ;
2011-02-15 15:37:30 +08:00
void __init pxa_set_fb_info ( struct device * parent , struct pxafb_mach_info * info )
2007-12-19 17:14:02 +08:00
{
2011-02-15 15:37:30 +08:00
pxa_device_fb . dev . parent = parent ;
2007-12-19 17:14:02 +08:00
pxa_register_device ( & pxa_device_fb , info ) ;
}
static struct resource pxa_resource_ffuart [ ] = {
{
2008-11-28 14:08:53 +08:00
. start = 0x40100000 ,
. end = 0x40100023 ,
2007-12-19 17:14:02 +08:00
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_FFUART ,
. end = IRQ_FFUART ,
. flags = IORESOURCE_IRQ ,
}
} ;
2009-11-09 13:34:08 +08:00
struct platform_device pxa_device_ffuart = {
2007-12-19 17:14:02 +08:00
. name = " pxa2xx-uart " ,
. id = 0 ,
. resource = pxa_resource_ffuart ,
. num_resources = ARRAY_SIZE ( pxa_resource_ffuart ) ,
} ;
2009-11-09 13:34:08 +08:00
void __init pxa_set_ffuart_info ( void * info )
{
pxa_register_device ( & pxa_device_ffuart , info ) ;
}
2007-12-19 17:14:02 +08:00
static struct resource pxa_resource_btuart [ ] = {
{
2008-11-28 14:08:53 +08:00
. start = 0x40200000 ,
. end = 0x40200023 ,
2007-12-19 17:14:02 +08:00
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_BTUART ,
. end = IRQ_BTUART ,
. flags = IORESOURCE_IRQ ,
}
} ;
struct platform_device pxa_device_btuart = {
. name = " pxa2xx-uart " ,
. id = 1 ,
. resource = pxa_resource_btuart ,
. num_resources = ARRAY_SIZE ( pxa_resource_btuart ) ,
} ;
2009-11-09 13:34:08 +08:00
void __init pxa_set_btuart_info ( void * info )
{
pxa_register_device ( & pxa_device_btuart , info ) ;
}
2007-12-19 17:14:02 +08:00
static struct resource pxa_resource_stuart [ ] = {
{
2008-11-28 14:08:53 +08:00
. start = 0x40700000 ,
. end = 0x40700023 ,
2007-12-19 17:14:02 +08:00
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_STUART ,
. end = IRQ_STUART ,
. flags = IORESOURCE_IRQ ,
}
} ;
struct platform_device pxa_device_stuart = {
. name = " pxa2xx-uart " ,
. id = 2 ,
. resource = pxa_resource_stuart ,
. num_resources = ARRAY_SIZE ( pxa_resource_stuart ) ,
} ;
2009-11-09 13:34:08 +08:00
void __init pxa_set_stuart_info ( void * info )
{
pxa_register_device ( & pxa_device_stuart , info ) ;
}
2007-12-19 17:14:02 +08:00
static struct resource pxa_resource_hwuart [ ] = {
{
2008-11-28 14:08:53 +08:00
. start = 0x41600000 ,
. end = 0x4160002F ,
2007-12-19 17:14:02 +08:00
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_HWUART ,
. end = IRQ_HWUART ,
. flags = IORESOURCE_IRQ ,
}
} ;
struct platform_device pxa_device_hwuart = {
. name = " pxa2xx-uart " ,
. id = 3 ,
. resource = pxa_resource_hwuart ,
. num_resources = ARRAY_SIZE ( pxa_resource_hwuart ) ,
} ;
2009-11-09 13:34:08 +08:00
void __init pxa_set_hwuart_info ( void * info )
{
if ( cpu_is_pxa255 ( ) )
pxa_register_device ( & pxa_device_hwuart , info ) ;
else
pr_info ( " UART: Ignoring attempt to register HWUART on non-PXA255 hardware " ) ;
}
2007-12-19 17:14:02 +08:00
static struct resource pxai2c_resources [ ] = {
{
. start = 0x40301680 ,
. end = 0x403016a3 ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_I2C ,
. end = IRQ_I2C ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa_device_i2c = {
. name = " pxa2xx-i2c " ,
. id = 0 ,
. resource = pxai2c_resources ,
. num_resources = ARRAY_SIZE ( pxai2c_resources ) ,
} ;
void __init pxa_set_i2c_info ( struct i2c_pxa_platform_data * info )
{
pxa_register_device ( & pxa_device_i2c , info ) ;
}
2008-11-28 15:01:55 +08:00
# ifdef CONFIG_PXA27x
static struct resource pxa27x_resources_i2c_power [ ] = {
{
. start = 0x40f00180 ,
. end = 0x40f001a3 ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_PWRI2C ,
. end = IRQ_PWRI2C ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa27x_device_i2c_power = {
. name = " pxa2xx-i2c " ,
. id = 1 ,
. resource = pxa27x_resources_i2c_power ,
. num_resources = ARRAY_SIZE ( pxa27x_resources_i2c_power ) ,
} ;
# endif
2007-12-19 17:14:02 +08:00
static struct resource pxai2s_resources [ ] = {
{
. start = 0x40400000 ,
. end = 0x40400083 ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_I2S ,
. end = IRQ_I2S ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa_device_i2s = {
. name = " pxa2xx-i2s " ,
. id = - 1 ,
. resource = pxai2s_resources ,
. num_resources = ARRAY_SIZE ( pxai2s_resources ) ,
} ;
2010-03-17 20:15:21 +00:00
struct platform_device pxa_device_asoc_ssp1 = {
. name = " pxa-ssp-dai " ,
. id = 0 ,
} ;
struct platform_device pxa_device_asoc_ssp2 = {
. name = " pxa-ssp-dai " ,
. id = 1 ,
} ;
struct platform_device pxa_device_asoc_ssp3 = {
. name = " pxa-ssp-dai " ,
. id = 2 ,
} ;
struct platform_device pxa_device_asoc_ssp4 = {
. name = " pxa-ssp-dai " ,
. id = 3 ,
} ;
struct platform_device pxa_device_asoc_platform = {
. name = " pxa-pcm-audio " ,
. id = - 1 ,
} ;
2007-12-19 17:14:02 +08:00
static u64 pxaficp_dmamask = ~ ( u32 ) 0 ;
2012-08-29 10:31:14 -05:00
static struct resource pxa_ir_resources [ ] = {
[ 0 ] = {
. start = IRQ_STUART ,
. end = IRQ_STUART ,
. flags = IORESOURCE_IRQ ,
} ,
[ 1 ] = {
. start = IRQ_ICP ,
. end = IRQ_ICP ,
. flags = IORESOURCE_IRQ ,
} ,
2015-09-12 13:36:49 +02:00
[ 3 ] = {
. start = 0x40800000 ,
. end = 0x4080001b ,
. flags = IORESOURCE_MEM ,
} ,
[ 4 ] = {
. start = 0x40700000 ,
. end = 0x40700023 ,
. flags = IORESOURCE_MEM ,
} ,
[ 5 ] = {
. start = 17 ,
. end = 17 ,
. flags = IORESOURCE_DMA ,
} ,
[ 6 ] = {
. start = 18 ,
. end = 18 ,
. flags = IORESOURCE_DMA ,
} ,
2012-08-29 10:31:14 -05:00
} ;
2007-12-19 17:14:02 +08:00
struct platform_device pxa_device_ficp = {
. name = " pxa2xx-ir " ,
. id = - 1 ,
2012-08-29 10:31:14 -05:00
. num_resources = ARRAY_SIZE ( pxa_ir_resources ) ,
. resource = pxa_ir_resources ,
2007-12-19 17:14:02 +08:00
. dev = {
. dma_mask = & pxaficp_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
} ;
void __init pxa_set_ficp_info ( struct pxaficp_platform_data * info )
{
pxa_register_device ( & pxa_device_ficp , info ) ;
}
2008-11-13 23:50:56 +01:00
static struct resource pxa_rtc_resources [ ] = {
[ 0 ] = {
. start = 0x40900000 ,
. end = 0x40900000 + 0x3b ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_RTC1Hz ,
. end = IRQ_RTC1Hz ,
2012-02-21 11:51:13 +08:00
. name = " rtc 1Hz " ,
2008-11-13 23:50:56 +01:00
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
. start = IRQ_RTCAlrm ,
. end = IRQ_RTCAlrm ,
2012-02-21 11:51:13 +08:00
. name = " rtc alarm " ,
2008-11-13 23:50:56 +01:00
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa_device_rtc = {
. name = " pxa-rtc " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa_rtc_resources ) ,
. resource = pxa_rtc_resources ,
} ;
2012-02-21 11:51:13 +08:00
struct platform_device sa1100_device_rtc = {
. name = " sa1100-rtc " ,
. id = - 1 ,
2015-02-02 17:50:32 -06:00
. num_resources = ARRAY_SIZE ( pxa_rtc_resources ) ,
. resource = pxa_rtc_resources ,
2012-02-21 11:51:13 +08:00
} ;
2008-06-10 12:30:05 +01:00
static struct resource pxa_ac97_resources [ ] = {
[ 0 ] = {
. start = 0x40500000 ,
. end = 0x40500000 + 0xfff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_AC97 ,
. end = IRQ_AC97 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static u64 pxa_ac97_dmamask = 0xffffffffUL ;
struct platform_device pxa_device_ac97 = {
. name = " pxa2xx-ac97 " ,
. id = - 1 ,
. dev = {
. dma_mask = & pxa_ac97_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxa_ac97_resources ) ,
. resource = pxa_ac97_resources ,
} ;
void __init pxa_set_ac97_info ( pxa2xx_audio_ops_t * ops )
{
pxa_register_device ( & pxa_device_ac97 , ops ) ;
}
2007-12-19 17:14:02 +08:00
# ifdef CONFIG_PXA25x
2008-04-13 21:44:04 +01:00
static struct resource pxa25x_resource_pwm0 [ ] = {
[ 0 ] = {
. start = 0x40b00000 ,
. end = 0x40b0000f ,
. flags = IORESOURCE_MEM ,
} ,
} ;
struct platform_device pxa25x_device_pwm0 = {
. name = " pxa25x-pwm " ,
. id = 0 ,
. resource = pxa25x_resource_pwm0 ,
. num_resources = ARRAY_SIZE ( pxa25x_resource_pwm0 ) ,
} ;
static struct resource pxa25x_resource_pwm1 [ ] = {
[ 0 ] = {
. start = 0x40c00000 ,
. end = 0x40c0000f ,
. flags = IORESOURCE_MEM ,
} ,
} ;
struct platform_device pxa25x_device_pwm1 = {
. name = " pxa25x-pwm " ,
. id = 1 ,
. resource = pxa25x_resource_pwm1 ,
. num_resources = ARRAY_SIZE ( pxa25x_resource_pwm1 ) ,
} ;
2007-12-19 17:14:02 +08:00
static u64 pxa25x_ssp_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa25x_resource_ssp [ ] = {
[ 0 ] = {
. start = 0x41000000 ,
. end = 0x4100001f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_SSP ,
. end = IRQ_SSP ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 13 ,
. end = 13 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 14 ,
. end = 14 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa25x_device_ssp = {
. name = " pxa25x-ssp " ,
. id = 0 ,
. dev = {
. dma_mask = & pxa25x_ssp_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa25x_resource_ssp ,
. num_resources = ARRAY_SIZE ( pxa25x_resource_ssp ) ,
} ;
static u64 pxa25x_nssp_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa25x_resource_nssp [ ] = {
[ 0 ] = {
. start = 0x41400000 ,
. end = 0x4140002f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_NSSP ,
. end = IRQ_NSSP ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 15 ,
. end = 15 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 16 ,
. end = 16 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa25x_device_nssp = {
. name = " pxa25x-nssp " ,
. id = 1 ,
. dev = {
. dma_mask = & pxa25x_nssp_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa25x_resource_nssp ,
. num_resources = ARRAY_SIZE ( pxa25x_resource_nssp ) ,
} ;
static u64 pxa25x_assp_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa25x_resource_assp [ ] = {
[ 0 ] = {
. start = 0x41500000 ,
. end = 0x4150002f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_ASSP ,
. end = IRQ_ASSP ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 23 ,
. end = 23 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 24 ,
. end = 24 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa25x_device_assp = {
/* ASSP is basically equivalent to NSSP */
. name = " pxa25x-nssp " ,
. id = 2 ,
. dev = {
. dma_mask = & pxa25x_assp_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa25x_resource_assp ,
. num_resources = ARRAY_SIZE ( pxa25x_resource_assp ) ,
} ;
# endif /* CONFIG_PXA25x */
# if defined(CONFIG_PXA27x) || defined(CONFIG_PXA3xx)
2010-11-24 11:54:19 +08:00
static struct resource pxa27x_resource_camera [ ] = {
2008-01-23 13:39:13 +08:00
[ 0 ] = {
2010-11-24 11:54:19 +08:00
. start = 0x50000000 ,
. end = 0x50000fff ,
2008-01-23 13:39:13 +08:00
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
2010-11-24 11:54:19 +08:00
. start = IRQ_CAMERA ,
. end = IRQ_CAMERA ,
2008-01-23 13:39:13 +08:00
. flags = IORESOURCE_IRQ ,
} ,
} ;
2010-11-24 11:54:19 +08:00
static u64 pxa27x_dma_mask_camera = DMA_BIT_MASK ( 32 ) ;
static struct platform_device pxa27x_device_camera = {
. name = " pxa27x-camera " ,
. id = 0 , /* This is used to put cameras on this interface */
. dev = {
. dma_mask = & pxa27x_dma_mask_camera ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_camera ) ,
. resource = pxa27x_resource_camera ,
2008-01-23 13:39:13 +08:00
} ;
2010-11-24 11:54:19 +08:00
void __init pxa_set_camera_info ( struct pxacamera_platform_data * info )
2008-01-23 13:39:13 +08:00
{
2010-11-24 11:54:19 +08:00
pxa_register_device ( & pxa27x_device_camera , info ) ;
2008-01-23 13:39:13 +08:00
}
2007-12-12 09:29:33 +08:00
static u64 pxa27x_ohci_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa27x_resource_ohci [ ] = {
[ 0 ] = {
. start = 0x4C000000 ,
. end = 0x4C00ff6f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_USBH1 ,
. end = IRQ_USBH1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa27x_device_ohci = {
. name = " pxa27x-ohci " ,
. id = - 1 ,
. dev = {
. dma_mask = & pxa27x_ohci_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ohci ) ,
. resource = pxa27x_resource_ohci ,
} ;
void __init pxa_set_ohci_info ( struct pxaohci_platform_data * info )
{
pxa_register_device ( & pxa27x_device_ohci , info ) ;
}
2010-11-24 11:54:19 +08:00
# endif /* CONFIG_PXA27x || CONFIG_PXA3xx */
2012-11-15 17:06:06 +08:00
# if defined(CONFIG_PXA27x) || defined(CONFIG_PXA3xx)
2010-11-24 11:54:19 +08:00
static struct resource pxa27x_resource_keypad [ ] = {
[ 0 ] = {
. start = 0x41500000 ,
. end = 0x4150004c ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_KEYPAD ,
. end = IRQ_KEYPAD ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa27x_device_keypad = {
. name = " pxa27x-keypad " ,
. id = - 1 ,
. resource = pxa27x_resource_keypad ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_keypad ) ,
} ;
void __init pxa_set_keypad_info ( struct pxa27x_keypad_platform_data * info )
{
pxa_register_device ( & pxa27x_device_keypad , info ) ;
}
2007-12-12 09:29:33 +08:00
2007-12-19 17:14:02 +08:00
static u64 pxa27x_ssp1_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa27x_resource_ssp1 [ ] = {
[ 0 ] = {
. start = 0x41000000 ,
. end = 0x4100003f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_SSP ,
. end = IRQ_SSP ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 13 ,
. end = 13 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 14 ,
. end = 14 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa27x_device_ssp1 = {
. name = " pxa27x-ssp " ,
. id = 0 ,
. dev = {
. dma_mask = & pxa27x_ssp1_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp1 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp1 ) ,
} ;
static u64 pxa27x_ssp2_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa27x_resource_ssp2 [ ] = {
[ 0 ] = {
. start = 0x41700000 ,
. end = 0x4170003f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_SSP2 ,
. end = IRQ_SSP2 ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 15 ,
. end = 15 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 16 ,
. end = 16 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa27x_device_ssp2 = {
. name = " pxa27x-ssp " ,
. id = 1 ,
. dev = {
. dma_mask = & pxa27x_ssp2_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp2 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp2 ) ,
} ;
static u64 pxa27x_ssp3_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa27x_resource_ssp3 [ ] = {
[ 0 ] = {
. start = 0x41900000 ,
. end = 0x4190003f ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_SSP3 ,
. end = IRQ_SSP3 ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for RX */
. start = 66 ,
. end = 66 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 67 ,
. end = 67 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa27x_device_ssp3 = {
. name = " pxa27x-ssp " ,
. id = 2 ,
. dev = {
. dma_mask = & pxa27x_ssp3_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp3 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp3 ) ,
} ;
2008-04-11 22:19:45 +02:00
2008-04-13 21:44:04 +01:00
static struct resource pxa27x_resource_pwm0 [ ] = {
[ 0 ] = {
. start = 0x40b00000 ,
. end = 0x40b0001f ,
. flags = IORESOURCE_MEM ,
} ,
} ;
struct platform_device pxa27x_device_pwm0 = {
. name = " pxa27x-pwm " ,
. id = 0 ,
. resource = pxa27x_resource_pwm0 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_pwm0 ) ,
} ;
static struct resource pxa27x_resource_pwm1 [ ] = {
[ 0 ] = {
. start = 0x40c00000 ,
. end = 0x40c0001f ,
. flags = IORESOURCE_MEM ,
} ,
} ;
struct platform_device pxa27x_device_pwm1 = {
. name = " pxa27x-pwm " ,
. id = 1 ,
. resource = pxa27x_resource_pwm1 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_pwm1 ) ,
} ;
2012-11-15 17:06:06 +08:00
# endif /* CONFIG_PXA27x || CONFIG_PXA3xx */
2007-12-19 17:14:02 +08:00
# ifdef CONFIG_PXA3xx
2007-12-21 19:15:36 +08:00
static struct resource pxa3xx_resources_mci2 [ ] = {
[ 0 ] = {
. start = 0x42000000 ,
. end = 0x42000fff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_MMC2 ,
. end = IRQ_MMC2 ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
. start = 93 ,
. end = 93 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
. start = 94 ,
. end = 94 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa3xx_device_mci2 = {
. name = " pxa2xx-mci " ,
. id = 1 ,
. dev = {
. dma_mask = & pxamci_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxa3xx_resources_mci2 ) ,
. resource = pxa3xx_resources_mci2 ,
} ;
void __init pxa3xx_set_mci2_info ( struct pxamci_platform_data * info )
{
pxa_register_device ( & pxa3xx_device_mci2 , info ) ;
}
2007-12-21 19:27:08 +08:00
static struct resource pxa3xx_resources_mci3 [ ] = {
[ 0 ] = {
. start = 0x42500000 ,
. end = 0x42500fff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_MMC3 ,
. end = IRQ_MMC3 ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
. start = 100 ,
. end = 100 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
. start = 101 ,
. end = 101 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
struct platform_device pxa3xx_device_mci3 = {
. name = " pxa2xx-mci " ,
. id = 2 ,
. dev = {
. dma_mask = & pxamci_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxa3xx_resources_mci3 ) ,
. resource = pxa3xx_resources_mci3 ,
} ;
void __init pxa3xx_set_mci3_info ( struct pxamci_platform_data * info )
{
pxa_register_device ( & pxa3xx_device_mci3 , info ) ;
}
2010-11-24 11:54:19 +08:00
static struct resource pxa3xx_resources_gcu [ ] = {
{
. start = 0x54000000 ,
. end = 0x54000fff ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = IRQ_GCU ,
. end = IRQ_GCU ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static u64 pxa3xx_gcu_dmamask = DMA_BIT_MASK ( 32 ) ;
struct platform_device pxa3xx_device_gcu = {
. name = " pxa3xx-gcu " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa3xx_resources_gcu ) ,
. resource = pxa3xx_resources_gcu ,
. dev = {
. dma_mask = & pxa3xx_gcu_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
} ;
# endif /* CONFIG_PXA3xx */
2012-11-15 17:06:06 +08:00
# if defined(CONFIG_PXA3xx)
2010-11-24 11:54:19 +08:00
static struct resource pxa3xx_resources_i2c_power [ ] = {
{
. start = 0x40f500c0 ,
. end = 0x40f500d3 ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_PWRI2C ,
. end = IRQ_PWRI2C ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
struct platform_device pxa3xx_device_i2c_power = {
. name = " pxa3xx-pwri2c " ,
. id = 1 ,
. resource = pxa3xx_resources_i2c_power ,
. num_resources = ARRAY_SIZE ( pxa3xx_resources_i2c_power ) ,
} ;
2008-06-02 15:22:03 +08:00
static struct resource pxa3xx_resources_nand [ ] = {
[ 0 ] = {
. start = 0x43100000 ,
. end = 0x43100053 ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_NAND ,
. end = IRQ_NAND ,
. flags = IORESOURCE_IRQ ,
} ,
[ 2 ] = {
/* DRCMR for Data DMA */
. start = 97 ,
. end = 97 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for Command DMA */
. start = 99 ,
. end = 99 ,
. flags = IORESOURCE_DMA ,
} ,
} ;
static u64 pxa3xx_nand_dma_mask = DMA_BIT_MASK ( 32 ) ;
struct platform_device pxa3xx_device_nand = {
. name = " pxa3xx-nand " ,
. id = - 1 ,
. dev = {
. dma_mask = & pxa3xx_nand_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. num_resources = ARRAY_SIZE ( pxa3xx_resources_nand ) ,
. resource = pxa3xx_resources_nand ,
} ;
void __init pxa3xx_set_nand_info ( struct pxa3xx_nand_platform_data * info )
{
pxa_register_device ( & pxa3xx_device_nand , info ) ;
}
2009-07-09 19:04:49 +02:00
2010-11-24 11:54:19 +08:00
static u64 pxa3xx_ssp4_dma_mask = DMA_BIT_MASK ( 32 ) ;
static struct resource pxa3xx_resource_ssp4 [ ] = {
[ 0 ] = {
. start = 0x41a00000 ,
. end = 0x41a0003f ,
2009-07-09 19:04:49 +02:00
. flags = IORESOURCE_MEM ,
} ,
2010-11-24 11:54:19 +08:00
[ 1 ] = {
. start = IRQ_SSP4 ,
. end = IRQ_SSP4 ,
2009-07-09 19:04:49 +02:00
. flags = IORESOURCE_IRQ ,
} ,
2010-11-24 11:54:19 +08:00
[ 2 ] = {
/* DRCMR for RX */
. start = 2 ,
. end = 2 ,
. flags = IORESOURCE_DMA ,
} ,
[ 3 ] = {
/* DRCMR for TX */
. start = 3 ,
. end = 3 ,
. flags = IORESOURCE_DMA ,
} ,
2009-07-09 19:04:49 +02:00
} ;
2014-08-13 21:59:19 +02:00
/*
* PXA3xx SSP is basically equivalent to PXA27x .
* However , we need to register the device by the correct name in order to
* make the driver set the correct internal type , hence we provide specific
* platform_devices for each of them .
*/
struct platform_device pxa3xx_device_ssp1 = {
. name = " pxa3xx-ssp " ,
. id = 0 ,
. dev = {
. dma_mask = & pxa27x_ssp1_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp1 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp1 ) ,
} ;
struct platform_device pxa3xx_device_ssp2 = {
. name = " pxa3xx-ssp " ,
. id = 1 ,
. dev = {
. dma_mask = & pxa27x_ssp2_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp2 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp2 ) ,
} ;
struct platform_device pxa3xx_device_ssp3 = {
. name = " pxa3xx-ssp " ,
. id = 2 ,
. dev = {
. dma_mask = & pxa27x_ssp3_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = pxa27x_resource_ssp3 ,
. num_resources = ARRAY_SIZE ( pxa27x_resource_ssp3 ) ,
} ;
2010-11-24 11:54:19 +08:00
struct platform_device pxa3xx_device_ssp4 = {
2014-08-13 21:59:19 +02:00
. name = " pxa3xx-ssp " ,
2010-11-24 11:54:19 +08:00
. id = 3 ,
2009-07-09 19:04:49 +02:00
. dev = {
2010-11-24 11:54:19 +08:00
. dma_mask = & pxa3xx_ssp4_dma_mask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
2009-07-09 19:04:49 +02:00
} ,
2010-11-24 11:54:19 +08:00
. resource = pxa3xx_resource_ssp4 ,
. num_resources = ARRAY_SIZE ( pxa3xx_resource_ssp4 ) ,
2009-07-09 19:04:49 +02:00
} ;
2012-11-15 17:06:06 +08:00
# endif /* CONFIG_PXA3xx */
2008-06-13 09:17:31 +01:00
2011-10-17 20:37:52 +08:00
struct resource pxa_resource_gpio [ ] = {
{
. start = 0x40e00000 ,
. end = 0x40e0ffff ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_GPIO0 ,
. end = IRQ_GPIO0 ,
. name = " gpio0 " ,
. flags = IORESOURCE_IRQ ,
} , {
. start = IRQ_GPIO1 ,
. end = IRQ_GPIO1 ,
. name = " gpio1 " ,
. flags = IORESOURCE_IRQ ,
} , {
. start = IRQ_GPIO_2_x ,
. end = IRQ_GPIO_2_x ,
. name = " gpio_mux " ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
2013-04-07 16:44:33 +08:00
struct platform_device pxa25x_device_gpio = {
# ifdef CONFIG_CPU_PXA26x
. name = " pxa26x-gpio " ,
# else
. name = " pxa25x-gpio " ,
# endif
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa_resource_gpio ) ,
. resource = pxa_resource_gpio ,
} ;
struct platform_device pxa27x_device_gpio = {
. name = " pxa27x-gpio " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa_resource_gpio ) ,
. resource = pxa_resource_gpio ,
} ;
struct platform_device pxa3xx_device_gpio = {
. name = " pxa3xx-gpio " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa_resource_gpio ) ,
. resource = pxa_resource_gpio ,
} ;
struct platform_device pxa93x_device_gpio = {
. name = " pxa93x-gpio " ,
2011-10-17 20:37:52 +08:00
. id = - 1 ,
. num_resources = ARRAY_SIZE ( pxa_resource_gpio ) ,
. resource = pxa_resource_gpio ,
} ;
2008-06-13 09:17:31 +01:00
/* pxa2xx-spi platform-device ID equals respective SSP platform-device ID + 1.
* See comment in arch / arm / mach - pxa / ssp . c : : ssp_probe ( ) */
void __init pxa2xx_set_spi_info ( unsigned id , struct pxa2xx_spi_master * info )
{
struct platform_device * pd ;
pd = platform_device_alloc ( " pxa2xx-spi " , id ) ;
if ( pd = = NULL ) {
printk ( KERN_ERR " pxa2xx-spi: failed to allocate device id %d \n " ,
id ) ;
return ;
}
pd - > dev . platform_data = info ;
platform_device_add ( pd ) ;
}
2015-02-14 23:38:39 +01:00
static struct mmp_dma_platdata pxa_dma_pdata = {
. dma_channels = 0 ,
2016-02-15 21:57:47 +01:00
. nb_requestors = 0 ,
2015-02-14 23:38:39 +01:00
} ;
static struct resource pxa_dma_resource [ ] = {
[ 0 ] = {
. start = 0x40000000 ,
. end = 0x4000ffff ,
. flags = IORESOURCE_MEM ,
} ,
[ 1 ] = {
. start = IRQ_DMA ,
. end = IRQ_DMA ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static u64 pxadma_dmamask = 0xffffffffUL ;
static struct platform_device pxa2xx_pxa_dma = {
. name = " pxa-dma " ,
. id = 0 ,
. dev = {
. dma_mask = & pxadma_dmamask ,
. coherent_dma_mask = 0xffffffff ,
} ,
. num_resources = ARRAY_SIZE ( pxa_dma_resource ) ,
. resource = pxa_dma_resource ,
} ;
2016-02-15 21:57:47 +01:00
void __init pxa2xx_set_dmac_info ( int nb_channels , int nb_requestors )
2015-02-14 23:38:39 +01:00
{
pxa_dma_pdata . dma_channels = nb_channels ;
2016-03-09 00:46:11 +01:00
pxa_dma_pdata . nb_requestors = nb_requestors ;
2015-02-14 23:38:39 +01:00
pxa_register_device ( & pxa2xx_pxa_dma , & pxa_dma_pdata ) ;
}