This patch enables CONFIG_CMD_GPIO for the Allwinner (sunxi) platform as well as providing the common gpio API (gpio_request/free, direction in/out, get/set etc). Signed-off-by: Chen-Yu Tsai <wens@csie.org> Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Ma Haijun <mahaijuns@gmail.com> Signed-off-by: Oliver Schinagl <oliver@schinagl.nl> Signed-off-by: Ian Campbell <ijc@hellion.org.uk> Cc: Henrik Nordström <henrik@henriknordstrom.net> Cc: Tom Cubie <Mr.hipboi@gmail.com> Acked-by: Hans de Goede <hdegoede@redhat.com>master
parent
5c58f8b685
commit
abce2c6220
@ -0,0 +1,102 @@ |
||||
/*
|
||||
* (C) Copyright 2012 Henrik Nordstrom <henrik@henriknordstrom.net> |
||||
* |
||||
* Based on earlier arch/arm/cpu/armv7/sunxi/gpio.c: |
||||
* |
||||
* (C) Copyright 2007-2011 |
||||
* Allwinner Technology Co., Ltd. <www.allwinnertech.com> |
||||
* Tom Cubie <tangliang@allwinnertech.com> |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
#include <common.h> |
||||
#include <asm/io.h> |
||||
#include <asm/gpio.h> |
||||
|
||||
static int sunxi_gpio_output(u32 pin, u32 val) |
||||
{ |
||||
u32 dat; |
||||
u32 bank = GPIO_BANK(pin); |
||||
u32 num = GPIO_NUM(pin); |
||||
struct sunxi_gpio *pio = BANK_TO_GPIO(bank); |
||||
|
||||
dat = readl(&pio->dat); |
||||
if (val) |
||||
dat |= 0x1 << num; |
||||
else |
||||
dat &= ~(0x1 << num); |
||||
|
||||
writel(dat, &pio->dat); |
||||
|
||||
return 0; |
||||
} |
||||
|
||||
static int sunxi_gpio_input(u32 pin) |
||||
{ |
||||
u32 dat; |
||||
u32 bank = GPIO_BANK(pin); |
||||
u32 num = GPIO_NUM(pin); |
||||
struct sunxi_gpio *pio = BANK_TO_GPIO(bank); |
||||
|
||||
dat = readl(&pio->dat); |
||||
dat >>= num; |
||||
|
||||
return dat & 0x1; |
||||
} |
||||
|
||||
int gpio_request(unsigned gpio, const char *label) |
||||
{ |
||||
return 0; |
||||
} |
||||
|
||||
int gpio_free(unsigned gpio) |
||||
{ |
||||
return 0; |
||||
} |
||||
|
||||
int gpio_direction_input(unsigned gpio) |
||||
{ |
||||
sunxi_gpio_set_cfgpin(gpio, SUNXI_GPIO_INPUT); |
||||
|
||||
return sunxi_gpio_input(gpio); |
||||
} |
||||
|
||||
int gpio_direction_output(unsigned gpio, int value) |
||||
{ |
||||
sunxi_gpio_set_cfgpin(gpio, SUNXI_GPIO_OUTPUT); |
||||
|
||||
return sunxi_gpio_output(gpio, value); |
||||
} |
||||
|
||||
int gpio_get_value(unsigned gpio) |
||||
{ |
||||
return sunxi_gpio_input(gpio); |
||||
} |
||||
|
||||
int gpio_set_value(unsigned gpio, int value) |
||||
{ |
||||
return sunxi_gpio_output(gpio, value); |
||||
} |
||||
|
||||
int sunxi_name_to_gpio(const char *name) |
||||
{ |
||||
int group = 0; |
||||
int groupsize = 9 * 32; |
||||
long pin; |
||||
char *eptr; |
||||
if (*name == 'P' || *name == 'p') |
||||
name++; |
||||
if (*name >= 'A') { |
||||
group = *name - (*name > 'a' ? 'a' : 'A'); |
||||
groupsize = 32; |
||||
name++; |
||||
} |
||||
|
||||
pin = simple_strtol(name, &eptr, 10); |
||||
if (!*name || *eptr) |
||||
return -1; |
||||
if (pin < 0 || pin > groupsize || group >= 9) |
||||
return -1; |
||||
return group * 32 + pin; |
||||
} |
Loading…
Reference in new issue