2008-07-15 06:04:37

by sasa sasa

[permalink] [raw]
Subject: Set_up irq problem while using gpio

Hi,

I have query that the below patch has to applied on irq/manage.c file or not.
--- kernel_old/irq/manage.c 2008-02-07 22:11:14.000000000 +0530
+++ kernel_new/irq/manage.c 2008-02-07 22:19:14.000000000 +0530
@@ -349,8 +349,14 @@
/* Setup the type (level, edge polarity) if configured: */
if (new->flags & IRQF_TRIGGER_MASK) {
if (desc->chip && desc->chip->set_type)
- desc->chip->set_type(irq,
- new->flags & IRQF_TRIGGER_MASK);
+ {
+ if((desc->chip->set_type(irq,
+ new->flags & IRQF_TRIGGER_MASK)))
+ {
+ spin_unlock_irqrestore(&desc->lock, flags);
+ return -ESPIPE;
+ }
+ }
else
/*
* IRQF_TRIGGER_* but the PIC does not support

The reason is that in case of gpio pins used as interrupt pin but that
pin has already been ocuupied in other mode (like alternate function
mode or in software mode) by other device. In that case, some error
mechanism must be there, if we are requesting that gpio pin as
interrupt through request_irq function.

Regards
Sasa


2008-07-15 12:32:37

by Ben Dooks

[permalink] [raw]
Subject: Re: Set_up irq problem while using gpio

On Tue, Jul 15, 2008 at 11:34:23AM +0530, sasa sasa wrote:
> Hi,
>
> I have query that the below patch has to applied on irq/manage.c file or not.
> --- kernel_old/irq/manage.c 2008-02-07 22:11:14.000000000 +0530
> +++ kernel_new/irq/manage.c 2008-02-07 22:19:14.000000000 +0530
> @@ -349,8 +349,14 @@
> /* Setup the type (level, edge polarity) if configured: */
> if (new->flags & IRQF_TRIGGER_MASK) {
> if (desc->chip && desc->chip->set_type)
> - desc->chip->set_type(irq,
> - new->flags & IRQF_TRIGGER_MASK);
> + {
> + if((desc->chip->set_type(irq,
> + new->flags & IRQF_TRIGGER_MASK)))
> + {
> + spin_unlock_irqrestore(&desc->lock, flags);
> + return -ESPIPE;
> + }
> + }

this is difficult to read, a better way would be to

ret = desc->chip->set_type(irq, new->flags & IRQF_TRIGGER_MASK)
if (ret) {
spin_unlock_irqrestore(&desc->lock, flags);
return ret;
}


If set_type() is meant to return an error, this should have been done
from the start, instead of being ignored.

tbh, the code could be further cleaned up by holding
the (new->flags & IRQF_TRIGGER_MASK in a variable such as new_trigger
which would stop the problem of wrapping lines...

> The reason is that in case of gpio pins used as interrupt pin but that
> pin has already been ocuupied in other mode (like alternate function
> mode or in software mode) by other device. In that case, some error
> mechanism must be there, if we are requesting that gpio pin as
> interrupt through request_irq function.

Hmm, I thought (when implementing the s3c24xx irq support) that
requesting the IRQ should change the pin mode appropriately.

--
Ben ([email protected], http://www.fluff.org/)

'a smiley only costs 4 bytes'

2008-07-16 04:08:34

by sasa sasa

[permalink] [raw]
Subject: Re: Set_up irq problem while using gpio

Ben,

> Hmm, I thought (when implementing the s3c24xx irq support) that
> requesting the IRQ should change the pin mode appropriately.

Does it mean that whenever we request gpio as interruot pin, it should
allow that request, no matter whether that gpio pin is already
occupied in other modes.
I think, it should return error like set_irq_type do. Internally both
set_irq_type and set_type do the same work, calls chip's set_type
function.

Regards
sasa

On Tue, Jul 15, 2008 at 6:02 PM, Ben Dooks <[email protected]> wrote:
> On Tue, Jul 15, 2008 at 11:34:23AM +0530, sasa sasa wrote:
>> Hi,
>>
>> I have query that the below patch has to applied on irq/manage.c file or not.
>> --- kernel_old/irq/manage.c 2008-02-07 22:11:14.000000000 +0530
>> +++ kernel_new/irq/manage.c 2008-02-07 22:19:14.000000000 +0530
>> @@ -349,8 +349,14 @@
>> /* Setup the type (level, edge polarity) if configured: */
>> if (new->flags & IRQF_TRIGGER_MASK) {
>> if (desc->chip && desc->chip->set_type)
>> - desc->chip->set_type(irq,
>> - new->flags & IRQF_TRIGGER_MASK);
>> + {
>> + if((desc->chip->set_type(irq,
>> + new->flags & IRQF_TRIGGER_MASK)))
>> + {
>> + spin_unlock_irqrestore(&desc->lock, flags);
>> + return -ESPIPE;
>> + }
>> + }
>
> this is difficult to read, a better way would be to
>
> ret = desc->chip->set_type(irq, new->flags & IRQF_TRIGGER_MASK)
> if (ret) {
> spin_unlock_irqrestore(&desc->lock, flags);
> return ret;
> }
>
>
> If set_type() is meant to return an error, this should have been done
> from the start, instead of being ignored.
>
> tbh, the code could be further cleaned up by holding
> the (new->flags & IRQF_TRIGGER_MASK in a variable such as new_trigger
> which would stop the problem of wrapping lines...
>
>> The reason is that in case of gpio pins used as interrupt pin but that
>> pin has already been ocuupied in other mode (like alternate function
>> mode or in software mode) by other device. In that case, some error
>> mechanism must be there, if we are requesting that gpio pin as
>> interrupt through request_irq function.
>
> Hmm, I thought (when implementing the s3c24xx irq support) that
> requesting the IRQ should change the pin mode appropriately.
>
> --
> Ben ([email protected], http://www.fluff.org/)
>
> 'a smiley only costs 4 bytes'
>

2008-07-17 09:21:13

by sasa sasa

[permalink] [raw]
Subject: [BUG]Set_up irq problem while using gpio

Hi ,

I think there is a bug in kernel/irq/manage.c file.
--- kernel_old/irq/manage.c 2008-02-07 22:11:14.000000000 +0530
+++ kernel_new/irq/manage.c 2008-02-07 22:19:14.000000000 +0530
@@ -349,8 +349,14 @@
/* Setup the type (level, edge polarity) if configured: */
if (new->flags & IRQF_TRIGGER_MASK) {
if (desc->chip && desc->chip->set_type)
- desc->chip->set_type(irq,
- new->flags & IRQF_TRIGGER_MASK);
+ {
+ if((desc->chip->set_type(irq,
+ new->flags & IRQF_TRIGGER_MASK)))
+ { *p = NULL;
+ spin_unlock_irqrestore(&desc->lock, flags);
+ return -ESPIPE;
+ }
+ }


The reason is that in case of gpio pins requested as irq pin may be
already ocuupied in other mode (like alternate function mode or in
software mode) by other device. In that case, some error mechanism
must be there, if we are requesting that gpio pin as
interrupt through request_irq function.

I think, it should return error like set_irq_type do. Internally both
set_irq_type and set_type do the same work, calls chip's set_type
function.

Regards
Sasa
---------- Forwarded message ----------
From: sasa sasa <[email protected]>
Date: Wed, Jul 16, 2008 at 9:38 AM
Subject: Re: Set_up irq problem while using gpio
To: Ben Dooks <[email protected]>
Cc: [email protected]


Ben,

> Hmm, I thought (when implementing the s3c24xx irq support) that
> requesting the IRQ should change the pin mode appropriately.

Does it mean that whenever we request gpio as interruot pin, it should
allow that request, no matter whether that gpio pin is already
occupied in other modes.
I think, it should return error like set_irq_type do. Internally both
set_irq_type and set_type do the same work, calls chip's set_type
function.

Regards
sasa

On Tue, Jul 15, 2008 at 6:02 PM, Ben Dooks <[email protected]> wrote:
> On Tue, Jul 15, 2008 at 11:34:23AM +0530, sasa sasa wrote:
>> Hi,
>>
>> I have query that the below patch has to applied on irq/manage.c file or not.
>> --- kernel_old/irq/manage.c 2008-02-07 22:11:14.000000000 +0530
>> +++ kernel_new/irq/manage.c 2008-02-07 22:19:14.000000000 +0530
>> @@ -349,8 +349,14 @@
>> /* Setup the type (level, edge polarity) if configured: */
>> if (new->flags & IRQF_TRIGGER_MASK) {
>> if (desc->chip && desc->chip->set_type)
>> - desc->chip->set_type(irq,
>> - new->flags & IRQF_TRIGGER_MASK);
>> + {
>> + if((desc->chip->set_type(irq,
>> + new->flags & IRQF_TRIGGER_MASK)))
>> + {
>> + spin_unlock_irqrestore(&desc->lock, flags);
>> + return -ESPIPE;
>> + }
>> + }
>
> this is difficult to read, a better way would be to
>
> ret = desc->chip->set_type(irq, new->flags & IRQF_TRIGGER_MASK)
> if (ret) {
> spin_unlock_irqrestore(&desc->lock, flags);
> return ret;
> }
>
>
> If set_type() is meant to return an error, this should have been done
> from the start, instead of being ignored.
>
> tbh, the code could be further cleaned up by holding
> the (new->flags & IRQF_TRIGGER_MASK in a variable such as new_trigger
> which would stop the problem of wrapping lines...
>
>> The reason is that in case of gpio pins used as interrupt pin but that
>> pin has already been ocuupied in other mode (like alternate function
>> mode or in software mode) by other device. In that case, some error
>> mechanism must be there, if we are requesting that gpio pin as
>> interrupt through request_irq function.
>
> Hmm, I thought (when implementing the s3c24xx irq support) that
> requesting the IRQ should change the pin mode appropriately.
>
> --
> Ben ([email protected], http://www.fluff.org/)
>
> 'a smiley only costs 4 bytes'
>