Message ID | 1398322659-20008-1-git-send-email-yegorslists@googlemail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Thu, Apr 24, 2014 at 8:57 AM, <yegorslists@googlemail.com> wrote: > From: Yegor Yefremov <yegorslists@googlemail.com> > > This patch implements gpio_chip's get_direction() routine, that > lets other drivers get particular GPIOs direction using > struct gpio_desc. > > Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com> > Acked-by: Javier Martinez Canillas <javier@dowhile0.org> > --- > Changes: > v3: get rid of _get_gpio_direction() (Linus Walleij) > v2: rework return value calculation Looks good to me, Kevin, Santosh? Part of me wants to list Javier as maintainer for this driver. > +static int gpio_get_direction(struct gpio_chip *chip, unsigned offset) > +{ > + struct gpio_bank *bank; > + unsigned long flags; > + void __iomem *reg; > + int dir; That is a bool, actually. But no big deal. > + > + bank = container_of(chip, struct gpio_bank, chip); > + reg = bank->base + bank->regs->direction; > + spin_lock_irqsave(&bank->lock, flags); > + dir = !!(readl_relaxed(reg) & BIT(offset)); > + spin_unlock_irqrestore(&bank->lock, flags); > + return dir; > +} Yours, Linus Walleij
On Thursday 24 April 2014 09:13 AM, Linus Walleij wrote: > On Thu, Apr 24, 2014 at 8:57 AM, <yegorslists@googlemail.com> wrote: > >> From: Yegor Yefremov <yegorslists@googlemail.com> >> >> This patch implements gpio_chip's get_direction() routine, that >> lets other drivers get particular GPIOs direction using >> struct gpio_desc. >> >> Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com> >> Acked-by: Javier Martinez Canillas <javier@dowhile0.org> >> --- >> Changes: >> v3: get rid of _get_gpio_direction() (Linus Walleij) >> v2: rework return value calculation > > Looks good to me, Kevin, Santosh? > Looks fine to me as well. Acked-by: Santosh Shilimkar <santosh.shilimkar@ti.com> > Part of me wants to list Javier as maintainer for this driver. > Am ok with it as well.
On Thu, Apr 24, 2014 at 8:57 AM, <yegorslists@googlemail.com> wrote: > From: Yegor Yefremov <yegorslists@googlemail.com> > > This patch implements gpio_chip's get_direction() routine, that > lets other drivers get particular GPIOs direction using > struct gpio_desc. > > Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com> > Acked-by: Javier Martinez Canillas <javier@dowhile0.org> > --- > Changes: > v3: get rid of _get_gpio_direction() (Linus Walleij) > v2: rework return value calculation This v3 version applied with Santosh's ACK. Yours, Linus Walleij
* Santosh Shilimkar <santosh.shilimkar@ti.com> [140424 06:30]: > On Thursday 24 April 2014 09:13 AM, Linus Walleij wrote: > > On Thu, Apr 24, 2014 at 8:57 AM, <yegorslists@googlemail.com> wrote: > > > >> From: Yegor Yefremov <yegorslists@googlemail.com> > >> > >> This patch implements gpio_chip's get_direction() routine, that > >> lets other drivers get particular GPIOs direction using > >> struct gpio_desc. > >> > >> Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com> > >> Acked-by: Javier Martinez Canillas <javier@dowhile0.org> > >> --- > >> Changes: > >> v3: get rid of _get_gpio_direction() (Linus Walleij) > >> v2: rework return value calculation > > > > Looks good to me, Kevin, Santosh? > > > Looks fine to me as well. > Acked-by: Santosh Shilimkar <santosh.shilimkar@ti.com> OK finally got around testing gpio/for-next here. Could not use todays linux next as it's broken again for whatever reasons and does not even compile for me. Boot tested gpio/next on few omap1 boards: h2, osk and 770 and things behave the same way as earlier for me on these boards. Also made sure the PM does not break as tested on n900 with the GPIO changes. So for the following patches, feel free to add: cb2a5fb059b5 gpio: do not set up hardware for IRQ_TYPE_NONE da09ceae78f7 gpio: omap: implement get_direction d04b76626e94 gpio: omap: convert driver to use gpiolib irqchip d4094cd7577c gpio: omap: check gpiochip_add() return value 820eade1b7f3 gpio: omap: convert to use irq_domain_add_simple() 717f70e39a98 gpio: omap: Use devm_ioremap_resource() Tested-by: Tony Lindgren <tony@atomide.com> Naturally no need to go back to edit the commits for my acks unless there are other reasons to redo the branches. > > Part of me wants to list Javier as maintainer for this driver. > > > Am ok with it as well. That sounds good to me too, looks like Javier is doing a good job on that already :) Regards, Tony
Linus Walleij <linus.walleij@linaro.org> writes: > On Thu, Apr 24, 2014 at 8:57 AM, <yegorslists@googlemail.com> wrote: > >> From: Yegor Yefremov <yegorslists@googlemail.com> >> >> This patch implements gpio_chip's get_direction() routine, that >> lets other drivers get particular GPIOs direction using >> struct gpio_desc. >> >> Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com> >> Acked-by: Javier Martinez Canillas <javier@dowhile0.org> >> --- >> Changes: >> v3: get rid of _get_gpio_direction() (Linus Walleij) >> v2: rework return value calculation > > Looks good to me, Kevin, Santosh? Reviewed-by: Kevin Hilman <khilman@linaro.org> > Part of me wants to list Javier as maintainer for this driver. That's fine with me. Kevin
diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c index 19b886c..62c12e4 100644 --- a/drivers/gpio/gpio-omap.c +++ b/drivers/gpio/gpio-omap.c @@ -27,6 +27,7 @@ #include <linux/irqdomain.h> #include <linux/irqchip/chained_irq.h> #include <linux/gpio.h> +#include <linux/bitops.h> #include <linux/platform_data/gpio-omap.h> #define OFF_MODE 1 @@ -936,6 +937,21 @@ static inline void mpuio_init(struct gpio_bank *bank) /*---------------------------------------------------------------------*/ +static int gpio_get_direction(struct gpio_chip *chip, unsigned offset) +{ + struct gpio_bank *bank; + unsigned long flags; + void __iomem *reg; + int dir; + + bank = container_of(chip, struct gpio_bank, chip); + reg = bank->base + bank->regs->direction; + spin_lock_irqsave(&bank->lock, flags); + dir = !!(readl_relaxed(reg) & BIT(offset)); + spin_unlock_irqrestore(&bank->lock, flags); + return dir; +} + static int gpio_input(struct gpio_chip *chip, unsigned offset) { struct gpio_bank *bank; @@ -1092,6 +1108,7 @@ static void omap_gpio_chip_init(struct gpio_bank *bank) */ bank->chip.request = omap_gpio_request; bank->chip.free = omap_gpio_free; + bank->chip.get_direction = gpio_get_direction; bank->chip.direction_input = gpio_input; bank->chip.get = gpio_get; bank->chip.direction_output = gpio_output;