Re: [PATCH v4 1/2] gpio/omap: don't create an IRQ mapping for every GPIO on DT

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 29/07/2013, at 12:27, Alexander Holler <holler@xxxxxxxxxxxxx> wrote:

> Am 29.07.2013 10:17, schrieb Javier Martinez Canillas:
>> Hi Alexander,
>> 
>> On Mon, Jul 29, 2013 at 8:41 AM, Alexander Holler <holler@xxxxxxxxxxxxx> wrote:
>>> Am 28.07.2013 21:06, schrieb Javier Martinez Canillas:
>>> 
>>>> On Sun, Jul 28, 2013 at 8:22 PM, Linus Walleij <linus.walleij@xxxxxxxxxx>
>>>> wrote:
>>>>> 
>>>>> On Sun, Jul 28, 2013 at 7:33 PM, Javier Martinez Canillas
>>>>> <martinez.javier@xxxxxxxxx> wrote:
>>>>> 
>>>>>> According to Documentation/devicetree/bindings/mmc/mmc.txt:
>>>>>> 
>>>>>> cd-gpios: Specify GPIOs for card detection, see gpio binding
>>>>>> 
>>>>>> So it just says that it is a GPIO for card detection and not an IRQ so
>>>>>> this assumption comes from either the omap_hsmmc driver or Alexander'
>>>>>> DTS is missing something like:
>>>>>> 
>>>>>>                 interrupt-parent = <&gpio6>;
>>>>>>                 interrupts = <16 8>;
>>> 
>>> 
>>> What do the values 16 and 8 mean here? GPIO numbers?
>>> And where do I have to place that?
>> 
>> If you look at Documentation/devicetree/bindings/interrupt-controller/interrupts.txt
>> for the two cells interrupt controllers definition:
>> 
>>  b) two cells
>>  ------------
>>  The #interrupt-cells property is set to 2 and the first cell defines the
>>  index of the interrupt within the controller, while the second cell is used
> 
> I had read that. And there is written, "index of the interrupt". So may
> I ask the question how you think people are translating GPIO number to
> interrupt index?. And if it's the same, will GPIO0_0 map to IRQ 0 or how
> is the magic formular people are supposed to use?
> 

Yes, the GPIO-IRQ is a especial case since the chip is both a GPIO and a IRQ controller. In this context the "index of the interrupt" is the physical index of the GPIO line within that GPIO bank. Since each OMAP GPIO bank has 32 GPIO lines, in this example, gpio6 + 16 = GPIO 176.

You define the hardware interrupt (GPIO line in this case) but that is not what drivers see, they see the virtual IRQ number mapped to the hardware IRQ which is just a cookie and the actual number depends on what GPIO to IRQ domain mapping is being used.

> Besides that, the existing standard DTS I've modified into my
> "non-standard" dts is arch/arm/boot/dts/am335x-bone.dts.
> 
> if you look at the definition of the GPIO bank 0 in
> arch/arm/boot/dts/am33xx.dtsi, you see
> 
> #interrupt-cells = <1>;
> 

Yes, that's probably because no one is using the edge/level flags on am33xx but that is a bug and has to be changed to #interrupt-cells = <2>

This has been fixed recently for omap3.dtsi recently too.

> Anyway, thanks for your time, but I don't want to spend more time on
> that topic.
> 

Thanks a lot for your time and sorry for the inconvenience. It seems these patches are going to be reverted anyways since it causes another regression on older OMAP1 platforms so you probably can forget about this issue.

A different "GPIO hogs" approach will be used to pre-define which GPIO are going to be used as IRQ so the core can request them and setup as input.

I expect you will have the same issue with this new approach though since the omap hsmmc driver will try to call gpio_request() on a previously requested GPIO.

So I think the driver has to be changed independently of the approach for auto request GPIO used.

> Regards,
> 
> Alexander Holler

Best regards,
Javier--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Arm (vger)]     [ARM Kernel]     [ARM MSM]     [Linux Tegra]     [Linux WPAN Networking]     [Linux Wireless Networking]     [Maemo Users]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux