1
0
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:
ejka 2007-09-21 12:37:50 +00:00
parent 9fb66acf63
commit 35a0fb9185
5 changed files with 33 additions and 33 deletions

View File

@ -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;

View File

@ -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);

View File

@ -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;

View File

@ -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;

View File

@ -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;