* [PATCH] gpio: pl061: add DT binding support
@ 2011-08-03 18:54 Rob Herring
2011-08-03 19:10 ` Baruch Siach
` (2 more replies)
0 siblings, 3 replies; 12+ messages in thread
From: Rob Herring @ 2011-08-03 18:54 UTC (permalink / raw)
To: linux-arm-kernel
From: Rob Herring <rob.herring@calxeda.com>
This adds devicetree binding support to the ARM pl061 driver removing the
platform_data dependency. When DT binding is used, the gpio numbering is
assigned dynamically. The interrupt assignment is converted to use the
irq_domain infrastructure.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Cc: Grant Likely <grant.likely@secretlab.ca>
---
drivers/gpio/gpio-pl061.c | 32 +++++++++++++++++++++++---------
1 files changed, 23 insertions(+), 9 deletions(-)
diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
index 2c5a18f..7ea74ff 100644
--- a/drivers/gpio/gpio-pl061.c
+++ b/drivers/gpio/gpio-pl061.c
@@ -23,6 +23,7 @@
#include <linux/amba/bus.h>
#include <linux/amba/pl061.h>
#include <linux/slab.h>
+#include <linux/of_irq.h>
#define GPIODIR 0x400
#define GPIOIS 0x404
@@ -246,6 +247,20 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
if (chip == NULL)
return -ENOMEM;
+ pdata = dev->dev.platform_data;
+ if (pdata) {
+ chip->gc.base = pdata->gpio_base;
+ chip->irq_base = pdata->irq_base;
+ } else if (dev->dev.of_node) {
+ u32 intspec = 0;
+ chip->gc.base = -1;
+ chip->irq_base = irq_create_of_mapping(dev->dev.of_node,
+ &intspec, 1);
+ } else {
+ ret = -ENODEV;
+ goto free_mem;
+ }
+
if (!request_mem_region(dev->res.start,
resource_size(&dev->res), "pl061")) {
ret = -EBUSY;
@@ -267,14 +282,11 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
chip->gc.get = pl061_get_value;
chip->gc.set = pl061_set_value;
chip->gc.to_irq = pl061_to_irq;
- chip->gc.base = pdata->gpio_base;
chip->gc.ngpio = PL061_GPIO_NR;
chip->gc.label = dev_name(&dev->dev);
chip->gc.dev = &dev->dev;
chip->gc.owner = THIS_MODULE;
- chip->irq_base = pdata->irq_base;
-
ret = gpiochip_add(&chip->gc);
if (ret)
goto iounmap;
@@ -283,7 +295,7 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
* irq_chip support
*/
- if (chip->irq_base == (unsigned) -1)
+ if (chip->irq_base == NO_IRQ)
return 0;
writeb(0, chip->base + GPIOIE); /* disable irqs */
@@ -307,11 +319,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
list_add(&chip->list, chip_list);
for (i = 0; i < PL061_GPIO_NR; i++) {
- if (pdata->directions & (1 << i))
- pl061_direction_output(&chip->gc, i,
- pdata->values & (1 << i));
- else
- pl061_direction_input(&chip->gc, i);
+ if (pdata) {
+ if (pdata->directions & (1 << i))
+ pl061_direction_output(&chip->gc, i,
+ pdata->values & (1 << i));
+ else
+ pl061_direction_input(&chip->gc, i);
+ }
irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
handle_simple_irq);
--
1.7.4.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH] gpio: pl061: add DT binding support
2011-08-03 18:54 [PATCH] gpio: pl061: add DT binding support Rob Herring
@ 2011-08-03 19:10 ` Baruch Siach
2011-08-03 22:22 ` Grant Likely
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
2 siblings, 0 replies; 12+ messages in thread
From: Baruch Siach @ 2011-08-03 19:10 UTC (permalink / raw)
To: linux-arm-kernel
Hi Rob,
On Wed, Aug 03, 2011 at 01:54:21PM -0500, Rob Herring wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> This adds devicetree binding support to the ARM pl061 driver removing the
> platform_data dependency. When DT binding is used, the gpio numbering is
> assigned dynamically. The interrupt assignment is converted to use the
> irq_domain infrastructure.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>
> ---
> drivers/gpio/gpio-pl061.c | 32 +++++++++++++++++++++++---------
> 1 files changed, 23 insertions(+), 9 deletions(-)
>
[snip]
> @@ -283,7 +295,7 @@ static int pl061_probe(struct amba_device *dev, const
> struct amba_id *id)
> * irq_chip support
> */
>
> - if (chip->irq_base == (unsigned) -1)
> + if (chip->irq_base == NO_IRQ)
Please update the comment at include/linux/amba/pl061.h as well.
> return 0;
>
> writeb(0, chip->base + GPIOIE); /* disable irqs */
> @@ -307,11 +319,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
[snip]
baruch
--
~. .~ Tk Open Systems
=}------------------------------------------------ooO--U--Ooo------------{=
- baruch at tkos.co.il - tel: +972.2.679.5364, http://www.tkos.co.il -
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] gpio: pl061: add DT binding support
2011-08-03 18:54 [PATCH] gpio: pl061: add DT binding support Rob Herring
2011-08-03 19:10 ` Baruch Siach
@ 2011-08-03 22:22 ` Grant Likely
2011-08-03 23:18 ` Rob Herring
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
2 siblings, 1 reply; 12+ messages in thread
From: Grant Likely @ 2011-08-03 22:22 UTC (permalink / raw)
To: linux-arm-kernel
On Wed, Aug 3, 2011 at 7:54 PM, Rob Herring <robherring2@gmail.com> wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> This adds devicetree binding support to the ARM pl061 driver removing the
> platform_data dependency. When DT binding is used, the gpio numbering is
> assigned dynamically. The interrupt assignment is converted to use the
> irq_domain infrastructure.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>
> ---
> ?drivers/gpio/gpio-pl061.c | ? 32 +++++++++++++++++++++++---------
> ?1 files changed, 23 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> index 2c5a18f..7ea74ff 100644
> --- a/drivers/gpio/gpio-pl061.c
> +++ b/drivers/gpio/gpio-pl061.c
> @@ -23,6 +23,7 @@
> ?#include <linux/amba/bus.h>
> ?#include <linux/amba/pl061.h>
> ?#include <linux/slab.h>
> +#include <linux/of_irq.h>
>
> ?#define GPIODIR 0x400
> ?#define GPIOIS ?0x404
> @@ -246,6 +247,20 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> ? ? ? ?if (chip == NULL)
> ? ? ? ? ? ? ? ?return -ENOMEM;
>
> + ? ? ? pdata = dev->dev.platform_data;
> + ? ? ? if (pdata) {
> + ? ? ? ? ? ? ? chip->gc.base = pdata->gpio_base;
> + ? ? ? ? ? ? ? chip->irq_base = pdata->irq_base;
> + ? ? ? } else if (dev->dev.of_node) {
> + ? ? ? ? ? ? ? u32 intspec = 0;
> + ? ? ? ? ? ? ? chip->gc.base = -1;
> + ? ? ? ? ? ? ? chip->irq_base = irq_create_of_mapping(dev->dev.of_node,
> + ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?&intspec, 1);
This looks wrong. intspec is always 0 here, when I would assume you
would want the value of the interrupts property from this device's
node. Is this the cascade irq number? Or is it supposed to be the
starting interrupt number for the gpios? If it is starting interrupt
number, then it should actually be dynamically assigned. If it is the
cascade, then platform_get_irq() should work.
g.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] gpio: pl061: add DT binding support
2011-08-03 22:22 ` Grant Likely
@ 2011-08-03 23:18 ` Rob Herring
2011-10-24 22:26 ` Grant Likely
0 siblings, 1 reply; 12+ messages in thread
From: Rob Herring @ 2011-08-03 23:18 UTC (permalink / raw)
To: linux-arm-kernel
Grant,
On 08/03/2011 05:22 PM, Grant Likely wrote:
> On Wed, Aug 3, 2011 at 7:54 PM, Rob Herring <robherring2@gmail.com> wrote:
>> From: Rob Herring <rob.herring@calxeda.com>
>>
>> This adds devicetree binding support to the ARM pl061 driver removing the
>> platform_data dependency. When DT binding is used, the gpio numbering is
>> assigned dynamically. The interrupt assignment is converted to use the
>> irq_domain infrastructure.
>>
>> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
>> Cc: Grant Likely <grant.likely@secretlab.ca>
>> ---
>> drivers/gpio/gpio-pl061.c | 32 +++++++++++++++++++++++---------
>> 1 files changed, 23 insertions(+), 9 deletions(-)
>>
>> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
>> index 2c5a18f..7ea74ff 100644
>> --- a/drivers/gpio/gpio-pl061.c
>> +++ b/drivers/gpio/gpio-pl061.c
>> @@ -23,6 +23,7 @@
>> #include <linux/amba/bus.h>
>> #include <linux/amba/pl061.h>
>> #include <linux/slab.h>
>> +#include <linux/of_irq.h>
>>
>> #define GPIODIR 0x400
>> #define GPIOIS 0x404
>> @@ -246,6 +247,20 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>> if (chip == NULL)
>> return -ENOMEM;
>>
>> + pdata = dev->dev.platform_data;
>> + if (pdata) {
>> + chip->gc.base = pdata->gpio_base;
>> + chip->irq_base = pdata->irq_base;
>> + } else if (dev->dev.of_node) {
>> + u32 intspec = 0;
>> + chip->gc.base = -1;
>> + chip->irq_base = irq_create_of_mapping(dev->dev.of_node,
>> + &intspec, 1);
>
> This looks wrong. intspec is always 0 here, when I would assume you
> would want the value of the interrupts property from this device's
> node. Is this the cascade irq number? Or is it supposed to be the
> starting interrupt number for the gpios? If it is starting interrupt
> number, then it should actually be dynamically assigned. If it is the
> cascade, then platform_get_irq() should work.
>
It's the latter case that I need to retrieve. I have this platform code
assigning the linux irq numbers:
struct device_node *node;
int n = 0;
node = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-gic");
if (!node)
panic("missing gic devicetree node\n");
irq_domain_add_simple(node, 0);
for_each_compatible_node(node, NULL, "arm,pl061") {
irq_domain_add_simple(node, 160 + (8 * n));
n++;
}
In this case with simple translation, intspec is really a don't care.
irq_create_of_mapping just finds the domain that matches the gpio
ctrlr's node and returns the domain's irq_base (+ 0) as the translate
function will just return the intspec value for the hw_irq.
Have I missed something? There is not yet any dynamic assignment of
linux irq numbers?
Rob
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-08-03 18:54 [PATCH] gpio: pl061: add DT binding support Rob Herring
2011-08-03 19:10 ` Baruch Siach
2011-08-03 22:22 ` Grant Likely
@ 2011-08-10 21:31 ` Rob Herring
2011-08-11 6:36 ` Baruch Siach
` (2 more replies)
2 siblings, 3 replies; 12+ messages in thread
From: Rob Herring @ 2011-08-10 21:31 UTC (permalink / raw)
To: linux-arm-kernel
From: Rob Herring <rob.herring@calxeda.com>
This adds devicetree binding support to the ARM pl061 driver removing the
platform_data dependency. When DT binding is used, the gpio numbering is
assigned dynamically. For now, interrupts are not supported with DT until
irqdomains learn dynamic irq assignment.
Rather than add another case of -1, updating the driver to use NO_IRQ.
Signed-off-by: Rob Herring <rob.herring@calxeda.com>
Cc: Grant Likely <grant.likely@secretlab.ca>
---
v2:
- Add other -1 to NO_IRQ conversions
- Drop DT irq support for now
drivers/gpio/gpio-pl061.c | 31 +++++++++++++++++++++----------
include/linux/amba/pl061.h | 3 +--
2 files changed, 22 insertions(+), 12 deletions(-)
diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
index 2c5a18f..093c90b 100644
--- a/drivers/gpio/gpio-pl061.c
+++ b/drivers/gpio/gpio-pl061.c
@@ -118,7 +118,7 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
{
struct pl061_gpio *chip = container_of(gc, struct pl061_gpio, gc);
- if (chip->irq_base == (unsigned) -1)
+ if (chip->irq_base == NO_IRQ)
return -EINVAL;
return chip->irq_base + offset;
@@ -246,6 +246,18 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
if (chip == NULL)
return -ENOMEM;
+ pdata = dev->dev.platform_data;
+ if (pdata) {
+ chip->gc.base = pdata->gpio_base;
+ chip->irq_base = pdata->irq_base;
+ } else if (dev->dev.of_node) {
+ chip->gc.base = -1;
+ chip->irq_base = NO_IRQ;
+ } else {
+ ret = -ENODEV;
+ goto free_mem;
+ }
+
if (!request_mem_region(dev->res.start,
resource_size(&dev->res), "pl061")) {
ret = -EBUSY;
@@ -267,14 +279,11 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
chip->gc.get = pl061_get_value;
chip->gc.set = pl061_set_value;
chip->gc.to_irq = pl061_to_irq;
- chip->gc.base = pdata->gpio_base;
chip->gc.ngpio = PL061_GPIO_NR;
chip->gc.label = dev_name(&dev->dev);
chip->gc.dev = &dev->dev;
chip->gc.owner = THIS_MODULE;
- chip->irq_base = pdata->irq_base;
-
ret = gpiochip_add(&chip->gc);
if (ret)
goto iounmap;
@@ -283,7 +292,7 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
* irq_chip support
*/
- if (chip->irq_base == (unsigned) -1)
+ if (chip->irq_base == NO_IRQ)
return 0;
writeb(0, chip->base + GPIOIE); /* disable irqs */
@@ -307,11 +316,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
list_add(&chip->list, chip_list);
for (i = 0; i < PL061_GPIO_NR; i++) {
- if (pdata->directions & (1 << i))
- pl061_direction_output(&chip->gc, i,
- pdata->values & (1 << i));
- else
- pl061_direction_input(&chip->gc, i);
+ if (pdata) {
+ if (pdata->directions & (1 << i))
+ pl061_direction_output(&chip->gc, i,
+ pdata->values & (1 << i));
+ else
+ pl061_direction_input(&chip->gc, i);
+ }
irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
handle_simple_irq);
diff --git a/include/linux/amba/pl061.h b/include/linux/amba/pl061.h
index 5ddd9ad..2412af9 100644
--- a/include/linux/amba/pl061.h
+++ b/include/linux/amba/pl061.h
@@ -7,8 +7,7 @@ struct pl061_platform_data {
unsigned gpio_base;
/* number of the first IRQ.
- * If the IRQ functionality in not desired this must be set to
- * (unsigned) -1.
+ * If the IRQ functionality in not desired this must be set to NO_IRQ.
*/
unsigned irq_base;
--
1.7.4.1
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
@ 2011-08-11 6:36 ` Baruch Siach
2011-08-11 16:48 ` Rob Herring
2011-09-22 23:08 ` Rob Herring
2011-10-24 22:24 ` Grant Likely
2 siblings, 1 reply; 12+ messages in thread
From: Baruch Siach @ 2011-08-11 6:36 UTC (permalink / raw)
To: linux-arm-kernel
Hi Rob,
On Wed, Aug 10, 2011 at 04:31:46PM -0500, Rob Herring wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> This adds devicetree binding support to the ARM pl061 driver removing the
> platform_data dependency. When DT binding is used, the gpio numbering is
> assigned dynamically. For now, interrupts are not supported with DT until
> irqdomains learn dynamic irq assignment.
>
> Rather than add another case of -1, updating the driver to use NO_IRQ.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>
> ---
>
> v2:
> - Add other -1 to NO_IRQ conversions
Migrating existing pl061_platform_data users to NO_IRQ would be nice as well.
But this should probably be a separate patch.
FWIW:
Acked-by: Baruch Siach <baruch@tkos.co.il>
baruch
--
~. .~ Tk Open Systems
=}------------------------------------------------ooO--U--Ooo------------{=
- baruch at tkos.co.il - tel: +972.2.679.5364, http://www.tkos.co.il -
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-08-11 6:36 ` Baruch Siach
@ 2011-08-11 16:48 ` Rob Herring
0 siblings, 0 replies; 12+ messages in thread
From: Rob Herring @ 2011-08-11 16:48 UTC (permalink / raw)
To: linux-arm-kernel
On 08/11/2011 01:36 AM, Baruch Siach wrote:
> Hi Rob,
>
> On Wed, Aug 10, 2011 at 04:31:46PM -0500, Rob Herring wrote:
>> From: Rob Herring <rob.herring@calxeda.com>
>>
>> This adds devicetree binding support to the ARM pl061 driver removing the
>> platform_data dependency. When DT binding is used, the gpio numbering is
>> assigned dynamically. For now, interrupts are not supported with DT until
>> irqdomains learn dynamic irq assignment.
>>
>> Rather than add another case of -1, updating the driver to use NO_IRQ.
>>
>> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
>> Cc: Grant Likely <grant.likely@secretlab.ca>
>> ---
>>
>> v2:
>> - Add other -1 to NO_IRQ conversions
>
> Migrating existing pl061_platform_data users to NO_IRQ would be nice as well.
> But this should probably be a separate patch.
>
Actually, I expect we can kill off the platform_data once all users are
converted over to device tree.
> FWIW:
>
> Acked-by: Baruch Siach <baruch@tkos.co.il>
Thanks.
Rob
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
2011-08-11 6:36 ` Baruch Siach
@ 2011-09-22 23:08 ` Rob Herring
2011-10-24 15:40 ` Rob Herring
2011-10-24 22:24 ` Grant Likely
2 siblings, 1 reply; 12+ messages in thread
From: Rob Herring @ 2011-09-22 23:08 UTC (permalink / raw)
To: linux-arm-kernel
Grant,
On 08/10/2011 04:31 PM, Rob Herring wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> This adds devicetree binding support to the ARM pl061 driver removing the
> platform_data dependency. When DT binding is used, the gpio numbering is
> assigned dynamically. For now, interrupts are not supported with DT until
> irqdomains learn dynamic irq assignment.
>
> Rather than add another case of -1, updating the driver to use NO_IRQ.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>
> ---
Ping. Any comments on this?
Rob
>
> v2:
> - Add other -1 to NO_IRQ conversions
> - Drop DT irq support for now
>
> drivers/gpio/gpio-pl061.c | 31 +++++++++++++++++++++----------
> include/linux/amba/pl061.h | 3 +--
> 2 files changed, 22 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> index 2c5a18f..093c90b 100644
> --- a/drivers/gpio/gpio-pl061.c
> +++ b/drivers/gpio/gpio-pl061.c
> @@ -118,7 +118,7 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
> {
> struct pl061_gpio *chip = container_of(gc, struct pl061_gpio, gc);
>
> - if (chip->irq_base == (unsigned) -1)
> + if (chip->irq_base == NO_IRQ)
> return -EINVAL;
>
> return chip->irq_base + offset;
> @@ -246,6 +246,18 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> if (chip == NULL)
> return -ENOMEM;
>
> + pdata = dev->dev.platform_data;
> + if (pdata) {
> + chip->gc.base = pdata->gpio_base;
> + chip->irq_base = pdata->irq_base;
> + } else if (dev->dev.of_node) {
> + chip->gc.base = -1;
> + chip->irq_base = NO_IRQ;
> + } else {
> + ret = -ENODEV;
> + goto free_mem;
> + }
> +
> if (!request_mem_region(dev->res.start,
> resource_size(&dev->res), "pl061")) {
> ret = -EBUSY;
> @@ -267,14 +279,11 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> chip->gc.get = pl061_get_value;
> chip->gc.set = pl061_set_value;
> chip->gc.to_irq = pl061_to_irq;
> - chip->gc.base = pdata->gpio_base;
> chip->gc.ngpio = PL061_GPIO_NR;
> chip->gc.label = dev_name(&dev->dev);
> chip->gc.dev = &dev->dev;
> chip->gc.owner = THIS_MODULE;
>
> - chip->irq_base = pdata->irq_base;
> -
> ret = gpiochip_add(&chip->gc);
> if (ret)
> goto iounmap;
> @@ -283,7 +292,7 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> * irq_chip support
> */
>
> - if (chip->irq_base == (unsigned) -1)
> + if (chip->irq_base == NO_IRQ)
> return 0;
>
> writeb(0, chip->base + GPIOIE); /* disable irqs */
> @@ -307,11 +316,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> list_add(&chip->list, chip_list);
>
> for (i = 0; i < PL061_GPIO_NR; i++) {
> - if (pdata->directions & (1 << i))
> - pl061_direction_output(&chip->gc, i,
> - pdata->values & (1 << i));
> - else
> - pl061_direction_input(&chip->gc, i);
> + if (pdata) {
> + if (pdata->directions & (1 << i))
> + pl061_direction_output(&chip->gc, i,
> + pdata->values & (1 << i));
> + else
> + pl061_direction_input(&chip->gc, i);
> + }
>
> irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
> handle_simple_irq);
> diff --git a/include/linux/amba/pl061.h b/include/linux/amba/pl061.h
> index 5ddd9ad..2412af9 100644
> --- a/include/linux/amba/pl061.h
> +++ b/include/linux/amba/pl061.h
> @@ -7,8 +7,7 @@ struct pl061_platform_data {
> unsigned gpio_base;
>
> /* number of the first IRQ.
> - * If the IRQ functionality in not desired this must be set to
> - * (unsigned) -1.
> + * If the IRQ functionality in not desired this must be set to NO_IRQ.
> */
> unsigned irq_base;
>
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-09-22 23:08 ` Rob Herring
@ 2011-10-24 15:40 ` Rob Herring
0 siblings, 0 replies; 12+ messages in thread
From: Rob Herring @ 2011-10-24 15:40 UTC (permalink / raw)
To: linux-arm-kernel
Grant,
On 09/22/2011 06:08 PM, Rob Herring wrote:
> Grant,
>
> On 08/10/2011 04:31 PM, Rob Herring wrote:
>> From: Rob Herring <rob.herring@calxeda.com>
>>
>> This adds devicetree binding support to the ARM pl061 driver removing the
>> platform_data dependency. When DT binding is used, the gpio numbering is
>> assigned dynamically. For now, interrupts are not supported with DT until
>> irqdomains learn dynamic irq assignment.
>>
>> Rather than add another case of -1, updating the driver to use NO_IRQ.
>>
>> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
>> Cc: Grant Likely <grant.likely@secretlab.ca>
>> ---
>
> Ping. Any comments on this?
>
Ping. Can you apply this for 3.2.
Rob
> Rob
>>
>> v2:
>> - Add other -1 to NO_IRQ conversions
>> - Drop DT irq support for now
>>
>> drivers/gpio/gpio-pl061.c | 31 +++++++++++++++++++++----------
>> include/linux/amba/pl061.h | 3 +--
>> 2 files changed, 22 insertions(+), 12 deletions(-)
>>
>> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
>> index 2c5a18f..093c90b 100644
>> --- a/drivers/gpio/gpio-pl061.c
>> +++ b/drivers/gpio/gpio-pl061.c
>> @@ -118,7 +118,7 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
>> {
>> struct pl061_gpio *chip = container_of(gc, struct pl061_gpio, gc);
>>
>> - if (chip->irq_base == (unsigned) -1)
>> + if (chip->irq_base == NO_IRQ)
>> return -EINVAL;
>>
>> return chip->irq_base + offset;
>> @@ -246,6 +246,18 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>> if (chip == NULL)
>> return -ENOMEM;
>>
>> + pdata = dev->dev.platform_data;
>> + if (pdata) {
>> + chip->gc.base = pdata->gpio_base;
>> + chip->irq_base = pdata->irq_base;
>> + } else if (dev->dev.of_node) {
>> + chip->gc.base = -1;
>> + chip->irq_base = NO_IRQ;
>> + } else {
>> + ret = -ENODEV;
>> + goto free_mem;
>> + }
>> +
>> if (!request_mem_region(dev->res.start,
>> resource_size(&dev->res), "pl061")) {
>> ret = -EBUSY;
>> @@ -267,14 +279,11 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>> chip->gc.get = pl061_get_value;
>> chip->gc.set = pl061_set_value;
>> chip->gc.to_irq = pl061_to_irq;
>> - chip->gc.base = pdata->gpio_base;
>> chip->gc.ngpio = PL061_GPIO_NR;
>> chip->gc.label = dev_name(&dev->dev);
>> chip->gc.dev = &dev->dev;
>> chip->gc.owner = THIS_MODULE;
>>
>> - chip->irq_base = pdata->irq_base;
>> -
>> ret = gpiochip_add(&chip->gc);
>> if (ret)
>> goto iounmap;
>> @@ -283,7 +292,7 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>> * irq_chip support
>> */
>>
>> - if (chip->irq_base == (unsigned) -1)
>> + if (chip->irq_base == NO_IRQ)
>> return 0;
>>
>> writeb(0, chip->base + GPIOIE); /* disable irqs */
>> @@ -307,11 +316,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>> list_add(&chip->list, chip_list);
>>
>> for (i = 0; i < PL061_GPIO_NR; i++) {
>> - if (pdata->directions & (1 << i))
>> - pl061_direction_output(&chip->gc, i,
>> - pdata->values & (1 << i));
>> - else
>> - pl061_direction_input(&chip->gc, i);
>> + if (pdata) {
>> + if (pdata->directions & (1 << i))
>> + pl061_direction_output(&chip->gc, i,
>> + pdata->values & (1 << i));
>> + else
>> + pl061_direction_input(&chip->gc, i);
>> + }
>>
>> irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
>> handle_simple_irq);
>> diff --git a/include/linux/amba/pl061.h b/include/linux/amba/pl061.h
>> index 5ddd9ad..2412af9 100644
>> --- a/include/linux/amba/pl061.h
>> +++ b/include/linux/amba/pl061.h
>> @@ -7,8 +7,7 @@ struct pl061_platform_data {
>> unsigned gpio_base;
>>
>> /* number of the first IRQ.
>> - * If the IRQ functionality in not desired this must be set to
>> - * (unsigned) -1.
>> + * If the IRQ functionality in not desired this must be set to NO_IRQ.
>> */
>> unsigned irq_base;
>>
>
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2] gpio: pl061: add DT binding support
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
2011-08-11 6:36 ` Baruch Siach
2011-09-22 23:08 ` Rob Herring
@ 2011-10-24 22:24 ` Grant Likely
2 siblings, 0 replies; 12+ messages in thread
From: Grant Likely @ 2011-10-24 22:24 UTC (permalink / raw)
To: linux-arm-kernel
On Wed, Aug 10, 2011 at 04:31:46PM -0500, Rob Herring wrote:
> From: Rob Herring <rob.herring@calxeda.com>
>
> This adds devicetree binding support to the ARM pl061 driver removing the
> platform_data dependency. When DT binding is used, the gpio numbering is
> assigned dynamically. For now, interrupts are not supported with DT until
> irqdomains learn dynamic irq assignment.
>
> Rather than add another case of -1, updating the driver to use NO_IRQ.
>
> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> Cc: Grant Likely <grant.likely@secretlab.ca>
Applied, thanks.
g.
> ---
>
> v2:
> - Add other -1 to NO_IRQ conversions
> - Drop DT irq support for now
>
> drivers/gpio/gpio-pl061.c | 31 +++++++++++++++++++++----------
> include/linux/amba/pl061.h | 3 +--
> 2 files changed, 22 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> index 2c5a18f..093c90b 100644
> --- a/drivers/gpio/gpio-pl061.c
> +++ b/drivers/gpio/gpio-pl061.c
> @@ -118,7 +118,7 @@ static int pl061_to_irq(struct gpio_chip *gc, unsigned offset)
> {
> struct pl061_gpio *chip = container_of(gc, struct pl061_gpio, gc);
>
> - if (chip->irq_base == (unsigned) -1)
> + if (chip->irq_base == NO_IRQ)
> return -EINVAL;
>
> return chip->irq_base + offset;
> @@ -246,6 +246,18 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> if (chip == NULL)
> return -ENOMEM;
>
> + pdata = dev->dev.platform_data;
> + if (pdata) {
> + chip->gc.base = pdata->gpio_base;
> + chip->irq_base = pdata->irq_base;
> + } else if (dev->dev.of_node) {
> + chip->gc.base = -1;
> + chip->irq_base = NO_IRQ;
> + } else {
> + ret = -ENODEV;
> + goto free_mem;
> + }
> +
> if (!request_mem_region(dev->res.start,
> resource_size(&dev->res), "pl061")) {
> ret = -EBUSY;
> @@ -267,14 +279,11 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> chip->gc.get = pl061_get_value;
> chip->gc.set = pl061_set_value;
> chip->gc.to_irq = pl061_to_irq;
> - chip->gc.base = pdata->gpio_base;
> chip->gc.ngpio = PL061_GPIO_NR;
> chip->gc.label = dev_name(&dev->dev);
> chip->gc.dev = &dev->dev;
> chip->gc.owner = THIS_MODULE;
>
> - chip->irq_base = pdata->irq_base;
> -
> ret = gpiochip_add(&chip->gc);
> if (ret)
> goto iounmap;
> @@ -283,7 +292,7 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> * irq_chip support
> */
>
> - if (chip->irq_base == (unsigned) -1)
> + if (chip->irq_base == NO_IRQ)
> return 0;
>
> writeb(0, chip->base + GPIOIE); /* disable irqs */
> @@ -307,11 +316,13 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> list_add(&chip->list, chip_list);
>
> for (i = 0; i < PL061_GPIO_NR; i++) {
> - if (pdata->directions & (1 << i))
> - pl061_direction_output(&chip->gc, i,
> - pdata->values & (1 << i));
> - else
> - pl061_direction_input(&chip->gc, i);
> + if (pdata) {
> + if (pdata->directions & (1 << i))
> + pl061_direction_output(&chip->gc, i,
> + pdata->values & (1 << i));
> + else
> + pl061_direction_input(&chip->gc, i);
> + }
>
> irq_set_chip_and_handler(i + chip->irq_base, &pl061_irqchip,
> handle_simple_irq);
> diff --git a/include/linux/amba/pl061.h b/include/linux/amba/pl061.h
> index 5ddd9ad..2412af9 100644
> --- a/include/linux/amba/pl061.h
> +++ b/include/linux/amba/pl061.h
> @@ -7,8 +7,7 @@ struct pl061_platform_data {
> unsigned gpio_base;
>
> /* number of the first IRQ.
> - * If the IRQ functionality in not desired this must be set to
> - * (unsigned) -1.
> + * If the IRQ functionality in not desired this must be set to NO_IRQ.
> */
> unsigned irq_base;
>
> --
> 1.7.4.1
>
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] gpio: pl061: add DT binding support
2011-08-03 23:18 ` Rob Herring
@ 2011-10-24 22:26 ` Grant Likely
2011-10-24 22:48 ` Rob Herring
0 siblings, 1 reply; 12+ messages in thread
From: Grant Likely @ 2011-10-24 22:26 UTC (permalink / raw)
To: linux-arm-kernel
On Wed, Aug 03, 2011 at 06:18:45PM -0500, Rob Herring wrote:
> Grant,
>
> On 08/03/2011 05:22 PM, Grant Likely wrote:
> > On Wed, Aug 3, 2011 at 7:54 PM, Rob Herring <robherring2@gmail.com> wrote:
> >> From: Rob Herring <rob.herring@calxeda.com>
> >>
> >> This adds devicetree binding support to the ARM pl061 driver removing the
> >> platform_data dependency. When DT binding is used, the gpio numbering is
> >> assigned dynamically. The interrupt assignment is converted to use the
> >> irq_domain infrastructure.
> >>
> >> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
> >> Cc: Grant Likely <grant.likely@secretlab.ca>
> >> ---
> >> drivers/gpio/gpio-pl061.c | 32 +++++++++++++++++++++++---------
> >> 1 files changed, 23 insertions(+), 9 deletions(-)
> >>
> >> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
> >> index 2c5a18f..7ea74ff 100644
> >> --- a/drivers/gpio/gpio-pl061.c
> >> +++ b/drivers/gpio/gpio-pl061.c
> >> @@ -23,6 +23,7 @@
> >> #include <linux/amba/bus.h>
> >> #include <linux/amba/pl061.h>
> >> #include <linux/slab.h>
> >> +#include <linux/of_irq.h>
> >>
> >> #define GPIODIR 0x400
> >> #define GPIOIS 0x404
> >> @@ -246,6 +247,20 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
> >> if (chip == NULL)
> >> return -ENOMEM;
> >>
> >> + pdata = dev->dev.platform_data;
> >> + if (pdata) {
> >> + chip->gc.base = pdata->gpio_base;
> >> + chip->irq_base = pdata->irq_base;
> >> + } else if (dev->dev.of_node) {
> >> + u32 intspec = 0;
> >> + chip->gc.base = -1;
> >> + chip->irq_base = irq_create_of_mapping(dev->dev.of_node,
> >> + &intspec, 1);
> >
> > This looks wrong. intspec is always 0 here, when I would assume you
> > would want the value of the interrupts property from this device's
> > node. Is this the cascade irq number? Or is it supposed to be the
> > starting interrupt number for the gpios? If it is starting interrupt
> > number, then it should actually be dynamically assigned. If it is the
> > cascade, then platform_get_irq() should work.
> >
> It's the latter case that I need to retrieve. I have this platform code
> assigning the linux irq numbers:
>
> struct device_node *node;
> int n = 0;
>
> node = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-gic");
> if (!node)
> panic("missing gic devicetree node\n");
> irq_domain_add_simple(node, 0);
>
> for_each_compatible_node(node, NULL, "arm,pl061") {
> irq_domain_add_simple(node, 160 + (8 * n));
> n++;
> }
>
> In this case with simple translation, intspec is really a don't care.
> irq_create_of_mapping just finds the domain that matches the gpio
> ctrlr's node and returns the domain's irq_base (+ 0) as the translate
> function will just return the intspec value for the hw_irq.
>
> Have I missed something? There is not yet any dynamic assignment of
> linux irq numbers?
Yes, the kernel does support dynamic irq number assignment, but the
interrupt controller still needs to manage it. I've not yet decided
what the best way to integrate it into irq_domain is.
g.
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH] gpio: pl061: add DT binding support
2011-10-24 22:26 ` Grant Likely
@ 2011-10-24 22:48 ` Rob Herring
0 siblings, 0 replies; 12+ messages in thread
From: Rob Herring @ 2011-10-24 22:48 UTC (permalink / raw)
To: linux-arm-kernel
On 10/24/2011 05:26 PM, Grant Likely wrote:
> On Wed, Aug 03, 2011 at 06:18:45PM -0500, Rob Herring wrote:
>> Grant,
>>
>> On 08/03/2011 05:22 PM, Grant Likely wrote:
>>> On Wed, Aug 3, 2011 at 7:54 PM, Rob Herring <robherring2@gmail.com> wrote:
>>>> From: Rob Herring <rob.herring@calxeda.com>
>>>>
>>>> This adds devicetree binding support to the ARM pl061 driver removing the
>>>> platform_data dependency. When DT binding is used, the gpio numbering is
>>>> assigned dynamically. The interrupt assignment is converted to use the
>>>> irq_domain infrastructure.
>>>>
>>>> Signed-off-by: Rob Herring <rob.herring@calxeda.com>
>>>> Cc: Grant Likely <grant.likely@secretlab.ca>
>>>> ---
>>>> drivers/gpio/gpio-pl061.c | 32 +++++++++++++++++++++++---------
>>>> 1 files changed, 23 insertions(+), 9 deletions(-)
>>>>
>>>> diff --git a/drivers/gpio/gpio-pl061.c b/drivers/gpio/gpio-pl061.c
>>>> index 2c5a18f..7ea74ff 100644
>>>> --- a/drivers/gpio/gpio-pl061.c
>>>> +++ b/drivers/gpio/gpio-pl061.c
>>>> @@ -23,6 +23,7 @@
>>>> #include <linux/amba/bus.h>
>>>> #include <linux/amba/pl061.h>
>>>> #include <linux/slab.h>
>>>> +#include <linux/of_irq.h>
>>>>
>>>> #define GPIODIR 0x400
>>>> #define GPIOIS 0x404
>>>> @@ -246,6 +247,20 @@ static int pl061_probe(struct amba_device *dev, const struct amba_id *id)
>>>> if (chip == NULL)
>>>> return -ENOMEM;
>>>>
>>>> + pdata = dev->dev.platform_data;
>>>> + if (pdata) {
>>>> + chip->gc.base = pdata->gpio_base;
>>>> + chip->irq_base = pdata->irq_base;
>>>> + } else if (dev->dev.of_node) {
>>>> + u32 intspec = 0;
>>>> + chip->gc.base = -1;
>>>> + chip->irq_base = irq_create_of_mapping(dev->dev.of_node,
>>>> + &intspec, 1);
>>>
>>> This looks wrong. intspec is always 0 here, when I would assume you
>>> would want the value of the interrupts property from this device's
>>> node. Is this the cascade irq number? Or is it supposed to be the
>>> starting interrupt number for the gpios? If it is starting interrupt
>>> number, then it should actually be dynamically assigned. If it is the
>>> cascade, then platform_get_irq() should work.
>>>
>> It's the latter case that I need to retrieve. I have this platform code
>> assigning the linux irq numbers:
>>
>> struct device_node *node;
>> int n = 0;
>>
>> node = of_find_compatible_node(NULL, NULL, "arm,cortex-a9-gic");
>> if (!node)
>> panic("missing gic devicetree node\n");
>> irq_domain_add_simple(node, 0);
>>
>> for_each_compatible_node(node, NULL, "arm,pl061") {
>> irq_domain_add_simple(node, 160 + (8 * n));
>> n++;
>> }
>>
>> In this case with simple translation, intspec is really a don't care.
>> irq_create_of_mapping just finds the domain that matches the gpio
>> ctrlr's node and returns the domain's irq_base (+ 0) as the translate
>> function will just return the intspec value for the hw_irq.
>>
>> Have I missed something? There is not yet any dynamic assignment of
>> linux irq numbers?
>
> Yes, the kernel does support dynamic irq number assignment, but the
> interrupt controller still needs to manage it. I've not yet decided
> what the best way to integrate it into irq_domain is.
>
I had since figured that out with the GIC series. We should discuss at
Connect. My plan here is to make generic-irq-chip use domains and
irq_alloc_descs, then convert pl061 to use generic-irq-chip.
Rob
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2011-10-24 22:48 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-08-03 18:54 [PATCH] gpio: pl061: add DT binding support Rob Herring
2011-08-03 19:10 ` Baruch Siach
2011-08-03 22:22 ` Grant Likely
2011-08-03 23:18 ` Rob Herring
2011-10-24 22:26 ` Grant Likely
2011-10-24 22:48 ` Rob Herring
2011-08-10 21:31 ` [PATCH v2] " Rob Herring
2011-08-11 6:36 ` Baruch Siach
2011-08-11 16:48 ` Rob Herring
2011-09-22 23:08 ` Rob Herring
2011-10-24 15:40 ` Rob Herring
2011-10-24 22:24 ` Grant Likely
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).