* [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
@ 2017-06-14 23:21 ` sathyanarayanan.kuppuswamy
0 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan.kuppuswamy @ 2017-06-14 23:21 UTC (permalink / raw)
To: linus.walleij
Cc: linux-gpio, linux-kernel, sathyaosid, Kuppuswamy Sathyanarayanan
From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
registers for virtual GPIOs") added support to skip GPIO register
update for virtual GPIOs, but it missed to add skip logic in
crystalcove_update_irq_ctrl() function. This patch fixes it.
Signed-off-by: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
---
drivers/gpio/gpio-crystalcove.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/gpio/gpio-crystalcove.c b/drivers/gpio/gpio-crystalcove.c
index e60156e..edc9aa8 100644
--- a/drivers/gpio/gpio-crystalcove.c
+++ b/drivers/gpio/gpio-crystalcove.c
@@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
{
int reg = to_reg(gpio, CTRL_IN);
+ if (reg < 0)
+ return;
+
regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
}
--
2.7.4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
@ 2017-06-14 23:21 ` sathyanarayanan.kuppuswamy
0 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan.kuppuswamy @ 2017-06-14 23:21 UTC (permalink / raw)
To: linus.walleij
Cc: linux-gpio, linux-kernel, sathyaosid, Kuppuswamy Sathyanarayanan
From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
registers for virtual GPIOs") added support to skip GPIO register
update for virtual GPIOs, but it missed to add skip logic in
crystalcove_update_irq_ctrl() function. This patch fixes it.
Signed-off-by: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
---
drivers/gpio/gpio-crystalcove.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/gpio/gpio-crystalcove.c b/drivers/gpio/gpio-crystalcove.c
index e60156e..edc9aa8 100644
--- a/drivers/gpio/gpio-crystalcove.c
+++ b/drivers/gpio/gpio-crystalcove.c
@@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
{
int reg = to_reg(gpio, CTRL_IN);
+ if (reg < 0)
+ return;
+
regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
}
--
2.7.4
^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
2017-06-14 23:21 ` sathyanarayanan.kuppuswamy
@ 2017-06-15 9:19 ` Andy Shevchenko
-1 siblings, 0 replies; 10+ messages in thread
From: Andy Shevchenko @ 2017-06-15 9:19 UTC (permalink / raw)
To: Kuppuswamy Sathyanarayanan
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
On Thu, Jun 15, 2017 at 2:21 AM,
<sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
> From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
>
> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
> registers for virtual GPIOs") added support to skip GPIO register
> update for virtual GPIOs, but it missed to add skip logic in
> crystalcove_update_irq_ctrl() function. This patch fixes it.
> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
> {
> int reg = to_reg(gpio, CTRL_IN);
>
> + if (reg < 0)
> + return;
> +
> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
> }
Shouldn't it have been done using irq_valid_mask flag in the first place?
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
@ 2017-06-15 9:19 ` Andy Shevchenko
0 siblings, 0 replies; 10+ messages in thread
From: Andy Shevchenko @ 2017-06-15 9:19 UTC (permalink / raw)
To: Kuppuswamy Sathyanarayanan
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
On Thu, Jun 15, 2017 at 2:21 AM,
<sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
> From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
>
> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
> registers for virtual GPIOs") added support to skip GPIO register
> update for virtual GPIOs, but it missed to add skip logic in
> crystalcove_update_irq_ctrl() function. This patch fixes it.
> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
> {
> int reg = to_reg(gpio, CTRL_IN);
>
> + if (reg < 0)
> + return;
> +
> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
> }
Shouldn't it have been done using irq_valid_mask flag in the first place?
--
With Best Regards,
Andy Shevchenko
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
2017-06-15 9:19 ` Andy Shevchenko
@ 2017-06-15 21:45 ` sathyanarayanan kuppuswamy
-1 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan kuppuswamy @ 2017-06-15 21:45 UTC (permalink / raw)
To: Andy Shevchenko
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
Hi Andy,
On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
> On Thu, Jun 15, 2017 at 2:21 AM,
> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>> From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
>>
>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>> registers for virtual GPIOs") added support to skip GPIO register
>> update for virtual GPIOs, but it missed to add skip logic in
>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
>> {
>> int reg = to_reg(gpio, CTRL_IN);
>>
>> + if (reg < 0)
>> + return;
>> +
>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
>> }
> Shouldn't it have been done using irq_valid_mask flag in the first place?
Agree. Setting irq_valid_mask would be the proper approach to skip IRQ
for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index based
checks in other IRQ set/unset functions in this driver and missed to add
it only in this update_irq_ctrl() function. May be I can submit a
separate patch to clean it up and use logic based on setting irq_valid_mask.
Even if we do the cleanup patch, I would still prefer to have this
check. Since to_reg() can return value < 0, its good to check it before
passing it to regmap_* functions. Let me know your comments.
>
--
Sathyanarayanan Kuppuswamy
Linux kernel developer
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
@ 2017-06-15 21:45 ` sathyanarayanan kuppuswamy
0 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan kuppuswamy @ 2017-06-15 21:45 UTC (permalink / raw)
To: Andy Shevchenko
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
Hi Andy,
On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
> On Thu, Jun 15, 2017 at 2:21 AM,
> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>> From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
>>
>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>> registers for virtual GPIOs") added support to skip GPIO register
>> update for virtual GPIOs, but it missed to add skip logic in
>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
>> {
>> int reg = to_reg(gpio, CTRL_IN);
>>
>> + if (reg < 0)
>> + return;
>> +
>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
>> }
> Shouldn't it have been done using irq_valid_mask flag in the first place?
Agree. Setting irq_valid_mask would be the proper approach to skip IRQ
for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index based
checks in other IRQ set/unset functions in this driver and missed to add
it only in this update_irq_ctrl() function. May be I can submit a
separate patch to clean it up and use logic based on setting irq_valid_mask.
Even if we do the cleanup patch, I would still prefer to have this
check. Since to_reg() can return value < 0, its good to check it before
passing it to regmap_* functions. Let me know your comments.
>
--
Sathyanarayanan Kuppuswamy
Linux kernel developer
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
2017-06-15 21:45 ` sathyanarayanan kuppuswamy
@ 2017-07-10 23:35 ` sathyanarayanan kuppuswamy
-1 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan kuppuswamy @ 2017-07-10 23:35 UTC (permalink / raw)
To: Andy Shevchenko, Hans de Goede
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
Hi Hans,
Do you have any comments on this patch ? It kind of fixes your patch, so
would prefer to get your comments.
On 06/15/2017 02:45 PM, sathyanarayanan kuppuswamy wrote:
> Hi Andy,
>
>
> On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
>> On Thu, Jun 15, 2017 at 2:21 AM,
>> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>>> From: Kuppuswamy Sathyanarayanan
>>> <sathyanarayanan.kuppuswamy@linux.intel.com>
>>>
>>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>>> registers for virtual GPIOs") added support to skip GPIO register
>>> update for virtual GPIOs, but it missed to add skip logic in
>>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct
>>> crystalcove_gpio *cg, int gpio)
>>> {
>>> int reg = to_reg(gpio, CTRL_IN);
>>>
>>> + if (reg < 0)
>>> + return;
>>> +
>>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE,
>>> cg->intcnt_value);
>>> }
>> Shouldn't it have been done using irq_valid_mask flag in the first
>> place?
> Agree. Setting irq_valid_mask would be the proper approach to skip IRQ
> for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index based
> checks in other IRQ set/unset functions in this driver and missed to
> add it only in this update_irq_ctrl() function. May be I can submit a
> separate patch to clean it up and use logic based on setting
> irq_valid_mask.
>
> Even if we do the cleanup patch, I would still prefer to have this
> check. Since to_reg() can return value < 0, its good to check it
> before passing it to regmap_* functions. Let me know your comments.
>
>>
>
--
Sathyanarayanan Kuppuswamy
Linux kernel developer
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
@ 2017-07-10 23:35 ` sathyanarayanan kuppuswamy
0 siblings, 0 replies; 10+ messages in thread
From: sathyanarayanan kuppuswamy @ 2017-07-10 23:35 UTC (permalink / raw)
To: Andy Shevchenko, Hans de Goede
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
Hi Hans,
Do you have any comments on this patch ? It kind of fixes your patch, so
would prefer to get your comments.
On 06/15/2017 02:45 PM, sathyanarayanan kuppuswamy wrote:
> Hi Andy,
>
>
> On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
>> On Thu, Jun 15, 2017 at 2:21 AM,
>> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>>> From: Kuppuswamy Sathyanarayanan
>>> <sathyanarayanan.kuppuswamy@linux.intel.com>
>>>
>>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>>> registers for virtual GPIOs") added support to skip GPIO register
>>> update for virtual GPIOs, but it missed to add skip logic in
>>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct
>>> crystalcove_gpio *cg, int gpio)
>>> {
>>> int reg = to_reg(gpio, CTRL_IN);
>>>
>>> + if (reg < 0)
>>> + return;
>>> +
>>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE,
>>> cg->intcnt_value);
>>> }
>> Shouldn't it have been done using irq_valid_mask flag in the first
>> place?
> Agree. Setting irq_valid_mask would be the proper approach to skip IRQ
> for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index based
> checks in other IRQ set/unset functions in this driver and missed to
> add it only in this update_irq_ctrl() function. May be I can submit a
> separate patch to clean it up and use logic based on setting
> irq_valid_mask.
>
> Even if we do the cleanup patch, I would still prefer to have this
> check. Since to_reg() can return value < 0, its good to check it
> before passing it to regmap_* functions. Let me know your comments.
>
>>
>
--
Sathyanarayanan Kuppuswamy
Linux kernel developer
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
2017-07-10 23:35 ` sathyanarayanan kuppuswamy
(?)
@ 2017-07-11 9:47 ` Hans de Goede
2017-07-11 17:20 ` Kuppuswamy, Sathyanarayanan
-1 siblings, 1 reply; 10+ messages in thread
From: Hans de Goede @ 2017-07-11 9:47 UTC (permalink / raw)
To: sathyanarayanan.kuppuswamy, Andy Shevchenko
Cc: Linus Walleij, linux-gpio, linux-kernel,
Sathyanarayanan Kuppuswamy Natarajan
Hi,
On 11-07-17 01:35, sathyanarayanan kuppuswamy wrote:
> Hi Hans,
>
> Do you have any comments on this patch ? It kind of fixes your patch, so would prefer to get your comments.
Sorry I did not notice this patch before, did you Cc me ?
As for the patch, I deliberately did not add the check
to crystalcove_update_irq_ctrl, crystalcove_update_irq_ctrl
only gets called from crystalcove_bus_sync_unlock if
UPDATE_IRQ_TYPE
UPDATE_IRQ_TYPE only gets set from crystalcove_irq_type
which at the top contains:
if (data->hwirq >= CRYSTALCOVE_GPIO_NUM)
return 0;
So crystalcove_update_irq_ctrl will never get called for
virtual GPIOs.
TL;DR: your patch is not necessary.
Regards,
Hans
>
>
> On 06/15/2017 02:45 PM, sathyanarayanan kuppuswamy wrote:
>> Hi Andy,
>>
>>
>> On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
>>> On Thu, Jun 15, 2017 at 2:21 AM,
>>> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>>>> From: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
>>>>
>>>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>>>> registers for virtual GPIOs") added support to skip GPIO register
>>>> update for virtual GPIOs, but it missed to add skip logic in
>>>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>>>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct crystalcove_gpio *cg, int gpio)
>>>> {
>>>> int reg = to_reg(gpio, CTRL_IN);
>>>>
>>>> + if (reg < 0)
>>>> + return;
>>>> +
>>>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE, cg->intcnt_value);
>>>> }
>>> Shouldn't it have been done using irq_valid_mask flag in the first place?
>> Agree. Setting irq_valid_mask would be the proper approach to skip IRQ for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index based checks in other IRQ set/unset functions in this driver and missed to add it only in this update_irq_ctrl() function. May be I can submit a separate patch to clean it up and use logic based on setting irq_valid_mask.
>>
>> Even if we do the cleanup patch, I would still prefer to have this check. Since to_reg() can return value < 0, its good to check it before passing it to regmap_* functions. Let me know your comments.
>>
>>>
>>
>
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs
2017-07-11 9:47 ` Hans de Goede
@ 2017-07-11 17:20 ` Kuppuswamy, Sathyanarayanan
0 siblings, 0 replies; 10+ messages in thread
From: Kuppuswamy, Sathyanarayanan @ 2017-07-11 17:20 UTC (permalink / raw)
To: Hans de Goede, sathyanarayanan.kuppuswamy, Andy Shevchenko
Cc: Linus Walleij, linux-gpio, linux-kernel
Hi Hans,
On 7/11/2017 2:47 AM, Hans de Goede wrote:
> Hi,
>
> On 11-07-17 01:35, sathyanarayanan kuppuswamy wrote:
>> Hi Hans,
>>
>> Do you have any comments on this patch ? It kind of fixes your patch,
>> so would prefer to get your comments.
>
> Sorry I did not notice this patch before, did you Cc me ?
>
> As for the patch, I deliberately did not add the check
> to crystalcove_update_irq_ctrl, crystalcove_update_irq_ctrl
> only gets called from crystalcove_bus_sync_unlock if
> UPDATE_IRQ_TYPE
>
> UPDATE_IRQ_TYPE only gets set from crystalcove_irq_type
> which at the top contains:
>
> if (data->hwirq >= CRYSTALCOVE_GPIO_NUM)
> return 0;
>
> So crystalcove_update_irq_ctrl will never get called for
> virtual GPIOs.
>
> TL;DR: your patch is not necessary.
Thanks for the clarification.
>
> Regards,
>
> Hans
>
>
>>
>>
>> On 06/15/2017 02:45 PM, sathyanarayanan kuppuswamy wrote:
>>> Hi Andy,
>>>
>>>
>>> On 06/15/2017 02:19 AM, Andy Shevchenko wrote:
>>>> On Thu, Jun 15, 2017 at 2:21 AM,
>>>> <sathyanarayanan.kuppuswamy@linux.intel.com> wrote:
>>>>> From: Kuppuswamy Sathyanarayanan
>>>>> <sathyanarayanan.kuppuswamy@linux.intel.com>
>>>>>
>>>>> Commit 9a752b4c9ab9 ("gpio: crystalcove: Do not write regular gpio
>>>>> registers for virtual GPIOs") added support to skip GPIO register
>>>>> update for virtual GPIOs, but it missed to add skip logic in
>>>>> crystalcove_update_irq_ctrl() function. This patch fixes it.
>>>>> @@ -134,6 +134,9 @@ static void crystalcove_update_irq_ctrl(struct
>>>>> crystalcove_gpio *cg, int gpio)
>>>>> {
>>>>> int reg = to_reg(gpio, CTRL_IN);
>>>>>
>>>>> + if (reg < 0)
>>>>> + return;
>>>>> +
>>>>> regmap_update_bits(cg->regmap, reg, CTLI_INTCNT_BE,
>>>>> cg->intcnt_value);
>>>>> }
>>>> Shouldn't it have been done using irq_valid_mask flag in the first
>>>> place?
>>> Agree. Setting irq_valid_mask would be the proper approach to skip
>>> IRQ for some GPIO pins. But commit 9a752b4c9ab9 added the GPIO index
>>> based checks in other IRQ set/unset functions in this driver and
>>> missed to add it only in this update_irq_ctrl() function. May be I
>>> can submit a separate patch to clean it up and use logic based on
>>> setting irq_valid_mask.
>>>
>>> Even if we do the cleanup patch, I would still prefer to have this
>>> check. Since to_reg() can return value < 0, its good to check it
>>> before passing it to regmap_* functions. Let me know your comments.
>>>
>>>>
>>>
>>
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2017-07-11 17:20 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-06-14 23:21 [PATCH v1 1/1] gpio: gpio-crystalcove: Skip IRQ CTRL register update for virtual GPIOs sathyanarayanan.kuppuswamy
2017-06-14 23:21 ` sathyanarayanan.kuppuswamy
2017-06-15 9:19 ` Andy Shevchenko
2017-06-15 9:19 ` Andy Shevchenko
2017-06-15 21:45 ` sathyanarayanan kuppuswamy
2017-06-15 21:45 ` sathyanarayanan kuppuswamy
2017-07-10 23:35 ` sathyanarayanan kuppuswamy
2017-07-10 23:35 ` sathyanarayanan kuppuswamy
2017-07-11 9:47 ` Hans de Goede
2017-07-11 17:20 ` Kuppuswamy, Sathyanarayanan
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.