The GPIOLIB allows the specification of a base gpio number for a
controller. That is not possible using OF. Instead, free gpio numbers
are assigned.

In order to allow static, predefined gpio numbers, a base property in
the gpio controller node specifies the first gpio number.

Signed-off-by: Wolfgang Ocker <[EMAIL PROTECTED]>
---

--- linux-2.6.27-rc7/drivers/of/gpio.c.of_gpiospecbase  2008-09-22 
00:29:55.000000000 +0200
+++ linux-2.6.27-rc7/drivers/of/gpio.c  2008-09-29 13:50:28.000000000 +0200
@@ -164,6 +164,8 @@
        int ret = -ENOMEM;
        struct of_gpio_chip *of_gc = &mm_gc->of_gc;
        struct gpio_chip *gc = &of_gc->gc;
+       const int *basep;
+       int baselen;
 
        gc->label = kstrdup(np->full_name, GFP_KERNEL);
        if (!gc->label)
@@ -173,7 +175,11 @@
        if (!mm_gc->regs)
                goto err1;
 
-       gc->base = -1;
+       basep = of_get_property(np, "base", &baselen);
+       if (!basep || baselen != sizeof(*basep))
+               gc->base = -1;
+       else
+               gc->base = *basep;
 
        if (!of_gc->xlate)
                of_gc->xlate = of_gpio_simple_xlate;
--- linux-2.6.27-rc7/Documentation/powerpc/booting-without-of.txt.spi_gpio_doc  
2008-09-29 14:14:08.000000000 +0200
+++ linux-2.6.27-rc7/Documentation/powerpc/booting-without-of.txt       
2008-09-29 14:24:26.000000000 +0200
@@ -2586,6 +2588,7 @@
                #gpio-cells = <2>;
                compatible = "fsl,qe-pario-bank-a", "fsl,qe-pario-bank";
                reg = <0x1400 0x18>;
+               base = < 0x20 >;
                gpio-controller;
        };
 



_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to