Active low GPIOs (was [PATCH v1 1/4] i2c: mux: Add i2c-arbitrator 'mux' driver)
Stephen Warren
swarren at wwwdotorg.org
Fri Feb 15 04:48:45 EST 2013
On 02/14/2013 10:05 AM, Doug Anderson wrote:
> Linus,
>
> On Thu, Feb 14, 2013 at 2:01 AM, Linus Walleij <linus.walleij at linaro.org> wrote:
>> On Thu, Feb 14, 2013 at 1:41 AM, Stephen Warren <swarren at wwwdotorg.org> wrote:
>>> On 02/13/2013 05:34 PM, Doug Anderson wrote:
>>
>>>> A little torn here. It adds a bunch of complexity to the code to
>>>> handle this case and there are no known or anticipated users. I only
>>>> wish that the GPIO polarity could be more hidden from drivers (add
>>>> functions like gpio_assert, gpio_deassert, etc)...
>>>
>>> Yes, that would be nice. Alex, LinusW?
>>
>> OK so good point since Alex is rewriting the way the external
>> API to GPIOs is done.
>>
>> So this is one of the evolutionary artifacts of the GPIO subsystem:
>> that it has this concept of clients having to know if they want to
>> drive the line low or high.
...
>> But changing it would have very drastic effects.
>> Consider this snippet from
>> arch/arm/boot/dts/snowball.dts:
>>
>> // External Micro SD slot
>> sdi0_per1 at 80126000 {
>> arm,primecell-periphid = <0x10480180>;
>> max-frequency = <50000000>;
>> bus-width = <4>;
>> mmc-cap-mmc-highspeed;
>> vmmc-supply = <&ab8500_ldo_aux3_reg>;
>>
>> cd-gpios = <&gpio6 26 0x4>; // 218
>> cd-inverted;
>
> We're actually kinda screwed today. What happens if you're on a
> Samsung SoC and you have:
> cd-gpios = <&gpc3 2 2 0x10003 3>;
> cd-inverted;
>
> What _should_ we do? I'd argue that we ought to be using
> "gpio_is_asserted" and then keeping the existing invert logic. This
> is much better than today where you need to do one of:
> * ignore the active low on this GPIO
> * ignore the cd-inverted property
> * manually apply _both_ of these properties.
This is actually why I rather dislike the idea that device tree has an
immutable bindings. To some exten, I imagine that much of
Documentation/stable_api_nonsense.txt could apply against device tree!
We can't fix problems like this by changing the definition of that
binding to remove the cd-inverted property and rely solely on the GPIO
specifier flags.
And I think it's ironic that you linked to the commit that adds the
inverted flag to the Samsung GPIO specifier; IIRC, Samsung's previous
lack of support for that flags was one of the reasons that a bunch of
bindings added their own foo-inverted or foo-active-high flags, since
not all GPIO specifiers could be relied upon to provide that information:-(
More information about the devicetree-discuss
mailing list