lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1740213.b4QuNDOMfZ@avalon>
Date:   Mon, 01 Oct 2018 18:55:56 +0300
From:   Laurent Pinchart <laurent.pinchart@...asonboard.com>
To:     Rob Herring <robh@...nel.org>
Cc:     Ricardo Ribalda Delgado <ricardo.ribalda@...il.com>,
        Pavel Machek <pavel@....cz>,
        Sakari Ailus <sakari.ailus@....fi>,
        Mauro Carvalho Chehab <mchehab@...nel.org>,
        Linux Media Mailing List <linux-media@...r.kernel.org>,
        "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
        Hans Verkuil <hans.verkuil@...co.com>,
        devicetree@...r.kernel.org
Subject: Re: [PATCH v4 3/7] [media] ad5820: DT new optional field enable-gpios

Hello,

On Monday, 1 October 2018 18:01:42 EEST Rob Herring wrote:
> On Mon, Oct 1, 2018 at 7:40 AM Ricardo Ribalda Delgado wrote:
> > On Mon, Oct 1, 2018 at 2:36 PM Rob Herring wrote:
> >> On Mon, Oct 1, 2018 at 3:20 AM Ricardo Ribalda Delgado wrote:
> >>> On Thu, Sep 27, 2018 at 8:23 PM Rob Herring wrote:
> >>>> On Thu, Sep 20, 2018 at 10:47:47PM +0200, Ricardo Ribalda Delgado 
wrote:
> >>>>> Document new enable-gpio field. It can be used to disable the part
> >>>>> enable-gpios without turning down its regulator.
> >>>>> 
> >>>>> Cc: devicetree@...r.kernel.org
> >>>>> Signed-off-by: Ricardo Ribalda Delgado <ricardo.ribalda@...il.com>
> >>>>> Acked-by: Pavel Machek <pavel@....cz>
> >>>>> ---
> >>>>> 
> >>>>>  Documentation/devicetree/bindings/media/i2c/ad5820.txt | 7
> >>>>>  +++++++
> >>>>>  1 file changed, 7 insertions(+)
> >>>>> 
> >>>>> diff --git
> >>>>> a/Documentation/devicetree/bindings/media/i2c/ad5820.txt
> >>>>> b/Documentation/devicetree/bindings/media/i2c/ad5820.txt index
> >>>>> 5940ca11c021..9ccd96d3d5f0 100644
> >>>>> --- a/Documentation/devicetree/bindings/media/i2c/ad5820.txt
> >>>>> +++ b/Documentation/devicetree/bindings/media/i2c/ad5820.txt
> >>>>> 
> >>>>> @@ -8,6 +8,12 @@ Required Properties:
> >>>>>    - VANA-supply: supply of voltage for VANA pin
> >>>>> 
> >>>>> +Optional properties:
> >>>>> +
> >>>>> +   - enable-gpios : GPIO spec for the XSHUTDOWN pin. Note that
> >>>>> the polarity of +the enable GPIO is the opposite of the XSHUTDOWN
> >>>>> pin (asserting the enable +GPIO deasserts the XSHUTDOWN signal
> >>>>> and vice versa).
> >>>> 
> >>>> shutdown-gpios is also standard and seems like it would make more
> >>>> sense here. Yes, it is a bit redundant to have both, but things just
> >>>> evolved that way and we don't want to totally abandon the hardware
> >>>> names (just all the variants).
> >>> 
> >>> Sorry to insist
> >>> 
> >>> The pin is called xshutdown, not shutdown and is inverse logic,
> >>> Wouldnt it make more sense to use the name enable-gpios?
> >> 
> >> Inverse of what? shutdown-gpios is the inverse of enable-gpios. By
> >> using shutdown-gpios you can just get rid of "Note that the polarity
> >> of the enable GPIO is the opposite of the XSHUTDOWN pin (asserting the
> >> enable GPIO deasserts the XSHUTDOWN signal and vice versa)."
> > 
> > The pin is called XSHUTDOWN
> > 
> > 0V means shutdown
> > 
> > 3.3V means enable
> > 
> > This is why I think is more clear to use enable as name in the device
> > tree.
> 
> Neither enable-gpios nor shutdown-gpios have a defined polarity. The
> polarity is part of the flags cell in the specifier.

To be precise, the polarity is the relationship between the logical level (low 
or high) *on the GPIO side* and the logical state (asserted or deasserted) of 
the signal *on the device side*. This is important in order to take all 
components on the signal path into account, such as inverters on the board. 
The polarity does tell what level to output on the GPIO in order to achieve a 
given effect.

The polarity, however, doesn't dictate what effect is expected. This is 
defined by the DT bindings (together with the documentation of the device). 
For instance an enable-gpios property in DT implies that an asserted logical 
state will enable the device. The GPIO polarity flags thus take into account a 
possible inverter at the device input (as in the difference between the ENABLE 
and nENABLE signals), but stops there.

In this case, we have an XSHUTDOWN pin that will shut the device down when 
driven to 0V. If we call the related DT property shutdown, its logical level 
will be the inverse of XSHUTDOWN: the signal will need to be driven low to 
assert the shutdown effect. The GPIO flags will thus need to take this into 
account, and documenting it in DT could be useful to avoid errors.

On the other hand, if we call the related DT property enable its logical level 
will the the same as XSHUTDOWN: the signal will need to be driven high to 
assert the enable effect.

On the driver side we would have to deassert shutdown or assert enable to 
enable the device.

I don't mind which option is selected, as long as the DT bindings are clear 
(without any inverter in the signal path beside the one inside the ad5820, the 
polarity would need to be high for the enable case and low for the shutdown 
case).

-- 
Regards,

Laurent Pinchart



Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ