All of lore.kernel.org
 help / color / mirror / Atom feed
From: Johan Hovold <johan@kernel.org>
To: Laxman Dewangan <ldewangan@nvidia.com>
Cc: Johan Hovold <johan@kernel.org>,
	Linus Walleij <linus.walleij@linaro.org>,
	Alexandre Courbot <gnurou@gmail.com>,
	Rob Herring <robh+dt@kernel.org>,
	Mark Rutland <mark.rutland@arm.com>,
	Frank Rowand <frowand.list@gmail.com>,
	"linux-gpio@vger.kernel.org" <linux-gpio@vger.kernel.org>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>
Subject: Re: [PATCH 1/1] gpio: core: Decouple open drain/source flag with active low/high
Date: Tue, 25 Jul 2017 14:06:32 +0200	[thread overview]
Message-ID: <20170725120632.GA27516@localhost> (raw)
In-Reply-To: <596F73BC.1000305@nvidia.com>

On Wed, Jul 19, 2017 at 08:29:08PM +0530, Laxman Dewangan wrote: 
> >> Good that you found this and fixed it before someone git hurt.
> > Well, while decoupling single-endedness from polarity was the right
> > thing to do, this change did actually break the DT binary interface.
> >
> > If you have an old compiled dtb whose source used GPIO_OPEN_DRAIN, you
> > now instead get *open-source* behaviour on 4.12:
> >
> > 	GPIO_OPEN_DRAIN = GPIO_SINGLE_ENDED | GPIO_ACTIVE_LOW
> > 	
> > 		=> active-low, but *open source*
> >
> > while if you recompile that source against 4.12 you do get the expected
> > open-drain behaviour, but now with inverted polarity:
> >
> > 	GPIO_OPEN_DRAIN = GPIO_SINGLE_ENDED | GPIO_LINE_OPEN_DRAIN
> > 	
> > 		=> open drain, but *active high*
> >
> > requiring the device tree to be updated by specifying
> >
> > 	(GPIO_OPEN_DRAIN | GPIO_ACTIVE_LOW)
> >
> > I guess the latter is fine, even if it is likely to amount to a fair bit
> > of debugging world wide.
> >
> > Perhaps all this can still be avoided by adding further flags and
> > deprecating others before people start migrating to 4.12 (after all,
> > GPIO_OPEN_DRAIN has been around since 4.4 even if there are no in-kernel
> > users).
> >
> > Or we accept the binary interface breakage -- it probably is pretty rare
> > that people update the kernel without updating the dtb. I can just
> > update the dts on the system that broke for me, and hopefully anyone
> > debugging this issue while updating to 4.12 will find this mail quickly.
> >
> 
> Yes, it breaks the older DTS with new kernel. However,  this point was 
> discussed before sending patch. As there was no user in the mainline DTs 
> for these macros, we made change.

These are generic gpio flags that can be used with a multitude of
devices (e.g. regulators, reset-signals for all sorts of ICs, etc.), and
whether there are any in-kernel users (dts) should probably not carry
much weight.

Some people are still stuck with 4.4 or 4.9 and it may still be a while
before they update to, say, the next LTS kernel (4.13) and get bitten by
this.

Thanks,
Johan

  reply	other threads:[~2017-07-25 12:06 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-04-06 13:35 [PATCH 1/1] gpio: core: Decouple open drain/source flag with active low/high Laxman Dewangan
2017-04-06 13:35 ` Laxman Dewangan
2017-04-06 16:10 ` Andy Shevchenko
2017-04-06 16:56   ` Laxman Dewangan
2017-04-06 17:30     ` Andy Shevchenko
2017-04-07 10:25 ` Linus Walleij
     [not found]   ` <CACRpkdaK1ut-1=NtqqL15QuQV+P2n8XidNqVspOfu+7x=XMvog-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2017-04-07 10:14     ` Laxman Dewangan
2017-04-07 10:14       ` Laxman Dewangan
2017-07-19 13:25   ` Johan Hovold
2017-07-19 14:59     ` Laxman Dewangan
2017-07-19 14:59       ` Laxman Dewangan
2017-07-25 12:06       ` Johan Hovold [this message]
     [not found]       ` <596F73BC.1000305-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2017-08-03  8:14         ` Linus Walleij
2017-08-03  8:14           ` Linus Walleij
2017-08-03 12:14           ` Johan Hovold

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=20170725120632.GA27516@localhost \
    --to=johan@kernel.org \
    --cc=devicetree@vger.kernel.org \
    --cc=frowand.list@gmail.com \
    --cc=gnurou@gmail.com \
    --cc=ldewangan@nvidia.com \
    --cc=linus.walleij@linaro.org \
    --cc=linux-gpio@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mark.rutland@arm.com \
    --cc=robh+dt@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.