On Wednesday, December 09, 2015 6:13 AM, Linus Walleij wrote: > The separate struct bgpio_chip has been a pain to handle, both > by being confusingly similar in name to struct gpio_chip and > for being contained inside a struct so that struct gpio_chip > is contained in a struct contained in a struct, making several > steps of dereferencing necessary. > > Make things simpler: include the fields directly into > <linux/gpio/driver.h>, #ifdef:ed for CONFIG_GENERIC_GPIO, and > get rid of the <linux/basic_mmio_gpio.h> altogether. Prefix > some of the member variables with bgpio_* and add proper > kerneldoc while we're at it. > > Modify all users to handle the change and use a struct > gpio_chip directly. And while we're at it: replace all > container_of() dereferencing by gpiochip_get_data() and > registering the gpio_chip with gpiochip_add_data(). > > Cc: arm@xxxxxxxxxx > Cc: Lee Jones <lee.jones@xxxxxxxxxx> > Cc: Alexander Shiyan <shc_work@xxxxxxx> > Cc: Shawn Guo <shawnguo@xxxxxxxxxx> > Cc: Sascha Hauer <kernel@xxxxxxxxxxxxxx> > Cc: Tony Lindgren <tony@xxxxxxxxxxx> > Cc: Kukjin Kim <kgene@xxxxxxxxxx> > Cc: Krzysztof Kozlowski <k.kozlowski@xxxxxxxxxxx> > Cc: Alexandre Courbot <gnurou@xxxxxxxxx> > Cc: Gregory Fong <gregory.0xf0@xxxxxxxxx> > Cc: Brian Norris <computersforpeace@xxxxxxxxx> > Cc: Florian Fainelli <f.fainelli@xxxxxxxxx> > Cc: Liviu Dudau <liviu.dudau@xxxxxxx> > Cc: Sudeep Holla <sudeep.holla@xxxxxxx> > Cc: Lorenzo Pieralisi <lorenzo.pieralisi@xxxxxxx> > Cc: Nicolas Pitre <nicolas.pitre@xxxxxxxxxx> > Cc: Olof Johansson <olof@xxxxxxxxx> > Cc: Vladimir Zapolskiy <vladimir_zapolskiy@xxxxxxxxxx> > Cc: Rabin Vincent <rabin@xxxxxx> > Cc: linux-arm-kernel@xxxxxxxxxxxxxxxxxxx > Cc: linux-omap@xxxxxxxxxxxxxxx > Cc: linux-samsung-soc@xxxxxxxxxxxxxxx > Cc: bcm-kernel-feedback-list@xxxxxxxxxxxx > Signed-off-by: Linus Walleij <linus.walleij@xxxxxxxxxx> > --- > ARM SoC folks and Lee: it would be great if you could > ACK the few lines hitting arch/arm/* and drivers/mfd/* in this > so I can take it through the GPIO tree. > --- <snip> > drivers/gpio/gpio-ep93xx.c | 25 +-- <snip> > diff --git a/drivers/gpio/gpio-ep93xx.c b/drivers/gpio/gpio-ep93xx.c > index 3e3947b35c83..ad279078fed7 100644 > --- a/drivers/gpio/gpio-ep93xx.c > +++ b/drivers/gpio/gpio-ep93xx.c > @@ -16,10 +16,11 @@ > #include <linux/module.h> > #include <linux/platform_device.h> > #include <linux/io.h> > -#include <linux/gpio.h> > #include <linux/irq.h> > #include <linux/slab.h> > -#include <linux/basic_mmio_gpio.h> > +#include <linux/gpio/driver.h> > +/* FIXME: this is here for gpio_to_irq() - get rid of this! */ > +#include <linux/gpio.h> > > #include <mach/hardware.h> > #include <mach/gpio-ep93xx.h> > @@ -28,7 +29,7 @@ > > struct ep93xx_gpio { > void __iomem *mmio_base; > - struct bgpio_chip bgc[8]; > + struct gpio_chip gc[8]; > }; > > /************************************************************************* > @@ -319,26 +320,26 @@ static int ep93xx_gpio_to_irq(struct gpio_chip *chip, unsigned offset) > return 64 + gpio; > } > > -static int ep93xx_gpio_add_bank(struct bgpio_chip *bgc, struct device *dev, > +static int ep93xx_gpio_add_bank(struct gpio_chip *gc, struct device *dev, > void __iomem *mmio_base, struct ep93xx_gpio_bank *bank) > { > void __iomem *data = mmio_base + bank->data; > void __iomem *dir = mmio_base + bank->dir; > int err; > > - err = bgpio_init(bgc, dev, 1, data, NULL, NULL, dir, NULL, 0); > + err = bgpio_init(gc, dev, 1, data, NULL, NULL, dir, NULL, 0); > if (err) > return err; > > - bgc->gc.label = bank->label; > - bgc->gc.base = bank->base; > + gc->label = bank->label; > + gc->base = bank->base; > > if (bank->has_debounce) { > - bgc->gc.set_debounce = ep93xx_gpio_set_debounce; > - bgc->gc.to_irq = ep93xx_gpio_to_irq; > + gc->set_debounce = ep93xx_gpio_set_debounce; > + gc->to_irq = ep93xx_gpio_to_irq; > } > > - return gpiochip_add(&bgc->gc); > + return gpiochip_add_data(gc, NULL); > } > > static int ep93xx_gpio_probe(struct platform_device *pdev) > @@ -358,10 +359,10 @@ static int ep93xx_gpio_probe(struct platform_device *pdev) > return PTR_ERR(ep93xx_gpio->mmio_base); > > for (i = 0; i < ARRAY_SIZE(ep93xx_gpio_banks); i++) { > - struct bgpio_chip *bgc = &ep93xx_gpio->bgc[i]; > + struct gpio_chip *gc = &ep93xx_gpio->gc[i]; > struct ep93xx_gpio_bank *bank = &ep93xx_gpio_banks[i]; > > - if (ep93xx_gpio_add_bank(bgc, &pdev->dev, > + if (ep93xx_gpio_add_bank(gc, &pdev->dev, > ep93xx_gpio->mmio_base, bank)) > dev_warn(&pdev->dev, "Unable to add gpio bank %s\n", > bank->label); For the drivers/gpio/gpio-ep93xx.c part: Acked-by: H Hartley Sweeten <hsweeten@xxxxxxxxxxxxxxxxxxx> -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html