Hi Linus, On 10/07/19 1:58 PM, Harish Jenny K N wrote: > Hi, > > On 09/07/19 9:38 PM, Rob Herring wrote: >> On Mon, Jul 8, 2019 at 11:25 PM Harish Jenny K N >> <harish_kandiga@xxxxxxxxxx> wrote: >>> Hi Rob, >>> >>> >>> On 09/07/19 4:06 AM, Rob Herring wrote: >>>> On Fri, Jun 28, 2019 at 3:31 AM Harish Jenny K N >>>> <harish_kandiga@xxxxxxxxxx> wrote: >>>>> Document the device tree binding for the inverter gpio >>>>> controller to configure the polarity of the gpio pins >>>>> used by the consumers. >>>>> >>>>> Signed-off-by: Harish Jenny K N <harish_kandiga@xxxxxxxxxx> >>>>> --- >>>>> .../devicetree/bindings/gpio/gpio-inverter.txt | 29 ++++++++++++++++++++++ >>>>> 1 file changed, 29 insertions(+) >>>>> create mode 100644 Documentation/devicetree/bindings/gpio/gpio-inverter.txt >>>>> >>>>> diff --git a/Documentation/devicetree/bindings/gpio/gpio-inverter.txt b/Documentation/devicetree/bindings/gpio/gpio-inverter.txt >>>>> new file mode 100644 >>>>> index 0000000..8bb6b2e >>>>> --- /dev/null >>>>> +++ b/Documentation/devicetree/bindings/gpio/gpio-inverter.txt >>>>> @@ -0,0 +1,29 @@ >>>>> +GPIO-INVERTER >>>>> +====== >>>>> +This binding defines the gpio-inverter. The gpio-inverter is a driver that >>>>> +allows to properly describe the gpio polarities on the hardware. >>>> I don't understand. Please explain this in terms of the hardware, not a driver. >>> gpio inverters can be used on different hardware to alter the polarity of gpio chips. >>> The polarity of pins can change from hardware to hardware with the use of inverters. >> Yes, I know what an inverter is. >> >>> This device tree binding models gpio inverters in the device tree to properly describe the hardware. >> We already define the active state of GPIOs in the consumers. If >> there's an inverter in the middle, the consumer active state is simply >> inverted. I don't agree that that is a hack as Linus said without some >> reasoning why an inverter needs to be modeled in DT. Anything about >> what 'userspace' needs is not a reason. That's a Linux thing that has >> little to do with hardware description. > > Yes we are talking about the hardware level inversions here. The usecase is for those without the gpio consumer driver. The usecase started with the concept of allowing an abstraction of the underlying hardware for the userland controlling program such that this program does not care whether the GPIO lines are inverted or not physically. In other words, a single userland controlling program can work unmodified across a variety of hardware platforms with the device tree mapping the logical to physical relationship of the GPIO hardware. > I totally understand anything about what 'userspace' needs is not a reason, but this is not restricted to userspace alone as kernel drivers may need this just as much. Also we are just modelling/describing the hardware state in the device tree. > > Just to mention that Linus Walleij had proposed this inverter model to describe the hardware and the gpio inverter driver is developed based on comments/review from him. > > Also my sincere request to Linus Walleij to please let his opinion know on this. > > Thanks, > > Best Regards, > Harish Jenny K N Can you please give your opinion on this. Thanks. Best Regards, Harish Jenny K N >