2010-12-08 03:26:56 +03:00
/*
* OMAP15xx specific gpio init
*
* Copyright ( C ) 2010 Texas Instruments Incorporated - http : //www.ti.com/
*
* Author :
* Charulatha V < charu @ ti . com >
*
* 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 version 2.
*
* This program is distributed " as is " WITHOUT ANY WARRANTY of any
* kind , whether express or implied ; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*/
# include <linux/gpio.h>
# define OMAP1_MPUIO_VBASE OMAP1_MPUIO_BASE
# define OMAP1510_GPIO_BASE 0xFFFCE000
/* gpio1 */
static struct __initdata resource omap15xx_mpu_gpio_resources [ ] = {
{
. start = OMAP1_MPUIO_VBASE ,
. end = OMAP1_MPUIO_VBASE + SZ_2K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = INT_MPUIO ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
2011-04-21 03:31:23 +04:00
static struct omap_gpio_reg_offs omap15xx_mpuio_regs = {
2011-04-23 01:37:16 +04:00
. revision = USHRT_MAX ,
2011-04-21 03:31:23 +04:00
. direction = OMAP_MPUIO_IO_CNTL ,
. datain = OMAP_MPUIO_INPUT_LATCH ,
. dataout = OMAP_MPUIO_OUTPUT ,
2011-04-21 20:17:35 +04:00
. irqstatus = OMAP_MPUIO_GPIO_INT ,
2011-04-21 20:53:06 +04:00
. irqenable = OMAP_MPUIO_GPIO_MASKIT ,
. irqenable_inv = true ,
2011-09-13 13:32:14 +04:00
. irqctrl = OMAP_MPUIO_GPIO_INT_EDGE ,
2011-04-21 03:31:23 +04:00
} ;
2010-12-08 03:26:56 +03:00
static struct __initdata omap_gpio_platform_data omap15xx_mpu_gpio_config = {
. virtual_irq_start = IH_MPUIO_BASE ,
2011-08-30 22:32:21 +04:00
. is_mpuio = true ,
2010-12-08 03:26:56 +03:00
. bank_width = 16 ,
2010-12-08 03:26:58 +03:00
. bank_stride = 1 ,
2011-04-21 03:31:23 +04:00
. regs = & omap15xx_mpuio_regs ,
2010-12-08 03:26:56 +03:00
} ;
2011-07-04 14:56:15 +04:00
static struct platform_device omap15xx_mpu_gpio = {
2010-12-08 03:26:56 +03:00
. name = " omap_gpio " ,
. id = 0 ,
. dev = {
. platform_data = & omap15xx_mpu_gpio_config ,
} ,
. num_resources = ARRAY_SIZE ( omap15xx_mpu_gpio_resources ) ,
. resource = omap15xx_mpu_gpio_resources ,
} ;
/* gpio2 */
static struct __initdata resource omap15xx_gpio_resources [ ] = {
{
. start = OMAP1510_GPIO_BASE ,
. end = OMAP1510_GPIO_BASE + SZ_2K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = INT_GPIO_BANK1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
2011-04-21 03:31:23 +04:00
static struct omap_gpio_reg_offs omap15xx_gpio_regs = {
2011-04-23 01:37:16 +04:00
. revision = USHRT_MAX ,
2011-04-21 03:31:23 +04:00
. direction = OMAP1510_GPIO_DIR_CONTROL ,
. datain = OMAP1510_GPIO_DATA_INPUT ,
. dataout = OMAP1510_GPIO_DATA_OUTPUT ,
2011-04-21 20:17:35 +04:00
. irqstatus = OMAP1510_GPIO_INT_STATUS ,
2011-04-21 20:53:06 +04:00
. irqenable = OMAP1510_GPIO_INT_MASK ,
. irqenable_inv = true ,
2011-09-13 13:32:14 +04:00
. irqctrl = OMAP1510_GPIO_INT_CONTROL ,
2011-05-25 09:53:50 +04:00
. pinctrl = OMAP1510_GPIO_PIN_CONTROL ,
2011-04-21 03:31:23 +04:00
} ;
2010-12-08 03:26:56 +03:00
static struct __initdata omap_gpio_platform_data omap15xx_gpio_config = {
. virtual_irq_start = IH_GPIO_BASE ,
. bank_width = 16 ,
2011-04-21 03:31:23 +04:00
. regs = & omap15xx_gpio_regs ,
2010-12-08 03:26:56 +03:00
} ;
2011-07-04 14:56:15 +04:00
static struct platform_device omap15xx_gpio = {
2010-12-08 03:26:56 +03:00
. name = " omap_gpio " ,
. id = 1 ,
. dev = {
. platform_data = & omap15xx_gpio_config ,
} ,
. num_resources = ARRAY_SIZE ( omap15xx_gpio_resources ) ,
. resource = omap15xx_gpio_resources ,
} ;
/*
* omap15xx_gpio_init needs to be done before
* machine_init functions access gpio APIs .
* Hence omap15xx_gpio_init is a postcore_initcall .
*/
static int __init omap15xx_gpio_init ( void )
{
if ( ! cpu_is_omap15xx ( ) )
return - EINVAL ;
platform_device_register ( & omap15xx_mpu_gpio ) ;
platform_device_register ( & omap15xx_gpio ) ;
return 0 ;
}
postcore_initcall ( omap15xx_gpio_init ) ;