2008-04-10 13:31:47 +01:00
/*
* linux / arch / arm / mach - sa1100 / gpio . c
*
* Generic SA - 1100 GPIO handling
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
2011-07-26 10:53:52 +01:00
# include <linux/gpio.h>
2008-04-10 13:31:47 +01:00
# include <linux/init.h>
# include <linux/module.h>
2013-09-25 13:33:55 +01:00
# include <linux/io.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2012-02-24 00:06:51 +01:00
# include <mach/irqs.h>
2008-04-10 13:31:47 +01:00
static int sa1100_gpio_get ( struct gpio_chip * chip , unsigned offset )
{
return GPLR & GPIO_GPIO ( offset ) ;
}
static void sa1100_gpio_set ( struct gpio_chip * chip , unsigned offset , int value )
{
if ( value )
GPSR = GPIO_GPIO ( offset ) ;
else
GPCR = GPIO_GPIO ( offset ) ;
}
static int sa1100_direction_input ( struct gpio_chip * chip , unsigned offset )
{
unsigned long flags ;
local_irq_save ( flags ) ;
GPDR & = ~ GPIO_GPIO ( offset ) ;
local_irq_restore ( flags ) ;
return 0 ;
}
static int sa1100_direction_output ( struct gpio_chip * chip , unsigned offset , int value )
{
unsigned long flags ;
local_irq_save ( flags ) ;
sa1100_gpio_set ( chip , offset , value ) ;
GPDR | = GPIO_GPIO ( offset ) ;
local_irq_restore ( flags ) ;
return 0 ;
}
2011-12-18 18:24:57 +00:00
static int sa1100_to_irq ( struct gpio_chip * chip , unsigned offset )
{
return offset < 11 ? ( IRQ_GPIO0 + offset ) : ( IRQ_GPIO11 - 11 + offset ) ;
}
2008-04-10 13:31:47 +01:00
static struct gpio_chip sa1100_gpio_chip = {
. label = " gpio " ,
. direction_input = sa1100_direction_input ,
. direction_output = sa1100_direction_output ,
. set = sa1100_gpio_set ,
. get = sa1100_gpio_get ,
2011-12-18 18:24:57 +00:00
. to_irq = sa1100_to_irq ,
2008-04-10 13:31:47 +01:00
. base = 0 ,
. ngpio = GPIO_MAX + 1 ,
} ;
void __init sa1100_init_gpio ( void )
{
gpiochip_add ( & sa1100_gpio_chip ) ;
}