From: Krzysztof Kozlowski <krzk@kernel.org>
To: Christophe Leroy <christophe.leroy@csgroup.eu>,
Rob Herring <robh@kernel.org>
Cc: Qiang Zhao <qiang.zhao@nxp.com>,
Linus Walleij <linus.walleij@linaro.org>,
Bartosz Golaszewski <brgl@bgdev.pl>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org,
linux-arm-kernel@lists.infradead.org, linux-gpio@vger.kernel.org,
devicetree@vger.kernel.org
Subject: Re: [PATCH v3 5/6] dt-bindings: soc: fsl: qe: Add support of IRQ in QE GPIO
Date: Fri, 29 Aug 2025 11:16:04 +0200 [thread overview]
Message-ID: <c314b7c6-f5b7-4f3e-8d67-e3c92ff8ff37@kernel.org> (raw)
In-Reply-To: <1ba37df7-2d4a-4258-8220-58ee7d609264@csgroup.eu>
On 29/08/2025 10:35, Christophe Leroy wrote:
>
>
> Le 29/08/2025 à 09:47, Krzysztof Kozlowski a écrit :
>> On 28/08/2025 16:12, Christophe Leroy wrote:
>>>
>>>
>>> Le 28/08/2025 à 15:28, Rob Herring a écrit :
>>>> On Mon, Aug 25, 2025 at 2:20 AM Christophe Leroy
>>>> <christophe.leroy@csgroup.eu> wrote:
>>>>>
>>>>> In the QE, a few GPIOs are IRQ capable. Similarly to
>>>>> commit 726bd223105c ("powerpc/8xx: Adding support of IRQ in MPC8xx
>>>>> GPIO"), add IRQ support to QE GPIO.
>>>>>
>>>>> Add property 'fsl,qe-gpio-irq-mask' similar to
>>>>> 'fsl,cpm1-gpio-irq-mask' that define which of the GPIOs have IRQs.
>>>>
>>>> Why do you need to know this? The ones that have interrupts will be
>>>> referenced by an 'interrupts' property somewhere.
>>>
>>> I don't follow you. The ones that have interrupts need to be reported by
>>> gc->qe_gpio_to_irq[] so that gpiod_to_irq() return the IRQ number, for
>>> instance to gpio_sysfs_request_irq() so that it can install an irq
>>> handler. I can't see where they would be referenced by an "interrupts"
>>> property.
>>
>> They would be referenced by every consumer of these interrupts. IOW,
>> this property is completely redundant, because DT holds this information
>> already in other place.
>
> But the gpio controller _is_ the consumer of these interrupts, it it
> _not_ the provider.
>
> The interrupts are provided by a separate interrupt controller. Let's
> take the exemple of powerpc 8xx. Here is the list of interrupts handled
> by the CPM interrupt controller on the 8xx:
>
> 1 - GPIO Port C Line 4 interrupt
> 2 - GPIO Port C Line 5 interrupt
> 3 - SMC2 Serial controller interrupt
> 4 - SMC1 Serial controller interrupt
> 5 - SPI controller interrupt
> 6 - GPIO Port C Line 6 interrupt
> 7 - Timer 4 interrupt
> 8 - SCCd Serial controller interrupt
> 9 - GPIO Port C Line 7 interrupt
> 10 - GPIO Port C Line 8 interrupt
> 11 - GPIO Port C Line 9 interrupt
> 12 - Timer 3 interrupt
> 13 - SCCc Serial controller interrupt
> 14 - GPIO Port C Line 10 interrupt
> 15 - GPIO Port C Line 11 interrupt
> 16 - I2C Controller interrupt
> 17 - RISC timer table interrupt
> 18 - Timer 2 interrupt
> 19 - SCCb Serial controller interrupt
> 20 - IDMA2 interrupt
> 21 - IDMA1 interrupt
> 22 - SDMA channel bus error interrupt
> 23 - GPIO Port C Line 12 interrupt
> 24 - GPIO Port C Line 13 interrupt
> 25 - Timer 1 interrupt
> 26 - GPIO Port C Line 14 interrupt
> 27 - SCCd Serial controller interrupt
> 28 - SCCc Serial controller interrupt
> 29 - SCCb Serial controller interrupt
> 30 - SCCa Serial controller interrupt
> 31 - GPIO Port C Line 15 interrupt
That list is fixed per soc/device, so already implied by compatible.
>
> As you can see in the list, the GPIO line interrupts are nested with
> other types of interrupts so GPIO controller and Interrupt controller
> are to be keept independant.
>
> That's more or less the same here with my series, patch 1 implements an
> interrupt controller (documented in patch 6) and then the GPIO
> controllers consume the interrupts, for instance in gpiolib functions
> gpio_sysfs_request_irq() [drivers/gpio/gpiolib-sysfs.c] or
> edge_detector_setup() or debounce_setup() [drivers/gpio/gpiolib-cdev.c]
>
> External drivers also use interrupts indirectly. For example driver
> sound/soc/soc-jack.c, it doesn't have any direct reference to an
> interrupt. The driver is given an array of GPIOs and then installs an
> IRQ in function snd_soc_jack_add_gpios() by doing
>
> request_any_context_irq(gpiod_to_irq(gpios[i].desc),
> gpio_handler,
> IRQF_SHARED |
> IRQF_TRIGGER_RISING |
> IRQF_TRIGGER_FALLING,
> gpios[i].name,
> &gpios[i]);
External drivers do not matter then. Your GPIO controller receives
specific interrupts (that's the interrupt property) and knows exactly
how each GPIO maps to it.
>
>>
>>>
>>>>
>>>>> Here is an exemple for port B of mpc8323 which has IRQs for
>>>>
>>>> typo
>>>>
>>>>> GPIOs PB7, PB9, PB25 and PB27.
>>>>>
>>>>> qe_pio_b: gpio-controller@1418 {
>>>>> compatible = "fsl,mpc8323-qe-pario-bank";
>>>>> reg = <0x1418 0x18>;
>>>>> interrupts = <4 5 6 7>;
>>>>> interrupt-parent = <&qepic>;
>>>>> gpio-controller;
>>>>> #gpio-cells = <2>;
>>>>> fsl,qe-gpio-irq-mask = <0x01400050>;
>>>>> };
>>>>
>>>> You are missing #interrupt-cells and interrupt-controller properties.
>>>
>>> The gpio controller is not an interrupt controller. The GPIO controller
>>> is brought by patch 1/6 and documented in patch 6/6.
>>
>> Then the IRQ mask property is not right here. If you say "this GPIOs
>> have IRQs" it means this is an interrupt controller.
>
> The mask tells to the GPIO controller which GPIO line has an interrupt
> (so it can install the edge detector) and which doesn't have an
> interrupt. The "interrupts" property gives a flat list of interrupts,
> the mask in the above example tells: interrupt 4 is for line 7,
> interrupt 5 is for line 9, interrupt 6 is for line 25, interrupt 7 is
> for line 27. Other lines don't have interrupts.
>
>>
>> If you say this is not an interrupt controller, then you cannot have
>> here interrupts per some GPIOs, obviously.
>
> It has been working that way on powerpc 8xx for 8 years, since commit
> 726bd223105c ("powerpc/8xx: Adding support of IRQ in MPC8xx GPIO")
>
> I don't understand why you say you cannot have
> here interrupts per some GPIOs. What am I missing ?
I used conditional. English conditional. If you claim this GPIO
controller is not an interrupt controller, then obviously it is not an
interrupt controller and cannot be used as interrupt controller.
If you use "foo" as interrupt controller, then clearly foo is an
interrupt controller.
Best regards,
Krzysztof
next prev parent reply other threads:[~2025-08-29 9:16 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-08-25 6:53 [PATCH v3 0/6] Add support of IRQs to QUICC ENGINE GPIOs Christophe Leroy
2025-08-25 6:53 ` [PATCH v3 1/6] soc: fsl: qe: Add an interrupt controller for QUICC Engine Ports Christophe Leroy
2025-08-25 6:53 ` [PATCH v3 2/6] soc: fsl: qe: Change GPIO driver to a proper platform driver Christophe Leroy
2025-08-25 12:56 ` Bartosz Golaszewski
2025-08-25 13:01 ` Bartosz Golaszewski
2025-08-26 8:40 ` [PATCH v4] " Christophe Leroy
2025-08-25 6:53 ` [PATCH v3 3/6] soc: fsl: qe: Drop legacy-of-mm-gpiochip.h header from GPIO driver Christophe Leroy
2025-08-25 6:53 ` [PATCH v3 4/6] soc: fsl: qe: Add support of IRQ in QE GPIO Christophe Leroy
2025-08-25 13:02 ` Bartosz Golaszewski
2025-08-26 8:41 ` [PATCH v4] " Christophe Leroy
2025-08-26 9:57 ` Bartosz Golaszewski
2025-08-25 6:53 ` [PATCH v3 5/6] dt-bindings: " Christophe Leroy
2025-08-28 13:28 ` Rob Herring
2025-08-28 14:12 ` Christophe Leroy
2025-08-29 7:47 ` Krzysztof Kozlowski
2025-08-29 8:35 ` Christophe Leroy
2025-08-29 9:16 ` Krzysztof Kozlowski [this message]
2025-08-29 9:41 ` Christophe Leroy
2025-08-29 10:51 ` Krzysztof Kozlowski
2025-08-29 7:48 ` Krzysztof Kozlowski
2025-08-25 6:53 ` [PATCH v3 6/6] dt-bindings: soc: fsl: qe: Add an interrupt controller for QUICC Engine Ports Christophe Leroy
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=c314b7c6-f5b7-4f3e-8d67-e3c92ff8ff37@kernel.org \
--to=krzk@kernel.org \
--cc=brgl@bgdev.pl \
--cc=christophe.leroy@csgroup.eu \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=krzk+dt@kernel.org \
--cc=linus.walleij@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linuxppc-dev@lists.ozlabs.org \
--cc=qiang.zhao@nxp.com \
--cc=robh@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).