x86: gpio: Correct GPIO setup ordering
authorSimon Glass <sjg@chromium.org>
Mon, 7 Mar 2016 02:28:13 +0000 (19:28 -0700)
committerBin Meng <bmeng.cn@gmail.com>
Thu, 17 Mar 2016 02:27:23 +0000 (10:27 +0800)
The Intel GPIO driver can set up the GPIO pin mapping when the first GPIO
is probed. However, it assumes that the first GPIO to be probed is in the
first GPIO bank. If this is not the case then the init will write to the
wrong registers.

Fix this. Also add a note that this code is deprecated. We should move to
using device tree instead.

Signed-off-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
arch/x86/include/asm/gpio.h
drivers/gpio/intel_ich6_gpio.c

index 403851b79275b16c9b7b9b4dc869c3df201edda8..40f4958052fca59b76fe13dc7f434e94ce0ba29f 100644 (file)
@@ -12,6 +12,7 @@
 struct ich6_bank_platdata {
        uint16_t base_addr;
        const char *bank_name;
+       int offset;
 };
 
 #define GPIO_MODE_NATIVE       0
@@ -146,6 +147,10 @@ struct pch_gpio_map {
        } set3;
 };
 
+/*
+ * Deprecated functions to set up the GPIO map. The device tree should be used
+ * instead.
+ */
 int gpio_ich6_pinctrl_init(void);
 void setup_pch_gpios(u16 gpiobase, const struct pch_gpio_map *gpio);
 void ich_gpio_set_gpio_map(const struct pch_gpio_map *map);
index 527ed6d0faba63401d100adc0c63e0304fdcff75..c81d0332c4748c4473af3fb0511b546be085d69d 100644 (file)
@@ -279,6 +279,7 @@ static int gpio_ich6_ofdata_to_platdata(struct udevice *dev)
                debug("%s: Invalid register offset %d\n", __func__, offset);
                return -EINVAL;
        }
+       plat->offset = offset;
        plat->base_addr = gpiobase + offset;
        plat->bank_name = fdt_getprop(gd->fdt_blob, dev->of_offset,
                                      "bank-name", NULL);
@@ -293,7 +294,8 @@ static int ich6_gpio_probe(struct udevice *dev)
        struct ich6_bank_priv *bank = dev_get_priv(dev);
 
        if (gd->arch.gpio_map) {
-               setup_pch_gpios(plat->base_addr, gd->arch.gpio_map);
+               setup_pch_gpios(plat->base_addr - plat->offset,
+                               gd->arch.gpio_map);
                gd->arch.gpio_map = NULL;
        }