Ping? On Tuesday 30 September 2014 17:40:47, Alexander Stein wrote: > This features already exists for board config setups. Add support for > device tree based systems. > > Signed-off-by: Alexander Stein <alexander.stein@xxxxxxxxxxxxxxxxxxxxx> > --- > I'm aware thatthe device tree binding description is missing yet. But for now > I just want some feedback about that approach. > > drivers/input/keyboard/gpio_keys.c | 31 ++++++++++++++++++------------- > 1 file changed, 18 insertions(+), 13 deletions(-) > > diff --git a/drivers/input/keyboard/gpio_keys.c b/drivers/input/keyboard/gpio_keys.c > index 8c98e97..7b90e1b 100644 > --- a/drivers/input/keyboard/gpio_keys.c > +++ b/drivers/input/keyboard/gpio_keys.c > @@ -29,6 +29,7 @@ > #include <linux/of.h> > #include <linux/of_platform.h> > #include <linux/of_gpio.h> > +#include <linux/of_irq.h> > #include <linux/spinlock.h> > > struct gpio_button_data { > @@ -617,28 +618,32 @@ gpio_keys_get_devtree_pdata(struct device *dev) > > i = 0; > for_each_child_of_node(node, pp) { > - int gpio; > + int gpio = -1; > + int irq; > enum of_gpio_flags flags; > > - if (!of_find_property(pp, "gpios", NULL)) { > + irq = irq_of_parse_and_map(pp, 0); > + > + if (of_find_property(pp, "gpios", NULL)) { > + gpio = of_get_gpio_flags(pp, 0, &flags); > + if (gpio < 0) { > + error = gpio; > + if (error != -EPROBE_DEFER) > + dev_err(dev, > + "Failed to get gpio flags, error: %d\n", > + error); > + return ERR_PTR(error); > + } > + } else if (irq == 0) { > pdata->nbuttons--; > - dev_warn(dev, "Found button without gpios\n"); > + dev_warn(dev, "Found button without gpios or irqs\n"); > continue; > } > > - gpio = of_get_gpio_flags(pp, 0, &flags); > - if (gpio < 0) { > - error = gpio; > - if (error != -EPROBE_DEFER) > - dev_err(dev, > - "Failed to get gpio flags, error: %d\n", > - error); > - return ERR_PTR(error); > - } > - > button = &pdata->buttons[i++]; > > button->gpio = gpio; > + button->irq = irq; > button->active_low = flags & OF_GPIO_ACTIVE_LOW; > > if (of_property_read_u32(pp, "linux,code", &button->code)) { > -- Dipl.-Inf. Alexander Stein SYS TEC electronic GmbH Am Windrad 2 08468 Heinsdorfergrund Tel.: 03765 38600-1156 Fax: 03765 38600-4100 Email: alexander.stein@xxxxxxxxxxxxxxxxxxxxx Website: www.systec-electronic.com Managing Director: Dipl.-Phys. Siegmar Schmidt Commercial registry: Amtsgericht Chemnitz, HRB 28082 -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html