Re: [PATCH 3/4] ARM: pinctrl: Add Broadcom Capri pinctrl driver

From: Heiko Stübner
Date: Mon Nov 04 2013 - 18:27:14 EST


Am Montag, 4. November 2013, 13:24:10 schrieb Linus Walleij:
> > In my driver, I have the "one entry per pin" support for all my
> > properties instead of just the function property, like the "drive_str"
> > property below:
> >
> > + grp_1 {
> > + brcm,pins = "pin1", "pin2", "pin3";
> > + brcm,function = "alt1", "alt2", "alt1";
> > + brcm,drive_str = <2 4 6>;
> > + brcm,slew = <1>;
> > + };
>
> On Sat, Oct 26, 2013 at 12:48 AM, Sherman Yin <syin@xxxxxxxxxxxx> wrote:
> > I thought that would be convenient and allow users to group pins together
> > based on functionality and without the restriction that the pins must
> > have the same properties.
> > Do you think that's a good idea and are there
> > plans to support that in the generic pinconfig? If so, I can look into
> > porting my implementation to pinconf-generic.c - but first I have to
> > figure out how some of the properties would work if more than one value
> > could be specified (eg. "bias-disable" which takes no values)
>
> Hm I don't quite get it I think. It depends on the old bindings still
> working and full compatibility with old device trees. It might be a bit
> confusing.
>
> I need help from Heiko on this I think.

I remember we had a discussion about how things like bias-disable explicitly
shouldn't have a value, when they are represented in the list-format:

pcfg_pull_none: pcfg_pull_none {
bias-disable;
};

so a bias-disable = <1> was explicitly "forbidden" [for a lack of a better
word]. And it was similar for other options, the parameter not meant to be
indicating if they are active but really only setting the "strength" or so.

But how to represent this in the list variant above, I don't know.

Having a brcm,bias-disable = <0>, <1>, ... thus looks wrong and also does not
seem to scale well to all the possible options (bias-* and the others).

Having a brcm,bias = <x>, <y>, <z>, ... with constants denoting pull-up, -
down, disable, etc might be possible, but I'm missing the electrical
engineering knowledge on the possibility of those bias-things being combined.



For example on my rockchip-pinctrl driver, the pins also do not need to have
the same configuration to be grouped together - inspired at the time by the
format the at91 driver uses. Here each pin forms a tuple instead of being
identified by an index. In it the basic function is set directly and then
references a predefined list of pinctrl options.


pcfg_pull_none: pcfg_pull_none {
bias-disable;
};

uart0 {
uart0_xfer: uart0-xfer {
rockchip,pins = <RK_GPIO1 0 RK_FUNC_1 &pcfg_pull_none>,
<RK_GPIO1 1 RK_FUNC_1 &pcfg_pull_none>;
};

...
};



A switch to something like to following would also be a possibility:

pcfg1: pcfg1 {
bias-disable;
slew-rate = <1>;
};

pcfg2: pcfg2 {
drive-strength = <2>;
};

grp_1 {
brcm,pins = "pin1", "pin2", "pin3";
brcm,function = "alt1", "alt2", "alt1";
brcm,pinconf = <&pcfg1>, <&pcfg2>
};



So far my unsorted thoughts [and recoverable memory] on this :-)
Heiko
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/