summaryrefslogtreecommitdiffstats
path: root/arch/arm/boards/animeo_ip/init.c
diff options
context:
space:
mode:
authorJean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>2013-01-26 01:08:54 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2013-01-27 12:18:52 +0100
commit7cf50cf26cfc13607bec45f5499900ae802e7e62 (patch)
tree05e3e492e8611bb1e6c03e56f91f125990b329cf /arch/arm/boards/animeo_ip/init.c
parent1857238192881ec8ddf2a074694e05795bb1ae67 (diff)
downloadbarebox-7cf50cf26cfc13607bec45f5499900ae802e7e62.tar.gz
barebox-7cf50cf26cfc13607bec45f5499900ae802e7e62.tar.xz
Animeo IP: use gpiolib ip to detect the hw version
if err assume SubCo SDN Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'arch/arm/boards/animeo_ip/init.c')
-rw-r--r--arch/arm/boards/animeo_ip/init.c50
1 files changed, 39 insertions, 11 deletions
diff --git a/arch/arm/boards/animeo_ip/init.c b/arch/arm/boards/animeo_ip/init.c
index 8622c6657e..ada3bb044e 100644
--- a/arch/arm/boards/animeo_ip/init.c
+++ b/arch/arm/boards/animeo_ip/init.c
@@ -29,28 +29,56 @@
static bool animeo_ip_is_buco;
static bool animeo_ip_is_io;
+static int animeo_ip_get_pio_revision(int gpio, char *name)
+{
+ int ret;
+
+ ret = gpio_request(gpio, name);
+ if (ret) {
+ pr_err("animeo_ip: can not request gpio %d as %s (%d)\n",
+ gpio, name, ret);
+ return ret;
+ }
+
+ ret = gpio_direction_input(gpio);
+
+ if (ret) {
+ pr_err("animeo_ip: can configure gpio %d (%s) as input (%d)\n",
+ gpio, name, ret);
+ return ret;
+ }
+
+ return gpio_get_value(gpio);
+}
+
static void animeo_ip_detect_version(void)
{
struct device_d *dev = NULL;
char *model, *version;
+ int val;
- at91_set_gpio_input(AT91_PIN_PC20, 0);
- at91_set_gpio_input(AT91_PIN_PC21, 0);
-
- animeo_ip_is_buco = !!gpio_get_value(AT91_PIN_PC20);
- animeo_ip_is_io = !!gpio_get_value(AT91_PIN_PC21);
+ animeo_ip_is_io = false;
+ animeo_ip_is_buco = false;
+ model = "SubCo";
+ version = "SDN";
dev = add_generic_device_res("animeo_ip", DEVICE_ID_SINGLE, NULL, 0, NULL);
- if (animeo_ip_is_buco)
- model = "BuCo";
- else
+ val = animeo_ip_get_pio_revision(AT91_PIN_PC20, "is_buco");
+ if (val < 0) {
+ pr_warn("Can not detect model use %s by default\n", model);
+ } else if (val) {
+ animeo_ip_is_buco = true;
model = "SubCo";
+ }
- if (animeo_ip_is_io)
+ val = animeo_ip_get_pio_revision(AT91_PIN_PC21, "is_io");
+ if (val < 0) {
+ pr_warn("Can not detect version use %s by default\n", model);
+ } else if (val) {
+ animeo_ip_is_io = true;
version = "IO";
- else
- version = "SDN";
+ }
dev_add_param_fixed(dev, "model", model);
dev_add_param_fixed(dev, "version", version);