2010-12-07 16:26:56 -08: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>
2012-08-30 15:37:24 -07:00
# include <linux/platform_data/gpio-omap.h>
2010-12-07 16:26:56 -08:00
2012-10-31 09:54:56 -07:00
# include <mach/irqs.h>
2010-12-07 16:26:56 -08:00
# define OMAP1_MPUIO_VBASE OMAP1_MPUIO_BASE
# define OMAP1510_GPIO_BASE 0xFFFCE000
/* gpio1 */
2013-10-18 08:54:16 -07:00
static struct resource omap15xx_mpu_gpio_resources [ ] = {
2010-12-07 16:26:56 -08:00
{
. start = OMAP1_MPUIO_VBASE ,
. end = OMAP1_MPUIO_VBASE + SZ_2K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = INT_MPUIO ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
2011-04-20 16:31:23 -07:00
static struct omap_gpio_reg_offs omap15xx_mpuio_regs = {
2011-04-22 14:37:16 -07:00
. revision = USHRT_MAX ,
2011-04-20 16:31:23 -07:00
. direction = OMAP_MPUIO_IO_CNTL ,
. datain = OMAP_MPUIO_INPUT_LATCH ,
. dataout = OMAP_MPUIO_OUTPUT ,
2011-04-21 09:17:35 -07:00
. irqstatus = OMAP_MPUIO_GPIO_INT ,
2011-04-21 09:53:06 -07:00
. irqenable = OMAP_MPUIO_GPIO_MASKIT ,
. irqenable_inv = true ,
2011-09-13 15:02:14 +05:30
. irqctrl = OMAP_MPUIO_GPIO_INT_EDGE ,
2011-04-20 16:31:23 -07:00
} ;
2013-10-18 08:54:16 -07:00
static struct omap_gpio_platform_data omap15xx_mpu_gpio_config = {
2011-08-31 00:02:21 +05:30
. is_mpuio = true ,
2010-12-07 16:26:56 -08:00
. bank_width = 16 ,
2010-12-07 16:26:58 -08:00
. bank_stride = 1 ,
2011-04-20 16:31:23 -07:00
. regs = & omap15xx_mpuio_regs ,
2010-12-07 16:26:56 -08:00
} ;
2011-07-04 03:56:15 -07:00
static struct platform_device omap15xx_mpu_gpio = {
2010-12-07 16:26:56 -08: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 */
2013-10-18 08:54:16 -07:00
static struct resource omap15xx_gpio_resources [ ] = {
2010-12-07 16:26:56 -08:00
{
. start = OMAP1510_GPIO_BASE ,
. end = OMAP1510_GPIO_BASE + SZ_2K - 1 ,
. flags = IORESOURCE_MEM ,
} ,
{
. start = INT_GPIO_BANK1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
2011-04-20 16:31:23 -07:00
static struct omap_gpio_reg_offs omap15xx_gpio_regs = {
2011-04-22 14:37:16 -07:00
. revision = USHRT_MAX ,
2011-04-20 16:31:23 -07:00
. direction = OMAP1510_GPIO_DIR_CONTROL ,
. datain = OMAP1510_GPIO_DATA_INPUT ,
. dataout = OMAP1510_GPIO_DATA_OUTPUT ,
2011-04-21 09:17:35 -07:00
. irqstatus = OMAP1510_GPIO_INT_STATUS ,
2011-04-21 09:53:06 -07:00
. irqenable = OMAP1510_GPIO_INT_MASK ,
. irqenable_inv = true ,
2011-09-13 15:02:14 +05:30
. irqctrl = OMAP1510_GPIO_INT_CONTROL ,
2011-05-25 11:23:50 +05:30
. pinctrl = OMAP1510_GPIO_PIN_CONTROL ,
2011-04-20 16:31:23 -07:00
} ;
2013-10-18 08:54:16 -07:00
static struct omap_gpio_platform_data omap15xx_gpio_config = {
2010-12-07 16:26:56 -08:00
. bank_width = 16 ,
2011-04-20 16:31:23 -07:00
. regs = & omap15xx_gpio_regs ,
2010-12-07 16:26:56 -08:00
} ;
2011-07-04 03:56:15 -07:00
static struct platform_device omap15xx_gpio = {
2010-12-07 16:26:56 -08: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 ) ;