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: <8F93AE08-B340-481B-A5B3-F42227D9D729@konsulko.com>
Date:	Wed, 8 Jun 2016 16:41:12 +0300
From:	Pantelis Antoniou <pantelis.antoniou@...sulko.com>
To:	Rob Herring <robherring2@...il.com>
Cc:	Linus Walleij <linus.walleij@...aro.org>,
	Alexandre Courbot <gnurou@...il.com>,
	Frank Rowand <frowand.list@...il.com>,
	Matt Porter <mporter@...sulko.com>,
	Koen Kooi <koen@...inion.thruhere.net>,
	Geert Uytterhoeven <geert@...ux-m68k.org>,
	Guenter Roeck <linux@...ck-us.net>,
	Marek Vasut <marex@...x.de>,
	"devicetree@...r.kernel.org" <devicetree@...r.kernel.org>,
	"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
	"linux-gpio@...r.kernel.org" <linux-gpio@...r.kernel.org>,
	Mark Rutland <mark.rutland@....com>
Subject: Re: [PATCH 2/2] gpio: Support cascaded GPIO chip lookup for OF

Hi Rob,

> On Jun 8, 2016, at 00:00 , Rob Herring <robherring2@...il.com> wrote:
> 
> +Mark R
> 
> On Fri, Jun 3, 2016 at 3:26 PM, Pantelis Antoniou
> <pantelis.antoniou@...sulko.com> wrote:
>> In certain cases it makes sense to create cascaded GPIO which
>> are not real GPIOs, merely point to the real backend GPIO chip.
> 
> In what cases? Make it clear what this is for. Connectors of course,
> but are there any other use cases you have in mind.
> 

Connectors is one obvious use-case. In fact even when there is no
connector but there is an obvious interface abstraction point you
might want to use it.

For instance a SoC package may have a number of different GPIO
controllers (that may or may not use the same IP block). You could
abstract all the gpio controllers away in a single GPIO controller
block.

>> In order to support this, cascaded of_xlate lookup need to be
>> performed.
>> 
>> For example let's take a connector that we want to abstract
>> having two GPIO pins from different GPIO controllers, connector
>> pin #0 connected to gpioA controller with offset 10 and gpioB
>> with 4.
> 
> A connector's GPIO number may or may not be related to connector pins.
> 

Obviously, this is just an example.

>> In pseudo DT form this is analogous to:
>> 
>>        gpioA: gpioa@...00 {
>>                compatible = "foocorp,gpio";
>>                ...
>>        };
>> 
>>        gpioB: gpiob@...00 {
>>                compatible = "foocorp,gpio";
>>                ....
>>        };
>> 
>>        gpioC: controller_gpio {
>>                compatible = "cascaded-gpio";
> 
> This compatible is kind of meaningless. I'd expect this to be a
> connector compatible.
> 

No, because this gpio patch is completely independent of the
existence of a connector.
 
>>                gpios = <&gpioA 10>, <&gpioB 5>;
> 
> As we discussed at ELC, I think this should be modeled after
> interrupt-map property like this:
> 
> gpio-map = <0 0 &soc_gpio 10 0>, <1 0 &soc_gpio 5 0>;
> gpio-map-mask = <0xff 0>;
> 
> This is more flexible, a known pattern, and allows remapping of flag cells.
> 

It’s just syntactic sugar. It can work either way.

> Also, we will likely have interrupt capable GPIOs, so they are going
> to need interrupt-map anyway.
> 

Devices that use interrupts usually convert the GPIO to an interrupt and use it.
Since the xlat op will return the real GPIO spec the interrupt conversion will work.

Bare interrupt lines are sort-of out of fashion nowadays I think. I’m eager to be
proven wrong though with a recent portable expansion board that uses them.

> Rob

Regards

— Pantelis

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ