On Mon, 25 Oct 2021 at 01:11, Linus Walleij <linus.walleij@xxxxxxxxxx> wrote: > On Thu, Oct 21, 2021 at 7:42 PM Emil Renner Berthing <kernel@xxxxxxxx> wrote: > > > Add bindings for the StarFive JH7100 GPIO/pin controller. > > > > Signed-off-by: Emil Renner Berthing <kernel@xxxxxxxx> > > That is a very terse commit message for an entirely new > SoC, please put a little blurb about this silicon there. > Like mention that it is RISC-V at least. Will do! > Overall quite interesting! > > > +$id: http://devicetree.org/schemas/pinctrl/starfive,jh7100-pinctrl.yaml# > > +$schema: http://devicetree.org/meta-schemas/core.yaml# > > + > > +title: StarFive JH7100 Pin Controller Device Tree Bindings > > + > > +maintainers: > > + - Emil Renner Berthing <kernel@xxxxxxxx> > > + - Drew Fustini <drew@xxxxxxxxxxxxxxx> > > Add description: talking about that this is a RISC-V SoC > and other implicit things that are really good to know. Gotcha. > > + starfive,signal-group: > > + description: | > > + The SoC has a global setting selecting one of 7 different pinmux > > + configurations of the pads named GPIO[0:63] and FUNC_SHARE[0:141]. After > > + this global setting is chosen only the 64 "GPIO" pins can be further > > + muxed by configuring them to be controlled by certain peripherals rather > > + than software. > > + Note that in configuration 0 none of GPIOs are routed to pads, and only > > + in configuration 1 are the GPIOs routed to the pads named GPIO[0:63]. > > + If this property is not set it defaults to the configuration already > > + chosen by the earlier boot stages. > > + $ref: /schemas/types.yaml#/definitions/uint32 > > + enum: [0, 1, 2, 3, 4, 5, 6] > > This still is hard for me to understand. Does it mean that 0..6 define > how the direct-to-peripheral-pins are set up? Yeah, so the SoC has many pins, but only the pins named GPIO[0:63] and FUNC_SHARE[0:141] can be muxed. To do that you first select one of 7 different "signal groups". This is a global setting. There is just a single register on the whole SoC where you write either 0, 1, .., or 6. As an example signal group 6 maps LCD output to FUNC_SHARE[40:97], ethernet phy connection to FUNC_SHARE[115:141], MIPI to GPIO[0:60] and confusingly it maps "GPIO0", "GPIO1", ..., "GPIO63" to pins FUNC_SHARE[0:63]. So the pin names doesn't necessarily match the function. In fact only signal group 1 maps GPIO0-63 to pins GPIO[0:63]. See table 11-1 starting on page 62 of this PDF: https://github.com/starfive-tech/JH7100_Docs/blob/main/JH7100%20Data%20Sheet%20V01.01.04-EN%20(4-21-2021).pdf GPIO0-63 can of course be used as GPIOs, but they can also have their output value and output enable controlled by certain (slow) peripherals like UARTs, I2C, SPI, PWM etc. These can be chosen freely. So once you've chosen signal group 6, you can have any of GPIO0-GPIO63 (that is any of pins FUNC_SHARE[0:63]) be controlled by the UART0 TX signal fx. So for each of GPIO0 to GPIO63 there is a register to select the output value signal and a register to select its output enable signal. You can see the list of signals to choose from in the header introduced in the previous patch. Input from GPIO0-63 to peripherals works the other way around. Here there is a register for each input signal, where you can select which (if any) of GPIO0-63 is routed to the peripheral. > Then it would make sense to describe what happens for 0, 1, 2 ...6 > i.e. what the different set-ups are. Yeah, so how much of table 11-1 does it make sense to write out. Certainly I can list how GPIO0-63 are mapped to pins for each of the 7 signal groups, but should I also list LCD, ethernet, interconnect, mipi etc. for each of the 7 signal groups? > Actually this is what we call group-based pin multiplexing in Linux, > this property seems to avoid using that concept. > See for example: > Documentation/devicetree/bindings/pinctrl/cortina,gemini-pinctrl.txt I don't think this is the same, but hope you can tell me after reading the description above. > > + patternProperties: > > + '-pins*$': > > + type: object > > + description: | > > + A pinctrl node should contain at least one subnode representing the > > + pinctrl groups available on the machine. Each subnode will list the > > + pins it needs, and how they should be configured, with regard to > > + muxer configuration, bias, input enable/disable, input schmitt > > + trigger enable/disable, slew-rate and drive strength. > > + $ref: "/schemas/pinctrl/pincfg-node.yaml" > > Nice that you use pincfg-node.yaml > > > + properties: > > + pins: > > + description: | > > + The list of pin identifiers that properties in the node apply to. > > + This should be set using either the PAD_GPIO or PAD_FUNC_SHARE > > + macro. Either this or "pinmux" has to be specified. > > + > > + pinmux: > > + description: | > > + The list of GPIO identifiers and their mux settings that > > + properties in the node apply to. This should be set using the > > + GPIOMUX macro. Either this or "pins" has to be specified. > > What about referencing > Documentation/devicetree/bindings/pinctrl/pinmux-node.yaml > for this? Sure. You just mean adding $ref: like above right? Thanks! /Emil