* [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent()
@ 2026-05-14 8:38 Maulik Shah
2026-05-19 3:20 ` Bjorn Andersson
2026-05-25 8:38 ` Linus Walleij
0 siblings, 2 replies; 5+ messages in thread
From: Maulik Shah @ 2026-05-14 8:38 UTC (permalink / raw)
To: Bjorn Andersson, Linus Walleij
Cc: linux-arm-msm, linux-gpio, linux-kernel, Maulik Shah
Replace open coded eoi call to parent irqchip with irq_chip_eoi_parent().
No functional impact.
Signed-off-by: Maulik Shah <maulik.shah@oss.qualcomm.com>
---
drivers/pinctrl/qcom/pinctrl-msm.c | 6 ++----
1 file changed, 2 insertions(+), 4 deletions(-)
diff --git a/drivers/pinctrl/qcom/pinctrl-msm.c b/drivers/pinctrl/qcom/pinctrl-msm.c
index 45b3a2763eb8..6771f5eb29e4 100644
--- a/drivers/pinctrl/qcom/pinctrl-msm.c
+++ b/drivers/pinctrl/qcom/pinctrl-msm.c
@@ -1012,10 +1012,8 @@ static void msm_gpio_irq_ack(struct irq_data *d)
static void msm_gpio_irq_eoi(struct irq_data *d)
{
- d = d->parent_data;
-
- if (d)
- d->chip->irq_eoi(d);
+ if (d->parent_data)
+ irq_chip_eoi_parent(d);
}
static bool msm_gpio_needs_dual_edge_parent_workaround(struct irq_data *d,
---
base-commit: e98d21c170b01ddef366f023bbfcf6b31509fa83
change-id: 20260514-pinctrl_msm_irq_eoi-ab736e16d411
Best regards,
--
Maulik Shah <maulik.shah@oss.qualcomm.com>
^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent()
2026-05-14 8:38 [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent() Maulik Shah
@ 2026-05-19 3:20 ` Bjorn Andersson
2026-05-19 3:33 ` Bjorn Andersson
2026-05-25 8:38 ` Linus Walleij
1 sibling, 1 reply; 5+ messages in thread
From: Bjorn Andersson @ 2026-05-19 3:20 UTC (permalink / raw)
To: Maulik Shah; +Cc: Linus Walleij, linux-arm-msm, linux-gpio, linux-kernel
On Thu, May 14, 2026 at 02:08:25PM +0530, Maulik Shah wrote:
> Replace open coded eoi call to parent irqchip with irq_chip_eoi_parent().
>
> No functional impact.
>
Reviewed-by: Bjorn Andersson <andersson@kernel.org>
Regards,
Bjorn
> Signed-off-by: Maulik Shah <maulik.shah@oss.qualcomm.com>
> ---
> drivers/pinctrl/qcom/pinctrl-msm.c | 6 ++----
> 1 file changed, 2 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/pinctrl/qcom/pinctrl-msm.c b/drivers/pinctrl/qcom/pinctrl-msm.c
> index 45b3a2763eb8..6771f5eb29e4 100644
> --- a/drivers/pinctrl/qcom/pinctrl-msm.c
> +++ b/drivers/pinctrl/qcom/pinctrl-msm.c
> @@ -1012,10 +1012,8 @@ static void msm_gpio_irq_ack(struct irq_data *d)
>
> static void msm_gpio_irq_eoi(struct irq_data *d)
> {
> - d = d->parent_data;
> -
> - if (d)
> - d->chip->irq_eoi(d);
> + if (d->parent_data)
> + irq_chip_eoi_parent(d);
> }
>
> static bool msm_gpio_needs_dual_edge_parent_workaround(struct irq_data *d,
>
> ---
> base-commit: e98d21c170b01ddef366f023bbfcf6b31509fa83
> change-id: 20260514-pinctrl_msm_irq_eoi-ab736e16d411
>
> Best regards,
> --
> Maulik Shah <maulik.shah@oss.qualcomm.com>
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent()
2026-05-19 3:20 ` Bjorn Andersson
@ 2026-05-19 3:33 ` Bjorn Andersson
2026-05-19 4:10 ` Maulik Shah (mkshah)
0 siblings, 1 reply; 5+ messages in thread
From: Bjorn Andersson @ 2026-05-19 3:33 UTC (permalink / raw)
To: Maulik Shah; +Cc: Linus Walleij, linux-arm-msm, linux-gpio, linux-kernel
On Mon, May 18, 2026 at 10:20:55PM -0500, Bjorn Andersson wrote:
> On Thu, May 14, 2026 at 02:08:25PM +0530, Maulik Shah wrote:
> > Replace open coded eoi call to parent irqchip with irq_chip_eoi_parent().
> >
> > No functional impact.
> >
>
> Reviewed-by: Bjorn Andersson <andersson@kernel.org>
>
On second though, I'm not sure I want to r-b this patch.
The commit message explains the action of the patch, not the reasons for
the patch. From the description I inferred that irq_chip_eoi_parent()
does implement what is open coded here, and a quick glance confirms
that.
I'm guessing that irq_chip_eoi_parent() didn't exist when
msm_gpio_irq_eoi() was written? Or was it not used for some reason?
> Regards,
> Bjorn
>
> > Signed-off-by: Maulik Shah <maulik.shah@oss.qualcomm.com>
> > ---
> > drivers/pinctrl/qcom/pinctrl-msm.c | 6 ++----
> > 1 file changed, 2 insertions(+), 4 deletions(-)
> >
> > diff --git a/drivers/pinctrl/qcom/pinctrl-msm.c b/drivers/pinctrl/qcom/pinctrl-msm.c
> > index 45b3a2763eb8..6771f5eb29e4 100644
> > --- a/drivers/pinctrl/qcom/pinctrl-msm.c
> > +++ b/drivers/pinctrl/qcom/pinctrl-msm.c
> > @@ -1012,10 +1012,8 @@ static void msm_gpio_irq_ack(struct irq_data *d)
> >
> > static void msm_gpio_irq_eoi(struct irq_data *d)
> > {
> > - d = d->parent_data;
> > -
> > - if (d)
> > - d->chip->irq_eoi(d);
> > + if (d->parent_data)
"I know that irq_chip_eoi_parent() will peak into d->parent_data, so
let's peek into the object first to avoid it dereferencing a NULL
pointer".
I see one other caller to irq_chip_eoi_parent() doing this, most
everyone else just register irq_chip_eoi_parent directly in the ops
struct.
Are we doing it right?
Regards,
Bjorn
> > + irq_chip_eoi_parent(d);
> > }
> >
> > static bool msm_gpio_needs_dual_edge_parent_workaround(struct irq_data *d,
> >
> > ---
> > base-commit: e98d21c170b01ddef366f023bbfcf6b31509fa83
> > change-id: 20260514-pinctrl_msm_irq_eoi-ab736e16d411
> >
> > Best regards,
> > --
> > Maulik Shah <maulik.shah@oss.qualcomm.com>
> >
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent()
2026-05-19 3:33 ` Bjorn Andersson
@ 2026-05-19 4:10 ` Maulik Shah (mkshah)
0 siblings, 0 replies; 5+ messages in thread
From: Maulik Shah (mkshah) @ 2026-05-19 4:10 UTC (permalink / raw)
To: Bjorn Andersson; +Cc: Linus Walleij, linux-arm-msm, linux-gpio, linux-kernel
On 5/19/2026 9:03 AM, Bjorn Andersson wrote:
> On Mon, May 18, 2026 at 10:20:55PM -0500, Bjorn Andersson wrote:
>> On Thu, May 14, 2026 at 02:08:25PM +0530, Maulik Shah wrote:
>>> Replace open coded eoi call to parent irqchip with irq_chip_eoi_parent().
>>>
>>> No functional impact.
>>>
>>
>> Reviewed-by: Bjorn Andersson <andersson@kernel.org>
>>
>
> On second though, I'm not sure I want to r-b this patch.
>
> The commit message explains the action of the patch, not the reasons for
> the patch. From the description I inferred that irq_chip_eoi_parent()
> does implement what is open coded here, and a quick glance confirms
> that.
>
> I'm guessing that irq_chip_eoi_parent() didn't exist when
> msm_gpio_irq_eoi() was written? Or was it not used for some reason?
irq_chip_eoi_parent() did exist before msm_gpio_irq_eoi() and msmgpio irqchip was using same
with a condition that pctrl->irq_chip.irq_eoi was only initialized to point irq_chip_eoi_parent()
for the cases where the gpio had a parent pdc/mpm irq number.
Later via [1] (as part to make irqchip immutable) pctrl->irq_chip.irq_eoi callback was updated to
use for each gpio interrupt and hence requiring the check like below inside eoi call to invoke only
if parent data (PDC/MPM) is valid.
d = d->parent_data;
if (d)
d->chip->irq_eoi(d);
[1] https://lore.kernel.org/all/20220419141846.598305-8-maz@kernel.org/
>
>> Regards,
>> Bjorn
>>
>>> Signed-off-by: Maulik Shah <maulik.shah@oss.qualcomm.com>
>>> ---
>>> drivers/pinctrl/qcom/pinctrl-msm.c | 6 ++----
>>> 1 file changed, 2 insertions(+), 4 deletions(-)
>>>
>>> diff --git a/drivers/pinctrl/qcom/pinctrl-msm.c b/drivers/pinctrl/qcom/pinctrl-msm.c
>>> index 45b3a2763eb8..6771f5eb29e4 100644
>>> --- a/drivers/pinctrl/qcom/pinctrl-msm.c
>>> +++ b/drivers/pinctrl/qcom/pinctrl-msm.c
>>> @@ -1012,10 +1012,8 @@ static void msm_gpio_irq_ack(struct irq_data *d)
>>>
>>> static void msm_gpio_irq_eoi(struct irq_data *d)
>>> {
>>> - d = d->parent_data;
>>> -
>>> - if (d)
>>> - d->chip->irq_eoi(d);
>>> + if (d->parent_data)
>
> "I know that irq_chip_eoi_parent() will peak into d->parent_data, so
> let's peek into the object first to avoid it dereferencing a NULL
> pointer".
>
> I see one other caller to irq_chip_eoi_parent() doing this, most
> everyone else just register irq_chip_eoi_parent directly in the ops
> struct.
>
> Are we doing it right?
Yes, because some gpios may not be wake up capable (they don't have their PDC / MPM interrupt)
and for such cases irq_domain_trim_hierarchy() makes irqd->parent_data = NULL, so this has to be
checked using if (d->parent_data) before invoking irq_chip_eoi_parent(), since internally
irq_chip_eoi_parent() de-references without a valid pointer check.
one can argue that the valid pointer check should be taken care inside irq_chip_eoi_parent()
(and all other irq_chip_*_parent() APIs) but i guess not all irqchip have cases where
irq_domain_trim_hierarchy() may be invoked and it would be overhead for them.
Thanks,
Maulik
>
> Regards,
> Bjorn
>
>>> + irq_chip_eoi_parent(d);
>>> }
>>>
>>> static bool msm_gpio_needs_dual_edge_parent_workaround(struct irq_data *d,
>>>
>>> ---
>>> base-commit: e98d21c170b01ddef366f023bbfcf6b31509fa83
>>> change-id: 20260514-pinctrl_msm_irq_eoi-ab736e16d411
>>>
>>> Best regards,
>>> --
>>> Maulik Shah <maulik.shah@oss.qualcomm.com>
>>>
>>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent()
2026-05-14 8:38 [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent() Maulik Shah
2026-05-19 3:20 ` Bjorn Andersson
@ 2026-05-25 8:38 ` Linus Walleij
1 sibling, 0 replies; 5+ messages in thread
From: Linus Walleij @ 2026-05-25 8:38 UTC (permalink / raw)
To: Maulik Shah; +Cc: Bjorn Andersson, linux-arm-msm, linux-gpio, linux-kernel
On Thu, May 14, 2026 at 10:38 AM Maulik Shah
<maulik.shah@oss.qualcomm.com> wrote:
> Replace open coded eoi call to parent irqchip with irq_chip_eoi_parent().
>
> No functional impact.
>
> Signed-off-by: Maulik Shah <maulik.shah@oss.qualcomm.com>
Please resend this with a commit log including all the reasoning
requested by Bjorn.
(Maybe that is already in my inbox, sorry then.)
Yours,
Linus Walleij
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2026-05-25 8:38 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-05-14 8:38 [PATCH] pinctrl: qcom: Replace open coded eoi call with irq_chip_eoi_parent() Maulik Shah
2026-05-19 3:20 ` Bjorn Andersson
2026-05-19 3:33 ` Bjorn Andersson
2026-05-19 4:10 ` Maulik Shah (mkshah)
2026-05-25 8:38 ` Linus Walleij
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.