2019-05-27 08:55:01 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
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 >
*/
2018-08-31 14:13:26 -05:00
2018-01-14 02:05:38 +01:00
# include <linux/gpio/driver.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>
2018-01-21 17:09:40 -06:00
# include <linux/pinctrl/consumer.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>
2018-08-31 14:13:26 -05:00
# include <linux/spinlock.h>
# include <asm-generic/gpio.h>
# define MAX_REGS_BANKS 5
# define MAX_INT_PER_BANK 32
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-07 17:06:32 -04:00
static void __iomem * gpio_base ;
2017-01-17 21:49:11 +05:30
static unsigned int offset_array [ 5 ] = { 0x10 , 0x38 , 0x60 , 0x88 , 0xb0 } ;
2007-07-10 13:03:43 +01:00
2018-08-31 14:13:26 -05:00
struct davinci_gpio_irq_data {
void __iomem * regs ;
struct davinci_gpio_controller * chip ;
int bank_num ;
} ;
struct davinci_gpio_controller {
struct gpio_chip chip ;
struct irq_domain * irq_domain ;
/* Serialize access to GPIO registers */
spinlock_t lock ;
void __iomem * regs [ MAX_REGS_BANKS ] ;
int gpio_unbanked ;
int irqs [ MAX_INT_PER_BANK ] ;
} ;
static inline u32 __gpio_mask ( unsigned gpio )
{
return 1 < < ( gpio % 32 ) ;
}
2015-07-13 01:18:56 +02:00
static inline struct davinci_gpio_regs __iomem * irq2regs ( struct irq_data * d )
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
2015-07-13 01:18:56 +02:00
g = ( __force struct davinci_gpio_regs __iomem * ) irq_data_get_irq_chip_data ( d ) ;
2010-02-25 16:49:56 -08:00
return g ;
}
2018-06-13 09:10:37 +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
{
2015-12-04 16:25:04 +01:00
struct davinci_gpio_controller * d = gpiochip_get_data ( chip ) ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_regs __iomem * g ;
2010-05-01 18:37:55 -04:00
unsigned long flags ;
2008-09-07 23:41:04 -07:00
u32 temp ;
2017-01-13 09:50:12 +05:30
int bank = offset / 32 ;
u32 mask = __gpio_mask ( offset ) ;
2007-07-10 13:03:43 +01:00
2017-01-13 09:50:12 +05:30
g = d - > regs [ bank ] ;
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
{
2015-12-04 16:25:04 +01:00
struct davinci_gpio_controller * d = gpiochip_get_data ( chip ) ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_regs __iomem * g ;
int bank = offset / 32 ;
2007-07-10 13:03:43 +01:00
2017-01-13 09:50:12 +05:30
g = d - > regs [ bank ] ;
return ! ! ( __gpio_mask ( 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
{
2015-12-04 16:25:04 +01:00
struct davinci_gpio_controller * d = gpiochip_get_data ( chip ) ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_regs __iomem * g ;
int bank = offset / 32 ;
2007-07-10 13:03:43 +01:00
2017-01-13 09:50:12 +05:30
g = d - > regs [ bank ] ;
writel_relaxed ( __gpio_mask ( 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 )
2015-11-23 20:53:18 +05:30
return dev_get_platdata ( & pdev - > dev ) ;
2013-11-21 23:45:29 +05:30
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 ;
}
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
{
2018-08-31 14:13:24 -05:00
int bank , i , ret = 0 ;
2018-06-13 09:10:37 +05:30
unsigned int ngpio , nbank , nirq ;
2013-08-18 10:48:58 +05:30
struct davinci_gpio_controller * chips ;
struct davinci_gpio_platform_data * pdata ;
struct device * dev = & pdev - > dev ;
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
2018-06-13 09:10:37 +05:30
/*
* If there are unbanked interrupts then the number of
* interrupts is equal to number of gpios else all are banked so
* number of interrupts is equal to number of banks ( each with 16 gpios )
*/
if ( pdata - > gpio_unbanked )
nirq = pdata - > gpio_unbanked ;
else
nirq = DIV_ROUND_UP ( ngpio , 16 ) ;
2018-08-31 14:13:24 -05:00
chips = devm_kzalloc ( dev , sizeof ( * chips ) , 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
2019-02-20 12:12:40 +01:00
gpio_base = devm_platform_ioremap_resource ( pdev , 0 ) ;
2013-08-18 10:48:58 +05:30
if ( IS_ERR ( gpio_base ) )
return PTR_ERR ( gpio_base ) ;
2010-05-07 17:06:32 -04:00
2018-06-13 09:10:37 +05:30
for ( i = 0 ; i < nirq ; i + + ) {
chips - > irqs [ i ] = platform_get_irq ( pdev , i ) ;
if ( chips - > irqs [ i ] < 0 ) {
dev_info ( dev , " IRQ not populated, err = %d \n " ,
chips - > irqs [ i ] ) ;
return chips - > irqs [ i ] ;
}
2018-06-13 09:10:36 +05:30
}
2018-08-31 14:13:23 -05:00
chips - > chip . label = dev_name ( dev ) ;
2008-09-07 23:41:04 -07:00
2017-01-13 09:50:12 +05:30
chips - > chip . direction_input = davinci_direction_in ;
chips - > chip . get = davinci_gpio_get ;
chips - > chip . direction_output = davinci_direction_out ;
chips - > chip . set = davinci_gpio_set ;
2008-09-07 23:41:04 -07:00
2017-01-13 09:50:12 +05:30
chips - > chip . ngpio = ngpio ;
2018-11-21 10:35:17 +01:00
chips - > chip . base = pdata - > no_auto_base ? pdata - > base : - 1 ;
2008-09-07 23:41:04 -07:00
2013-11-21 23:45:29 +05:30
# ifdef CONFIG_OF_GPIO
2017-01-13 09:50:12 +05:30
chips - > chip . of_gpio_n_cells = 2 ;
chips - > chip . parent = dev ;
chips - > chip . of_node = dev - > of_node ;
2018-01-21 17:09:40 -06:00
if ( of_property_read_bool ( dev - > of_node , " gpio-ranges " ) ) {
chips - > chip . request = gpiochip_generic_request ;
chips - > chip . free = gpiochip_generic_free ;
}
2013-11-21 23:45:29 +05:30
# endif
2017-01-13 09:50:12 +05:30
spin_lock_init ( & chips - > lock ) ;
2008-09-07 23:41:04 -07:00
2018-08-31 14:13:24 -05:00
nbank = DIV_ROUND_UP ( ngpio , 32 ) ;
for ( bank = 0 ; bank < nbank ; bank + + )
2017-01-13 09:50:12 +05:30
chips - > regs [ bank ] = gpio_base + offset_array [ bank ] ;
2007-07-10 13:03:43 +01:00
2017-07-20 15:12:16 +05:30
ret = devm_gpiochip_add_data ( dev , & chips - > chip , chips ) ;
if ( ret )
2018-08-31 14:13:23 -05:00
return ret ;
2017-07-20 15:12:16 +05:30
2013-08-18 10:48:58 +05:30
platform_set_drvdata ( pdev , chips ) ;
2018-06-13 09:10:37 +05:30
ret = davinci_gpio_irq_setup ( pdev ) ;
2017-07-20 15:12:17 +05:30
if ( ret )
2018-08-31 14:13:23 -05:00
return ret ;
2017-07-20 15:12:17 +05:30
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
{
2015-07-13 01:18:56 +02:00
struct davinci_gpio_regs __iomem * g = irq2regs ( d ) ;
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
{
2015-07-13 01:18:56 +02:00
struct davinci_gpio_regs __iomem * g = irq2regs ( d ) ;
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
} ;
2015-09-14 10:42:37 +02:00
static void gpio_irq_handler ( struct irq_desc * desc )
2007-07-10 13:03:43 +01:00
{
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 ;
2017-01-13 09:50:12 +05:30
int bank_num ;
2011-07-12 00:03:11 +03:00
struct davinci_gpio_controller * d ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_irq_data * irqdata ;
2007-07-10 13:03:43 +01:00
2017-01-13 09:50:12 +05:30
irqdata = ( struct davinci_gpio_irq_data * ) irq_desc_get_handler_data ( desc ) ;
bank_num = irqdata - > bank_num ;
g = irqdata - > regs ;
d = irqdata - > chip ;
2011-06-06 11:51:43 +02:00
2007-07-10 13:03:43 +01:00
/* we only care about one bank */
2017-01-13 09:50:12 +05:30
if ( ( bank_num % 2 ) = = 1 )
2007-07-10 13:03:43 +01:00
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 ;
2017-01-13 09:50:12 +05:30
irq_hw_number_t hw_irq ;
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 ) ;
2017-01-13 09:50:12 +05:30
/* Max number of gpios per controller is 144 so
* hw_irq will be in [ 0. .143 ]
*/
hw_irq = ( bank_num / 2 ) * 32 + bit ;
2013-11-21 23:45:27 +05:30
generic_handle_irq (
2017-01-13 09:50:12 +05:30
irq_find_mapping ( d - > irq_domain , hw_irq ) ) ;
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 )
{
2015-12-04 16:25:04 +01:00
struct davinci_gpio_controller * d = gpiochip_get_data ( chip ) ;
2009-06-25 17:01:31 -07:00
2013-12-18 12:07:51 +02:00
if ( d - > irq_domain )
2017-01-13 09:50:12 +05:30
return irq_create_mapping ( d - > irq_domain , offset ) ;
2013-12-18 12:07:51 +02:00
else
return - ENXIO ;
2009-06-25 17:01:31 -07:00
}
static int gpio_to_irq_unbanked ( struct gpio_chip * chip , unsigned offset )
{
2015-12-04 16:25:04 +01:00
struct davinci_gpio_controller * d = gpiochip_get_data ( 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 )
2018-06-13 09:10:37 +05:30
return d - > irqs [ 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 ;
2018-06-13 09:10:37 +05:30
u32 mask , i ;
2012-03-11 18:16:11 +05:30
2015-06-01 16:05:19 +08:00
d = ( struct davinci_gpio_controller * ) irq_data_get_irq_handler_data ( data ) ;
2017-11-10 16:43:17 +05:30
g = ( struct davinci_gpio_regs __iomem * ) d - > regs [ 0 ] ;
2018-06-13 09:10:37 +05:30
for ( i = 0 ; i < MAX_INT_PER_BANK ; i + + )
if ( data - > irq = = d - > irqs [ i ] )
break ;
if ( i = = MAX_INT_PER_BANK )
return - EINVAL ;
mask = __gpio_mask ( i ) ;
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 )
{
2017-01-17 21:49:11 +05:30
struct davinci_gpio_controller * chips =
( struct davinci_gpio_controller * ) d - > host_data ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_regs __iomem * g = chips - > regs [ hw / 32 ] ;
2013-11-21 23:45:27 +05:30
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 ) ) ;
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 ;
2015-12-30 22:16:38 +08:00
gpio_unbanked = * irq_data_get_chip_type ( irq_get_irq_data ( irq ) ) ;
2014-02-13 17:58:45 +02:00
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
*/
2018-06-13 09:10:37 +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 ;
2017-05-23 14:48:57 +05:30
int ret ;
2007-07-10 13:03:43 +01:00
struct clk * clk ;
2008-12-07 11:46:23 -08:00
u32 binten = 0 ;
2018-06-13 09:10:36 +05:30
unsigned ngpio ;
2013-08-18 10:48:58 +05:30
struct device * dev = & pdev - > dev ;
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 ;
2017-01-13 09:50:12 +05:30
struct davinci_gpio_irq_data * irqdata ;
2014-02-13 17:58:45 +02:00
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 ;
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 ) ) {
2017-07-20 15:12:18 +05:30
dev_err ( dev , " 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
}
2018-06-13 09:10:37 +05:30
2017-05-23 14:48:57 +05:30
ret = clk_prepare_enable ( clk ) ;
if ( ret )
return ret ;
2007-07-10 13:03:43 +01:00
2013-12-18 12:07:51 +02:00
if ( ! pdata - > gpio_unbanked ) {
2017-03-04 17:23:36 +01:00
irq = devm_irq_alloc_descs ( dev , - 1 , 0 , ngpio , 0 ) ;
2013-12-18 12:07:51 +02:00
if ( irq < 0 ) {
dev_err ( dev , " Couldn't allocate IRQ numbers \n " ) ;
2017-05-23 14:48:57 +05:30
clk_disable_unprepare ( clk ) ;
2013-12-18 12:07:51 +02:00
return irq ;
}
2013-11-21 23:45:27 +05:30
2016-01-28 19:08:50 +05:30
irq_domain = irq_domain_add_legacy ( dev - > of_node , ngpio , irq , 0 ,
2013-12-18 12:07:51 +02:00
& davinci_gpio_irq_ops ,
chips ) ;
if ( ! irq_domain ) {
dev_err ( dev , " Couldn't register an IRQ domain \n " ) ;
2017-05-23 14:48:57 +05:30
clk_disable_unprepare ( clk ) ;
2013-12-18 12:07:51 +02:00
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 .
*/
2017-01-13 09:50:12 +05:30
chips - > chip . to_irq = gpio_to_irq_banked ;
chips - > 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 */
2017-01-13 09:50:12 +05:30
chips - > chip . to_irq = gpio_to_irq_unbanked ;
chips - > gpio_unbanked = pdata - > gpio_unbanked ;
2015-07-02 14:31:30 -04:00
binten = GENMASK ( pdata - > gpio_unbanked / 16 , 0 ) ;
2009-06-25 17:01:31 -07:00
/* AINTC handles mask/unmask; GPIO handles triggering */
2018-06-13 09:10:37 +05:30
irq = chips - > irqs [ 0 ] ;
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 */
2017-01-13 09:50:12 +05:30
g = chips - > regs [ 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 */
2018-06-13 09:10:37 +05:30
for ( gpio = 0 ; gpio < pdata - > gpio_unbanked ; gpio + + ) {
irq_set_chip ( chips - > irqs [ gpio ] , irq_chip ) ;
irq_set_handler_data ( chips - > irqs [ gpio ] , chips ) ;
irq_set_status_flags ( chips - > irqs [ gpio ] ,
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 .
*/
2018-06-13 09:10:37 +05:30
for ( gpio = 0 , bank = 0 ; gpio < ngpio ; bank + + , gpio + = 16 ) {
2017-01-17 21:49:11 +05:30
/* disabled by default, enabled only as needed
* There are register sets for 32 GPIOs . 2 banks of 16
* GPIOs are covered by each set of registers hence divide by 2
*/
2017-01-13 09:50:12 +05:30
g = chips - > regs [ bank / 2 ] ;
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
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 .
*/
2017-01-13 09:50:12 +05:30
irqdata = devm_kzalloc ( & pdev - > dev ,
sizeof ( struct
davinci_gpio_irq_data ) ,
GFP_KERNEL ) ;
2017-05-23 14:48:57 +05:30
if ( ! irqdata ) {
clk_disable_unprepare ( clk ) ;
2017-01-13 09:50:12 +05:30
return - ENOMEM ;
2017-05-23 14:48:57 +05:30
}
2017-01-13 09:50:12 +05:30
irqdata - > regs = g ;
irqdata - > bank_num = bank ;
irqdata - > chip = chips ;
2018-06-13 09:10:37 +05:30
irq_set_chained_handler_and_data ( chips - > irqs [ bank ] ,
gpio_irq_handler , irqdata ) ;
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
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 ) ;
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 " ,
. 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 ) ;