summaryrefslogtreecommitdiffstats
path: root/drivers/gpio
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2013-11-21 11:19:36 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2013-11-27 10:42:53 +0100
commit15d60e523086a642ced3bf4f07e2666098845fc6 (patch)
treef8bc9a3c5140f91d4cb9a16365e5153a2d8c46c5 /drivers/gpio
parent5c8ea4ff9a0f305334d3aa73a35a3898bd2a61f6 (diff)
downloadbarebox-15d60e523086a642ced3bf4f07e2666098845fc6.tar.gz
barebox-15d60e523086a642ced3bf4f07e2666098845fc6.tar.xz
gpio: omap: Add devicetree probe support
This adds devicetree probe support for the OMAP gpio ports and also makes sure the corresponding platform_devices don't get registered when they are already present from devicetree. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'drivers/gpio')
-rw-r--r--drivers/gpio/gpio-omap.c39
1 files changed, 38 insertions, 1 deletions
diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c
index 49ffbda503..e66a614f21 100644
--- a/drivers/gpio/gpio-omap.c
+++ b/drivers/gpio/gpio-omap.c
@@ -48,6 +48,18 @@ struct omap_gpio_chip {
struct gpio_chip chip;
};
+struct omap_gpio_drvdata {
+ unsigned int regofs;
+};
+
+static struct omap_gpio_drvdata gpio_omap3_drvdata = {
+ .regofs = 0x0,
+};
+
+static struct omap_gpio_drvdata gpio_omap4_drvdata = {
+ .regofs = 0x100,
+};
+
static inline int omap_get_gpio_index(int gpio)
{
return gpio & 0x1f;
@@ -129,11 +141,24 @@ static struct gpio_ops omap_gpio_ops = {
static int omap_gpio_probe(struct device_d *dev)
{
struct omap_gpio_chip *omapgpio;
+ struct omap_gpio_drvdata *drvdata = NULL;
+
+ dev_get_drvdata(dev, (unsigned long *)&drvdata);
omapgpio = xzalloc(sizeof(*omapgpio));
omapgpio->base = dev_request_mem_region(dev, 0);
+ if (drvdata)
+ omapgpio->base += drvdata->regofs;
+
omapgpio->chip.ops = &omap_gpio_ops;
- omapgpio->chip.base = dev->id * 32;
+ if (dev->id < 0) {
+ omapgpio->chip.base = of_alias_get_id(dev->device_node, "gpio");
+ if (omapgpio->chip.base < 0)
+ return omapgpio->chip.base;
+ omapgpio->chip.base *= 32;
+ } else {
+ omapgpio->chip.base = dev->id * 32;
+ }
omapgpio->chip.ngpio = 32;
omapgpio->chip.dev = dev;
gpiochip_add(&omapgpio->chip);
@@ -144,9 +169,21 @@ static int omap_gpio_probe(struct device_d *dev)
return 0;
}
+static __maybe_unused struct of_device_id omap_gpio_dt_ids[] = {
+ {
+ .compatible = "ti,omap4-gpio",
+ .data = (unsigned long)&gpio_omap4_drvdata,
+ }, {
+ .compatible = "ti,omap3-gpio",
+ .data = (unsigned long)&gpio_omap3_drvdata,
+ }, {
+ }
+};
+
static struct driver_d omap_gpio_driver = {
.name = "omap-gpio",
.probe = omap_gpio_probe,
+ .of_compatible = DRV_OF_COMPAT(omap_gpio_dt_ids),
};
static int omap_gpio_add(void)