2007-07-10 13:03:43 +01:00
/*
* TI DaVinci GPIO Support
*
2008-09-07 23:41:04 -07:00
* Copyright ( c ) 2006 - 2007 David Brownell
2007-07-10 13:03:43 +01:00
* Copyright ( c ) 2007 , MontaVista Software , Inc . < source @ mvista . 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 ; either version 2 of the License , or
* ( at your option ) any later version .
*/
2011-07-26 10:53:52 +01:00
# include <linux/gpio.h>
2007-07-10 13:03:43 +01:00
# include <linux/errno.h>
# include <linux/kernel.h>
# include <linux/clk.h>
# include <linux/err.h>
# include <linux/io.h>
2013-08-18 10:48:58 +05:30
# include <linux/irq.h>
2013-11-21 23:45:27 +05:30
# include <linux/irqdomain.h>
2013-11-21 23:45:29 +05:30
# include <linux/module.h>
# include <linux/of.h>
# include <linux/of_device.h>
2013-08-18 10:48:58 +05:30
# include <linux/platform_device.h>
# include <linux/platform_data/gpio-davinci.h>
2013-11-26 21:40:09 +02:00
# include <linux/irqchip/chained_irq.h>
2007-07-10 13:03:43 +01:00
2010-05-01 18:37:53 -04:00
struct davinci_gpio_regs {
u32 dir ;
u32 out_data ;
u32 set_data ;
u32 clr_data ;
u32 in_data ;
u32 set_rising ;
u32 clr_rising ;
u32 set_falling ;
u32 clr_falling ;
u32 intstat ;
} ;
2014-02-13 17:58:45 +02:00
typedef struct irq_chip * ( * gpio_get_irq_chip_cb_t ) ( unsigned int irq ) ;
2013-08-18 10:48:57 +05:30
# define BINTEN 0x8 /* GPIO Interrupt Per-Bank Enable Register */
2010-05-01 18:37:51 -04:00
# define chip2controller(chip) \
2010-05-01 18:37:52 -04:00
container_of ( chip , struct davinci_gpio_controller , chip )
2010-05-01 18:37:51 -04:00
2010-05-07 17:06:32 -04:00
static void __iomem * gpio_base ;
2007-07-10 13:03:43 +01:00
2013-08-18 10:48:58 +05:30
static struct davinci_gpio_regs __iomem * gpio2regs ( unsigned gpio )
2007-07-10 13:03:43 +01:00
{
2010-05-01 18:37:53 -04:00
void __iomem * ptr ;
if ( gpio < 32 * 1 )
2010-05-07 17:06:32 -04:00
ptr = gpio_base + 0x10 ;
2010-05-01 18:37:53 -04:00
else if ( gpio < 32 * 2 )
2010-05-07 17:06:32 -04:00
ptr = gpio_base + 0x38 ;
2010-05-01 18:37:53 -04:00
else if ( gpio < 32 * 3 )
2010-05-07 17:06:32 -04:00
ptr = gpio_base + 0x60 ;
2010-05-01 18:37:53 -04:00
else if ( gpio < 32 * 4 )
2010-05-07 17:06:32 -04:00
ptr = gpio_base + 0x88 ;
2010-05-01 18:37:53 -04:00
else if ( gpio < 32 * 5 )
2010-05-07 17:06:32 -04:00
ptr = gpio_base + 0xb0 ;
2010-05-01 18:37:53 -04:00
else
ptr = NULL ;
return ptr ;
2007-07-10 13:03:43 +01:00
}
2010-05-01 18:37:52 -04:00
static inline struct davinci_gpio_regs __iomem * irq2regs ( int irq )
2010-02-25 16:49:56 -08:00
{
2010-05-01 18:37:52 -04:00
struct davinci_gpio_regs __iomem * g ;
2010-02-25 16:49:56 -08:00
2011-03-24 13:25:22 +01:00
g = ( __force struct davinci_gpio_regs __iomem * ) irq_get_chip_data ( irq ) ;
2010-02-25 16:49:56 -08:00
return g ;
}
2013-08-18 10:48:58 +05:30
static int davinci_gpio_irq_setup ( struct platform_device * pdev ) ;
2008-09-07 23:41:04 -07:00
/*--------------------------------------------------------------------------*/
2010-05-01 18:38:27 -04:00
/* board setup code *MUST* setup pinmux and enable the GPIO clock. */
2010-05-01 18:37:51 -04:00
static inline int __davinci_direction ( struct gpio_chip * chip ,
unsigned offset , bool out , int value )
2007-07-10 13:03:43 +01:00
{
2010-05-01 18:37:52 -04:00
struct davinci_gpio_controller * d = chip2controller ( chip ) ;
struct davinci_gpio_regs __iomem * g = d - > regs ;
2010-05-01 18:37:55 -04:00
unsigned long flags ;
2008-09-07 23:41:04 -07:00
u32 temp ;
2010-05-01 18:37:51 -04:00
u32 mask = 1 < < offset ;
2007-07-10 13:03:43 +01:00
2010-05-01 18:37:55 -04:00
spin_lock_irqsave ( & d - > lock , flags ) ;
2013-12-11 23:22:07 +05:30
temp = readl_relaxed ( & g - > dir ) ;
2010-05-01 18:37:51 -04:00
if ( out ) {
temp & = ~ mask ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , value ? & g - > set_data : & g - > clr_data ) ;
2010-05-01 18:37:51 -04:00
} else {
temp | = mask ;
}
2013-12-11 23:22:07 +05:30
writel_relaxed ( temp , & g - > dir ) ;
2010-05-01 18:37:55 -04:00
spin_unlock_irqrestore ( & d - > lock , flags ) ;
2007-07-10 13:03:43 +01:00
2008-09-07 23:41:04 -07:00
return 0 ;
}
2007-07-10 13:03:43 +01:00
2010-05-01 18:37:51 -04:00
static int davinci_direction_in ( struct gpio_chip * chip , unsigned offset )
{
return __davinci_direction ( chip , offset , false , 0 ) ;
}
static int
davinci_direction_out ( struct gpio_chip * chip , unsigned offset , int value )
{
return __davinci_direction ( chip , offset , true , value ) ;
}
2007-07-10 13:03:43 +01:00
/*
* Read the pin ' s value ( works even if it ' s set up as output ) ;
* returns zero / nonzero .
*
* Note that changes are synched to the GPIO clock , so reading values back
* right after you ' ve set them may give old values .
*/
2008-09-07 23:41:04 -07:00
static int davinci_gpio_get ( struct gpio_chip * chip , unsigned offset )
2007-07-10 13:03:43 +01:00
{
2010-05-01 18:37:52 -04:00
struct davinci_gpio_controller * d = chip2controller ( chip ) ;
struct davinci_gpio_regs __iomem * g = d - > regs ;
2007-07-10 13:03:43 +01:00
2013-12-11 23:22:07 +05:30
return ( 1 < < offset ) & readl_relaxed ( & g - > in_data ) ;
2007-07-10 13:03:43 +01:00
}
2008-09-07 23:41:04 -07:00
/*
* Assuming the pin is muxed as a gpio output , set its output value .
*/
static void
davinci_gpio_set ( struct gpio_chip * chip , unsigned offset , int value )
2007-07-10 13:03:43 +01:00
{
2010-05-01 18:37:52 -04:00
struct davinci_gpio_controller * d = chip2controller ( chip ) ;
struct davinci_gpio_regs __iomem * g = d - > regs ;
2007-07-10 13:03:43 +01:00
2013-12-11 23:22:07 +05:30
writel_relaxed ( ( 1 < < offset ) , value ? & g - > set_data : & g - > clr_data ) ;
2008-09-07 23:41:04 -07:00
}
2013-11-21 23:45:29 +05:30
static struct davinci_gpio_platform_data *
davinci_gpio_get_pdata ( struct platform_device * pdev )
{
struct device_node * dn = pdev - > dev . of_node ;
struct davinci_gpio_platform_data * pdata ;
int ret ;
u32 val ;
if ( ! IS_ENABLED ( CONFIG_OF ) | | ! pdev - > dev . of_node )
return pdev - > dev . platform_data ;
pdata = devm_kzalloc ( & pdev - > dev , sizeof ( * pdata ) , GFP_KERNEL ) ;
if ( ! pdata )
return NULL ;
ret = of_property_read_u32 ( dn , " ti,ngpio " , & val ) ;
if ( ret )
goto of_err ;
pdata - > ngpio = val ;
ret = of_property_read_u32 ( dn , " ti,davinci-gpio-unbanked " , & val ) ;
if ( ret )
goto of_err ;
pdata - > gpio_unbanked = val ;
return pdata ;
of_err :
dev_err ( & pdev - > dev , " Populating pdata from DT failed: err %d \n " , ret ) ;
return NULL ;
}
2014-03-05 12:21:01 +01:00
# ifdef CONFIG_OF_GPIO
static int davinci_gpio_of_xlate ( struct gpio_chip * gc ,
const struct of_phandle_args * gpiospec ,
u32 * flags )
{
struct davinci_gpio_controller * chips = dev_get_drvdata ( gc - > dev ) ;
struct davinci_gpio_platform_data * pdata = dev_get_platdata ( gc - > dev ) ;
if ( gpiospec - > args [ 0 ] > pdata - > ngpio )
return - EINVAL ;
if ( gc ! = & chips [ gpiospec - > args [ 0 ] / 32 ] . chip )
return - EINVAL ;
if ( flags )
* flags = gpiospec - > args [ 1 ] ;
return gpiospec - > args [ 0 ] % 32 ;
}
# endif
2013-08-18 10:48:58 +05:30
static int davinci_gpio_probe ( struct platform_device * pdev )
2008-09-07 23:41:04 -07:00
{
int i , base ;
2009-04-15 12:40:35 -07:00
unsigned ngpio ;
2013-08-18 10:48:58 +05:30
struct davinci_gpio_controller * chips ;
struct davinci_gpio_platform_data * pdata ;
struct davinci_gpio_regs __iomem * regs ;
struct device * dev = & pdev - > dev ;
struct resource * res ;
2013-11-21 23:45:29 +05:30
pdata = davinci_gpio_get_pdata ( pdev ) ;
2013-08-18 10:48:58 +05:30
if ( ! pdata ) {
dev_err ( dev , " No platform data found \n " ) ;
return - EINVAL ;
}
2010-05-01 18:37:54 -04:00
2013-11-21 23:45:29 +05:30
dev - > platform_data = pdata ;
2009-04-15 12:40:35 -07:00
/*
* The gpio banks conceptually expose a segmented bitmap ,
2008-12-07 11:46:23 -08:00
* and " ngpio " is one more than the largest zero - based
* bit index that ' s valid .
*/
2013-08-18 10:48:58 +05:30
ngpio = pdata - > ngpio ;
2009-04-15 12:40:35 -07:00
if ( ngpio = = 0 ) {
2013-08-18 10:48:58 +05:30
dev_err ( dev , " How many GPIOs? \n " ) ;
2008-12-07 11:46:23 -08:00
return - EINVAL ;
}
2013-11-21 17:34:35 +02:00
if ( WARN_ON ( ARCH_NR_GPIOS < ngpio ) )
ngpio = ARCH_NR_GPIOS ;
2008-12-07 11:46:23 -08:00
2013-08-18 10:48:58 +05:30
chips = devm_kzalloc ( dev ,
ngpio * sizeof ( struct davinci_gpio_controller ) ,
GFP_KERNEL ) ;
2014-04-29 17:33:26 +09:00
if ( ! chips )
2010-05-07 17:06:32 -04:00
return - ENOMEM ;
2013-08-18 10:48:58 +05:30
res = platform_get_resource ( pdev , IORESOURCE_MEM , 0 ) ;
if ( ! res ) {
dev_err ( dev , " Invalid memory resource \n " ) ;
return - EBUSY ;
}
gpio_base = devm_ioremap_resource ( dev , res ) ;
if ( IS_ERR ( gpio_base ) )
return PTR_ERR ( gpio_base ) ;
2010-05-07 17:06:32 -04:00
2008-12-07 11:46:23 -08:00
for ( i = 0 , base = 0 ; base < ngpio ; i + + , base + = 32 ) {
2008-09-07 23:41:04 -07:00
chips [ i ] . chip . label = " DaVinci " ;
chips [ i ] . chip . direction_input = davinci_direction_in ;
chips [ i ] . chip . get = davinci_gpio_get ;
chips [ i ] . chip . direction_output = davinci_direction_out ;
chips [ i ] . chip . set = davinci_gpio_set ;
chips [ i ] . chip . base = base ;
2008-12-07 11:46:23 -08:00
chips [ i ] . chip . ngpio = ngpio - base ;
2008-09-07 23:41:04 -07:00
if ( chips [ i ] . chip . ngpio > 32 )
chips [ i ] . chip . ngpio = 32 ;
2013-11-21 23:45:29 +05:30
# ifdef CONFIG_OF_GPIO
2014-03-05 12:21:01 +01:00
chips [ i ] . chip . of_gpio_n_cells = 2 ;
chips [ i ] . chip . of_xlate = davinci_gpio_of_xlate ;
chips [ i ] . chip . dev = dev ;
2013-11-21 23:45:29 +05:30
chips [ i ] . chip . of_node = dev - > of_node ;
# endif
2010-05-01 18:37:55 -04:00
spin_lock_init ( & chips [ i ] . lock ) ;
2010-05-01 18:37:53 -04:00
regs = gpio2regs ( base ) ;
chips [ i ] . regs = regs ;
chips [ i ] . set_data = & regs - > set_data ;
chips [ i ] . clr_data = & regs - > clr_data ;
chips [ i ] . in_data = & regs - > in_data ;
2008-09-07 23:41:04 -07:00
gpiochip_add ( & chips [ i ] . chip ) ;
}
2007-07-10 13:03:43 +01:00
2013-08-18 10:48:58 +05:30
platform_set_drvdata ( pdev , chips ) ;
davinci_gpio_irq_setup ( pdev ) ;
2007-07-10 13:03:43 +01:00
return 0 ;
}
2008-09-07 23:41:04 -07:00
/*--------------------------------------------------------------------------*/
2007-07-10 13:03:43 +01:00
/*
* We expect irqs will normally be set up as input pins , but they can also be
* used as output pins . . . which is convenient for testing .
*
2008-12-07 11:46:23 -08:00
* NOTE : The first few GPIOs also have direct INTC hookups in addition
2009-06-25 17:01:31 -07:00
* to their GPIOBNK0 irq , with a bit less overhead .
2007-07-10 13:03:43 +01:00
*
2008-12-07 11:46:23 -08:00
* All those INTC hookups ( direct , plus several IRQ banks ) can also
2007-07-10 13:03:43 +01:00
* serve as EDMA event triggers .
*/
2010-11-29 10:27:27 +01:00
static void gpio_irq_disable ( struct irq_data * d )
2007-07-10 13:03:43 +01:00
{
2010-11-29 10:27:27 +01:00
struct davinci_gpio_regs __iomem * g = irq2regs ( d - > irq ) ;
2011-03-24 13:25:22 +01:00
u32 mask = ( u32 ) irq_data_get_irq_handler_data ( d ) ;
2007-07-10 13:03:43 +01:00
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , & g - > clr_falling ) ;
writel_relaxed ( mask , & g - > clr_rising ) ;
2007-07-10 13:03:43 +01:00
}
2010-11-29 10:27:27 +01:00
static void gpio_irq_enable ( struct irq_data * d )
2007-07-10 13:03:43 +01:00
{
2010-11-29 10:27:27 +01:00
struct davinci_gpio_regs __iomem * g = irq2regs ( d - > irq ) ;
2011-03-24 13:25:22 +01:00
u32 mask = ( u32 ) irq_data_get_irq_handler_data ( d ) ;
2011-03-24 12:47:04 +01:00
unsigned status = irqd_get_trigger_type ( d ) ;
2007-07-10 13:03:43 +01:00
2009-05-04 13:14:27 -07:00
status & = IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING ;
if ( ! status )
status = IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING ;
if ( status & IRQ_TYPE_EDGE_FALLING )
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , & g - > set_falling ) ;
2009-05-04 13:14:27 -07:00
if ( status & IRQ_TYPE_EDGE_RISING )
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , & g - > set_rising ) ;
2007-07-10 13:03:43 +01:00
}
2010-11-29 10:27:27 +01:00
static int gpio_irq_type ( struct irq_data * d , unsigned trigger )
2007-07-10 13:03:43 +01:00
{
if ( trigger & ~ ( IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING ) )
return - EINVAL ;
return 0 ;
}
static struct irq_chip gpio_irqchip = {
. name = " GPIO " ,
2010-11-29 10:27:27 +01:00
. irq_enable = gpio_irq_enable ,
. irq_disable = gpio_irq_disable ,
. irq_set_type = gpio_irq_type ,
2011-03-24 12:47:04 +01:00
. flags = IRQCHIP_SET_TYPE_MASKED ,
2007-07-10 13:03:43 +01:00
} ;
static void
gpio_irq_handler ( unsigned irq , struct irq_desc * desc )
{
2011-06-06 11:51:43 +02:00
struct davinci_gpio_regs __iomem * g ;
2007-07-10 13:03:43 +01:00
u32 mask = 0xffff ;
2011-07-12 00:03:11 +03:00
struct davinci_gpio_controller * d ;
2007-07-10 13:03:43 +01:00
2011-07-12 00:03:11 +03:00
d = ( struct davinci_gpio_controller * ) irq_desc_get_handler_data ( desc ) ;
g = ( struct davinci_gpio_regs __iomem * ) d - > regs ;
2011-06-06 11:51:43 +02:00
2007-07-10 13:03:43 +01:00
/* we only care about one bank */
if ( irq & 1 )
mask < < = 16 ;
/* temporarily mask (level sensitive) parent IRQ */
2013-11-26 21:40:09 +02:00
chained_irq_enter ( irq_desc_get_chip ( desc ) , desc ) ;
2007-07-10 13:03:43 +01:00
while ( 1 ) {
u32 status ;
2013-11-21 23:45:27 +05:30
int bit ;
2007-07-10 13:03:43 +01:00
/* ack any irqs */
2013-12-11 23:22:07 +05:30
status = readl_relaxed ( & g - > intstat ) & mask ;
2007-07-10 13:03:43 +01:00
if ( ! status )
break ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( status , & g - > intstat ) ;
2007-07-10 13:03:43 +01:00
/* now demux them to the right lowlevel handler */
2011-07-12 00:03:11 +03:00
2007-07-10 13:03:43 +01:00
while ( status ) {
2013-11-21 23:45:27 +05:30
bit = __ffs ( status ) ;
status & = ~ BIT ( bit ) ;
generic_handle_irq (
irq_find_mapping ( d - > irq_domain ,
d - > chip . base + bit ) ) ;
2007-07-10 13:03:43 +01:00
}
}
2013-11-26 21:40:09 +02:00
chained_irq_exit ( irq_desc_get_chip ( desc ) , desc ) ;
2007-07-10 13:03:43 +01:00
/* now it may re-trigger */
}
2009-06-25 17:01:31 -07:00
static int gpio_to_irq_banked ( struct gpio_chip * chip , unsigned offset )
{
2010-05-01 18:37:52 -04:00
struct davinci_gpio_controller * d = chip2controller ( chip ) ;
2009-06-25 17:01:31 -07:00
2013-12-18 12:07:51 +02:00
if ( d - > irq_domain )
return irq_create_mapping ( d - > irq_domain , d - > chip . base + offset ) ;
else
return - ENXIO ;
2009-06-25 17:01:31 -07:00
}
static int gpio_to_irq_unbanked ( struct gpio_chip * chip , unsigned offset )
{
2013-08-18 10:48:58 +05:30
struct davinci_gpio_controller * d = chip2controller ( chip ) ;
2009-06-25 17:01:31 -07:00
2013-08-18 10:48:57 +05:30
/*
* NOTE : we assume for now that only irqs in the first gpio_chip
2009-06-25 17:01:31 -07:00
* can provide direct - mapped IRQs to AINTC ( up to 32 GPIOs ) .
*/
2013-11-08 12:15:55 +05:30
if ( offset < d - > gpio_unbanked )
2013-08-18 10:48:58 +05:30
return d - > gpio_irq + offset ;
2009-06-25 17:01:31 -07:00
else
return - ENODEV ;
}
2012-03-11 18:16:11 +05:30
static int gpio_irq_type_unbanked ( struct irq_data * data , unsigned trigger )
2009-06-25 17:01:31 -07:00
{
2012-03-11 18:16:11 +05:30
struct davinci_gpio_controller * d ;
struct davinci_gpio_regs __iomem * g ;
u32 mask ;
d = ( struct davinci_gpio_controller * ) data - > handler_data ;
g = ( struct davinci_gpio_regs __iomem * ) d - > regs ;
2013-08-18 10:48:58 +05:30
mask = __gpio_mask ( data - > irq - d - > gpio_irq ) ;
2009-06-25 17:01:31 -07:00
if ( trigger & ~ ( IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING ) )
return - EINVAL ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , ( trigger & IRQ_TYPE_EDGE_FALLING )
2009-06-25 17:01:31 -07:00
? & g - > set_falling : & g - > clr_falling ) ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( mask , ( trigger & IRQ_TYPE_EDGE_RISING )
2009-06-25 17:01:31 -07:00
? & g - > set_rising : & g - > clr_rising ) ;
return 0 ;
}
2013-11-21 23:45:27 +05:30
static int
davinci_gpio_irq_map ( struct irq_domain * d , unsigned int irq ,
irq_hw_number_t hw )
{
struct davinci_gpio_regs __iomem * g = gpio2regs ( hw ) ;
irq_set_chip_and_handler_name ( irq , & gpio_irqchip , handle_simple_irq ,
" davinci_gpio " ) ;
irq_set_irq_type ( irq , IRQ_TYPE_NONE ) ;
irq_set_chip_data ( irq , ( __force void * ) g ) ;
irq_set_handler_data ( irq , ( void * ) __gpio_mask ( hw ) ) ;
set_irq_flags ( irq , IRQF_VALID ) ;
return 0 ;
}
static const struct irq_domain_ops davinci_gpio_irq_ops = {
. map = davinci_gpio_irq_map ,
. xlate = irq_domain_xlate_onetwocell ,
} ;
2014-02-13 17:58:45 +02:00
static struct irq_chip * davinci_gpio_get_irq_chip ( unsigned int irq )
{
static struct irq_chip_type gpio_unbanked ;
gpio_unbanked = * container_of ( irq_get_chip ( irq ) ,
struct irq_chip_type , chip ) ;
return & gpio_unbanked . chip ;
} ;
static struct irq_chip * keystone_gpio_get_irq_chip ( unsigned int irq )
{
static struct irq_chip gpio_unbanked ;
gpio_unbanked = * irq_get_chip ( irq ) ;
return & gpio_unbanked ;
} ;
static const struct of_device_id davinci_gpio_ids [ ] ;
2007-07-10 13:03:43 +01:00
/*
2008-12-07 11:46:23 -08:00
* NOTE : for suspend / resume , probably best to make a platform_device with
* suspend_late / resume_resume calls hooking into results of the set_wake ( )
2007-07-10 13:03:43 +01:00
* calls . . . so if no gpios are wakeup events the clock can be disabled ,
* with outputs left at previously set levels , and so that VDD3P3V . IOPWDN0
2008-12-07 11:46:23 -08:00
* ( dm6446 ) can be set appropriately for GPIOV33 pins .
2007-07-10 13:03:43 +01:00
*/
2013-08-18 10:48:58 +05:30
static int davinci_gpio_irq_setup ( struct platform_device * pdev )
2007-07-10 13:03:43 +01:00
{
2014-02-15 17:12:05 +04:00
unsigned gpio , bank ;
int irq ;
2007-07-10 13:03:43 +01:00
struct clk * clk ;
2008-12-07 11:46:23 -08:00
u32 binten = 0 ;
2009-04-15 12:40:35 -07:00
unsigned ngpio , bank_irq ;
2013-08-18 10:48:58 +05:30
struct device * dev = & pdev - > dev ;
struct resource * res ;
struct davinci_gpio_controller * chips = platform_get_drvdata ( pdev ) ;
struct davinci_gpio_platform_data * pdata = dev - > platform_data ;
struct davinci_gpio_regs __iomem * g ;
2013-12-18 12:07:51 +02:00
struct irq_domain * irq_domain = NULL ;
2014-02-13 17:58:45 +02:00
const struct of_device_id * match ;
struct irq_chip * irq_chip ;
gpio_get_irq_chip_cb_t gpio_get_irq_chip ;
/*
* Use davinci_gpio_get_irq_chip by default to handle non DT cases
*/
gpio_get_irq_chip = davinci_gpio_get_irq_chip ;
match = of_match_device ( of_match_ptr ( davinci_gpio_ids ) ,
dev ) ;
if ( match )
gpio_get_irq_chip = ( gpio_get_irq_chip_cb_t ) match - > data ;
2009-04-15 12:40:35 -07:00
2013-08-18 10:48:58 +05:30
ngpio = pdata - > ngpio ;
res = platform_get_resource ( pdev , IORESOURCE_IRQ , 0 ) ;
if ( ! res ) {
dev_err ( dev , " Invalid IRQ resource \n " ) ;
return - EBUSY ;
}
2008-12-07 11:46:23 -08:00
2013-08-18 10:48:58 +05:30
bank_irq = res - > start ;
if ( ! bank_irq ) {
dev_err ( dev , " Invalid IRQ resource \n " ) ;
return - ENODEV ;
2008-12-07 11:46:23 -08:00
}
2007-07-10 13:03:43 +01:00
2013-08-18 10:48:58 +05:30
clk = devm_clk_get ( dev , " gpio " ) ;
2007-07-10 13:03:43 +01:00
if ( IS_ERR ( clk ) ) {
printk ( KERN_ERR " Error %ld getting gpio clock? \n " ,
PTR_ERR ( clk ) ) ;
2008-12-07 11:46:23 -08:00
return PTR_ERR ( clk ) ;
2007-07-10 13:03:43 +01:00
}
2012-08-30 14:03:57 -04:00
clk_prepare_enable ( clk ) ;
2007-07-10 13:03:43 +01:00
2013-12-18 12:07:51 +02:00
if ( ! pdata - > gpio_unbanked ) {
irq = irq_alloc_descs ( - 1 , 0 , ngpio , 0 ) ;
if ( irq < 0 ) {
dev_err ( dev , " Couldn't allocate IRQ numbers \n " ) ;
return irq ;
}
2013-11-21 23:45:27 +05:30
2013-12-18 12:07:51 +02:00
irq_domain = irq_domain_add_legacy ( NULL , ngpio , irq , 0 ,
& davinci_gpio_irq_ops ,
chips ) ;
if ( ! irq_domain ) {
dev_err ( dev , " Couldn't register an IRQ domain \n " ) ;
return - ENODEV ;
}
2013-11-21 23:45:27 +05:30
}
2013-08-18 10:48:57 +05:30
/*
* Arrange gpio_to_irq ( ) support , handling either direct IRQs or
2009-06-25 17:01:31 -07:00
* banked IRQs . Having GPIOs in the first GPIO bank use direct
* IRQs , while the others use banked IRQs , would need some setup
* tweaks to recognize hardware which can do that .
*/
for ( gpio = 0 , bank = 0 ; gpio < ngpio ; bank + + , gpio + = 32 ) {
chips [ bank ] . chip . to_irq = gpio_to_irq_banked ;
2013-12-18 12:07:51 +02:00
chips [ bank ] . irq_domain = irq_domain ;
2009-06-25 17:01:31 -07:00
}
/*
* AINTC can handle direct / unbanked IRQs for GPIOs , with the GPIO
* controller only handling trigger modes . We currently assume no
* IRQ mux conflicts ; gpio_irq_type_unbanked ( ) is only for GPIOs .
*/
2013-08-18 10:48:58 +05:30
if ( pdata - > gpio_unbanked ) {
2009-06-25 17:01:31 -07:00
/* pass "bank 0" GPIO IRQs to AINTC */
chips [ 0 ] . chip . to_irq = gpio_to_irq_unbanked ;
2013-11-08 12:15:55 +05:30
chips [ 0 ] . gpio_irq = bank_irq ;
chips [ 0 ] . gpio_unbanked = pdata - > gpio_unbanked ;
2009-06-25 17:01:31 -07:00
binten = BIT ( 0 ) ;
/* AINTC handles mask/unmask; GPIO handles triggering */
irq = bank_irq ;
2014-02-13 17:58:45 +02:00
irq_chip = gpio_get_irq_chip ( irq ) ;
irq_chip - > name = " GPIO-AINTC " ;
irq_chip - > irq_set_type = gpio_irq_type_unbanked ;
2009-06-25 17:01:31 -07:00
/* default trigger: both edges */
2010-05-01 18:37:52 -04:00
g = gpio2regs ( 0 ) ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( ~ 0 , & g - > set_falling ) ;
writel_relaxed ( ~ 0 , & g - > set_rising ) ;
2009-06-25 17:01:31 -07:00
/* set the direct IRQs up to use that irqchip */
2013-08-18 10:48:58 +05:30
for ( gpio = 0 ; gpio < pdata - > gpio_unbanked ; gpio + + , irq + + ) {
2014-02-13 17:58:45 +02:00
irq_set_chip ( irq , irq_chip ) ;
2012-03-11 18:16:11 +05:30
irq_set_handler_data ( irq , & chips [ gpio / 32 ] ) ;
2011-03-24 12:47:04 +01:00
irq_set_status_flags ( irq , IRQ_TYPE_EDGE_BOTH ) ;
2009-06-25 17:01:31 -07:00
}
goto done ;
}
/*
* Or , AINTC can handle IRQs for banks of 16 GPIO IRQs , which we
* then chain through our own handler .
*/
2013-11-21 23:45:27 +05:30
for ( gpio = 0 , bank = 0 ; gpio < ngpio ; bank + + , bank_irq + + , gpio + = 16 ) {
2009-06-25 17:01:31 -07:00
/* disabled by default, enabled only as needed */
2010-05-01 18:37:52 -04:00
g = gpio2regs ( gpio ) ;
2013-12-11 23:22:07 +05:30
writel_relaxed ( ~ 0 , & g - > clr_falling ) ;
writel_relaxed ( ~ 0 , & g - > clr_rising ) ;
2007-07-10 13:03:43 +01:00
/* set up all irqs in this bank */
2011-03-24 13:25:22 +01:00
irq_set_chained_handler ( bank_irq , gpio_irq_handler ) ;
2011-07-12 00:03:11 +03:00
/*
* Each chip handles 32 gpios , and each irq bank consists of 16
* gpio irqs . Pass the irq bank ' s corresponding controller to
* the chained irq handler .
*/
irq_set_handler_data ( bank_irq , & chips [ gpio / 32 ] ) ;
2007-07-10 13:03:43 +01:00
2008-12-07 11:46:23 -08:00
binten | = BIT ( bank ) ;
2007-07-10 13:03:43 +01:00
}
2009-06-25 17:01:31 -07:00
done :
2013-08-18 10:48:57 +05:30
/*
* BINTEN - - per - bank interrupt enable . genirq would also let these
2007-07-10 13:03:43 +01:00
* bits be set / cleared dynamically .
*/
2013-12-11 23:22:07 +05:30
writel_relaxed ( binten , gpio_base + BINTEN ) ;
2007-07-10 13:03:43 +01:00
return 0 ;
}
2013-08-18 10:48:58 +05:30
2013-11-21 23:45:29 +05:30
# if IS_ENABLED(CONFIG_OF)
static const struct of_device_id davinci_gpio_ids [ ] = {
2014-02-13 17:58:45 +02:00
{ . compatible = " ti,keystone-gpio " , keystone_gpio_get_irq_chip } ,
{ . compatible = " ti,dm6441-gpio " , davinci_gpio_get_irq_chip } ,
2013-11-21 23:45:29 +05:30
{ /* sentinel */ } ,
} ;
MODULE_DEVICE_TABLE ( of , davinci_gpio_ids ) ;
# endif
2013-08-18 10:48:58 +05:30
static struct platform_driver davinci_gpio_driver = {
. probe = davinci_gpio_probe ,
. driver = {
2013-11-21 23:45:29 +05:30
. name = " davinci_gpio " ,
. owner = THIS_MODULE ,
. of_match_table = of_match_ptr ( davinci_gpio_ids ) ,
2013-08-18 10:48:58 +05:30
} ,
} ;
/**
* GPIO driver registration needs to be done before machine_init functions
* access GPIO . Hence davinci_gpio_drv_reg ( ) is a postcore_initcall .
*/
static int __init davinci_gpio_drv_reg ( void )
{
return platform_driver_register ( & davinci_gpio_driver ) ;
}
postcore_initcall ( davinci_gpio_drv_reg ) ;