Message ID | 20231221083622.3445726-2-yuklin.soo@starfivetech.com |
---|---|
State | New |
Headers | show |
Series | Add Pinctrl driver for Starfive JH8100 SoC | expand |
On Thu, 21 Dec 2023 16:36:17 +0800, Alex Soo wrote: > Add dt-binding documentation and header file for JH8100 pinctrl > driver. > > Signed-off-by: Alex Soo <yuklin.soo@starfivetech.com> > Reviewed-by: Ley Foon Tan <leyfoon.tan@starfivetech.com> > --- > .../pinctrl/starfive,jh8100-aon-pinctrl.yaml | 183 +++++++++++ > .../starfive,jh8100-sys-east-pinctrl.yaml | 188 +++++++++++ > .../starfive,jh8100-sys-gmac-pinctrl.yaml | 124 +++++++ > .../starfive,jh8100-sys-west-pinctrl.yaml | 188 +++++++++++ > .../pinctrl/starfive,jh8100-pinctrl.h | 303 ++++++++++++++++++ > 5 files changed, 986 insertions(+) > create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jh8100-aon-pinctrl.yaml > create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-east-pinctrl.yaml > create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.yaml > create mode 100644 Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-west-pinctrl.yaml > create mode 100644 include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > My bot found errors running 'make DT_CHECKER_FLAGS=-m dt_binding_check' on your patch (DT_CHECKER_FLAGS is new in v5.13): yamllint warnings/errors: dtschema/dtc warnings/errors: Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.example.dts:18:18: fatal error: dt-bindings/clock/starfive,jh8100.h: No such file or directory 18 | #include <dt-bindings/clock/starfive,jh8100.h> | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ compilation terminated. make[2]: *** [scripts/Makefile.lib:419: Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.example.dtb] Error 1 make[2]: *** Waiting for unfinished jobs.... make[1]: *** [/builds/robherring/dt-review-ci/linux/Makefile:1424: dt_binding_check] Error 2 make: *** [Makefile:234: __sub-make] Error 2 doc reference errors (make refcheckdocs): See https://patchwork.ozlabs.org/project/devicetree-bindings/patch/20231221083622.3445726-2-yuklin.soo@starfivetech.com The base for the series is generally the latest rc1. A different dependency should be noted in *this* patch. If you already ran 'make dt_binding_check' and didn't see the above error(s), then make sure 'yamllint' is installed and dt-schema is up to date: pip3 install dtschema --upgrade Please check and re-submit after running the above command yourself. Note that DT_SCHEMA_FILES can be set to your schema file to speed up checking your schema. However, it must be unset to test all examples with your schema.
On 21/12/2023 14:57, Linus Walleij wrote: >> + drive-strength: >> + enum: [ 2, 4, 8, 12 ] > > Milliamperes? Then spell that out in a description: Or just use drive-strength-microamp Best regards, Krzysztof
On 21/12/2023 09:36, Alex Soo wrote: > Add dt-binding documentation and header file for JH8100 pinctrl > driver. > > Signed-off-by: Alex Soo <yuklin.soo@starfivetech.com> > Reviewed-by: Ley Foon Tan <leyfoon.tan@starfivetech.com> > --- A nit, subject: drop second/last, redundant "bindings". The "dt-bindings" prefix is already stating that these are bindings. ... > + i nterrupt-controller: true > + > + gpio-controller: true > + > + '#gpio-cells': > + const: 2 > + > +patternProperties: > + '-[0-9]+$': This is a bit too wide pattern. Consider some suffix like -grp or -group. Look at other bindings how they do it. > + type: object > + additionalProperties: false > + patternProperties: > + '-pins$': > + type: object > + description: | > + A pinctrl node should contain at least one subnode representing the > + pinctrl groups available in the domain. 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. > + allOf: > + - $ref: /schemas/pinctrl/pincfg-node.yaml > + - $ref: /schemas/pinctrl/pinmux-node.yaml > + additionalProperties: false Why the rest of the properties is not applicable? > + > + properties: > + pinmux: > + description: | > + The list of GPIOs and their mux settings or function select. > + The GPIOMUX and PINMUX macros are used to configure the > + I/O multiplexing and function selection respectively. > + > + bias-disable: true > + > + bias-pull-up: > + type: boolean > + > + bias-pull-down: > + type: boolean > + > + drive-strength: > + enum: [ 2, 4, 8, 12 ] > + > + input-enable: true > + > + input-disable: true > + > + input-schmitt-enable: true > + > + input-schmitt-disable: true > + > + slew-rate: > + maximum: 1 > + > +required: > + - compatible > + - reg > + - resets > + - interrupts > + - interrupt-controller > + - gpio-controller > + - '#gpio-cells' > + > +additionalProperties: false > + > +examples: > + - | > + #include <dt-bindings/clock/starfive,jh8100.h> > + #include <dt-bindings/reset/starfive-jh8100.h> > + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> > + > + soc { > + #address-cells = <2>; > + #size-cells = <2>; > + > + pinctrl_aon: pinctrl@1f300000 { > + compatible = "starfive,jh8100-aon-pinctrl", > + "syscon", "simple-mfd"; You did not even bother to test it before sending. > + reg = <0x0 0x1f300000 0x0 0x10000>; > + resets = <&aoncrg 0>; Use 4 spaces for example indentation. > + interrupts = <160>; > + interrupt-controller; > + gpio-controller; > + #gpio-cells = <2>; Incomplete example. I'll stop review, except one more comment, this was not tested and does not work. Reviewing code which was never tested is a waste of reviewer's time. ... > diff --git a/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > new file mode 100644 > index 000000000000..c57b7ece37a2 > --- /dev/null > +++ b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > @@ -0,0 +1,303 @@ > +/* SPDX-License-Identifier: GPL-2.0 OR MIT */ > +/* > + * Copyright (C) 2023 StarFive Technology Co., Ltd. > + * Author: Alex Soo <yuklin.soo@starfivetech.com> > + * > + */ > + > +#ifndef __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ > +#define __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ > + > +/* sys_iomux_west pins */ > +#define PAD_GPIO0_W 0 > +#define PAD_GPIO1_W 1 > +#define PAD_GPIO2_W 2 > +#define PAD_GPIO3_W 3 > +#define PAD_GPIO4_W 4 > +#define PAD_GPIO5_W 5 > +#define PAD_GPIO6_W 6 > +#define PAD_GPIO7_W 7 > +#define PAD_GPIO8_W 8 > +#define PAD_GPIO9_W 9 > +#define PAD_GPIO10_W 10 > +#define PAD_GPIO11_W 11 > +#define PAD_GPIO12_W 12 > +#define PAD_GPIO13_W 13 > +#define PAD_GPIO14_W 14 > +#define PAD_GPIO15_W 15 > + > +/* sys_iomux_west syscon */ > +#define SYS_W_VREF_GPIO_W_SYSCON_REG 0x6c > +#define SYS_W_VREF_GPIO_W_SYSCON_MASK GENMASK(1, 0) > +#define SYS_W_VREF_GPIO_W_SYSCON_SHIFT 0 > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_REG 0x70 > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_MASK GENMASK(1, 0) > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_SHIFT 0 None of these are bindings, drop. > + > +/* sys_iomux_east pins */ > +#define PAD_GPIO0_E 0 > +#define PAD_GPIO1_E 1 > +#define PAD_GPIO2_E 2 > +#define PAD_GPIO3_E 3 > +#define PAD_GPIO4_E 4 > +#define PAD_GPIO5_E 5 > +#define PAD_GPIO6_E 6 > +#define PAD_GPIO7_E 7 > +#define PAD_GPIO8_E 8 > +#define PAD_GPIO9_E 9 > +#define PAD_GPIO10_E 10 > +#define PAD_GPIO11_E 11 > +#define PAD_GPIO12_E 12 > +#define PAD_GPIO13_E 13 > +#define PAD_GPIO14_E 14 > +#define PAD_GPIO15_E 15 > +#define PAD_GPIO16_E 16 > +#define PAD_GPIO17_E 17 > +#define PAD_GPIO18_E 18 > +#define PAD_GPIO19_E 19 > +#define PAD_GPIO20_E 20 > +#define PAD_GPIO21_E 21 > +#define PAD_GPIO22_E 22 > +#define PAD_GPIO23_E 23 > +#define PAD_GPIO24_E 24 > +#define PAD_GPIO25_E 25 > +#define PAD_GPIO26_E 26 > +#define PAD_GPIO27_E 27 > +#define PAD_GPIO28_E 28 > +#define PAD_GPIO29_E 29 > +#define PAD_GPIO30_E 30 > +#define PAD_GPIO31_E 31 > +#define PAD_GPIO32_E 32 > +#define PAD_GPIO33_E 33 > +#define PAD_GPIO34_E 34 > +#define PAD_GPIO35_E 35 > +#define PAD_GPIO36_E 36 > +#define PAD_GPIO37_E 37 > +#define PAD_GPIO38_E 38 > +#define PAD_GPIO39_E 39 > +#define PAD_GPIO40_E 40 > +#define PAD_GPIO41_E 41 > +#define PAD_GPIO42_E 42 > +#define PAD_GPIO43_E 43 > +#define PAD_GPIO44_E 44 > +#define PAD_GPIO45_E 45 > +#define PAD_GPIO46_E 46 > +#define PAD_GPIO47_E 47 Please explain why do you think these are bindings? > + > +/* sys_iomux_east syscon */ > +#define SYS_E_VREF_GPIO_E0_SYSCON_REG 0x0fc > +#define SYS_E_VREF_GPIO_E0_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_GPIO_E0_SYSCON_SHIFT 0 > +#define SYS_E_VREF_GPIO_E1_SYSCON_REG 0x100 > +#define SYS_E_VREF_GPIO_E1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_GPIO_E1_SYSCON_SHIFT 0 > +#define SYS_E_VREF_GPIO_E2_SYSCON_REG 0x104 > +#define SYS_E_VREF_GPIO_E2_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_GPIO_E2_SYSCON_SHIFT 0 > +#define SYS_E_VREF_GPIO_E3_SYSCON_REG 0x108 > +#define SYS_E_VREF_GPIO_E3_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_GPIO_E3_SYSCON_SHIFT 0 > +#define SYS_E_VREF_ATB_STG1_SYSCON_REG 0x10c > +#define SYS_E_VREF_ATB_STG1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_ATB_STG1_SYSCON_SHIFT 0 > +#define SYS_E_VREF_ATB_USB_SYSCON_REG 0x110 > +#define SYS_E_VREF_ATB_USB_SYSCON_MASK GENMASK(1, 0) > +#define SYS_E_VREF_ATB_USB_SYSCON_SHIFT 0 Drop all of this, not bindings. > + > +/* sys_iomux_gmac pins */ > +#define PAD_GMAC1_MDC 0 > +#define PAD_GMAC1_MDIO 1 > +#define PAD_GMAC1_RXD0 2 > +#define PAD_GMAC1_RXD1 3 > +#define PAD_GMAC1_RXD2 4 > +#define PAD_GMAC1_RXD3 5 > +#define PAD_GMAC1_RXDV 6 > +#define PAD_GMAC1_RXC 7 > +#define PAD_GMAC1_TXD0 8 > +#define PAD_GMAC1_TXD1 9 > +#define PAD_GMAC1_TXD2 10 > +#define PAD_GMAC1_TXD3 11 > +#define PAD_GMAC1_TXEN 12 > +#define PAD_GMAC1_TXC 13 > + > +/* sys_iomux_gmac vref syscon registers */ > +#define SYS_G_VREF_GMAC1_SYSCON_REG 0x08 > +#define SYS_G_VREF_GMAC1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_VREF_GMAC1_SYSCON_SHIFT 0 > +#define SYS_G_VREF_SDIO1_SYSCON_REG 0x0c > +#define SYS_G_VREF_SDIO1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_VREF_SDIO1_SYSCON_SHIFT 0 Drop all this. > + > +/* sys_iomux_gmac interface (rmii/rgmii) syscon registers */ > +#define SYS_G_GMAC1_MDC_SYSCON_REG 0x10 > +#define SYS_G_GMAC1_MDC_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_MDC_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_MDIO_SYSCON_REG 0x14 > +#define SYS_G_GMAC1_MDIO_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_MDIO_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXD0_SYSCON_REG 0x18 > +#define SYS_G_GMAC1_RXD0_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXD0_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXD1_SYSCON_REG 0x1c > +#define SYS_G_GMAC1_RXD1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXD1_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXD2_SYSCON_REG 0x20 > +#define SYS_G_GMAC1_RXD2_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXD2_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXD3_SYSCON_REG 0x24 > +#define SYS_G_GMAC1_RXD3_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXD3_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXDV_SYSCON_REG 0x28 > +#define SYS_G_GMAC1_RXDV_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXDV_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_RXC_SYSCON_REG 0x2c > +#define SYS_G_GMAC1_RXC_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_RXC_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXD0_SYSCON_REG 0x30 > +#define SYS_G_GMAC1_TXD0_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXD0_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXD1_SYSCON_REG 0x34 > +#define SYS_G_GMAC1_TXD1_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXD1_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXD2_SYSCON_REG 0x38 > +#define SYS_G_GMAC1_TXD2_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXD2_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXD3_SYSCON_REG 0x3c > +#define SYS_G_GMAC1_TXD3_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXD3_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXEN_SYSCON_REG 0x40 > +#define SYS_G_GMAC1_TXEN_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXEN_SYSCON_SHIFT 0 > +#define SYS_G_GMAC1_TXC_SYSCON_REG 0x44 > +#define SYS_G_GMAC1_TXC_SYSCON_MASK GENMASK(1, 0) > +#define SYS_G_GMAC1_TXC_SYSCON_SHIFT 0 Drop all this. > + > +/* sys_iomux_gmac timing (slew rate) registers */ Srsly, "registers", so not bindings. > + > +#define GPOUT_LOW 0 > +#define GPOUT_HIGH 1 That's it. Really. Please do not redefine existing bindings. > + > +#define GPOEN_ENABLE 0 > +#define GPOEN_DISABLE 1 > + > +#define GPI_NONE 255 > + > +/* vref syscon value */ > +#define PAD_VREF_SYSCON_IO_3V3 0 > +#define PAD_VREF_SYSCON_IO_1V8 2 > + > +/* gmac interface (rmii/rgmii) syscon value */ > +#define GMAC_RMII_MODE 0 /* RMII mode, DVDD 2.5V/3.3V */ > +#define GMAC_RGMII_MODE 1 /* RGMII mode, DVDD 1.8V/2.5V */ > + > +/* gmac timing syscon value */ > +#define GMAC_SLEW_RATE_FAST 0 > +#define GMAC_SLEW_RATE_SLOW 1 Drop all above. > + > +#endif Best regards, Krzysztof
> -----Original Message----- > From: Linus Walleij <linus.walleij@linaro.org> > Sent: Thursday, December 21, 2023 9:57 PM > To: Yuklin Soo <yuklin.soo@starfivetech.com> > Cc: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>; Hal Feng > <hal.feng@starfivetech.com>; Leyfoon Tan <leyfoon.tan@starfivetech.com>; > Jianlong Huang <jianlong.huang@starfivetech.com>; Emil Renner Berthing > <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > Drew Fustini <drew@beagleboard.org>; linux-gpio@vger.kernel.org; linux- > kernel@vger.kernel.org; devicetree@vger.kernel.org; linux- > riscv@lists.infradead.org; Paul Walmsley <paul.walmsley@sifive.com>; Palmer > Dabbelt <palmer@dabbelt.com>; Albert Ou <aou@eecs.berkeley.edu> > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > bindings > > Hi Alex, > > thanks for your patch! > > On Thu, Dec 21, 2023 at 9:36 AM Alex Soo <yuklin.soo@starfivetech.com> > wrote: > > > Add dt-binding documentation and header file for JH8100 pinctrl > > driver. > > > > Signed-off-by: Alex Soo <yuklin.soo@starfivetech.com> > > Reviewed-by: Ley Foon Tan <leyfoon.tan@starfivetech.com> > (...) > > +title: StarFive JH8100 AON Pin Controller > > If AON means "always-on" then spell that out in the title, the world has too > many opaque TLAs. > > title: StarFive JH8100 AON (always-on) Pin Controller This title will be updated as shown above to clarify the meaning of acronym AON. > > (...) > > + properties: > > + pinmux: > > + description: | > > + The list of GPIOs and their mux settings or function select. > > + The GPIOMUX and PINMUX macros are used to configure the > > + I/O multiplexing and function selection respectively. > > + > > + bias-disable: true > > + > > + bias-pull-up: > > + type: boolean > > + > > + bias-pull-down: > > + type: boolean > > + > > + drive-strength: > > + enum: [ 2, 4, 8, 12 ] > > Milliamperes? Then spell that out in a description: Yes, the unit is milliamperes, “drive-strength:” will be changed to “drive-strength: Drive strength in mA” > > > + Voltage regulator supply the actual voltage to the GPIO bank while > > + the syscon register configuration in bit [1:0] indicates the current voltage > setting. > > + > > + +------+------+-------------------+ > > + | Bit1 | Bit0 | Reference Voltage | > > + +------+------+-------------------+ > > + | 0 | 0 | 3.3 V | > > + +------+------+-------------------+ > > + | 1 | x | 1.8 V | > > + +------+------+-------------------+ > > + > > + To increase the device voltage, set bit [1:0] to the new operating > > + state first before raising the actual voltage to the higher operating point. > > + > > + To decrease the device voltage, hold bit [1:0] to the current > > + operating state until the actual voltage has stabilized at the > > + lower operating point before changing the setting. > > + > > + Alternatively, a device voltage change can always be initiated by > > + first setting syscon register bit [1:0] = 0, the safe 3.3V startup > > + condition, before changing the device voltage. Then once the actual > > + voltage is changed and has stabilized at the new operating point, bit [1:0] > can be reset as appropriate. > > Actually: where is this information even used? Each pin controller in JH8100 SoC has a set of regmap-based syscon registers to serve different purposes in respective pinctrl domain. In AON (always-on) pinctrl, there are: - syscon registers to indicate the I/O voltage level of eMMC, SD0, RGPIOs, and XSPI. - syscon registers to control the GMAC settings. The former will be used in the SD/eMMC device driver to indicate the change in voltage supply during voltage switching in the initialization process. The syscon register configuration provides information to indicate the device I/O voltage level. The device driver must make sure these syscon registers are configured properly. In case if setting syscon register to indicate device I/O voltage as 1.8V, but the actual voltage supply is 3.3V. The pads used for the device I/O interface will get damaged. > > > + slew-rate: > > + maximum: 1 > > Milliseconds? Write unit in description please. The slew-rate is a single bit in the IO Pad configuration register. Bit value 0 means slow and 1 means fast. slew-rate: maximum: 1 will be changed to slew-rate: enum: [ 0, 1 ] default: 0 description: | 0: slow (half frequency) 1: fast Is that okay? > > Yours, > Linus Walleij
> -----Original Message----- > From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > Sent: Thursday, December 21, 2023 11:45 PM > To: Linus Walleij <linus.walleij@linaro.org>; Yuklin Soo > <yuklin.soo@starfivetech.com> > Cc: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>; Hal Feng > <hal.feng@starfivetech.com>; Leyfoon Tan <leyfoon.tan@starfivetech.com>; > Jianlong Huang <jianlong.huang@starfivetech.com>; Emil Renner Berthing > <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > Drew Fustini <drew@beagleboard.org>; linux-gpio@vger.kernel.org; linux- > kernel@vger.kernel.org; devicetree@vger.kernel.org; linux- > riscv@lists.infradead.org; Paul Walmsley <paul.walmsley@sifive.com>; Palmer > Dabbelt <palmer@dabbelt.com>; Albert Ou <aou@eecs.berkeley.edu> > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > bindings > > On 21/12/2023 14:57, Linus Walleij wrote: > >> + drive-strength: > >> + enum: [ 2, 4, 8, 12 ] > > > > Milliamperes? Then spell that out in a description: > > Or just use drive-strength-microamp Suggest changing “drive-strength:” to “drive-strength: Drive strength in mA” since the unit is in mA. > > Best regards, > Krzysztof
On Thu, Jan 04, 2024 at 03:12:31AM +0000, Yuklin Soo wrote: > > > > -----Original Message----- > > From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > > Sent: Thursday, December 21, 2023 11:45 PM > > To: Linus Walleij <linus.walleij@linaro.org>; Yuklin Soo > > <yuklin.soo@starfivetech.com> > > Cc: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>; Hal Feng > > <hal.feng@starfivetech.com>; Leyfoon Tan <leyfoon.tan@starfivetech.com>; > > Jianlong Huang <jianlong.huang@starfivetech.com>; Emil Renner Berthing > > <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > > Drew Fustini <drew@beagleboard.org>; linux-gpio@vger.kernel.org; linux- > > kernel@vger.kernel.org; devicetree@vger.kernel.org; linux- > > riscv@lists.infradead.org; Paul Walmsley <paul.walmsley@sifive.com>; Palmer > > Dabbelt <palmer@dabbelt.com>; Albert Ou <aou@eecs.berkeley.edu> > > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > > bindings > > > > On 21/12/2023 14:57, Linus Walleij wrote: > > >> + drive-strength: > > >> + enum: [ 2, 4, 8, 12 ] > > > > > > Milliamperes? Then spell that out in a description: > > > > Or just use drive-strength-microamp > > Suggest changing “drive-strength:” to “drive-strength: Drive strength in mA” since the unit is in mA. Just call the property "drive-strength-microamp". We have existing users of that property. Cheers, Conor.
> -----Original Message----- > From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > Sent: Thursday, December 21, 2023 11:50 PM > To: Yuklin Soo <yuklin.soo@starfivetech.com>; Linus Walleij > <linus.walleij@linaro.org>; Bartosz Golaszewski > <bartosz.golaszewski@linaro.org>; Hal Feng <hal.feng@starfivetech.com>; > Leyfoon Tan <leyfoon.tan@starfivetech.com>; Jianlong Huang > <jianlong.huang@starfivetech.com>; Emil Renner Berthing > <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > Drew Fustini <drew@beagleboard.org> > Cc: linux-gpio@vger.kernel.org; linux-kernel@vger.kernel.org; > devicetree@vger.kernel.org; linux-riscv@lists.infradead.org; Paul Walmsley > <paul.walmsley@sifive.com>; Palmer Dabbelt <palmer@dabbelt.com>; > Albert Ou <aou@eecs.berkeley.edu> > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > bindings > > On 21/12/2023 09:36, Alex Soo wrote: > > Add dt-binding documentation and header file for JH8100 pinctrl > > driver. > > > > Signed-off-by: Alex Soo <yuklin.soo@starfivetech.com> > > Reviewed-by: Ley Foon Tan <leyfoon.tan@starfivetech.com> > > --- > > > A nit, subject: drop second/last, redundant "bindings". The "dt-bindings" > prefix is already stating that these are bindings. > > ... > > + i > > nterrupt-controller: true > > + > > + gpio-controller: true > > + > > + '#gpio-cells': > > + const: 2 > > + > > +patternProperties: > > + '-[0-9]+$': > > This is a bit too wide pattern. Consider some suffix like -grp or -group. Look at > other bindings how they do it. The regular expression "-[0-9]+$" will be changed to "-grp$" to standardize client node names to end with suffix "-grp" instead of "-<numerical _number>". In device tree source, for instance, i2c0 node name will be changed to “i2c0-grp”. > > > + type: object > > + additionalProperties: false > > + patternProperties: > > + '-pins$': > > + type: object > > + description: | > > + A pinctrl node should contain at least one subnode representing the > > + pinctrl groups available in the domain. 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. > > + allOf: > > + - $ref: /schemas/pinctrl/pincfg-node.yaml > > + - $ref: /schemas/pinctrl/pinmux-node.yaml > > + additionalProperties: false > > Why the rest of the properties is not applicable? The regex “-pins$” make sure all client subnode names end with suffix “-pins” (e.g, i2c0-scl-pins, i2c-sda-pins) All properties inside these subnodes are defined in ‘pincfg-node.yaml’ and ‘pinmux-mode.yaml’. No other properties are used beside that. i2c0_pins: i2c0-grp { i2c0-scl-pins { pinmux = <GPIOMUX(PAD_GPIO9_E, GPOUT_SYS_I2C0_CLK, GPOEN_SYS_I2C0_CLK, GPI_SYS_I2C0_CLK)>; bias-pull-up; input-enable; }; i2c0-sda-pins { pinmux = <GPIOMUX(PAD_GPIO10_E, GPOUT_SYS_I2C0_DATA, GPOEN_SYS_I2C0_DATA, GPI_SYS_I2C0_DATA)>; bias-pull-up; input-enable; }; }; > > > + > > + properties: > > + pinmux: > > + description: | > > + The list of GPIOs and their mux settings or function select. > > + The GPIOMUX and PINMUX macros are used to configure the > > + I/O multiplexing and function selection respectively. > > + > > + bias-disable: true > > + > > + bias-pull-up: > > + type: boolean > > + > > + bias-pull-down: > > + type: boolean > > + > > + drive-strength: > > + enum: [ 2, 4, 8, 12 ] > > + > > + input-enable: true > > + > > + input-disable: true > > + > > + input-schmitt-enable: true > > + > > + input-schmitt-disable: true > > + > > + slew-rate: > > + maximum: 1 > > + > > +required: > > + - compatible > > + - reg > > + - resets > > + - interrupts > > + - interrupt-controller > > + - gpio-controller > > + - '#gpio-cells' > > + > > +additionalProperties: false > > + > > +examples: > > + - | > > + #include <dt-bindings/clock/starfive,jh8100.h> > > + #include <dt-bindings/reset/starfive-jh8100.h> > > + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> > > + > > + soc { > > + #address-cells = <2>; > > + #size-cells = <2>; > > + > > + pinctrl_aon: pinctrl@1f300000 { > > + compatible = "starfive,jh8100-aon-pinctrl", > > + "syscon", "simple-mfd"; > > You did not even bother to test it before sending. > > > + reg = <0x0 0x1f300000 0x0 0x10000>; > > + resets = <&aoncrg 0>; > > Use 4 spaces for example indentation. Now 4 spaces are used for indentation. > > > + interrupts = <160>; > > + interrupt-controller; > > + gpio-controller; > > + #gpio-cells = <2>; > > > Incomplete example. Only the “pinctrl_gmac” does not provide any pinmuxing capability. The example in “pinctrl_aon”, “pinctrl_east”, and “pinctrl_west” will be updated with the client driver pinmuxing. examples: - | soc { #address-cells = <2>; #size-cells = <2>; pinctrl_aon: pinctrl@1f300000 { compatible = "starfive,jh8100-aon-pinctrl", "syscon", "simple-mfd"; reg = <0x0 0x1f300000 0x0 0x10000>; resets = <&aoncrg 0>; interrupts = <160>; interrupt-controller; gpio-controller; #gpio-cells = <2>; i2c7_pins: i2c7-grp { i2c7-scl-pins { pinmux = <0x23265409>; bias-pull-up; input-enable; }; i2c7-sda-pins { pinmux = <0x2427580a>; bias-pull-up; input-enable; }; }; }; }; > > I'll stop review, except one more comment, this was not tested and does not > work. Reviewing code which was never tested is a waste of reviewer's time. > > > ... > > > diff --git a/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > > b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > > new file mode 100644 > > index 000000000000..c57b7ece37a2 > > --- /dev/null > > +++ b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h > > @@ -0,0 +1,303 @@ > > +/* SPDX-License-Identifier: GPL-2.0 OR MIT */ > > +/* > > + * Copyright (C) 2023 StarFive Technology Co., Ltd. > > + * Author: Alex Soo <yuklin.soo@starfivetech.com> > > + * > > + */ > > + > > +#ifndef __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ > > +#define __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ > > + > > +/* sys_iomux_west pins */ > > +#define PAD_GPIO0_W 0 > > +#define PAD_GPIO1_W 1 > > +#define PAD_GPIO2_W 2 > > +#define PAD_GPIO3_W 3 > > +#define PAD_GPIO4_W 4 > > +#define PAD_GPIO5_W 5 > > +#define PAD_GPIO6_W 6 > > +#define PAD_GPIO7_W 7 > > +#define PAD_GPIO8_W 8 > > +#define PAD_GPIO9_W 9 > > +#define PAD_GPIO10_W 10 > > +#define PAD_GPIO11_W 11 > > +#define PAD_GPIO12_W 12 > > +#define PAD_GPIO13_W 13 > > +#define PAD_GPIO14_W 14 > > +#define PAD_GPIO15_W 15 > > + > > +/* sys_iomux_west syscon */ > > +#define SYS_W_VREF_GPIO_W_SYSCON_REG 0x6c > > +#define SYS_W_VREF_GPIO_W_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_W_VREF_GPIO_W_SYSCON_SHIFT 0 > > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_REG 0x70 > > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_SHIFT 0 > > None of these are bindings, drop. All the SYSCON macros will be removed. > > > + > > +/* sys_iomux_east pins */ > > +#define PAD_GPIO0_E 0 > > +#define PAD_GPIO1_E 1 > > +#define PAD_GPIO2_E 2 > > +#define PAD_GPIO3_E 3 > > +#define PAD_GPIO4_E 4 > > +#define PAD_GPIO5_E 5 > > +#define PAD_GPIO6_E 6 > > +#define PAD_GPIO7_E 7 > > +#define PAD_GPIO8_E 8 > > +#define PAD_GPIO9_E 9 > > +#define PAD_GPIO10_E 10 > > +#define PAD_GPIO11_E 11 > > +#define PAD_GPIO12_E 12 > > +#define PAD_GPIO13_E 13 > > +#define PAD_GPIO14_E 14 > > +#define PAD_GPIO15_E 15 > > +#define PAD_GPIO16_E 16 > > +#define PAD_GPIO17_E 17 > > +#define PAD_GPIO18_E 18 > > +#define PAD_GPIO19_E 19 > > +#define PAD_GPIO20_E 20 > > +#define PAD_GPIO21_E 21 > > +#define PAD_GPIO22_E 22 > > +#define PAD_GPIO23_E 23 > > +#define PAD_GPIO24_E 24 > > +#define PAD_GPIO25_E 25 > > +#define PAD_GPIO26_E 26 > > +#define PAD_GPIO27_E 27 > > +#define PAD_GPIO28_E 28 > > +#define PAD_GPIO29_E 29 > > +#define PAD_GPIO30_E 30 > > +#define PAD_GPIO31_E 31 > > +#define PAD_GPIO32_E 32 > > +#define PAD_GPIO33_E 33 > > +#define PAD_GPIO34_E 34 > > +#define PAD_GPIO35_E 35 > > +#define PAD_GPIO36_E 36 > > +#define PAD_GPIO37_E 37 > > +#define PAD_GPIO38_E 38 > > +#define PAD_GPIO39_E 39 > > +#define PAD_GPIO40_E 40 > > +#define PAD_GPIO41_E 41 > > +#define PAD_GPIO42_E 42 > > +#define PAD_GPIO43_E 43 > > +#define PAD_GPIO44_E 44 > > +#define PAD_GPIO45_E 45 > > +#define PAD_GPIO46_E 46 > > +#define PAD_GPIO47_E 47 > > Please explain why do you think these are bindings? The “PAD_GPIO*_*” represent the pin numbers of the PAD_GPIO pins in each domain. It is part of the pinmux value. The pinmux value is generated by macro GPIOMUX as follow: pinmux = <GPIOMUX(Pin_Number, Output_Signal_Index, Output_Enable_Signal_Index, Input_Signal_Index)>; Use I2C0 as example, pinmux = <GPIOMUX(PAD_GPIO9_E, GPOUT_SYS_I2C0_CLK, GPOEN_SYS_I2C0_CLK, GPI_SYS_I2C0_CLK)>; > > > + > > +/* sys_iomux_east syscon */ > > +#define SYS_E_VREF_GPIO_E0_SYSCON_REG 0x0fc > > +#define SYS_E_VREF_GPIO_E0_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_GPIO_E0_SYSCON_SHIFT 0 > > +#define SYS_E_VREF_GPIO_E1_SYSCON_REG 0x100 > > +#define SYS_E_VREF_GPIO_E1_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_GPIO_E1_SYSCON_SHIFT 0 > > +#define SYS_E_VREF_GPIO_E2_SYSCON_REG 0x104 > > +#define SYS_E_VREF_GPIO_E2_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_GPIO_E2_SYSCON_SHIFT 0 > > +#define SYS_E_VREF_GPIO_E3_SYSCON_REG 0x108 > > +#define SYS_E_VREF_GPIO_E3_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_GPIO_E3_SYSCON_SHIFT 0 > > +#define SYS_E_VREF_ATB_STG1_SYSCON_REG 0x10c > > +#define SYS_E_VREF_ATB_STG1_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_ATB_STG1_SYSCON_SHIFT 0 > > +#define SYS_E_VREF_ATB_USB_SYSCON_REG 0x110 > > +#define SYS_E_VREF_ATB_USB_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_E_VREF_ATB_USB_SYSCON_SHIFT 0 > > Drop all of this, not bindings. All the SYSCON macros will be removed. > > > + > > +/* sys_iomux_gmac pins */ > > +#define PAD_GMAC1_MDC 0 > > +#define PAD_GMAC1_MDIO 1 > > +#define PAD_GMAC1_RXD0 2 > > +#define PAD_GMAC1_RXD1 3 > > +#define PAD_GMAC1_RXD2 4 > > +#define PAD_GMAC1_RXD3 5 > > +#define PAD_GMAC1_RXDV 6 > > +#define PAD_GMAC1_RXC 7 > > +#define PAD_GMAC1_TXD0 8 > > +#define PAD_GMAC1_TXD1 9 > > +#define PAD_GMAC1_TXD2 10 > > +#define PAD_GMAC1_TXD3 11 > > +#define PAD_GMAC1_TXEN 12 > > +#define PAD_GMAC1_TXC 13 > > + > > +/* sys_iomux_gmac vref syscon registers */ > > +#define SYS_G_VREF_GMAC1_SYSCON_REG 0x08 > > +#define SYS_G_VREF_GMAC1_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_VREF_GMAC1_SYSCON_SHIFT 0 > > +#define SYS_G_VREF_SDIO1_SYSCON_REG 0x0c > > +#define SYS_G_VREF_SDIO1_SYSCON_MASK GENMASK(1, 0) > > +#define SYS_G_VREF_SDIO1_SYSCON_SHIFT 0 > > Drop all this. All the GMAC and SYSCON macros will be removed. > > > + > > +/* sys_iomux_gmac interface (rmii/rgmii) syscon registers */ > > +#define SYS_G_GMAC1_MDC_SYSCON_REG 0x10 > > +#define SYS_G_GMAC1_MDC_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_MDC_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_MDIO_SYSCON_REG 0x14 > > +#define SYS_G_GMAC1_MDIO_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_MDIO_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXD0_SYSCON_REG 0x18 > > +#define SYS_G_GMAC1_RXD0_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_RXD0_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXD1_SYSCON_REG 0x1c > > +#define SYS_G_GMAC1_RXD1_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_RXD1_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXD2_SYSCON_REG 0x20 > > +#define SYS_G_GMAC1_RXD2_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_RXD2_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXD3_SYSCON_REG 0x24 > > +#define SYS_G_GMAC1_RXD3_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_RXD3_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXDV_SYSCON_REG 0x28 > > +#define SYS_G_GMAC1_RXDV_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_RXDV_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_RXC_SYSCON_REG 0x2c > > +#define SYS_G_GMAC1_RXC_SYSCON_MASK GENMASK(1, 0) > > +#define SYS_G_GMAC1_RXC_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXD0_SYSCON_REG 0x30 > > +#define SYS_G_GMAC1_TXD0_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_TXD0_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXD1_SYSCON_REG 0x34 > > +#define SYS_G_GMAC1_TXD1_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_TXD1_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXD2_SYSCON_REG 0x38 > > +#define SYS_G_GMAC1_TXD2_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_TXD2_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXD3_SYSCON_REG 0x3c > > +#define SYS_G_GMAC1_TXD3_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_TXD3_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXEN_SYSCON_REG 0x40 > > +#define SYS_G_GMAC1_TXEN_SYSCON_MASK GENMASK(1, > 0) > > +#define SYS_G_GMAC1_TXEN_SYSCON_SHIFT 0 > > +#define SYS_G_GMAC1_TXC_SYSCON_REG 0x44 > > +#define SYS_G_GMAC1_TXC_SYSCON_MASK GENMASK(1, 0) > > +#define SYS_G_GMAC1_TXC_SYSCON_SHIFT 0 > > Drop all this. All the SYSCON macros will be removed. > > > > + > > +/* sys_iomux_gmac timing (slew rate) registers */ > > Srsly, "registers", so not bindings. All these will be removed. > > > > + > > +#define GPOUT_LOW 0 > > +#define GPOUT_HIGH 1 > > That's it. Really. Please do not redefine existing bindings. > > > + > > +#define GPOEN_ENABLE 0 > > +#define GPOEN_DISABLE 1 > > + > > +#define GPI_NONE 255 > > + > > +/* vref syscon value */ > > +#define PAD_VREF_SYSCON_IO_3V3 0 > > +#define PAD_VREF_SYSCON_IO_1V8 2 > > + > > +/* gmac interface (rmii/rgmii) syscon value */ > > +#define GMAC_RMII_MODE 0 /* RMII > mode, DVDD 2.5V/3.3V */ > > +#define GMAC_RGMII_MODE 1 /* > RGMII mode, DVDD 1.8V/2.5V */ > > + > > +/* gmac timing syscon value */ > > +#define GMAC_SLEW_RATE_FAST 0 > > +#define GMAC_SLEW_RATE_SLOW 1 > > Drop all above. All SYSCON macros will be dropped. However, the following will be kept in the header file, #define GPOUT_LOW 0 #define GPOUT_HIGH 1 #define GPOEN_ENABLE 0 #define GPOEN_DISABLE 1 #define GPI_NONE 255 > > > + > > +#endif > > Best regards, > Krzysztof
On 07/02/2024 03:42, Yuklin Soo wrote: >> >>> + type: object >>> + additionalProperties: false >>> + patternProperties: >>> + '-pins$': >>> + type: object >>> + description: | >>> + A pinctrl node should contain at least one subnode representing the >>> + pinctrl groups available in the domain. 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. >>> + allOf: >>> + - $ref: /schemas/pinctrl/pincfg-node.yaml >>> + - $ref: /schemas/pinctrl/pinmux-node.yaml >>> + additionalProperties: false >> >> Why the rest of the properties is not applicable? > > The regex “-pins$” make sure all client subnode names end with suffix “-pins” (e.g, i2c0-scl-pins, i2c-sda-pins) I did not talk about subnodes. I asked why the rest of pincfg and pinmux schema properties are not allowed. >>> +#define PAD_GPIO9_E 9 >>> +#define PAD_GPIO10_E 10 >>> +#define PAD_GPIO11_E 11 >>> +#define PAD_GPIO12_E 12 >>> +#define PAD_GPIO13_E 13 >>> +#define PAD_GPIO14_E 14 >>> +#define PAD_GPIO15_E 15 >>> +#define PAD_GPIO16_E 16 >>> +#define PAD_GPIO17_E 17 >>> +#define PAD_GPIO18_E 18 >>> +#define PAD_GPIO19_E 19 >>> +#define PAD_GPIO20_E 20 >>> +#define PAD_GPIO21_E 21 >>> +#define PAD_GPIO22_E 22 >>> +#define PAD_GPIO23_E 23 >>> +#define PAD_GPIO24_E 24 >>> +#define PAD_GPIO25_E 25 >>> +#define PAD_GPIO26_E 26 >>> +#define PAD_GPIO27_E 27 >>> +#define PAD_GPIO28_E 28 >>> +#define PAD_GPIO29_E 29 >>> +#define PAD_GPIO30_E 30 >>> +#define PAD_GPIO31_E 31 >>> +#define PAD_GPIO32_E 32 >>> +#define PAD_GPIO33_E 33 >>> +#define PAD_GPIO34_E 34 >>> +#define PAD_GPIO35_E 35 >>> +#define PAD_GPIO36_E 36 >>> +#define PAD_GPIO37_E 37 >>> +#define PAD_GPIO38_E 38 >>> +#define PAD_GPIO39_E 39 >>> +#define PAD_GPIO40_E 40 >>> +#define PAD_GPIO41_E 41 >>> +#define PAD_GPIO42_E 42 >>> +#define PAD_GPIO43_E 43 >>> +#define PAD_GPIO44_E 44 >>> +#define PAD_GPIO45_E 45 >>> +#define PAD_GPIO46_E 46 >>> +#define PAD_GPIO47_E 47 >> >> Please explain why do you think these are bindings? > > The “PAD_GPIO*_*” represent the pin numbers of the PAD_GPIO pins in each domain. So not bindings. > It is part of the pinmux value. The pinmux value is generated by macro GPIOMUX as follow: > > pinmux = <GPIOMUX(Pin_Number, Output_Signal_Index, > Output_Enable_Signal_Index, > Input_Signal_Index)>; > > Use I2C0 as example, > pinmux = <GPIOMUX(PAD_GPIO9_E, GPOUT_SYS_I2C0_CLK, > GPOEN_SYS_I2C0_CLK, > GPI_SYS_I2C0_CLK)>; So not bindings. Read my question - I did not ask what are these. I asked why these are bindings. Your explanation suggests these are not. Drop. You can always store some defines in DTS headers. > >> >>> + >>> +/* sys_iomux_east syscon */ >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_REG 0x0fc >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_SHIFT 0 >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_REG 0x100 >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_SHIFT 0 >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_REG 0x104 >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_SHIFT 0 >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_REG 0x108 >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_SHIFT 0 >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_REG 0x10c >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_SHIFT 0 >>> +#define SYS_E_VREF_ATB_USB_SYSCON_REG 0x110 >>> +#define SYS_E_VREF_ATB_USB_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_E_VREF_ATB_USB_SYSCON_SHIFT 0 >> >> Drop all of this, not bindings. > > All the SYSCON macros will be removed. > >> >>> + >>> +/* sys_iomux_gmac pins */ >>> +#define PAD_GMAC1_MDC 0 >>> +#define PAD_GMAC1_MDIO 1 >>> +#define PAD_GMAC1_RXD0 2 >>> +#define PAD_GMAC1_RXD1 3 >>> +#define PAD_GMAC1_RXD2 4 >>> +#define PAD_GMAC1_RXD3 5 >>> +#define PAD_GMAC1_RXDV 6 >>> +#define PAD_GMAC1_RXC 7 >>> +#define PAD_GMAC1_TXD0 8 >>> +#define PAD_GMAC1_TXD1 9 >>> +#define PAD_GMAC1_TXD2 10 >>> +#define PAD_GMAC1_TXD3 11 >>> +#define PAD_GMAC1_TXEN 12 >>> +#define PAD_GMAC1_TXC 13 >>> + >>> +/* sys_iomux_gmac vref syscon registers */ >>> +#define SYS_G_VREF_GMAC1_SYSCON_REG 0x08 >>> +#define SYS_G_VREF_GMAC1_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_VREF_GMAC1_SYSCON_SHIFT 0 >>> +#define SYS_G_VREF_SDIO1_SYSCON_REG 0x0c >>> +#define SYS_G_VREF_SDIO1_SYSCON_MASK GENMASK(1, 0) >>> +#define SYS_G_VREF_SDIO1_SYSCON_SHIFT 0 >> >> Drop all this. > > All the GMAC and SYSCON macros will be removed. > >> >>> + >>> +/* sys_iomux_gmac interface (rmii/rgmii) syscon registers */ >>> +#define SYS_G_GMAC1_MDC_SYSCON_REG 0x10 >>> +#define SYS_G_GMAC1_MDC_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_MDC_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_MDIO_SYSCON_REG 0x14 >>> +#define SYS_G_GMAC1_MDIO_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_MDIO_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXD0_SYSCON_REG 0x18 >>> +#define SYS_G_GMAC1_RXD0_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_RXD0_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXD1_SYSCON_REG 0x1c >>> +#define SYS_G_GMAC1_RXD1_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_RXD1_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXD2_SYSCON_REG 0x20 >>> +#define SYS_G_GMAC1_RXD2_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_RXD2_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXD3_SYSCON_REG 0x24 >>> +#define SYS_G_GMAC1_RXD3_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_RXD3_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXDV_SYSCON_REG 0x28 >>> +#define SYS_G_GMAC1_RXDV_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_RXDV_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_RXC_SYSCON_REG 0x2c >>> +#define SYS_G_GMAC1_RXC_SYSCON_MASK GENMASK(1, 0) >>> +#define SYS_G_GMAC1_RXC_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXD0_SYSCON_REG 0x30 >>> +#define SYS_G_GMAC1_TXD0_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_TXD0_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXD1_SYSCON_REG 0x34 >>> +#define SYS_G_GMAC1_TXD1_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_TXD1_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXD2_SYSCON_REG 0x38 >>> +#define SYS_G_GMAC1_TXD2_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_TXD2_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXD3_SYSCON_REG 0x3c >>> +#define SYS_G_GMAC1_TXD3_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_TXD3_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXEN_SYSCON_REG 0x40 >>> +#define SYS_G_GMAC1_TXEN_SYSCON_MASK GENMASK(1, >> 0) >>> +#define SYS_G_GMAC1_TXEN_SYSCON_SHIFT 0 >>> +#define SYS_G_GMAC1_TXC_SYSCON_REG 0x44 >>> +#define SYS_G_GMAC1_TXC_SYSCON_MASK GENMASK(1, 0) >>> +#define SYS_G_GMAC1_TXC_SYSCON_SHIFT 0 >> >> Drop all this. > > All the SYSCON macros will be removed. > >> >> >>> + >>> +/* sys_iomux_gmac timing (slew rate) registers */ >> >> Srsly, "registers", so not bindings. > > All these will be removed. > >> >> >>> + >>> +#define GPOUT_LOW 0 >>> +#define GPOUT_HIGH 1 >> >> That's it. Really. Please do not redefine existing bindings. >> >>> + >>> +#define GPOEN_ENABLE 0 >>> +#define GPOEN_DISABLE 1 >>> + >>> +#define GPI_NONE 255 >>> + >>> +/* vref syscon value */ >>> +#define PAD_VREF_SYSCON_IO_3V3 0 >>> +#define PAD_VREF_SYSCON_IO_1V8 2 >>> + >>> +/* gmac interface (rmii/rgmii) syscon value */ >>> +#define GMAC_RMII_MODE 0 /* RMII >> mode, DVDD 2.5V/3.3V */ >>> +#define GMAC_RGMII_MODE 1 /* >> RGMII mode, DVDD 1.8V/2.5V */ >>> + >>> +/* gmac timing syscon value */ >>> +#define GMAC_SLEW_RATE_FAST 0 >>> +#define GMAC_SLEW_RATE_SLOW 1 >> >> Drop all above. > > All SYSCON macros will be dropped. > However, the following will be kept in the header file, > #define GPOUT_LOW 0 > #define GPOUT_HIGH 1 > > #define GPOEN_ENABLE 0 > #define GPOEN_DISABLE 1 > > #define GPI_NONE 255 No, why? I think I commented quite strongly about it. Best regards, Krzysztof
> -----Original Message----- > From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > Sent: Tuesday, February 20, 2024 4:10 PM > To: Yuklin Soo <yuklin.soo@starfivetech.com>; Linus Walleij > <linus.walleij@linaro.org>; Bartosz Golaszewski > <bartosz.golaszewski@linaro.org>; Hal Feng <hal.feng@starfivetech.com>; > Leyfoon Tan <leyfoon.tan@starfivetech.com>; Jianlong Huang > <jianlong.huang@starfivetech.com>; Emil Renner Berthing > <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > Drew Fustini <drew@beagleboard.org> > Cc: linux-gpio@vger.kernel.org; linux-kernel@vger.kernel.org; > devicetree@vger.kernel.org; linux-riscv@lists.infradead.org; Paul Walmsley > <paul.walmsley@sifive.com>; Palmer Dabbelt <palmer@dabbelt.com>; > Albert Ou <aou@eecs.berkeley.edu> > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > bindings > > On 07/02/2024 03:42, Yuklin Soo wrote: > >> > >>> + type: object > >>> + additionalProperties: false > >>> + patternProperties: > >>> + '-pins$': > >>> + type: object > >>> + description: | > >>> + A pinctrl node should contain at least one subnode representing > the > >>> + pinctrl groups available in the domain. 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. > >>> + allOf: > >>> + - $ref: /schemas/pinctrl/pincfg-node.yaml > >>> + - $ref: /schemas/pinctrl/pinmux-node.yaml > >>> + additionalProperties: false > >> > >> Why the rest of the properties is not applicable? > > > > The regex “-pins$” make sure all client subnode names end with suffix > > “-pins” (e.g, i2c0-scl-pins, i2c-sda-pins) > > I did not talk about subnodes. > > I asked why the rest of pincfg and pinmux schema properties are not allowed. Initially, I wanted to allow all properties in the pincfg and pinmux schema. I misunderstood the meaning of “additionalProperties: false” and I thought it means all additional properties outside the pincfg and pinmux schema are excluded. The “additionalProperties” will be set to “true” to include the rest of the properties in pincfg and pinmux schema and not to be restricted to only the properties defined in the documents. This will be fixed in the next version. > > > >>> +#define PAD_GPIO9_E 9 > >>> +#define PAD_GPIO10_E 10 > >>> +#define PAD_GPIO11_E 11 > >>> +#define PAD_GPIO12_E 12 > >>> +#define PAD_GPIO13_E 13 > >>> +#define PAD_GPIO14_E 14 > >>> +#define PAD_GPIO15_E 15 > >>> +#define PAD_GPIO16_E 16 > >>> +#define PAD_GPIO17_E 17 > >>> +#define PAD_GPIO18_E 18 > >>> +#define PAD_GPIO19_E 19 > >>> +#define PAD_GPIO20_E 20 > >>> +#define PAD_GPIO21_E 21 > >>> +#define PAD_GPIO22_E 22 > >>> +#define PAD_GPIO23_E 23 > >>> +#define PAD_GPIO24_E 24 > >>> +#define PAD_GPIO25_E 25 > >>> +#define PAD_GPIO26_E 26 > >>> +#define PAD_GPIO27_E 27 > >>> +#define PAD_GPIO28_E 28 > >>> +#define PAD_GPIO29_E 29 > >>> +#define PAD_GPIO30_E 30 > >>> +#define PAD_GPIO31_E 31 > >>> +#define PAD_GPIO32_E 32 > >>> +#define PAD_GPIO33_E 33 > >>> +#define PAD_GPIO34_E 34 > >>> +#define PAD_GPIO35_E 35 > >>> +#define PAD_GPIO36_E 36 > >>> +#define PAD_GPIO37_E 37 > >>> +#define PAD_GPIO38_E 38 > >>> +#define PAD_GPIO39_E 39 > >>> +#define PAD_GPIO40_E 40 > >>> +#define PAD_GPIO41_E 41 > >>> +#define PAD_GPIO42_E 42 > >>> +#define PAD_GPIO43_E 43 > >>> +#define PAD_GPIO44_E 44 > >>> +#define PAD_GPIO45_E 45 > >>> +#define PAD_GPIO46_E 46 > >>> +#define PAD_GPIO47_E 47 > >> > >> Please explain why do you think these are bindings? > > > > The “PAD_GPIO*_*” represent the pin numbers of the PAD_GPIO pins in > each domain. > > So not bindings. > > > It is part of the pinmux value. The pinmux value is generated by macro > GPIOMUX as follow: > > > > pinmux = <GPIOMUX(Pin_Number, Output_Signal_Index, > > Output_Enable_Signal_Index, > > Input_Signal_Index)>; > > > > Use I2C0 as example, > > pinmux = <GPIOMUX(PAD_GPIO9_E, GPOUT_SYS_I2C0_CLK, > > GPOEN_SYS_I2C0_CLK, > > GPI_SYS_I2C0_CLK)>; > > So not bindings. Read my question - I did not ask what are these. I asked why > these are bindings. Your explanation suggests these are not. Drop. > > You can always store some defines in DTS headers. All the “PAD_GPIO*_*” and “PAD_RGPIO*” macros are used by the pinctrl driver and the JH8100 device tree. Dropping all these macros will cause the delete of the DT-binding header file “include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h”. These macros will be moved to the DTS header file “arch/riscv/boot/dts/starfive/jh8100-pinfunc.h” and the driver header file “drivers/pinctrl/starfive/pinctrl-starfive-jh8100.h” and appear as duplicated in both places. Is that okay? Please advise. > > > > >> > >>> + > >>> +/* sys_iomux_east syscon */ > >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_REG 0x0fc > >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_GPIO_E0_SYSCON_SHIFT 0 > >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_REG 0x100 > >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_GPIO_E1_SYSCON_SHIFT 0 > >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_REG 0x104 > >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_GPIO_E2_SYSCON_SHIFT 0 > >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_REG 0x108 > >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_GPIO_E3_SYSCON_SHIFT 0 > >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_REG 0x10c > >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_ATB_STG1_SYSCON_SHIFT 0 > >>> +#define SYS_E_VREF_ATB_USB_SYSCON_REG 0x110 > >>> +#define SYS_E_VREF_ATB_USB_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_E_VREF_ATB_USB_SYSCON_SHIFT 0 > >> > >> Drop all of this, not bindings. > > > > All the SYSCON macros will be removed. > > > >> > >>> + > >>> +/* sys_iomux_gmac pins */ > >>> +#define PAD_GMAC1_MDC 0 > >>> +#define PAD_GMAC1_MDIO 1 > >>> +#define PAD_GMAC1_RXD0 2 > >>> +#define PAD_GMAC1_RXD1 3 > >>> +#define PAD_GMAC1_RXD2 4 > >>> +#define PAD_GMAC1_RXD3 5 > >>> +#define PAD_GMAC1_RXDV 6 > >>> +#define PAD_GMAC1_RXC 7 > >>> +#define PAD_GMAC1_TXD0 8 > >>> +#define PAD_GMAC1_TXD1 9 > >>> +#define PAD_GMAC1_TXD2 10 > >>> +#define PAD_GMAC1_TXD3 11 > >>> +#define PAD_GMAC1_TXEN 12 > >>> +#define PAD_GMAC1_TXC 13 > >>> + > >>> +/* sys_iomux_gmac vref syscon registers */ > >>> +#define SYS_G_VREF_GMAC1_SYSCON_REG 0x08 > >>> +#define SYS_G_VREF_GMAC1_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_VREF_GMAC1_SYSCON_SHIFT 0 > >>> +#define SYS_G_VREF_SDIO1_SYSCON_REG 0x0c > >>> +#define SYS_G_VREF_SDIO1_SYSCON_MASK GENMASK(1, > 0) > >>> +#define SYS_G_VREF_SDIO1_SYSCON_SHIFT 0 > >> > >> Drop all this. > > > > All the GMAC and SYSCON macros will be removed. > > > >> > >>> + > >>> +/* sys_iomux_gmac interface (rmii/rgmii) syscon registers */ > >>> +#define SYS_G_GMAC1_MDC_SYSCON_REG 0x10 > >>> +#define SYS_G_GMAC1_MDC_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_MDC_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_MDIO_SYSCON_REG 0x14 > >>> +#define SYS_G_GMAC1_MDIO_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_MDIO_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXD0_SYSCON_REG 0x18 > >>> +#define SYS_G_GMAC1_RXD0_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_RXD0_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXD1_SYSCON_REG 0x1c > >>> +#define SYS_G_GMAC1_RXD1_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_RXD1_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXD2_SYSCON_REG 0x20 > >>> +#define SYS_G_GMAC1_RXD2_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_RXD2_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXD3_SYSCON_REG 0x24 > >>> +#define SYS_G_GMAC1_RXD3_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_RXD3_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXDV_SYSCON_REG 0x28 > >>> +#define SYS_G_GMAC1_RXDV_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_RXDV_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_RXC_SYSCON_REG 0x2c > >>> +#define SYS_G_GMAC1_RXC_SYSCON_MASK GENMASK(1, > 0) > >>> +#define SYS_G_GMAC1_RXC_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXD0_SYSCON_REG 0x30 > >>> +#define SYS_G_GMAC1_TXD0_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_TXD0_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXD1_SYSCON_REG 0x34 > >>> +#define SYS_G_GMAC1_TXD1_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_TXD1_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXD2_SYSCON_REG 0x38 > >>> +#define SYS_G_GMAC1_TXD2_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_TXD2_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXD3_SYSCON_REG 0x3c > >>> +#define SYS_G_GMAC1_TXD3_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_TXD3_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXEN_SYSCON_REG 0x40 > >>> +#define SYS_G_GMAC1_TXEN_SYSCON_MASK GENMASK(1, > >> 0) > >>> +#define SYS_G_GMAC1_TXEN_SYSCON_SHIFT 0 > >>> +#define SYS_G_GMAC1_TXC_SYSCON_REG 0x44 > >>> +#define SYS_G_GMAC1_TXC_SYSCON_MASK GENMASK(1, > 0) > >>> +#define SYS_G_GMAC1_TXC_SYSCON_SHIFT 0 > >> > >> Drop all this. > > > > All the SYSCON macros will be removed. > > > >> > >> > >>> + > >>> +/* sys_iomux_gmac timing (slew rate) registers */ > >> > >> Srsly, "registers", so not bindings. > > > > All these will be removed. > > > >> > >> > >>> + > >>> +#define GPOUT_LOW 0 > >>> +#define GPOUT_HIGH 1 > >> > >> That's it. Really. Please do not redefine existing bindings. > >> > >>> + > >>> +#define GPOEN_ENABLE 0 > >>> +#define GPOEN_DISABLE 1 > >>> + > >>> +#define GPI_NONE 255 > >>> + > >>> +/* vref syscon value */ > >>> +#define PAD_VREF_SYSCON_IO_3V3 0 > >>> +#define PAD_VREF_SYSCON_IO_1V8 2 > >>> + > >>> +/* gmac interface (rmii/rgmii) syscon value */ > >>> +#define GMAC_RMII_MODE 0 /* > RMII > >> mode, DVDD 2.5V/3.3V */ > >>> +#define GMAC_RGMII_MODE 1 /* > >> RGMII mode, DVDD 1.8V/2.5V */ > >>> + > >>> +/* gmac timing syscon value */ > >>> +#define GMAC_SLEW_RATE_FAST 0 > >>> +#define GMAC_SLEW_RATE_SLOW 1 > >> > >> Drop all above. > > > > All SYSCON macros will be dropped. > > However, the following will be kept in the header file, > > #define GPOUT_LOW 0 > > #define GPOUT_HIGH 1 > > > > #define GPOEN_ENABLE 0 > > #define GPOEN_DISABLE 1 > > > > #define GPI_NONE 255 > > No, why? > > I think I commented quite strongly about it. All above macros are used by the pinctrl driver and the JH8100 device tree. Dropping these macros together with the PAD_GPIO* macros will cause the delete of the DT-binding header file “include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h”. These macros will be moved to the DTS header file “arch/riscv/boot/dts/starfive/jh8100-pinfunc.h” and the driver header file “drivers/pinctrl/starfive/pinctrl-starfive-jh8100.h” and appear as duplicated in both places. Is that okay? Please advise. > > Best regards, > Krzysztof
> -----Original Message----- > From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > Sent: Tuesday, March 5, 2024 10:07 PM > To: Yuklin Soo <yuklin.soo@starfivetech.com>; Linus Walleij > <linus.walleij@linaro.org>; Bartosz Golaszewski > <bartosz.golaszewski@linaro.org>; Hal Feng <hal.feng@starfivetech.com>; > Leyfoon Tan <leyfoon.tan@starfivetech.com>; Jianlong Huang > <jianlong.huang@starfivetech.com>; Emil Renner Berthing <kernel@esmil.dk>; > Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley <conor+dt@kernel.org>; > Drew Fustini <drew@beagleboard.org> > Cc: linux-gpio@vger.kernel.org; linux-kernel@vger.kernel.org; > devicetree@vger.kernel.org; linux-riscv@lists.infradead.org; Paul Walmsley > <paul.walmsley@sifive.com>; Palmer Dabbelt <palmer@dabbelt.com>; Albert > Ou <aou@eecs.berkeley.edu> > Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add JH8100 pinctrl > bindings > > On 05/03/2024 13:00, Yuklin Soo wrote: > > > > > >> -----Original Message----- > >> From: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> > >> Sent: Tuesday, February 20, 2024 4:10 PM > >> To: Yuklin Soo <yuklin.soo@starfivetech.com>; Linus Walleij > >> <linus.walleij@linaro.org>; Bartosz Golaszewski > >> <bartosz.golaszewski@linaro.org>; Hal Feng > >> <hal.feng@starfivetech.com>; Leyfoon Tan > >> <leyfoon.tan@starfivetech.com>; Jianlong Huang > >> <jianlong.huang@starfivetech.com>; Emil Renner Berthing > >> <kernel@esmil.dk>; Rob Herring <robh@kernel.org>; Krzysztof Kozlowski > >> <krzysztof.kozlowski+dt@linaro.org>; Conor Dooley > >> <conor+dt@kernel.org>; Drew Fustini <drew@beagleboard.org> > >> Cc: linux-gpio@vger.kernel.org; linux-kernel@vger.kernel.org; > >> devicetree@vger.kernel.org; linux-riscv@lists.infradead.org; Paul > >> Walmsley <paul.walmsley@sifive.com>; Palmer Dabbelt > >> <palmer@dabbelt.com>; Albert Ou <aou@eecs.berkeley.edu> > >> Subject: Re: [RFC PATCH 1/6] dt-bindings: pinctrl: starfive: add > >> JH8100 pinctrl bindings > >> > >> On 07/02/2024 03:42, Yuklin Soo wrote: > >>>> > >>>>> + type: object > >>>>> + additionalProperties: false > >>>>> + patternProperties: > >>>>> + '-pins$': > >>>>> + type: object > >>>>> + description: | > >>>>> + A pinctrl node should contain at least one subnode > >>>>> + representing > >> the > >>>>> + pinctrl groups available in the domain. 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. > >>>>> + allOf: > >>>>> + - $ref: /schemas/pinctrl/pincfg-node.yaml > >>>>> + - $ref: /schemas/pinctrl/pinmux-node.yaml > >>>>> + additionalProperties: false > >>>> > >>>> Why the rest of the properties is not applicable? > >>> > >>> The regex “-pins$” make sure all client subnode names end with > >>> suffix “-pins” (e.g, i2c0-scl-pins, i2c-sda-pins) > >> > >> I did not talk about subnodes. > >> > >> I asked why the rest of pincfg and pinmux schema properties are not > allowed. > > > > Initially, I wanted to allow all properties in the pincfg and pinmux schema. I > misunderstood the meaning of “additionalProperties: false” > > and I thought it means all additional properties outside the pincfg > > and pinmux schema are excluded. The “additionalProperties” will be set > > to “true” to include the rest of the properties in pincfg and pinmux > > schema and not to be restricted to only the properties defined in > > In that case drop all the properties and use unevaluatedProperties: false. Isn’t that sufficient just to use “unevaluatedProperties: false” ? To drop all the properties, we will be losing information below: drive-strength-microamp: enum: [ 2000, 4000, 8000, 12000 ] slew-rate: enum: [ 0, 1 ] default: 0 description: | 0: slow (half frequency) 1: fast > > Fix your email setup, to wrap emails properly. This is unreadable. > > > > >> > >> Best regards, > >> Krzysztof > > > > Best regards, > Krzysztof
diff --git a/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-aon-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-aon-pinctrl.yaml new file mode 100644 index 000000000000..ec099a0d4c77 --- /dev/null +++ b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-aon-pinctrl.yaml @@ -0,0 +1,183 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/pinctrl/starfive,jh8100-aon-pinctrl.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: StarFive JH8100 AON Pin Controller + +description: | + Pinctrl bindings for JH8100 RISC-V SoC from StarFive Technology Ltd. + + The JH8100 SoC has 4 pinctrl domains - sys_east, sys_west, sys_gmac, and aon. + This document provides an overview of the "aon" pinctrl domain. + + The "aon" pinctrl domain contains a pin controller which provides + - I/O multiplexing for peripheral signals specific to this domain. + - function selection for GMAC0 interface modes. + - GPIO pins which support external GPIO interrupts or external wake-up. + - syscon for device reference voltage. + + In the AON Pin Controller, the pins named PAD_RGPIO0 to PAD_GPIO15 can be + multiplexed and have configurable bias, drive strength, schmitt trigger etc. + Only peripherals in the AON domain can have their I/O go through the 16 + "PAD_RGPIOs". This includes I2C, UART, watchdog, eMMC, SDIO0, XSPI etc. + + All these peripherals can be connected to any of the 16 PAD_RGPIOs in such a way + that any iopad can be set up to be controlled by any of the peripherals. + + The pin muxing is illustrated by the diagram below. + _____________ + | | + RGPIO0 --------------| |--- PAD_RGPIO0 + RGPIO1 --------------| AON I/O MUX |--- PAD_RGPIO1 + ... | | ... + I2C8 SDA interface --| |--- PAD_RGPIO15 + | | + ------------- + + Alternatively, the "PAD_RGPIOS" can be multiplexed to other peripherals through + function selection. Each iopad has a maximum of up to 3 functions - 0, 1, and 2. + Function 0 is the default function or peripheral signal of an iopad. + The function 1 and function 2 are other optional functions or peripheral signals + available to an iopad. + + The AON Pin Controller provides regmap based syscon to configure + + 1. reference voltage level of + - eMMC I/O interface (1.8V) + - SDIO0 I/O interface (3.3V, 1.8V) + - RGPIO bank (3.3V) + - Each RGPIO in the RGPIO bank share the same voltage level + - GMAC0 (3.3V, 2.5V, 1.8V) + - RMII mode, DVDD 2.5V/3.3V + - RGMII mode, DVDD 1.8V/2.5V + - XSPI (3.3V) + + Voltage regulator supply the actual voltage to the device while the syscon register + configuration in bit [1:0] indicates the current voltage setting. + + +------+------+-------------------+ + | Bit1 | Bit0 | Reference Voltage | + +------+------+-------------------+ + | 0 | 0 | 3.3 V | + +------+------+-------------------+ + | 0 | 1 | 2.5 V | + +------+------+-------------------+ + | 1 | x | 1.8 V | + +------+------+-------------------+ + + To increase the device voltage, set bit [1:0] to the new operating state first before + raising the actual voltage to the higher operating point. + + To decrease the device voltage, hold bit [1:0] to the current operating state until + the actual voltage has stabilized at the lower operating point before changing the + setting. + + Alternatively, a device voltage change can always be initiated by first setting syscon + register bit [1:0] = 0, the safe 3.3V startup condition, before changing the device + voltage. Then once the actual voltage is changed and has stabilized at the new operating + point, bit [1:0] can be reset as appropriate. + +maintainers: + - Alex Soo <yuklin.soo@starfivetech.com> + +properties: + compatible: + const: starfive,jh8100-aon-pinctrl + + reg: + maxItems: 1 + + resets: + maxItems: 1 + + interrupts: + maxItems: 1 + + interrupt-controller: true + + gpio-controller: true + + '#gpio-cells': + const: 2 + +patternProperties: + '-[0-9]+$': + type: object + additionalProperties: false + patternProperties: + '-pins$': + type: object + description: | + A pinctrl node should contain at least one subnode representing the + pinctrl groups available in the domain. 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. + allOf: + - $ref: /schemas/pinctrl/pincfg-node.yaml + - $ref: /schemas/pinctrl/pinmux-node.yaml + additionalProperties: false + + properties: + pinmux: + description: | + The list of GPIOs and their mux settings or function select. + The GPIOMUX and PINMUX macros are used to configure the + I/O multiplexing and function selection respectively. + + bias-disable: true + + bias-pull-up: + type: boolean + + bias-pull-down: + type: boolean + + drive-strength: + enum: [ 2, 4, 8, 12 ] + + input-enable: true + + input-disable: true + + input-schmitt-enable: true + + input-schmitt-disable: true + + slew-rate: + maximum: 1 + +required: + - compatible + - reg + - resets + - interrupts + - interrupt-controller + - gpio-controller + - '#gpio-cells' + +additionalProperties: false + +examples: + - | + #include <dt-bindings/clock/starfive,jh8100.h> + #include <dt-bindings/reset/starfive-jh8100.h> + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> + + soc { + #address-cells = <2>; + #size-cells = <2>; + + pinctrl_aon: pinctrl@1f300000 { + compatible = "starfive,jh8100-aon-pinctrl", + "syscon", "simple-mfd"; + reg = <0x0 0x1f300000 0x0 0x10000>; + resets = <&aoncrg 0>; + interrupts = <160>; + interrupt-controller; + gpio-controller; + #gpio-cells = <2>; + }; + }; diff --git a/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-east-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-east-pinctrl.yaml new file mode 100644 index 000000000000..849fc19558af --- /dev/null +++ b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-east-pinctrl.yaml @@ -0,0 +1,188 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/pinctrl/starfive,jh8100-sys-east-pinctrl.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: StarFive JH8100 SYS_EAST Pin Controller + +description: | + Pinctrl bindings for JH8100 RISC-V SoC from StarFive Technology Ltd. + + The JH8100 SoC has 4 pinctrl domains - sys_east, sys_west, sys_gmac, and aon. + This document provides an overview of the "sys_east" pinctrl domain. + + The "sys_east" pinctrl domain contains a pin controller which provides + - I/O multiplexing for peripheral signals specific to this domain. + - function selection for GPIO pads. + - GPIO interrupt handling. + - syscon for device voltage reference. + + In the SYS_EAST Pin Controller, the pins named PAD_GPIO0_E to PAD_GPIO47_E can + be multiplexed and have configurable bias, drive strength, schmitt trigger etc. + Only peripherals in the SYS_EAST domain can have their I/O go through the 48 + "PAD_GPIOs". This includes CANs, I2Cs, I2Ss, SPIs, UARTs, PWMs, SMBUS0, SDIO1 etc. + + All these peripherals can be connected to any of the 48 PAD_GPIOs in such a way + that any iopad can be set up to be controlled by any of the peripherals. + + The pin muxing is illustrated by the diagram below. + __________________ + | | + GPIO0 ----------------------| |--- PAD_GPIO0_E + GPIO1 ----------------------| SYS_EAST I/O MUX |--- PAD_GPIO1_E + GPIO2 ----------------------| |--- PAD_GPIO2_E + ... | | ... + I2C0 Clock interface -------| |--- PAD_GPIO9_E + I2C0 Data interface -------| |--- PAD_GPIO10_E + ... | | ... + UART0 transmit interface ---| |--- PAD_GPIO20_E + UART0 receive interface ----| |--- PAD_GPIO21_E + ... | | ... + GPIO47 ---------------------| |--- PAD_GPIO47_E + | | + ------------------ + + Alternatively, the "PAD_GPIOs" can be multiplexed to other peripherals through + function selection. Each iopad has a maximum of up to 3 functions - 0, 1, and 2. + Function 0 is the default function or peripheral signal of an iopad. + The function 1 and function 2 are other optional functions or peripheral signals + available to an iopad. + + The "sys_east" pinctrl domain has 4 GPIO banks - E0, E1, E2, and E3. Each GPIO bank + can be set to a different voltage level (3.3V or 1.8V) while GPIOs in the same bank + will share the same voltage level. + + The SYS_EAST Pin Controller provides regmap based syscon registers to configure the + reference voltage level in each GPIO bank. + + Voltage regulator supply the actual voltage to the GPIO bank while the syscon register + configuration in bit [1:0] indicates the current voltage setting. + + +------+------+-------------------+ + | Bit1 | Bit0 | Reference Voltage | + +------+------+-------------------+ + | 0 | 0 | 3.3 V | + +------+------+-------------------+ + | 1 | x | 1.8 V | + +------+------+-------------------+ + + To increase the device voltage, set bit [1:0] to the new operating state first before + raising the actual voltage to the higher operating point. + + To decrease the device voltage, hold bit [1:0] to the current operating state until + the actual voltage has stabilized at the lower operating point before changing the + setting. + + Alternatively, a device voltage change can always be initiated by first setting syscon + register bit [1:0] = 0, the safe 3.3V startup condition, before changing the device + voltage. Then once the actual voltage is changed and has stabilized at the new operating + point, bit [1:0] can be reset as appropriate. + +maintainers: + - Alex Soo <yuklin.soo@starfivetech.com> + +properties: + compatible: + const: starfive,jh8100-sys-pinctrl-east + + reg: + maxItems: 1 + + clocks: + maxItems: 1 + + resets: + maxItems: 1 + + interrupts: + maxItems: 1 + + interrupt-controller: true + + gpio-controller: true + + '#gpio-cells': + const: 2 + +patternProperties: + '-[0-9]+$': + type: object + additionalProperties: false + patternProperties: + '-pins$': + type: object + description: | + A pinctrl node should contain at least one subnode representing the + pinctrl groups available in the domain. 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. + allOf: + - $ref: /schemas/pinctrl/pincfg-node.yaml + - $ref: /schemas/pinctrl/pinmux-node.yaml + additionalProperties: false + + properties: + pinmux: + description: | + The list of GPIOs and their mux settings or function select. + The GPIOMUX and PINMUX macros are used to configure the + I/O multiplexing and function selection respectively. + + bias-disable: true + + bias-pull-up: + type: boolean + + bias-pull-down: + type: boolean + + drive-strength: + enum: [ 2, 4, 8, 12 ] + + input-enable: true + + input-disable: true + + input-schmitt-enable: true + + input-schmitt-disable: true + + slew-rate: + maximum: 1 + +required: + - compatible + - reg + - clocks + - resets + - interrupts + - interrupt-controller + - gpio-controller + - '#gpio-cells' + +additionalProperties: false + +examples: + - | + #include <dt-bindings/clock/starfive,jh8100.h> + #include <dt-bindings/reset/starfive-jh8100.h> + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> + + soc { + #address-cells = <2>; + #size-cells = <2>; + + pinctrl_east: pinctrl@122d0000 { + compatible = "starfive,jh8100-sys-pinctrl-east", + "syscon", "simple-mfd"; + reg = <0x0 0x122d0000 0x0 0x10000>; + clocks = <&syscrg_ne 153>; + resets = <&syscrg_ne 48>; + interrupts = <182>; + interrupt-controller; + gpio-controller; + #gpio-cells = <2>; + }; + }; diff --git a/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.yaml new file mode 100644 index 000000000000..301690456e40 --- /dev/null +++ b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-gmac-pinctrl.yaml @@ -0,0 +1,124 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/pinctrl/starfive,jh8100-sys-gmac-pinctrl.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: StarFive JH8100 SYS_GMAC Pin Controller + +description: | + Pinctrl bindings for JH8100 RISC-V SoC from StarFive Technology Ltd. + + The JH8100 SoC has 4 pinctrl domains - sys_east, sys_west, sys_gmac, and aon. + This document provides an overview of the "sys_gmac" pinctrl domain. + + The "sys_gmac" pinctrl domain contains a pin-controller which provides + - function selection for GMAC1 interface modes. + - syscon for device voltage reference. + - syscon for GMAC modes and slew rate control. + + The SYS_GMAC Pin Controller does not have any PAD_GPIOs, therefore, it does not + support the GPIO pads' I/O Multiplexing and interrupt handling. + + The SYS_GMAC Pin Controller provides regmap based syscon to configure + + 1. reference voltage level of + - SDIO1 (3.3V, 1.8V) + - GMAC1 (3.3V, 2.5V, 1.8V) + - RMII mode, DVDD 2.5V/3.3V + - RGMII mode, DVDD 1.8V/2.5V + + +------+------+-------------------+ + | Bit1 | Bit0 | Reference Voltage | + +------+------+-------------------+ + | 0 | 0 | 3.3 V | + +------+------+-------------------+ + | 0 | 1 | 2.5 V | + +------+------+-------------------+ + | 1 | x | 1.8 V | + +------+------+-------------------+ + + To increase the device voltage, set bit [1:0] to the new operating state first before + raising the actual voltage to the higher operating point. + + To decrease the device voltage, hold bit [1:0] to the current operating state until + the actual voltage has stabilized at the lower operating point before changing the + setting. + + Alternatively, a device voltage change can always be initiated by first setting syscon + register bit [1:0] = 0, the safe 3.3V startup condition, before changing the device + voltage. Then once the actual voltage is changed and has stabilized at the new operating + point, bit [1:0] can be reset as appropriate. + + 2. GMAC1 interface slew rate + + +------+-----------+ + | Bit2 | Slew Rate | + +------+-----------+ + | 0 | Fast | + +------+-----------+ + | 1 | Slow | + +------+-----------+ + +maintainers: + - Alex Soo <yuklin.soo@starfivetech.com> + +properties: + compatible: + const: starfive,jh8100-sys-pinctrl-gmac + + reg: + maxItems: 1 + + clocks: + maxItems: 1 + + resets: + maxItems: 1 + +patternProperties: + '-[0-9]+$': + type: object + additionalProperties: false + patternProperties: + '-pins$': + type: object + description: | + A pinctrl node should contain at least one subnode representing the + pinctrl groups available in the domain. 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. + allOf: + - $ref: /schemas/pinctrl/pincfg-node.yaml + - $ref: /schemas/pinctrl/pinmux-node.yaml + additionalProperties: false + +required: + - compatible + - reg + - clocks + - resets + +additionalProperties: false + +examples: + - | + #include <dt-bindings/clock/starfive,jh8100.h> + #include <dt-bindings/reset/starfive-jh8100.h> + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> + + soc { + #address-cells = <2>; + #size-cells = <2>; + + pinctrl_gmac: pinctrl@12770000 { + compatible = "starfive,jh8100-sys-pinctrl-gmac", + "syscon", "simple-mfd"; + status = "disabled"; + reg = <0x0 0x12770000 0x0 0x10000>; + clocks = <&gmac_sdio_crg 16>; + resets = <&gmac_sdio_crg 3>; + }; + + }; diff --git a/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-west-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-west-pinctrl.yaml new file mode 100644 index 000000000000..608acb76230c --- /dev/null +++ b/Documentation/devicetree/bindings/pinctrl/starfive,jh8100-sys-west-pinctrl.yaml @@ -0,0 +1,188 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/pinctrl/starfive,jh8100-sys-west-pinctrl.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: StarFive JH8100 SYS_WEST Pin Controller + +description: | + Pinctrl bindings for JH8100 RISC-V SoC from StarFive Technology Ltd. + + The JH8100 SoC has 4 pinctrl domains - sys_east, sys_west, sys_gmac, and aon. + This document provides an overview of the "sys_west" pinctrl domain. + + The "sys_west" pinctrl domain contains a pin-controller which provides + - I/O multiplexing for peripheral signals specific to this domain. + - function selection for GPIO pads. + - GPIO interrupt handling. + - syscon for device voltage reference. + + In the SYS_WEST Pin Controller, the pins named PAD_GPIO0_W to PAD_GPIO15_W can + be multiplexed and have configurable bias, drive strength, schmitt trigger etc. + Only peripherals in the SYS_WEST domain can have their I/O go through the 16 + "PAD_GPIOs". This includes I2Cs, HD_AUDIO, HIFI4, SPIs, UARTs, SMBUS1 etc. + + All these peripherals can be connected to any of the 16 PAD_GPIOs in such a way + that any iopad can be set up to be controlled by any of the peripherals. + + The pin muxing is illustrated by the diagram below. + __________________ + | | + GPIO0 ----------------------| |--- PAD_GPIO0_W + GPIO1 ----------------------| SYS_WEST I/O MUX |--- PAD_GPIO1_W + GPIO2 ----------------------| |--- PAD_GPIO2_W + ... | | ... + HIFI4 JTAG TDO interface ---| |--- PAD_GPIO10_W + HIFI4 JTAG TDI interface ---| |--- PAD_GPIO11_W + SMBUS1 Data interface -----| |--- PAD_GPIO12_W + SMBUS1 Clock interface -----| |--- PAD_GPIO13_W + ... | | ... + GPIO14 ---------------------| |--- PAD_GPIO14_W + GPIO15 ---------------------| |--- PAD_GPIO15_W + | | + ------------------ + + Alternatively, the "PAD_GPIOs" can be multiplexed to other peripherals through + function selection. Each iopad has a maximum of up to 3 functions - 0, 1, and 2. + Function 0 is the default function or peripheral signal of an iopad. + The function 1 and function 2 are other optional functions or peripheral signals + available to an iopad. + + The "sys_west" pinctrl domain consist of 1 GPIO bank. The GPIO bank can be set to + a different voltage level (3.3V or 1.8V) while GPIOs in the same bank will share + the same voltage level. + + The SYS_WEST Pin Controller provides regmap based syscon registers to configure the + reference voltage level in the GPIO bank. + + Voltage regulator supply the actual voltage to the GPIO bank while the syscon register + configuration in bit [1:0] indicates the current voltage setting. + + +------+------+-------------------+ + | Bit1 | Bit0 | Reference Voltage | + +------+------+-------------------+ + | 0 | 0 | 3.3 V | + +------+------+-------------------+ + | 1 | x | 1.8 V | + +------+------+-------------------+ + + To increase the device voltage, set bit [1:0] to the new operating state first before + raising the actual voltage to the higher operating point. + + To decrease the device voltage, hold bit [1:0] to the current operating state until + the actual voltage has stabilized at the lower operating point before changing the + setting. + + Alternatively, a device voltage change can always be initiated by first setting syscon + register bit [1:0] = 0, the safe 3.3V startup condition, before changing the device + voltage. Then once the actual voltage is changed and has stabilized at the new operating + point, bit [1:0] can be reset as appropriate. + +maintainers: + - Alex Soo <yuklin.soo@starfivetech.com> + +properties: + compatible: + const: starfive,jh8100-sys-pinctrl-west + + reg: + maxItems: 1 + + clocks: + maxItems: 1 + + resets: + maxItems: 1 + + interrupts: + maxItems: 1 + + interrupt-controller: true + + gpio-controller: true + + '#gpio-cells': + const: 2 + +patternProperties: + '-[0-9]+$': + type: object + additionalProperties: false + patternProperties: + '-pins$': + type: object + description: | + A pinctrl node should contain at least one subnode representing the + pinctrl groups available in the domain. 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. + allOf: + - $ref: /schemas/pinctrl/pincfg-node.yaml + - $ref: /schemas/pinctrl/pinmux-node.yaml + additionalProperties: false + + properties: + pinmux: + description: | + The list of GPIOs and their mux settings or function select. + The GPIOMUX and PINMUX macros are used to configure the + I/O multiplexing and function selection respectively. + + bias-disable: true + + bias-pull-up: + type: boolean + + bias-pull-down: + type: boolean + + drive-strength: + enum: [ 2, 4, 8, 12 ] + + input-enable: true + + input-disable: true + + input-schmitt-enable: true + + input-schmitt-disable: true + + slew-rate: + maximum: 1 + +required: + - compatible + - reg + - clocks + - resets + - interrupts + - interrupt-controller + - gpio-controller + - '#gpio-cells' + +additionalProperties: false + +examples: + - | + #include <dt-bindings/clock/starfive,jh8100.h> + #include <dt-bindings/reset/starfive-jh8100.h> + #include <dt-bindings/pinctrl/starfive,jh8100-pinctrl.h> + + soc { + #address-cells = <2>; + #size-cells = <2>; + + pinctrl_west: pinctrl@123e0000 { + compatible = "starfive,jh8100-sys-pinctrl-west", + "syscon", "simple-mfd"; + interrupts = <183>; + reg = <0x0 0x123e0000 0x0 0x10000>; + clocks = <&syscrg_nw 6>; + resets = <&syscrg_nw 1>; + interrupt-controller; + gpio-controller; + #gpio-cells = <2>; + }; + }; diff --git a/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h new file mode 100644 index 000000000000..c57b7ece37a2 --- /dev/null +++ b/include/dt-bindings/pinctrl/starfive,jh8100-pinctrl.h @@ -0,0 +1,303 @@ +/* SPDX-License-Identifier: GPL-2.0 OR MIT */ +/* + * Copyright (C) 2023 StarFive Technology Co., Ltd. + * Author: Alex Soo <yuklin.soo@starfivetech.com> + * + */ + +#ifndef __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ +#define __DT_BINDINGS_PINCTRL_STARFIVE_JH8100_H__ + +/* sys_iomux_west pins */ +#define PAD_GPIO0_W 0 +#define PAD_GPIO1_W 1 +#define PAD_GPIO2_W 2 +#define PAD_GPIO3_W 3 +#define PAD_GPIO4_W 4 +#define PAD_GPIO5_W 5 +#define PAD_GPIO6_W 6 +#define PAD_GPIO7_W 7 +#define PAD_GPIO8_W 8 +#define PAD_GPIO9_W 9 +#define PAD_GPIO10_W 10 +#define PAD_GPIO11_W 11 +#define PAD_GPIO12_W 12 +#define PAD_GPIO13_W 13 +#define PAD_GPIO14_W 14 +#define PAD_GPIO15_W 15 + +/* sys_iomux_west syscon */ +#define SYS_W_VREF_GPIO_W_SYSCON_REG 0x6c +#define SYS_W_VREF_GPIO_W_SYSCON_MASK GENMASK(1, 0) +#define SYS_W_VREF_GPIO_W_SYSCON_SHIFT 0 +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_REG 0x70 +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_MASK GENMASK(1, 0) +#define SYS_W_VREF_ATB_ISP_VOUT_SYSCON_SHIFT 0 + +/* sys_iomux_east pins */ +#define PAD_GPIO0_E 0 +#define PAD_GPIO1_E 1 +#define PAD_GPIO2_E 2 +#define PAD_GPIO3_E 3 +#define PAD_GPIO4_E 4 +#define PAD_GPIO5_E 5 +#define PAD_GPIO6_E 6 +#define PAD_GPIO7_E 7 +#define PAD_GPIO8_E 8 +#define PAD_GPIO9_E 9 +#define PAD_GPIO10_E 10 +#define PAD_GPIO11_E 11 +#define PAD_GPIO12_E 12 +#define PAD_GPIO13_E 13 +#define PAD_GPIO14_E 14 +#define PAD_GPIO15_E 15 +#define PAD_GPIO16_E 16 +#define PAD_GPIO17_E 17 +#define PAD_GPIO18_E 18 +#define PAD_GPIO19_E 19 +#define PAD_GPIO20_E 20 +#define PAD_GPIO21_E 21 +#define PAD_GPIO22_E 22 +#define PAD_GPIO23_E 23 +#define PAD_GPIO24_E 24 +#define PAD_GPIO25_E 25 +#define PAD_GPIO26_E 26 +#define PAD_GPIO27_E 27 +#define PAD_GPIO28_E 28 +#define PAD_GPIO29_E 29 +#define PAD_GPIO30_E 30 +#define PAD_GPIO31_E 31 +#define PAD_GPIO32_E 32 +#define PAD_GPIO33_E 33 +#define PAD_GPIO34_E 34 +#define PAD_GPIO35_E 35 +#define PAD_GPIO36_E 36 +#define PAD_GPIO37_E 37 +#define PAD_GPIO38_E 38 +#define PAD_GPIO39_E 39 +#define PAD_GPIO40_E 40 +#define PAD_GPIO41_E 41 +#define PAD_GPIO42_E 42 +#define PAD_GPIO43_E 43 +#define PAD_GPIO44_E 44 +#define PAD_GPIO45_E 45 +#define PAD_GPIO46_E 46 +#define PAD_GPIO47_E 47 + +/* sys_iomux_east syscon */ +#define SYS_E_VREF_GPIO_E0_SYSCON_REG 0x0fc +#define SYS_E_VREF_GPIO_E0_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_GPIO_E0_SYSCON_SHIFT 0 +#define SYS_E_VREF_GPIO_E1_SYSCON_REG 0x100 +#define SYS_E_VREF_GPIO_E1_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_GPIO_E1_SYSCON_SHIFT 0 +#define SYS_E_VREF_GPIO_E2_SYSCON_REG 0x104 +#define SYS_E_VREF_GPIO_E2_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_GPIO_E2_SYSCON_SHIFT 0 +#define SYS_E_VREF_GPIO_E3_SYSCON_REG 0x108 +#define SYS_E_VREF_GPIO_E3_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_GPIO_E3_SYSCON_SHIFT 0 +#define SYS_E_VREF_ATB_STG1_SYSCON_REG 0x10c +#define SYS_E_VREF_ATB_STG1_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_ATB_STG1_SYSCON_SHIFT 0 +#define SYS_E_VREF_ATB_USB_SYSCON_REG 0x110 +#define SYS_E_VREF_ATB_USB_SYSCON_MASK GENMASK(1, 0) +#define SYS_E_VREF_ATB_USB_SYSCON_SHIFT 0 + +/* sys_iomux_gmac pins */ +#define PAD_GMAC1_MDC 0 +#define PAD_GMAC1_MDIO 1 +#define PAD_GMAC1_RXD0 2 +#define PAD_GMAC1_RXD1 3 +#define PAD_GMAC1_RXD2 4 +#define PAD_GMAC1_RXD3 5 +#define PAD_GMAC1_RXDV 6 +#define PAD_GMAC1_RXC 7 +#define PAD_GMAC1_TXD0 8 +#define PAD_GMAC1_TXD1 9 +#define PAD_GMAC1_TXD2 10 +#define PAD_GMAC1_TXD3 11 +#define PAD_GMAC1_TXEN 12 +#define PAD_GMAC1_TXC 13 + +/* sys_iomux_gmac vref syscon registers */ +#define SYS_G_VREF_GMAC1_SYSCON_REG 0x08 +#define SYS_G_VREF_GMAC1_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_VREF_GMAC1_SYSCON_SHIFT 0 +#define SYS_G_VREF_SDIO1_SYSCON_REG 0x0c +#define SYS_G_VREF_SDIO1_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_VREF_SDIO1_SYSCON_SHIFT 0 + +/* sys_iomux_gmac interface (rmii/rgmii) syscon registers */ +#define SYS_G_GMAC1_MDC_SYSCON_REG 0x10 +#define SYS_G_GMAC1_MDC_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_MDC_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_MDIO_SYSCON_REG 0x14 +#define SYS_G_GMAC1_MDIO_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_MDIO_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXD0_SYSCON_REG 0x18 +#define SYS_G_GMAC1_RXD0_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXD0_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXD1_SYSCON_REG 0x1c +#define SYS_G_GMAC1_RXD1_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXD1_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXD2_SYSCON_REG 0x20 +#define SYS_G_GMAC1_RXD2_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXD2_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXD3_SYSCON_REG 0x24 +#define SYS_G_GMAC1_RXD3_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXD3_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXDV_SYSCON_REG 0x28 +#define SYS_G_GMAC1_RXDV_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXDV_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_RXC_SYSCON_REG 0x2c +#define SYS_G_GMAC1_RXC_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_RXC_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXD0_SYSCON_REG 0x30 +#define SYS_G_GMAC1_TXD0_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXD0_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXD1_SYSCON_REG 0x34 +#define SYS_G_GMAC1_TXD1_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXD1_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXD2_SYSCON_REG 0x38 +#define SYS_G_GMAC1_TXD2_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXD2_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXD3_SYSCON_REG 0x3c +#define SYS_G_GMAC1_TXD3_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXD3_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXEN_SYSCON_REG 0x40 +#define SYS_G_GMAC1_TXEN_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXEN_SYSCON_SHIFT 0 +#define SYS_G_GMAC1_TXC_SYSCON_REG 0x44 +#define SYS_G_GMAC1_TXC_SYSCON_MASK GENMASK(1, 0) +#define SYS_G_GMAC1_TXC_SYSCON_SHIFT 0 + +/* sys_iomux_gmac timing (slew rate) registers */ +#define SYS_G_GMAC1_MDC_SLEW_REG 0x10 +#define SYS_G_GMAC1_MDC_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_MDC_SLEW_SHIFT 2 +#define SYS_G_GMAC1_MDIO_SLEW_REG 0x14 +#define SYS_G_GMAC1_MDIO_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_MDIO_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXD0_SLEW_REG 0x18 +#define SYS_G_GMAC1_RXD0_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXD0_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXD1_SLEW_REG 0x1c +#define SYS_G_GMAC1_RXD1_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXD1_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXD2_SLEW_REG 0x20 +#define SYS_G_GMAC1_RXD2_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXD2_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXD3_SLEW_REG 0x24 +#define SYS_G_GMAC1_RXD3_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXD3_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXDV_SLEW_REG 0x28 +#define SYS_G_GMAC1_RXDV_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXDV_SLEW_SHIFT 2 +#define SYS_G_GMAC1_RXC_SLEW_REG 0x2c +#define SYS_G_GMAC1_RXC_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_RXC_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXD0_SLEW_REG 0x30 +#define SYS_G_GMAC1_TXD0_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXD0_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXD1_SLEW_REG 0x34 +#define SYS_G_GMAC1_TXD1_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXD1_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXD2_SLEW_REG 0x38 +#define SYS_G_GMAC1_TXD2_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXD2_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXD3_SLEW_REG 0x3c +#define SYS_G_GMAC1_TXD3_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXD3_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXEN_SLEW_REG 0x40 +#define SYS_G_GMAC1_TXEN_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXEN_SLEW_SHIFT 2 +#define SYS_G_GMAC1_TXC_SLEW_REG 0x44 +#define SYS_G_GMAC1_TXC_SLEW_MASK BIT(2) +#define SYS_G_GMAC1_TXC_SLEW_SHIFT 2 + +/* aon_iomux pins */ +#define PAD_RGPIO0 0 +#define PAD_RGPIO1 1 +#define PAD_RGPIO2 2 +#define PAD_RGPIO3 3 +#define PAD_RGPIO4 4 +#define PAD_RGPIO5 5 +#define PAD_RGPIO6 6 +#define PAD_RGPIO7 7 +#define PAD_RGPIO8 8 +#define PAD_RGPIO9 9 +#define PAD_RGPIO10 10 +#define PAD_RGPIO11 11 +#define PAD_RGPIO12 12 +#define PAD_RGPIO13 13 +#define PAD_RGPIO14 14 +#define PAD_RGPIO15 15 +#define PAD_TESTEN 16 +#define PAD_RSTN 17 +#define PAD_OSCK_XIN 18 +#define PAD_OSCK_XOUT 19 +#define PAD_OSCM_XIN 20 +#define PAD_OSCM_XOUT 21 +#define PAD_GMAC0_MDC 22 +#define PAD_GMAC0_MDIO 23 +#define PAD_GMAC0_RXD0 24 +#define PAD_GMAC0_RXD1 25 +#define PAD_GMAC0_RXD2 26 +#define PAD_GMAC0_RXD3 27 +#define PAD_GMAC0_RXDV 28 +#define PAD_GMAC0_RXC 29 +#define PAD_GMAC0_TXD0 30 +#define PAD_GMAC0_TXD1 31 +#define PAD_GMAC0_TXD2 32 +#define PAD_GMAC0_TXD3 33 +#define PAD_GMAC0_TXEN 34 +#define PAD_GMAC0_TXC 35 + +/* aon_iomux vref syscon registers */ +#define AON_VREF_RGPIO_SYSCON_REG 0x58 +#define AON_VREF_RGPIO_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_RGPIO_SYSCON_SHIFT 0 +#define AON_VREF_GMAC_SYSCON_REG 0X5c +#define AON_VREF_GMAC_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_GMAC_SYSCON_SHIFT 0 +#define AON_VREF_XSPI_SYSCON_REG 0x60 +#define AON_VREF_XSPI_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_XSPI_SYSCON_SHIFT 0 +#define AON_VREF_EMMC_U0_SYSCON_REG 0x64 +#define AON_VREF_EMMC_U0_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_EMMC_U0_SYSCON_SHIFT 0 +#define AON_VREF_EMMC_U1_SYSCON_REG 0x68 +#define AON_VREF_EMMC_U1_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_EMMC_U1_SYSCON_SHIFT 0 +#define AON_VREF_EMMC_U2_SYSCON_REG 0x6c +#define AON_VREF_EMMC_U2_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_EMMC_U2_SYSCON_SHIFT 0 +#define AON_VREF_SDIO_U0_SYSCON_REG 0x70 +#define AON_VREF_SDIO_U0_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_SDIO_U0_SYSCON_SHIFT 0 +#define AON_VREF_SDIO_U1_SYSCON_REG 0x74 +#define AON_VREF_SDIO_U1_SYSCON_MASK GENMASK(1, 0) +#define AON_VREF_SDIO_U1_SYSCON_SHIFT 0 + +#define GPOUT_LOW 0 +#define GPOUT_HIGH 1 + +#define GPOEN_ENABLE 0 +#define GPOEN_DISABLE 1 + +#define GPI_NONE 255 + +/* vref syscon value */ +#define PAD_VREF_SYSCON_IO_3V3 0 +#define PAD_VREF_SYSCON_IO_1V8 2 + +/* gmac interface (rmii/rgmii) syscon value */ +#define GMAC_RMII_MODE 0 /* RMII mode, DVDD 2.5V/3.3V */ +#define GMAC_RGMII_MODE 1 /* RGMII mode, DVDD 1.8V/2.5V */ + +/* gmac timing syscon value */ +#define GMAC_SLEW_RATE_FAST 0 +#define GMAC_SLEW_RATE_SLOW 1 + +#endif