mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-27 16:01:05 +02:00
make gpio conformant to generic gpio spec.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@8911 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
9fb66acf63
commit
35a0fb9185
@ -20,9 +20,9 @@
|
|||||||
|
|
||||||
#include <asm/ar7/gpio.h>
|
#include <asm/ar7/gpio.h>
|
||||||
|
|
||||||
static char *ar7_gpio_list[AR7_GPIO_MAX] = { 0, };
|
static const char *ar7_gpio_list[AR7_GPIO_MAX] = { 0, };
|
||||||
|
|
||||||
int gpio_request(unsigned gpio, char *label)
|
int gpio_request(unsigned gpio, const char *label)
|
||||||
{
|
{
|
||||||
if (gpio >= AR7_GPIO_MAX)
|
if (gpio >= AR7_GPIO_MAX)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -58,10 +58,9 @@ static int vlynq_on(struct vlynq_device *dev)
|
|||||||
if ((result = ar7_gpio_enable(pdata->gpio_bit)))
|
if ((result = ar7_gpio_enable(pdata->gpio_bit)))
|
||||||
goto out_enabled;
|
goto out_enabled;
|
||||||
|
|
||||||
if ((result = gpio_direction_output(pdata->gpio_bit)))
|
if ((result = gpio_direction_output(pdata->gpio_bit, 0)))
|
||||||
goto out_gpio_enabled;
|
goto out_gpio_enabled;
|
||||||
|
|
||||||
gpio_set_value(pdata->gpio_bit, 0);
|
|
||||||
mdelay(50);
|
mdelay(50);
|
||||||
|
|
||||||
gpio_set_value(pdata->gpio_bit, 1);
|
gpio_set_value(pdata->gpio_bit, 1);
|
||||||
|
@ -73,7 +73,7 @@ static ssize_t ar7_gpio_write(struct file *file, const char __user *buf,
|
|||||||
case 'o':
|
case 'o':
|
||||||
case 'O':
|
case 'O':
|
||||||
case '>':
|
case '>':
|
||||||
gpio_direction_output(pin);
|
gpio_direction_output(pin, 0);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -73,7 +73,7 @@ static int ar7_leds_probe(struct platform_device *pdev)
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
ar7_gpio_enable(AR7_GPIO_BIT_STATUS_LED);
|
ar7_gpio_enable(AR7_GPIO_BIT_STATUS_LED);
|
||||||
gpio_direction_output(AR7_GPIO_BIT_STATUS_LED);
|
gpio_direction_output(AR7_GPIO_BIT_STATUS_LED, 0);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -22,36 +22,10 @@
|
|||||||
|
|
||||||
#define AR7_GPIO_MAX 32
|
#define AR7_GPIO_MAX 32
|
||||||
|
|
||||||
extern int gpio_request(unsigned gpio, char *label);
|
extern int gpio_request(unsigned gpio, const char *label);
|
||||||
extern void gpio_free(unsigned gpio);
|
extern void gpio_free(unsigned gpio);
|
||||||
|
|
||||||
/* Common GPIO layer */
|
/* Common GPIO layer */
|
||||||
static inline int gpio_direction_input(unsigned gpio)
|
|
||||||
{
|
|
||||||
void __iomem *gpio_dir =
|
|
||||||
(void __iomem *)KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_DIR);
|
|
||||||
|
|
||||||
if (gpio >= AR7_GPIO_MAX)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
writel(readl(gpio_dir) | (1 << gpio), gpio_dir);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int gpio_direction_output(unsigned gpio)
|
|
||||||
{
|
|
||||||
void __iomem *gpio_dir =
|
|
||||||
(void __iomem *)KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_DIR);
|
|
||||||
|
|
||||||
if (gpio >= AR7_GPIO_MAX)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
writel(readl(gpio_dir) & ~(1 << gpio), gpio_dir);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int gpio_get_value(unsigned gpio)
|
static inline int gpio_get_value(unsigned gpio)
|
||||||
{
|
{
|
||||||
void __iomem *gpio_in =
|
void __iomem *gpio_in =
|
||||||
@ -78,6 +52,33 @@ static inline void gpio_set_value(unsigned gpio, int value)
|
|||||||
writel(tmp, gpio_out);
|
writel(tmp, gpio_out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int gpio_direction_input(unsigned gpio)
|
||||||
|
{
|
||||||
|
void __iomem *gpio_dir =
|
||||||
|
(void __iomem *)KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_DIR);
|
||||||
|
|
||||||
|
if (gpio >= AR7_GPIO_MAX)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
writel(readl(gpio_dir) | (1 << gpio), gpio_dir);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline int gpio_direction_output(unsigned gpio, int value)
|
||||||
|
{
|
||||||
|
void __iomem *gpio_dir =
|
||||||
|
(void __iomem *)KSEG1ADDR(AR7_REGS_GPIO + AR7_GPIO_DIR);
|
||||||
|
|
||||||
|
if (gpio >= AR7_GPIO_MAX)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
gpio_set_value(gpio, value);
|
||||||
|
writel(readl(gpio_dir) & ~(1 << gpio), gpio_dir);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static inline int gpio_to_irq(unsigned gpio)
|
static inline int gpio_to_irq(unsigned gpio)
|
||||||
{
|
{
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user