On Fri 08 Dec 09:22 PST 2017, Charles Keepax wrote: > On Fri, Dec 08, 2017 at 03:40:49PM +0100, Linus Walleij wrote: > > On Fri, Dec 8, 2017 at 3:29 PM, Charles Keepax > > <ckeepax@xxxxxxxxxxxxxxxxxxxxx> wrote: > > > > > (...) I have finally > > > managed to get some time to look over the pinctrl-single stuff. > > > > > > Naively one could convert the pinctrl-single stuff over to use > > > the patches I proposed creating one large group for the driver > > > and then mux each pin individually from within that. However I > > > am not really sure it would make sense. From the implementation > > > so far the pinctrl-single stuff appears to target systems where > > > there isn't really a concept of groups. Each pin is just a > > > completely separate entry and you can only configure things one > > > pin at a time. In that case it almost makes more sense to model > > > each pin as an individual group such that it is clearly distinct > > > from the others. My thinking had been more along the lines of you > > > perhaps have a group that represents an I2S port but you can also > > > individually assign each of those pins as a GPIO when not in use > > > as the I2S port. > > > > So then I toss the qcom driver into the game instead :) > > > > If you look at drivers/pinctrl/qcom/* e.g. pinctrl-ipq4019.c or > > essentially any of the subdrivers, you find exactly this scenario. > > > > I am concerned that if we add infrastructure for this, it needs > > to have more than one user. Qualcomm does fit your description > > above I think. > > > > Yeah I could certainly have a hunt through for other users that > would make good candidates to update. The QC driver certainly > looks like it would be capable of muxing individual pins, > although it looks like it might not let you mux an individual > GPIO at the moment, need to dig into that more. > In the Qualcomm hardware we have X GPIO pins and some number of special purpose pins. GPIO pins can be muxed and controlled individually and the special purpose pins (e.g. SDCC) are controlled as a group. I expected to describe both of these types as "pinctrl groups", but after struggling with this I realized that as the control is on pin-granularity (for the GPIOs) this is what should be represented as a group in pinctl/pinmux/pinconf. So each GPIO pin can be controlled/muxed individually and as such is represented as a group, special groups are describes as one group (matching the single set of registers). To configure a "logical group" (e.g. a UART), we list each pin (technically group), specify the same function and the necessary configuration options. So if you hardware supports configuring individual pins within a group my suggestion is that you should rework the driver to make "group" match "configurable thing" and then tie together logical groups when configuring your system. PS. A side effect of this is that e.g. UART is a function of 4 pins, but by specifying the pinmux/pinconf of only two of them I have a 2 pin UART, without having to describe this setup in the pinctrl driver. Regards, Bjorn -- To unsubscribe from this list: send the line "unsubscribe linux-gpio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html