[ARM] S3C: Add GPIO chip tracking
authorBen Dooks <ben-linux@fluff.org>
Fri, 31 Oct 2008 16:14:32 +0000 (16:14 +0000)
committerBen Dooks <ben-linux@fluff.org>
Mon, 15 Dec 2008 23:33:42 +0000 (23:33 +0000)
The gpiolib driver keeps its chip array to itself
and having a separate array for s3c-only gpios stops
any non-s3c gpio being used in one of the s3c specific
configuration calls.

Signed-off-by: Ben Dooks <ben-linux@fluff.org>
arch/arm/plat-s3c/Kconfig
arch/arm/plat-s3c/gpio.c
arch/arm/plat-s3c/include/plat/gpio-core.h
arch/arm/plat-s3c64xx/Kconfig

index d7767e0305d08663b4a27d513f04929d21088650..77fc38f51874754ac7168ac71edb5fea76ab4950 100644 (file)
@@ -114,6 +114,12 @@ config S3C_GPIO_SPACE
          one bank to another to be caught, at the expense of using a little
          more memory.
 
+config S3C_GPIO_TRACK
+       bool
+       help
+         Internal configuration option to enable the s3c specific gpio
+         chip tracking if the platform requires it.
+
 # device definitions to compile in
 
 config S3C_DEV_HSMMC
index f035d4550c43cd3791a40a26a14a42c436291a80..d71dd6d9ce5ca4585bbc944d99ecbcebba6e6859 100644 (file)
 
 #include <plat/gpio-core.h>
 
+#ifdef CONFIG_S3C_GPIO_TRACK
+struct s3c_gpio_chip *s3c_gpios[S3C_GPIO_END];
+
+static __init void s3c_gpiolib_track(struct s3c_gpio_chip *chip)
+{
+       unsigned int gpn;
+       int i;
+
+       gpn = chip->chip.base;
+       for (i = 0; i < chip->chip.ngpio; i++, gpn++) {
+               BUG_ON(gpn > ARRAY_SIZE(s3c_gpios));
+               s3c_gpios[gpn] = chip;
+       }
+}
+#endif /* CONFIG_S3C_GPIO_TRACK */
+
 /* Default routines for controlling GPIO, based on the original S3C24XX
  * GPIO functions which deal with the case where each gpio bank of the
  * chip is as following:
@@ -109,6 +125,7 @@ static int s3c_gpiolib_get(struct gpio_chip *chip, unsigned offset)
 __init void s3c_gpiolib_add(struct s3c_gpio_chip *chip)
 {
        struct gpio_chip *gc = &chip->chip;
+       int ret;
 
        BUG_ON(!chip->base);
        BUG_ON(!gc->label);
@@ -124,5 +141,7 @@ __init void s3c_gpiolib_add(struct s3c_gpio_chip *chip)
                gc->get = s3c_gpiolib_get;
 
        /* gpiochip_add() prints own failure message on error. */
-       gpiochip_add(gc);
+       ret = gpiochip_add(gc);
+       if (ret >= 0)
+               s3c_gpiolib_track(chip);
 }
index 3cb9105c4811f77a0b729b819ac8c44f0aa31956..ad68b32a7f9d7646a7e65e66ac3f92613ca0a8b5 100644 (file)
@@ -47,3 +47,26 @@ static inline struct s3c_gpio_chip *to_s3c_gpio(struct gpio_chip *gpc)
  * other parts of the system.
  */
 extern void s3c_gpiolib_add(struct s3c_gpio_chip *chip);
+
+
+/* CONFIG_S3C_GPIO_TRACK enables the tracking of the s3c specific gpios
+ * for use with the configuration calls, and other parts of the s3c gpiolib
+ * support code.
+ *
+ * Not all s3c support code will need this, as some configurations of cpu
+ * may only support one or two different configuration options and have an
+ * easy gpio to s3c_gpio_chip mapping function. If this is the case, then
+ * the machine support file should provide its own s3c_gpiolib_getchip()
+ * and any other necessary functions.
+ */
+
+#ifdef CONFIG_S3C_GPIO_TRACK
+extern struct s3c_gpio_chip *s3c_gpios[S3C_GPIO_END];
+
+static inline struct s3c_gpio_chip *s3c_gpiolib_getchip(unsigned int chip)
+{
+       return s3c_gpios[chip];
+}
+#else
+static inline void s3c_gpiolib_track(struct s3c_gpio_chip *chip) { }
+#endif
index bd832ba0cf77c11f10c6ffcbfa5ee200e77d9205..3df2ec19d08a6933cac9b1ec3e8576fa7cb8e994 100644 (file)
@@ -14,6 +14,7 @@ config PLAT_S3C64XX
        default y
        select NO_IOPORT
        select ARCH_REQUIRE_GPIOLIB
+       select S3C_GPIO_TRACK
        help
          Base platform code for any Samsung S3C64XX device