[PATCH 07/11] pinctrl: use ngpios propety from DT
Jonas Gorski
jogo at openwrt.org
Thu Oct 29 07:47:19 PDT 2015
On 29.10.2015 15:36, Linus Walleij wrote:
> On Wed, Oct 28, 2015 at 12:52 PM, Pramod Kumar <pramodku at broadcom.com> wrote:
>
>> I discussed with ASIC team regarding this iProc GPIO block. They use a library to create the GPIOs block where "total number of GPIO pins( let say N) in GPIO block" is used as an parameter.
>> Library uses a construct for *a* GPIO pin. This gets instantiated N times to create a complete GPIO block with N pins.
>>
>> All iProc based SoCs uses this library. So I'm not sure whether attaching "total number of GPIOs pins" to compatible-string make sense in this case.
>> I personally feel that passing this number from the DT makes more sense here. Any iProc based future as well as current SoCs would be able to use this driver without any change.
>>
>> Please advise us in this case.
>
> Hm! You make a good case.
>
> But this contradicts the traditional use of ngpios.
>
> But on the other hand:
> git grep ngpio Documentation/devicetree/bindings/gpio/
>
> Gives at hand that the use of ngpio[s] is a complete mess.
>
> :(
>
> I will think about patching the standard bindings to fix this mess
> and include your case. Give me some time.
Using ngpios to restrict the amount of actually available GPIOs from
the possible amount of GPIOs seems a rather limited use, as rerouted
gpios are seldom at the end of the GPIO space.
So maybe it makes more sense to use ngpio as the number of
possible gpios and then have an additional "reserved-gpios"
bitmask / list of unavailable gpios?
Ideally those would be just consumed by a pinctrl instance, but I
guess that these are sometimes controlled through pinstrapping,
so there might be no driver to attach to them.
Regards
Jonas
More information about the linux-arm-kernel
mailing list